7 #ifndef PXR_BASE_ARCH_STACK_TRACE_H
8 #define PXR_BASE_ARCH_STACK_TRACE_H
53 const char* extraLogMsg =
nullptr);
74 const char* extraLogMsg =
nullptr);
99 const char *
const argv[],
100 const char*
const fatalArgv[]);
138 const char*
const argv[],
139 const char*
const crashArgv[]);
151 const std::string& programName,
152 const std::string& reason);
164 const std::string& programName,
165 const std::string& reason);
238 std::vector<std::string>
const *lines);
252 const std::string& reason,
254 const std::string& sessionLog =
"");
269 const std::string& sessionLog =
"");
299 std::vector<uintptr_t> *frames);
312 const std::vector<uintptr_t> &frames,
313 bool skipUnknownFrames =
false);
337 #if defined(ARCH_OS_DARWIN)
342 #define ETIME ECANCELED
344 #endif // end ARCH_OS_DARWIN
350 #endif // PXR_BASE_ARCH_STACK_TRACE_H
std::function< std::string(uintptr_t address)> ArchStackTraceCallback
A callback to get a symbolic representation of an address.
GLuint GLsizei const GLchar * message
ARCH_API void ArchSetProcessStateLogCommand(const char *command, const char *const argv[], const char *const fatalArgv[])
ARCH_API void ArchGetStackFrames(size_t maxDepth, std::vector< uintptr_t > *frames)
ARCH_API int ArchCrashHandlerSystemv(const char *pathname, char *const argv[], int timeout, ArchCrashHandlerSystemCB callback, void *userData)
GLsizei const GLfloat * value
ARCH_API void ArchLogFatalProcessState(const char *reason, const char *message=nullptr, const char *extraLogMsg=nullptr)
ARCH_API bool ArchIsAppCrashing()
ARCH_API void ArchSetProgramNameForErrors(const char *progName)
ARCH_API void ArchLogSessionInfo(const char *crashStackTrace=NULL)
ARCH_API void ArchPrintStackTrace(FILE *fout, const std::string &programName, const std::string &reason)
Print a stack trace to the given FILE pointer.
ARCH_API void ArchLogStackTrace(const std::string &progName, const std::string &reason, bool fatal=false, const std::string &sessionLog="")
ARCH_API void ArchSetLogSession(const char *command, const char *const argv[], const char *const crashArgv[])
GLbitfield GLuint64 timeout
ARCH_API void ArchLogCurrentProcessState(const char *reason, const char *message=nullptr, const char *extraLogMsg=nullptr)
ARCH_API void ArchGetStackTraceCallback(ArchStackTraceCallback *cb)
ARCH_API void ArchSetStackTraceCallback(const ArchStackTraceCallback &cb)
ARCH_API const char * ArchGetProgramNameForErrors()
ARCH_API bool ArchGetFatalStackLogging()
ARCH_API void ArchSetProgramInfoForErrors(const std::string &key, const std::string &value)
PXR_NAMESPACE_CLOSE_SCOPE PXR_NAMESPACE_OPEN_SCOPE
ARCH_API void ArchPrintStackFrames(std::ostream &out, const std::vector< uintptr_t > &frames, bool skipUnknownFrames=false)
Print stack frames to the given ostream.
#define PXR_NAMESPACE_CLOSE_SCOPE
void(* ArchCrashHandlerSystemCB)(void *userData)
ARCH_API void ArchSetExtraLogInfoForErrors(const std::string &key, std::vector< std::string > const *lines)
ARCH_API std::vector< std::string > ArchGetStackTrace(size_t maxDepth)
ARCH_API time_t ArchGetAppLaunchTime()
ARCH_API void ArchEnableSessionLogging()
ARCH_API std::string ArchGetProgramInfoForErrors(const std::string &key)
ARCH_API void ArchSetFatalStackLogging(bool flag)