asserts to catch >static initialization order fiasco<
git-svn-id: svn://svn.code.sf.net/p/loki-lib/code/trunk@180 7ec92016-0320-0410-acc4-a06ded1c099a
This commit is contained in:
parent
dddd95d48d
commit
c4e9df64c2
1 changed files with 10 additions and 15 deletions
|
@ -140,20 +140,16 @@ namespace Loki
|
||||||
CRITICAL_SECTION mtx_;
|
CRITICAL_SECTION mtx_;
|
||||||
bool init_;
|
bool init_;
|
||||||
|
|
||||||
Initializer()
|
Initializer():init_(false)
|
||||||
{
|
|
||||||
init();
|
|
||||||
}
|
|
||||||
~Initializer()
|
|
||||||
{
|
|
||||||
assert( init_ );
|
|
||||||
::DeleteCriticalSection(&mtx_);
|
|
||||||
}
|
|
||||||
void init()
|
|
||||||
{
|
{
|
||||||
::InitializeCriticalSection(&mtx_);
|
::InitializeCriticalSection(&mtx_);
|
||||||
init_=true;
|
init_=true;
|
||||||
}
|
}
|
||||||
|
~Initializer()
|
||||||
|
{
|
||||||
|
assert(init_);
|
||||||
|
::DeleteCriticalSection(&mtx_);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static Initializer initializer_;
|
static Initializer initializer_;
|
||||||
|
@ -169,18 +165,17 @@ namespace Loki
|
||||||
public:
|
public:
|
||||||
Lock()
|
Lock()
|
||||||
{
|
{
|
||||||
assert( initializer_.init_ );
|
assert(initializer_.init_);
|
||||||
//if(!initializer_.init_) initializer_.init();
|
::EnterCriticalSection(&initializer_.mtx_);
|
||||||
::EnterCriticalSection(&initializer_.mtx_);
|
|
||||||
}
|
}
|
||||||
explicit Lock(const ClassLevelLockable&)
|
explicit Lock(const ClassLevelLockable&)
|
||||||
{
|
{
|
||||||
assert( initializer_.init_ );
|
assert(initializer_.init_);
|
||||||
::EnterCriticalSection(&initializer_.mtx_);
|
::EnterCriticalSection(&initializer_.mtx_);
|
||||||
}
|
}
|
||||||
~Lock()
|
~Lock()
|
||||||
{
|
{
|
||||||
assert( initializer_.init_ );
|
assert(initializer_.init_);
|
||||||
::LeaveCriticalSection(&initializer_.mtx_);
|
::LeaveCriticalSection(&initializer_.mtx_);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue