144 static
void fail(const
xtd::
string& message) {
145 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
155 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
156 fail__(message, detail_message);
162 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
174 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
175 write_line_(message);
182 template<
class ...args_t>
184 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
185 write_line_(xtd::string::format(
format, args...));
189 template<
class ...args_t>
190 static void print(
const char*
format, args_t&& ... args) {
191 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
192 write_line_(xtd::string::format(
format, args...));
201 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
209 template<
class ...objects_t>
211 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
220 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
228 template<
class ...objects_t>
230 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
239 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
247 template<
class ...objects_t>
249 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
262 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
270 template<
class object_t>
271 static void write(
const object_t& message) {
272 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
273 write_(xtd::string::format(
"{}", message));
282 template<
class object_t>
284 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
285 write_(xtd::string::format(
"{}", message), category);
293 template<
class ...args_t>
295 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
296 write_(string::format(
format, args...));
300 template<
class ...args_t>
301 static void write(
const char*
format, args_t&& ... args) {
302 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
303 write_(string::format(
format, args...));
314 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
315 if (condition) write_(message);
318 template<
class object_t>
324 static void write_if(
bool condition,
const object_t& message) {
325 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
326 if (condition) write_(xtd::string::format(
"{}", message));
335 template<
class object_t>
337 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
338 if (condition) write_(xtd::string::format(
"{}", message), category);
347 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
356 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
357 write_line_(message);
364 template<
class object_t>
366 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
367 write_line_(xtd::string::format(
"{}", message));
376 template<
class object_t>
378 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
379 write_line_(xtd::string::format(
"{}", message), category);
386 template<
class ...args_t>
388 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
389 write_line_(string::format(
format, args...));
393 template<
class ...args_t>
394 static void write_line(
const char*
format, args_t&& ... args) {
395 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
396 write_line_(string::format(
format, args...));
407 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
408 if (condition) write_line_(message);
416 template<
class object_t>
418 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
419 if (condition) write_line_(message);
428 template<
class object_t>
430 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
431 if (condition) write_line_(message, category);
438 static inline bool __should_aborted__(
const xtd::diagnostics::stack_frame& stack_frame,
bool condition,
const xtd::string& message) {
return __should_aborted__(stack_frame, condition, message, xtd::string::empty_string);}
440 #if !defined(NDEBUG) || defined(DEBUG) || defined(TRACE)
441 auto result = xtd::diagnostics::debug::assert_dialog(condition, message, detail_message, stack_frame);
457 [[deprecated(
"Replaced by xtd::diagnostics::default_trace_listener::assert_ui_enabled - Will be removed in version 0.4.0.")]]
464 [[deprecated(
"Replaced by xtd::diagnostics::default_trace_listener::assert_ui_enabled - Will be removed in version 0.4.0.")]]
472 static
xtd::
string assert_dialog_caption();
473 static
bool internal_show_assert_dialog() noexcept;
474 static
void fail__(const
xtd::
string& message);
475 static
void fail__(const
xtd::
string& message, const
xtd::
string& detail_message);
476 static
void flush_();
478 static
void write_(const
xtd::
string& message);
479 static
void write_(const
xtd::
string& message, const
xtd::
string& category);
480 static
void write_line_(const
xtd::
string& message);
481 static
void write_line_(const
xtd::
string& message, const
xtd::
string& category);
483 inline static
bool auto_flush_ = false;
484 inline static
uint32 indent_level_ = 0;
485 inline static
uint32 indent_size_ = 4;
487 static
xtd::
string source_name_;
Contains add_last_arg_to_command_ macro.
Contains xtd::diagnostics::assert_dialog_result enum class.
Provides a set of methods and properties that help you debug the execution of your code....
Definition debug.hpp:59
static void write(const xtd::string &message)
Writes a message to the trace listeners in the listeners collection.
Definition debug.hpp:261
static void write_if(bool condition, const object_t &message, const xtd::string &category)
Writes a category name and message to the trace listeners in the Listeners collection if a condition ...
Definition debug.hpp:336
static void trace_information(const xtd::string &message, const objects_t &... args)
Writes an informational message to the trace listeners in the listeners collection using the specifie...
Definition debug.hpp:229
static void cassert(bool condition, const xtd::diagnostics::stack_frame &stack_frame=xtd::diagnostics::stack_frame::current())
Checks for a condition; if the condition is false, displays a message box that shows the call stack.
static void indent() noexcept
Increases the current indent_level by one.
static void write_line()
Writes a line terminator to the trace listeners in the listeners collection.
Definition debug.hpp:346
static void fail(const xtd::string &message)
Emits the specified error message.
Definition debug.hpp:144
static void write(const object_t &message, const xtd::string &category)
Writes a category name and message to the trace listeners in the listeners collection.
Definition debug.hpp:283
static void print(const xtd::string &message)
Writes a message followed by a line terminator to the trace listeners in the listeners collection.
Definition debug.hpp:173
static void write_line_if(bool condition, const object_t &message)
Writes a message followed by a line terminator to the trace listeners in the Listeners collection if ...
Definition debug.hpp:417
static void write_line(const object_t &message)
Writes a message followed by a line terminator to the trace listeners in the listeners collection.
Definition debug.hpp:365
static listener_collection & listeners() noexcept
Gets the collection of listeners that is monitoring the trace output.
static void write(const xtd::string &format, args_t &&... args)
Writes a formatted string to the trace listeners in the listeners collection.
Definition debug.hpp:294
xtd::diagnostics::trace_listener_collection listener_collection
Represents a collection of xtd::diagnostics::trace_listener.
Definition debug.hpp:65
static bool auto_flush() noexcept
Gets whether xtd::diagnostics::debug::flush should be called on the xtd::diagnostics::debug::Listener...
static uint32 indent_level() noexcept
Gets the indent level.
static void trace_error(const xtd::string &message, const objects_t &... args)
Writes an error message to the trace listeners in the listeners collection using the specified array ...
Definition debug.hpp:210
static void write_line_if(bool condition, const object_t &message, const xtd::string &category)
Writes a category name and message followed by a line terminator to the trace listeners in the Listen...
Definition debug.hpp:429
static void fail(const xtd::string &message, const xtd::string &detail_message)
Emits an error message and a detailed error message.
Definition debug.hpp:154
static void write_line(const xtd::string &message)
Writes a message followed by a line terminator to the trace listeners in the listeners collection.
Definition debug.hpp:355
static void write_if(bool condition, const object_t &message)
Writes a message to the trace listeners in the Listeners collection if a condition is true.
Definition debug.hpp:324
static void print(const xtd::string &format, args_t &&... args)
Writes a formatted string followed by a line terminator to the trace listeners in the listeners colle...
Definition debug.hpp:183
static void trace_error(const xtd::string &message)
Writes an error message to the trace listeners in the Listeners collection using the specified messag...
Definition debug.hpp:200
static void trace_warning(const xtd::string &message)
Writes a warning message to the trace listeners in the listeners collection using the specified messa...
Definition debug.hpp:238
static void write(const object_t &message)
Writes a message to the trace listeners in the listeners collection.
Definition debug.hpp:271
static void flush()
Flushes the output buffer and causes buffered data to write to the listeners collection.
Definition debug.hpp:161
static uint32 indent_size() noexcept
Gets the number of spaces in an indent.
static bool use_global_lock() noexcept
Gets a value indicating whether the global lock should be used.
static void write_line(const xtd::string &format, args_t &&... args)
Writes a formatted string followed by a line terminator to the trace listeners in the listeners colle...
Definition debug.hpp:387
static void unindent() noexcept
Decreases the current indent_level by one.
static void trace_information(const xtd::string &message)
Writes an informational message to the trace listeners in the listeners collection using the specifie...
Definition debug.hpp:219
static void write_line(const object_t &message, const xtd::string &category)
Writes a category name and message followed by a line terminator to the trace listeners in the listen...
Definition debug.hpp:377
static bool show_assert_dialog() noexcept
Gets a value indicating whether the assert dialog should be show.
static void trace_warning(const xtd::string &message, const objects_t &... args)
Writes a warning message to the trace listeners in the listeners collection using the specified array...
Definition debug.hpp:248
static void write_if(bool condition, const xtd::string &message)
Writes a message to the trace listeners in the Listeners collection if a condition is true.
Definition debug.hpp:313
static void write_line_if(bool condition, const xtd::string &message)
Writes a message followed by a line terminator to the trace listeners in the Listeners collection if ...
Definition debug.hpp:406
Provides information about a xtd::diagnostics::stack_frame, which represents a function call on the c...
Definition stack_frame.hpp:48
Represents a collection of xtd::diagnostics::trace_listener.
Definition trace_listener_collection.hpp:29
Provides a set of methods and properties that help you debug the execution of your code....
Definition trace.hpp:40
static void exit()
Terminates this process and returns an exit code to the operating system.
Contains core_export_ keyword.
Contains xtd::diagnostics::debugger class.
Contains xtd::environment class.
#define static_
This keyword is use to represent a static object. A static object can't be instantiated (constructors...
Definition static.hpp:37
#define core_export_
Define shared library export.
Definition core_export.hpp:13
xtd::basic_string< char > string
Represents text as a sequence of UTF-8 code units.
Definition __string_definitions.hpp:43
std::uint32_t uint32
Represents a 32-bit unsigned integer.
Definition uint32.hpp:23
assert_dialog_result
Specifies identifiers to indicate the return value of an assert dialog box.
Definition assert_dialog_result.hpp:25
trace_event_type
Identifies the type of event that has caused the trace.
Definition trace_event_type.hpp:25
@ retry
The assert dialog return value is Retry (usually sent from a button labeled Retry).
Definition assert_dialog_result.hpp:29
@ abort
The assert dialog return value is Abort (usually sent from a button labeled Abort).
Definition assert_dialog_result.hpp:27
@ warning
Warning Noncritical problem.
Definition trace_event_type.hpp:31
@ information
Informational message.
Definition trace_event_type.hpp:33
@ error
Recoverable error.
Definition trace_event_type.hpp:29
The xtd::diagnostics namespace provides classes that allow you to interact with system processes,...
Definition assert_dialog_result.hpp:10
The xtd namespace contains all fundamental classes to access Hardware, Os, System,...
Definition abstract_object.hpp:8
void print(FILE *file, arg_t &&value)
Writes the text representation of the specified value to the file output stream.
Definition print.hpp:19
Contains xtd::diagnostics::stack_trace class.
Contains xtd::static_object class.
Contains xtd::string alias.
Contains xtd::diagnostics::trace_listener_collection class.