mirror of
https://github.com/gcc-mirror/gcc.git
synced 2026-05-06 14:59:39 +02:00
78 lines
2.5 KiB
Plaintext
78 lines
2.5 KiB
Plaintext
|
|
// Debugging support -*- C++ -*-
|
||
|
|
|
||
|
|
// Copyright The GNU Toolchain Authors.
|
||
|
|
//
|
||
|
|
// This file is part of the GNU ISO C++ Library. This library is free
|
||
|
|
// software; you can redistribute it and/or modify it under the
|
||
|
|
// terms of the GNU General Public License as published by the
|
||
|
|
// Free Software Foundation; either version 3.
|
||
|
|
|
||
|
|
// 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 General Public License for more details.
|
||
|
|
|
||
|
|
// Under Section 7 of GPL version 3, you are granted additional
|
||
|
|
// permissions described in the GCC Runtime Library Exception, version
|
||
|
|
// 3.1, as published by the Free Software Foundation.
|
||
|
|
|
||
|
|
// You should have received a copy of the GNU General Public License and
|
||
|
|
// a copy of the GCC Runtime Library Exception along with this program;
|
||
|
|
// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
|
||
|
|
// <http://www.gnu.org/licenses/>.
|
||
|
|
|
||
|
|
/** @file include/debugging
|
||
|
|
* This is a Standard C++ Library header.
|
||
|
|
*/
|
||
|
|
|
||
|
|
#ifndef _GLIBCXX_DEBUGGING
|
||
|
|
#define _GLIBCXX_DEBUGGING 1
|
||
|
|
|
||
|
|
#define __glibcxx_want_debugging
|
||
|
|
#include <bits/version.h>
|
||
|
|
|
||
|
|
#if __cpp_lib_debugging // C++ >= 26
|
||
|
|
namespace std _GLIBCXX_VISIBILITY(default)
|
||
|
|
{
|
||
|
|
// N.B. _GLIBCXX_BEGIN_NAMESPACE_VERSION is not used here.
|
||
|
|
|
||
|
|
/** Try to determine if the program is running under control of a debugger.
|
||
|
|
*
|
||
|
|
* On GNU/Linux systems this function will only return true if the program
|
||
|
|
* is being traced by another program which is known to be a debugger.
|
||
|
|
* This is determined by checking the command name of the tracing program
|
||
|
|
* against a list of known debuggers, such as "gdb".
|
||
|
|
*
|
||
|
|
* On other POSIX-based systems, this function will return true if the
|
||
|
|
* program is being traced by any other process, which means it can return
|
||
|
|
* true for non-debugger utilities that use the ptrace system call.
|
||
|
|
*
|
||
|
|
* @since C++26
|
||
|
|
*/
|
||
|
|
bool
|
||
|
|
is_debugger_present() noexcept;
|
||
|
|
|
||
|
|
/** Stop the program with a breakpoint or debug trap.
|
||
|
|
*
|
||
|
|
* The details of how a breakpoint is implemented are platform-specific.
|
||
|
|
* Some systems provide a special instruction, such as `int3` in x86.
|
||
|
|
* When no more appropriate mechanism is available, this will stop the
|
||
|
|
* program using `__builtin_trap()`. It might not be possible for the
|
||
|
|
* program to continue after such a breakpoint.
|
||
|
|
*
|
||
|
|
* @since C++26
|
||
|
|
*/
|
||
|
|
void
|
||
|
|
breakpoint() noexcept;
|
||
|
|
|
||
|
|
/** Stop the program if it is running under control of a debugger.
|
||
|
|
*
|
||
|
|
* @since C++26
|
||
|
|
*/
|
||
|
|
void
|
||
|
|
breakpoint_if_debugging() noexcept;
|
||
|
|
|
||
|
|
} // namespace std
|
||
|
|
#endif
|
||
|
|
#endif // _GLIBCXX_DEBUGGING
|