Newer
Older
Brad Payne (Vir Linden)
committed
/**
* @file llcallstack.h
* @brief run-time extraction of the current callstack
*
* $LicenseInfo:firstyear=2016&license=viewerlgpl$
* Second Life Viewer Source Code
* Copyright (C) 2016, Linden Research, Inc.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* version 2.1 of the License only.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*
* Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA
* $/LicenseInfo$
*/
Brad Payne (Vir Linden)
committed
#include <map>
Brad Payne (Vir Linden)
committed
class LLCallStackImpl;
class LLCallStack
{
public:
Brad Payne (Vir Linden)
committed
LLCallStack(S32 skip_count=0, bool verbose=false);
Brad Payne (Vir Linden)
committed
std::vector<std::string> m_strings;
Brad Payne (Vir Linden)
committed
bool m_verbose;
Brad Payne (Vir Linden)
committed
bool contains(const std::string& str);
Brad Payne (Vir Linden)
committed
private:
static LLCallStackImpl *s_impl;
Brad Payne (Vir Linden)
committed
S32 m_skipCount;
Brad Payne (Vir Linden)
committed
};
LL_COMMON_API std::ostream& operator<<(std::ostream& s, const LLCallStack& call_stack);
Brad Payne (Vir Linden)
committed
class LLContextStrings
{
public:
LLContextStrings();
static void addContextString(const std::string& str);
static void removeContextString(const std::string& str);
static void output(std::ostream& os);
static LLContextStrings* getThreadLocalInstance();
Brad Payne (Vir Linden)
committed
static bool contains(const std::string& str);
Brad Payne (Vir Linden)
committed
private:
std::map<std::string,S32> m_contextStrings;
};
class LLScopedContextString
{
public:

Rye Mutt
committed
LLScopedContextString(const std::string str):
m_str(std::move(str))
Brad Payne (Vir Linden)
committed
{
LLContextStrings::addContextString(m_str);
}
~LLScopedContextString()
{
LLContextStrings::removeContextString(m_str);
}
private:
std::string m_str;
};
Brad Payne (Vir Linden)
committed
// Mostly exists as a class to hook an ostream override to.
Brad Payne (Vir Linden)
committed
struct LLContextStatus
{
Brad Payne (Vir Linden)
committed
bool contains(const std::string& str);
Brad Payne (Vir Linden)
committed
};
LL_COMMON_API std::ostream& operator<<(std::ostream& s, const LLContextStatus& context_status);
Brad Payne (Vir Linden)
committed
Brad Payne (Vir Linden)
committed
#define dumpStack(tag) \
static const bool enable_log = debugLoggingEnabled(tag); \
if (enable_log) \
Brad Payne (Vir Linden)
committed
{ \
LLCallStack cs; \
LL_DEBUGS(tag) << "STACK:\n" << "====================\n" << cs << "====================" << LL_ENDL; \
}
#else
#define dumpStack(tag)
#endif