12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- //
- // Copyright 2018 The Abseil Authors.
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // https://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- //
- #ifndef ABSL_DEBUGGING_INTERNAL_EXAMINE_STACK_H_
- #define ABSL_DEBUGGING_INTERNAL_EXAMINE_STACK_H_
- #include "absl/base/config.h"
- namespace absl {
- ABSL_NAMESPACE_BEGIN
- namespace debugging_internal {
- // Type of function used for printing in stack trace dumping, etc.
- // We avoid closures to keep things simple.
- typedef void OutputWriter(const char*, void*);
- // RegisterDebugStackTraceHook() allows to register a single routine
- // `hook` that is called each time DumpStackTrace() is called.
- // `hook` may be called from a signal handler.
- typedef void (*SymbolizeUrlEmitter)(void* const stack[], int depth,
- OutputWriter* writer, void* writer_arg);
- // Registration of SymbolizeUrlEmitter for use inside of a signal handler.
- // This is inherently unsafe and must be signal safe code.
- void RegisterDebugStackTraceHook(SymbolizeUrlEmitter hook);
- SymbolizeUrlEmitter GetDebugStackTraceHook();
- // Returns the program counter from signal context, or nullptr if
- // unknown. `vuc` is a ucontext_t*. We use void* to avoid the use of
- // ucontext_t on non-POSIX systems.
- void* GetProgramCounter(void* const vuc);
- // Uses `writer` to dump the program counter, stack trace, and stack
- // frame sizes.
- void DumpPCAndFrameSizesAndStackTrace(void* const pc, void* const stack[],
- int frame_sizes[], int depth,
- int min_dropped_frames,
- bool symbolize_stacktrace,
- OutputWriter* writer, void* writer_arg);
- // Dump current stack trace omitting the topmost `min_dropped_frames` stack
- // frames.
- void DumpStackTrace(int min_dropped_frames, int max_num_frames,
- bool symbolize_stacktrace, OutputWriter* writer,
- void* writer_arg);
- } // namespace debugging_internal
- ABSL_NAMESPACE_END
- } // namespace absl
- #endif // ABSL_DEBUGGING_INTERNAL_EXAMINE_STACK_H_
|