From: Pierre Ossman Date: Tue, 15 Nov 2011 12:07:43 +0000 (+0000) Subject: Add method to query how long since we last wrote something to a fd. X-Git-Tag: v1.1.90~22 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=3c837139f1872a3d966ca146d4ed6ae9b8f0b722;p=tigervnc.git Add method to query how long since we last wrote something to a fd. git-svn-id: svn://svn.code.sf.net/p/tigervnc/code/trunk@4802 3789f03b-4d11-0410-bbf8-ca57d06f2519 --- diff --git a/common/rdr/FdOutStream.cxx b/common/rdr/FdOutStream.cxx index a6b85e21..533faa3f 100644 --- a/common/rdr/FdOutStream.cxx +++ b/common/rdr/FdOutStream.cxx @@ -1,4 +1,5 @@ /* Copyright (C) 2002-2005 RealVNC Ltd. All Rights Reserved. + * Copyright 2011 Pierre Ossman for Cendio AB * * This is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -44,6 +45,7 @@ #include #include +#include using namespace rdr; @@ -56,6 +58,8 @@ FdOutStream::FdOutStream(int fd_, bool blocking_, int timeoutms_, int bufSize_) { ptr = start = sentUpTo = new U8[bufSize]; end = start + bufSize; + + gettimeofday(&lastWrite, NULL); } FdOutStream::~FdOutStream() @@ -86,6 +90,11 @@ int FdOutStream::bufferUsage() return ptr - sentUpTo; } +unsigned FdOutStream::getIdleTime() +{ + return rfb::msSince(&lastWrite); +} + void FdOutStream::flush() { int timeoutms_; @@ -218,5 +227,7 @@ int FdOutStream::writeWithTimeout(const void* data, int length, int timeoutms) if (n < 0) throw SystemException("write",errno); + gettimeofday(&lastWrite, NULL); + return n; } diff --git a/common/rdr/FdOutStream.h b/common/rdr/FdOutStream.h index daa88b24..b7f6cb01 100644 --- a/common/rdr/FdOutStream.h +++ b/common/rdr/FdOutStream.h @@ -1,4 +1,5 @@ /* Copyright (C) 2002-2005 RealVNC Ltd. All Rights Reserved. + * Copyright 2011 Pierre Ossman for Cendio AB * * This is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -23,6 +24,8 @@ #ifndef __RDR_FDOUTSTREAM_H__ #define __RDR_FDOUTSTREAM_H__ +#include + #include namespace rdr { @@ -43,6 +46,8 @@ namespace rdr { int bufferUsage(); + unsigned getIdleTime(); + private: int overrun(int itemSize, int nItems); int writeWithTimeout(const void* data, int length, int timeoutms); @@ -53,6 +58,7 @@ namespace rdr { int offset; U8* start; U8* sentUpTo; + struct timeval lastWrite; }; }