mirror of
https://github.com/shadps4-emu/ext-cryptopp.git
synced 2024-11-23 09:59:42 +00:00
Update documentation
This commit is contained in:
parent
49157a3652
commit
d6f4a75431
128
trap.h
128
trap.h
@ -3,18 +3,17 @@
|
||||
/// \file trap.h
|
||||
/// \brief Debugging and diagnostic assertions
|
||||
/// \details <tt>CRYPTOPP_ASSERT</tt> is the library's debugging and diagnostic
|
||||
/// assertion. <tt>CRYPTOPP_ASSERT</tt> is enabled by <tt>CRYPTOPP_DEBUG</tt>,
|
||||
/// <tt>DEBUG</tt> or <tt>_DEBUG</tt>.
|
||||
/// assertion. <tt>CRYPTOPP_ASSERT</tt> is enabled by <tt>CRYPTOPP_DEBUG</tt>,
|
||||
/// <tt>DEBUG</tt> or <tt>_DEBUG</tt>.
|
||||
/// \details <tt>CRYPTOPP_ASSERT</tt> raises a <tt>SIGTRAP</tt> (Unix) or calls
|
||||
/// <tt>__debugbreak()</tt> (Windows). <tt>CRYPTOPP_ASSERT</tt> is only in
|
||||
/// effect when the user requests a debug configuration. Unlike Posix assert,
|
||||
/// <tt>NDEBUG</tt> (or failure to define it) does not affect the library.
|
||||
/// The traditional Posix define <tt>NDEBUG</tt> has no effect on
|
||||
/// <tt>CRYPTOPP_DEBUG</tt> or DebugTrapHandler.
|
||||
/// <tt>DebugBreak()</tt> (Windows).
|
||||
/// \details <tt>CRYPTOPP_ASSERT</tt> is only in effect when the user requests a
|
||||
/// debug configuration. <tt>NDEBUG</tt> (or failure to define it) does not
|
||||
/// affect <tt>CRYPTOPP_ASSERT</tt>.
|
||||
/// \since Crypto++ 5.6.5
|
||||
/// \sa DebugTrapHandler, <A
|
||||
/// HREF="http://github.com/weidai11/cryptopp/issues/277">Issue 277</A>,
|
||||
/// <A HREF="http://seclists.org/oss-sec/2016/q3/520">CVE-2016-7420</A>
|
||||
/// HREF="http://github.com/weidai11/cryptopp/issues/277">Issue 277</A>,
|
||||
/// <A HREF="http://seclists.org/oss-sec/2016/q3/520">CVE-2016-7420</A>
|
||||
|
||||
#ifndef CRYPTOPP_TRAP_H
|
||||
#define CRYPTOPP_TRAP_H
|
||||
@ -37,39 +36,40 @@
|
||||
#if defined(CRYPTOPP_DOXYGEN_PROCESSING)
|
||||
/// \brief Debugging and diagnostic assertion
|
||||
/// \details <tt>CRYPTOPP_ASSERT</tt> is the library's debugging and diagnostic
|
||||
/// assertion. <tt>CRYPTOPP_ASSERT</tt> is enabled by the preprocessor macros
|
||||
/// <tt>CRYPTOPP_DEBUG</tt>, <tt>DEBUG</tt> or <tt>_DEBUG</tt>.
|
||||
/// assertion. <tt>CRYPTOPP_ASSERT</tt> is enabled by the preprocessor macros
|
||||
/// <tt>CRYPTOPP_DEBUG</tt>, <tt>DEBUG</tt> or <tt>_DEBUG</tt>.
|
||||
/// \details <tt>CRYPTOPP_ASSERT</tt> raises a <tt>SIGTRAP</tt> (Unix) or calls
|
||||
/// <tt>DebugBreak()</tt> (Windows). <tt>CRYPTOPP_ASSERT</tt> is only in effect
|
||||
/// when the user explicitly requests a debug configuration.
|
||||
/// <tt>DebugBreak()</tt> (Windows). <tt>CRYPTOPP_ASSERT</tt> is only in effect
|
||||
/// when the user explicitly requests a debug configuration.
|
||||
/// \details If you want to ensure <tt>CRYPTOPP_ASSERT</tt> is inert, then <em>do
|
||||
/// not</em> define <tt>CRYPTOPP_DEBUG</tt>, <tt>DEBUG</tt> or <tt>_DEBUG</tt>.
|
||||
/// Avoiding the defines means <tt>CRYPTOPP_ASSERT</tt> is preprocessed into an
|
||||
/// empty string.
|
||||
/// not</em> define <tt>CRYPTOPP_DEBUG</tt>, <tt>DEBUG</tt> or <tt>_DEBUG</tt>.
|
||||
/// Avoiding the defines means <tt>CRYPTOPP_ASSERT</tt> is preprocessed into an
|
||||
/// empty string.
|
||||
/// \details The traditional Posix define <tt>NDEBUG</tt> has no effect on
|
||||
/// <tt>CRYPTOPP_DEBUG</tt>, <tt>CRYPTOPP_ASSERT</tt> or DebugTrapHandler.
|
||||
/// <tt>CRYPTOPP_DEBUG</tt>, <tt>CRYPTOPP_ASSERT</tt> or DebugTrapHandler.
|
||||
/// \details An example of using CRYPTOPP_ASSERT and DebugTrapHandler is shown
|
||||
/// below. The library's test program, <tt>cryptest.exe</tt> (from test.cpp),
|
||||
/// exercises the structure:
|
||||
/// below. The library's test program, <tt>cryptest.exe</tt> (from test.cpp),
|
||||
/// exercises the structure:
|
||||
/// <pre>
|
||||
/// \#if defined(CRYPTOPP_DEBUG) && defined(UNIX_SIGNALS_AVAILABLE)
|
||||
/// static const DebugTrapHandler g_dummyHandler;
|
||||
/// \#endif
|
||||
/// \#if defined(CRYPTOPP_DEBUG) && defined(UNIX_SIGNALS_AVAILABLE)
|
||||
/// static const DebugTrapHandler g_dummyHandler;
|
||||
/// \#endif
|
||||
///
|
||||
/// int main(int argc, char* argv[])
|
||||
/// {
|
||||
/// CRYPTOPP_ASSERT(argv != nullptr);
|
||||
/// ...
|
||||
/// }
|
||||
/// int main(int argc, char* argv[])
|
||||
/// {
|
||||
/// CRYPTOPP_ASSERT(argv != nullptr);
|
||||
/// ...
|
||||
/// }
|
||||
/// </pre>
|
||||
/// \since Crypto++ 5.6.5
|
||||
/// \sa DebugTrapHandler, SignalHandler, <A
|
||||
/// HREF="http://github.com/weidai11/cryptopp/issues/277">Issue 277</A>,
|
||||
/// <A HREF="http://seclists.org/oss-sec/2016/q3/520">CVE-2016-7420</A>
|
||||
/// HREF="http://github.com/weidai11/cryptopp/issues/277">Issue 277</A>,
|
||||
/// <A HREF="http://seclists.org/oss-sec/2016/q3/520">CVE-2016-7420</A>
|
||||
# define CRYPTOPP_ASSERT(exp) { ... }
|
||||
#endif
|
||||
|
||||
#if defined(CRYPTOPP_DEBUG) && defined(UNIX_SIGNALS_AVAILABLE)
|
||||
#if defined(CRYPTOPP_DEBUG)
|
||||
# if defined(UNIX_SIGNALS_AVAILABLE) || defined(__CYGWIN__)
|
||||
# define CRYPTOPP_ASSERT(exp) { \
|
||||
if (!(exp)) { \
|
||||
std::ostringstream oss; \
|
||||
@ -81,7 +81,7 @@
|
||||
raise(SIGTRAP); \
|
||||
} \
|
||||
}
|
||||
#elif CRYPTOPP_DEBUG && defined(CRYPTOPP_WIN32_AVAILABLE) && !defined(__CYGWIN__)
|
||||
# elif CRYPTOPP_DEBUG && defined(CRYPTOPP_WIN32_AVAILABLE)
|
||||
# define CRYPTOPP_ASSERT(exp) { \
|
||||
if (!(exp)) { \
|
||||
std::ostringstream oss; \
|
||||
@ -93,10 +93,10 @@
|
||||
if (IsDebuggerPresent()) {DebugBreak();} \
|
||||
} \
|
||||
}
|
||||
#endif // DEBUG and Unix or Windows
|
||||
# endif // Unix or Windows
|
||||
#endif // CRYPTOPP_DEBUG
|
||||
|
||||
// Remove CRYPTOPP_ASSERT in non-debug builds.
|
||||
// Can't use CRYPTOPP_UNUSED due to circular dependency
|
||||
#ifndef CRYPTOPP_ASSERT
|
||||
# define CRYPTOPP_ASSERT(exp) (void)0
|
||||
#endif
|
||||
@ -108,47 +108,47 @@ NAMESPACE_BEGIN(CryptoPP)
|
||||
#if (CRYPTOPP_DEBUG && defined(UNIX_SIGNALS_AVAILABLE)) || defined(CRYPTOPP_DOXYGEN_PROCESSING)
|
||||
/// \brief Default SIGTRAP handler
|
||||
/// \details DebugTrapHandler() can be used by a program to install an empty
|
||||
/// SIGTRAP handler. If present, the handler ensures there is a signal
|
||||
/// handler in place for <tt>SIGTRAP</tt> raised by
|
||||
/// <tt>CRYPTOPP_ASSERT</tt>. If <tt>CRYPTOPP_ASSERT</tt> raises
|
||||
/// <tt>SIGTRAP</tt> <em>without</em> a handler, then one of two things can
|
||||
/// occur. First, the OS might allow the program to continue. Second, the OS
|
||||
/// might terminate the program. OS X allows the program to continue, while
|
||||
/// some Linuxes terminate the program.
|
||||
/// SIGTRAP handler. If present, the handler ensures there is a signal
|
||||
/// handler in place for <tt>SIGTRAP</tt> raised by
|
||||
/// <tt>CRYPTOPP_ASSERT</tt>. If <tt>CRYPTOPP_ASSERT</tt> raises
|
||||
/// <tt>SIGTRAP</tt> <em>without</em> a handler, then one of two things can
|
||||
/// occur. First, the OS might allow the program to continue. Second, the OS
|
||||
/// might terminate the program. OS X allows the program to continue, while
|
||||
/// some Linuxes terminate the program.
|
||||
/// \details If DebugTrapHandler detects another handler in place, then it will
|
||||
/// not install a handler. This ensures a debugger can gain control of the
|
||||
/// <tt>SIGTRAP</tt> signal without contention. It also allows multiple
|
||||
/// DebugTrapHandler to be created without contentious or unusual behavior.
|
||||
/// Though multiple DebugTrapHandler can be created, a program should only
|
||||
/// create one, if needed.
|
||||
/// not install a handler. This ensures a debugger can gain control of the
|
||||
/// <tt>SIGTRAP</tt> signal without contention. It also allows multiple
|
||||
/// DebugTrapHandler to be created without contentious or unusual behavior.
|
||||
/// Though multiple DebugTrapHandler can be created, a program should only
|
||||
/// create one, if needed.
|
||||
/// \details A DebugTrapHandler is subject to C++ static initialization
|
||||
/// [dis]order. If you need to install a handler and it must be installed
|
||||
/// early, then reference the code associated with
|
||||
/// <tt>CRYPTOPP_INIT_PRIORITY</tt> in cryptlib.cpp and cpu.cpp.
|
||||
/// [dis]order. If you need to install a handler and it must be installed
|
||||
/// early, then reference the code associated with
|
||||
/// <tt>CRYPTOPP_INIT_PRIORITY</tt> in cryptlib.cpp and cpu.cpp.
|
||||
/// \details If you want to ensure <tt>CRYPTOPP_ASSERT</tt> is inert, then
|
||||
/// <em>do not</em> define <tt>CRYPTOPP_DEBUG</tt>, <tt>DEBUG</tt> or
|
||||
/// <tt>_DEBUG</tt>. Avoiding the defines means <tt>CRYPTOPP_ASSERT</tt>
|
||||
/// is processed into <tt>((void)(exp))</tt>.
|
||||
/// <em>do not</em> define <tt>CRYPTOPP_DEBUG</tt>, <tt>DEBUG</tt> or
|
||||
/// <tt>_DEBUG</tt>. Avoiding the defines means <tt>CRYPTOPP_ASSERT</tt>
|
||||
/// is processed into <tt>((void)0)</tt>.
|
||||
/// \details The traditional Posix define <tt>NDEBUG</tt> has no effect on
|
||||
/// <tt>CRYPTOPP_DEBUG</tt>, <tt>CRYPTOPP_ASSERT</tt> or DebugTrapHandler.
|
||||
/// <tt>CRYPTOPP_DEBUG</tt>, <tt>CRYPTOPP_ASSERT</tt> or DebugTrapHandler.
|
||||
/// \details An example of using \ref CRYPTOPP_ASSERT "CRYPTOPP_ASSERT" and
|
||||
/// DebugTrapHandler is shown below. The library's test program,
|
||||
/// <tt>cryptest.exe</tt> (from test.cpp), exercises the structure:
|
||||
/// DebugTrapHandler is shown below. The library's test program,
|
||||
/// <tt>cryptest.exe</tt> (from test.cpp), exercises the structure:
|
||||
/// <pre>
|
||||
/// \#if defined(CRYPTOPP_DEBUG) && defined(UNIX_SIGNALS_AVAILABLE)
|
||||
/// static const DebugTrapHandler g_dummyHandler;
|
||||
/// \#endif
|
||||
/// \#if defined(CRYPTOPP_DEBUG) && defined(UNIX_SIGNALS_AVAILABLE)
|
||||
/// const DebugTrapHandler g_dummyHandler;
|
||||
/// \#endif
|
||||
///
|
||||
/// int main(int argc, char* argv[])
|
||||
/// {
|
||||
/// CRYPTOPP_ASSERT(argv != nullptr);
|
||||
/// ...
|
||||
/// }
|
||||
/// int main(int argc, char* argv[])
|
||||
/// {
|
||||
/// CRYPTOPP_ASSERT(argv != nullptr);
|
||||
/// ...
|
||||
/// }
|
||||
/// </pre>
|
||||
/// \since Crypto++ 5.6.5
|
||||
/// \sa \ref CRYPTOPP_ASSERT "CRYPTOPP_ASSERT", SignalHandler, <A
|
||||
/// HREF="http://github.com/weidai11/cryptopp/issues/277">Issue 277</A>,
|
||||
/// <A HREF="http://seclists.org/oss-sec/2016/q3/520">CVE-2016-7420</A>
|
||||
/// HREF="http://github.com/weidai11/cryptopp/issues/277">Issue 277</A>,
|
||||
/// <A HREF="http://seclists.org/oss-sec/2016/q3/520">CVE-2016-7420</A>
|
||||
|
||||
#if defined(CRYPTOPP_DOXYGEN_PROCESSING)
|
||||
class DebugTrapHandler : public SignalHandler<SIGILL, false> { };
|
||||
|
Loading…
Reference in New Issue
Block a user