mirror of
https://github.com/dashpay/dash.git
synced 2024-12-26 20:42:59 +01:00
Use thread-local storage for LogPrint(category...)
This prevents crashes at shutdown where a global destructor calls LogPrint(category...) after mapMultiArgs has been deleted.
This commit is contained in:
parent
962b1cf441
commit
0b238b2786
24
src/util.cpp
24
src/util.cpp
@ -242,17 +242,23 @@ int LogPrint(const char* category, const char* pszFormat, ...)
|
|||||||
if (!fDebug)
|
if (!fDebug)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
const vector<string>& categories = mapMultiArgs["-debug"];
|
// Give each thread quick access to -debug settings.
|
||||||
bool allCategories = count(categories.begin(), categories.end(), string(""));
|
// This helps prevent issues debugging global destructors,
|
||||||
|
// where mapMultiArgs might be deleted before another
|
||||||
// Only look for categories, if not -debug/-debug=1 was passed,
|
// global destructor calls LogPrint()
|
||||||
// as that implies every category should be logged.
|
static boost::thread_specific_ptr<set<string> > ptrCategory;
|
||||||
if (!allCategories)
|
if (ptrCategory.get() == NULL)
|
||||||
{
|
{
|
||||||
// Category was not found (not supplied via -debug=<category>)
|
const vector<string>& categories = mapMultiArgs["-debug"];
|
||||||
if (find(categories.begin(), categories.end(), string(category)) == categories.end())
|
ptrCategory.reset(new set<string>(categories.begin(), categories.end()));
|
||||||
return 0;
|
// thread_specific_ptr automatically deletes the set when the thread ends.
|
||||||
}
|
}
|
||||||
|
const set<string>& setCategories = *ptrCategory.get();
|
||||||
|
|
||||||
|
// if not debugging everything and not debugging specific category, LogPrint does nothing.
|
||||||
|
if (setCategories.count(string("")) == 0 &&
|
||||||
|
setCategories.count(string(category)) == 0)
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int ret = 0; // Returns total number of characters written
|
int ret = 0; // Returns total number of characters written
|
||||||
|
Loading…
Reference in New Issue
Block a user