1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- #include "Critical.h"
- #include "Globals.h"
- #include "Thread.h"
- #include <iostream>
- #include <time.h>
- using namespace Framework;
- Critical::Critical()
- {
- InitializeCriticalSection( &cs );
- owner = 0;
- lockCount = 0;
- id = (int)time( 0 );
- }
- Critical::~Critical()
- {
- DeleteCriticalSection( &cs );
- }
- void Critical::lock()
- {
- pthread_t t = GetCurrentThread();
- Thread *tmp = getThreadRegister()->zThread( t );
- if( tmp )
- tmp->addCriticalLock();
- EnterCriticalSection( &cs );
- if( !owner )
- owner = tmp;
- lockCount++;
- }
- bool Critical::tryLock()
- {
- if( lockCount > 0 )
- return false;
- Thread *tmp = getThreadRegister()->zThread( GetCurrentThread() );
- if( tmp )
- tmp->addCriticalLock();
- EnterCriticalSection( &cs );
- if( !owner )
- owner = tmp;
- lockCount++;
- return true;
- }
- void Critical::unlock()
- {
- if( owner && GetThreadId( owner->getThreadHandle() ) != GetThreadId( GetCurrentThread() ) )
- throw std::runtime_error( "A Thread that does not own a Critical Object trys to unlock it" );
- Thread *tmp = owner;
- if( !--lockCount )
- owner = 0;
- LeaveCriticalSection( &cs );
- if( tmp )
- tmp->removeCriticalLock();
- }
- bool Critical::isLocked() const
- {
- return lockCount > 0;
- }
- const Thread *Critical::zOwner() const
- {
- return owner;
- }
|