diff options
| author | Mike Buland <eichlan@xagasoft.com> | 2010-04-27 17:07:55 +0000 | 
|---|---|---|
| committer | Mike Buland <eichlan@xagasoft.com> | 2010-04-27 17:07:55 +0000 | 
| commit | 1889b55dcbb3f5c5cccc3bcd986b13d0d108ed6c (patch) | |
| tree | 3ea239424e33edfc8d9b80aa6b923d944cd0bfa1 | |
| parent | 801e7de1f85656746d832508baf4583907826420 (diff) | |
| download | libbu++-1889b55dcbb3f5c5cccc3bcd986b13d0d108ed6c.tar.gz libbu++-1889b55dcbb3f5c5cccc3bcd986b13d0d108ed6c.tar.bz2 libbu++-1889b55dcbb3f5c5cccc3bcd986b13d0d108ed6c.tar.xz libbu++-1889b55dcbb3f5c5cccc3bcd986b13d0d108ed6c.zip | |
The Bu::Ito thread class has changed the rules on the run function.  It no
longer returns anything, that's fine, it's in a class, but it also is protected
now.  That doesn't really effect child classes much, they can make run public,
but I reccomend protected to avoid confusion.
Diffstat (limited to '')
| -rw-r--r-- | src/ito.cpp | 6 | ||||
| -rw-r--r-- | src/ito.h | 20 | ||||
| -rw-r--r-- | src/itoserver.cpp | 10 | ||||
| -rw-r--r-- | src/itoserver.h | 8 | ||||
| -rw-r--r-- | src/tests/itoheap.cpp | 4 | ||||
| -rw-r--r-- | src/tests/itoqueue1.cpp | 8 | ||||
| -rw-r--r-- | src/tests/itoqueue2.cpp | 8 | ||||
| -rw-r--r-- | src/tests/socketblock.cpp | 4 | 
8 files changed, 27 insertions, 41 deletions
| diff --git a/src/ito.cpp b/src/ito.cpp index dba1a87..0218ecc 100644 --- a/src/ito.cpp +++ b/src/ito.cpp | |||
| @@ -32,9 +32,9 @@ bool Bu::Ito::stop() | |||
| 32 | 32 | ||
| 33 | void *Bu::Ito::threadRunner( void *pThread ) | 33 | void *Bu::Ito::threadRunner( void *pThread ) | 
| 34 | { | 34 | { | 
| 35 | void *pRet = ((Ito *)pThread)->run(); | 35 | ((Ito *)pThread)->run(); | 
| 36 | pthread_exit( pRet ); | 36 | pthread_exit( NULL ); | 
| 37 | return pRet; | 37 | return NULL; | 
| 38 | } | 38 | } | 
| 39 | 39 | ||
| 40 | bool Bu::Ito::join() | 40 | bool Bu::Ito::join() | 
| @@ -61,16 +61,6 @@ namespace Bu | |||
| 61 | bool stop(); | 61 | bool stop(); | 
| 62 | 62 | ||
| 63 | /** | 63 | /** | 
| 64 | * The workhorse of the Ito class. This is the function that will run | ||
| 65 | * in the thread, when this function exits the thread dies and is | ||
| 66 | * cleaned up by the system. Make sure to read up on ItoMutex, | ||
| 67 | * ItoCondition, and cancel to see how to control and protect | ||
| 68 | * everything you do in a safe way within this function. | ||
| 69 | *@returns I'm not sure right now, but this is the posix standard form. | ||
| 70 | */ | ||
| 71 | virtual void *run()=0; | ||
| 72 | |||
| 73 | /** | ||
| 74 | * Join the thread in action. This function performs what is commonly | 64 | * Join the thread in action. This function performs what is commonly | 
| 75 | * called a thread join. That is that it effectively makes the calling | 65 | * called a thread join. That is that it effectively makes the calling | 
| 76 | * thread an the Ito thread contained in the called object one in the | 66 | * thread an the Ito thread contained in the called object one in the | 
| @@ -89,6 +79,16 @@ namespace Bu | |||
| 89 | 79 | ||
| 90 | protected: | 80 | protected: | 
| 91 | /** | 81 | /** | 
| 82 | * The workhorse of the Ito class. This is the function that will run | ||
| 83 | * in the thread, when this function exits the thread dies and is | ||
| 84 | * cleaned up by the system. Make sure to read up on ItoMutex, | ||
| 85 | * ItoCondition, and cancel to see how to control and protect | ||
| 86 | * everything you do in a safe way within this function. | ||
| 87 | *@returns I'm not sure right now, but this is the posix standard form. | ||
| 88 | */ | ||
| 89 | virtual void run()=0; | ||
| 90 | |||
| 91 | /** | ||
| 92 | * This is the hidden-heard of the thread system. While run is what the | 92 | * This is the hidden-heard of the thread system. While run is what the | 
| 93 | * user gets to override, and everything said about it is true, this is | 93 | * user gets to override, and everything said about it is true, this is | 
| 94 | * the function that actually makes up the thread, it simply calls the | 94 | * the function that actually makes up the thread, it simply calls the | 
| diff --git a/src/itoserver.cpp b/src/itoserver.cpp index 0640aad..279310d 100644 --- a/src/itoserver.cpp +++ b/src/itoserver.cpp | |||
| @@ -74,7 +74,7 @@ void Bu::ItoServer::addClient( int nSocket, int nPort ) | |||
| 74 | pC->start(); | 74 | pC->start(); | 
| 75 | } | 75 | } | 
| 76 | 76 | ||
| 77 | void *Bu::ItoServer::run() | 77 | void Bu::ItoServer::run() | 
| 78 | { | 78 | { | 
| 79 | for(;;) | 79 | for(;;) | 
| 80 | { | 80 | { | 
| @@ -105,8 +105,6 @@ void *Bu::ItoServer::run() | |||
| 105 | delete pCli; | 105 | delete pCli; | 
| 106 | } | 106 | } | 
| 107 | } | 107 | } | 
| 108 | |||
| 109 | return NULL; | ||
| 110 | } | 108 | } | 
| 111 | 109 | ||
| 112 | void Bu::ItoServer::clientCleanup( int iSocket ) | 110 | void Bu::ItoServer::clientCleanup( int iSocket ) | 
| @@ -138,7 +136,7 @@ Bu::ItoServer::ItoClient::~ItoClient() | |||
| 138 | { | 136 | { | 
| 139 | } | 137 | } | 
| 140 | 138 | ||
| 141 | void *Bu::ItoServer::ItoClient::run() | 139 | void Bu::ItoServer::ItoClient::run() | 
| 142 | { | 140 | { | 
| 143 | imProto.lock(); | 141 | imProto.lock(); | 
| 144 | rSrv.onNewConnection( pClient, iPort ); | 142 | rSrv.onNewConnection( pClient, iPort ); | 
| @@ -186,7 +184,7 @@ void *Bu::ItoServer::ItoClient::run() | |||
| 186 | 184 | ||
| 187 | rSrv.clientCleanup( iSocket ); | 185 | rSrv.clientCleanup( iSocket ); | 
| 188 | 186 | ||
| 189 | return NULL; | 187 | return; | 
| 190 | } | 188 | } | 
| 191 | } | 189 | } | 
| 192 | 190 | ||
| @@ -197,8 +195,6 @@ void *Bu::ItoServer::ItoClient::run() | |||
| 197 | imProto.unlock(); | 195 | imProto.unlock(); | 
| 198 | } | 196 | } | 
| 199 | } | 197 | } | 
| 200 | |||
| 201 | return NULL; | ||
| 202 | } | 198 | } | 
| 203 | 199 | ||
| 204 | Bu::ItoServer::SrvClientLink::SrvClientLink( ItoClient *pClient ) : | 200 | Bu::ItoServer::SrvClientLink::SrvClientLink( ItoClient *pClient ) : | 
| diff --git a/src/itoserver.h b/src/itoserver.h index 1b45748..c08d453 100644 --- a/src/itoserver.h +++ b/src/itoserver.h | |||
| @@ -69,7 +69,8 @@ namespace Bu | |||
| 69 | virtual void onNewConnection( Client *pClient, int nPort )=0; | 69 | virtual void onNewConnection( Client *pClient, int nPort )=0; | 
| 70 | virtual void onClosedConnection( Client *pClient )=0; | 70 | virtual void onClosedConnection( Client *pClient )=0; | 
| 71 | 71 | ||
| 72 | virtual void *run(); | 72 | protected: | 
| 73 | virtual void run(); | ||
| 73 | 74 | ||
| 74 | private: | 75 | private: | 
| 75 | class SrvClientLink; | 76 | class SrvClientLink; | 
| @@ -81,11 +82,12 @@ namespace Bu | |||
| 81 | int nTimeoutSec, int nTimeoutUSec ); | 82 | int nTimeoutSec, int nTimeoutUSec ); | 
| 82 | virtual ~ItoClient(); | 83 | virtual ~ItoClient(); | 
| 83 | 84 | ||
| 84 | virtual void *run(); | ||
| 85 | |||
| 86 | typedef ItoQueue<Bu::FString *> StringQueue; | 85 | typedef ItoQueue<Bu::FString *> StringQueue; | 
| 87 | StringQueue qMsg; | 86 | StringQueue qMsg; | 
| 88 | 87 | ||
| 88 | protected: | ||
| 89 | virtual void run(); | ||
| 90 | |||
| 89 | private: | 91 | private: | 
| 90 | ItoServer &rSrv; | 92 | ItoServer &rSrv; | 
| 91 | Client *pClient; | 93 | Client *pClient; | 
| diff --git a/src/tests/itoheap.cpp b/src/tests/itoheap.cpp index 92bf3cf..347f1e0 100644 --- a/src/tests/itoheap.cpp +++ b/src/tests/itoheap.cpp | |||
| @@ -23,7 +23,7 @@ public: | |||
| 23 | { | 23 | { | 
| 24 | } | 24 | } | 
| 25 | 25 | ||
| 26 | void *run() | 26 | void run() | 
| 27 | { | 27 | { | 
| 28 | for( int j = 0; j < 10; j++ ) | 28 | for( int j = 0; j < 10; j++ ) | 
| 29 | { | 29 | { | 
| @@ -39,8 +39,6 @@ public: | |||
| 39 | printf("Nothing yet...\n"); | 39 | printf("Nothing yet...\n"); | 
| 40 | } | 40 | } | 
| 41 | } | 41 | } | 
| 42 | |||
| 43 | return NULL; | ||
| 44 | } | 42 | } | 
| 45 | 43 | ||
| 46 | Bu::ItoHeap<int> hInt; | 44 | Bu::ItoHeap<int> hInt; | 
| diff --git a/src/tests/itoqueue1.cpp b/src/tests/itoqueue1.cpp index 815216d..a034c87 100644 --- a/src/tests/itoqueue1.cpp +++ b/src/tests/itoqueue1.cpp | |||
| @@ -19,7 +19,7 @@ public: | |||
| 19 | { | 19 | { | 
| 20 | } | 20 | } | 
| 21 | 21 | ||
| 22 | void *run() | 22 | void run() | 
| 23 | { | 23 | { | 
| 24 | for( int i = 0; i < 10; i++ ) | 24 | for( int i = 0; i < 10; i++ ) | 
| 25 | { | 25 | { | 
| @@ -35,8 +35,6 @@ public: | |||
| 35 | } | 35 | } | 
| 36 | usleep( (int)(((double)rand())/((double)RAND_MAX)*2000000.0) ); | 36 | usleep( (int)(((double)rand())/((double)RAND_MAX)*2000000.0) ); | 
| 37 | } | 37 | } | 
| 38 | |||
| 39 | return NULL; | ||
| 40 | } | 38 | } | 
| 41 | 39 | ||
| 42 | private: | 40 | private: | 
| @@ -54,7 +52,7 @@ public: | |||
| 54 | { | 52 | { | 
| 55 | } | 53 | } | 
| 56 | 54 | ||
| 57 | void *run() | 55 | void run() | 
| 58 | { | 56 | { | 
| 59 | for( int i = 0; i < 11; i++ ) | 57 | for( int i = 0; i < 11; i++ ) | 
| 60 | { | 58 | { | 
| @@ -62,8 +60,6 @@ public: | |||
| 62 | q.enqueue( new std::string( strbase ) ); | 60 | q.enqueue( new std::string( strbase ) ); | 
| 63 | printf("[%d] write: %s\n", id, strbase ); | 61 | printf("[%d] write: %s\n", id, strbase ); | 
| 64 | } | 62 | } | 
| 65 | |||
| 66 | return NULL; | ||
| 67 | } | 63 | } | 
| 68 | 64 | ||
| 69 | private: | 65 | private: | 
| diff --git a/src/tests/itoqueue2.cpp b/src/tests/itoqueue2.cpp index d1f20a4..b11aa32 100644 --- a/src/tests/itoqueue2.cpp +++ b/src/tests/itoqueue2.cpp | |||
| @@ -19,7 +19,7 @@ public: | |||
| 19 | { | 19 | { | 
| 20 | } | 20 | } | 
| 21 | 21 | ||
| 22 | void *run() | 22 | void run() | 
| 23 | { | 23 | { | 
| 24 | for( int i = 0; i < 10; i++ ) | 24 | for( int i = 0; i < 10; i++ ) | 
| 25 | { | 25 | { | 
| @@ -35,8 +35,6 @@ public: | |||
| 35 | delete pStr; | 35 | delete pStr; | 
| 36 | } | 36 | } | 
| 37 | } | 37 | } | 
| 38 | |||
| 39 | return NULL; | ||
| 40 | } | 38 | } | 
| 41 | 39 | ||
| 42 | private: | 40 | private: | 
| @@ -54,7 +52,7 @@ public: | |||
| 54 | { | 52 | { | 
| 55 | } | 53 | } | 
| 56 | 54 | ||
| 57 | void *run() | 55 | void run() | 
| 58 | { | 56 | { | 
| 59 | for( int i = 0; i < 11; i++ ) | 57 | for( int i = 0; i < 11; i++ ) | 
| 60 | { | 58 | { | 
| @@ -62,8 +60,6 @@ public: | |||
| 62 | printf("[%d] write: %s\n", id, strbase ); | 60 | printf("[%d] write: %s\n", id, strbase ); | 
| 63 | q.enqueue( new std::string( strbase ) ); | 61 | q.enqueue( new std::string( strbase ) ); | 
| 64 | } | 62 | } | 
| 65 | |||
| 66 | return NULL; | ||
| 67 | } | 63 | } | 
| 68 | 64 | ||
| 69 | private: | 65 | private: | 
| diff --git a/src/tests/socketblock.cpp b/src/tests/socketblock.cpp index 3d50aa0..a1ea18d 100644 --- a/src/tests/socketblock.cpp +++ b/src/tests/socketblock.cpp | |||
| @@ -19,7 +19,7 @@ public: | |||
| 19 | { | 19 | { | 
| 20 | } | 20 | } | 
| 21 | 21 | ||
| 22 | virtual void *run() | 22 | virtual void run() | 
| 23 | { | 23 | { | 
| 24 | Bu::Socket c = s.accept( 45, 0 ); | 24 | Bu::Socket c = s.accept( 45, 0 ); | 
| 25 | printf("TstServer: Accetped connection.\n"); fflush( stdout ); | 25 | printf("TstServer: Accetped connection.\n"); fflush( stdout ); | 
| @@ -33,8 +33,6 @@ public: | |||
| 33 | 33 | ||
| 34 | printf("TstServer: Closing connection...\n"); fflush( stdout ); | 34 | printf("TstServer: Closing connection...\n"); fflush( stdout ); | 
| 35 | c.close(); | 35 | c.close(); | 
| 36 | |||
| 37 | return NULL; | ||
| 38 | } | 36 | } | 
| 39 | 37 | ||
| 40 | Bu::ServerSocket s; | 38 | Bu::ServerSocket s; | 
