* Purple is the legal property of its developers, whose names are too numerous
* to list here. Please refer to the COPYRIGHT file distributed with this
* This program 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 2 of the License, or
* (at your option) any later version.
* This program 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.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
#if !defined(PURPLE_GLOBAL_HEADER_INSIDE) && !defined(PURPLE_COMPILATION)
# error "only <purple.h> may be included directly"
* @section_id: libpurple-debug
* @short_description: <filename>debug.h</filename>
* The standard _get_type macro for #PurpleDebugUi.
#define PURPLE_TYPE_DEBUG_UI (purple_debug_ui_get_type())
G_DECLARE_INTERFACE(PurpleDebugUi, purple_debug_ui, PURPLE, DEBUG_UI, GObject)
* @PURPLE_DEBUG_ALL: All debug levels.
* @PURPLE_DEBUG_MISC: General chatter.
* @PURPLE_DEBUG_INFO: General operation Information.
* @PURPLE_DEBUG_WARNING: Warnings.
* @PURPLE_DEBUG_ERROR: Errors.
* @PURPLE_DEBUG_FATAL: Fatal errors.
* PurpleDebugUiInterface:
* @print: Called to output a debug string to the UI.
* @is_enabled: Returns if debug printing is enabled in the UI for a @level and
struct _PurpleDebugUiInterface
GTypeInterface parent_iface;
void (*print)(PurpleDebugUi *self,
PurpleDebugLevel level, const char *category,
gboolean (*is_enabled)(PurpleDebugUi *self,
void (*_purple_reserved1)(PurpleDebugUi *self);
void (*_purple_reserved2)(PurpleDebugUi *self);
void (*_purple_reserved3)(PurpleDebugUi *self);
void (*_purple_reserved4)(PurpleDebugUi *self);
/**************************************************************************/
/**************************************************************************/
* @level: The debug level.
* @category: The category (or %NULL).
* @format: The format string.
* @...: The parameters to insert into the format string.
* Outputs debug information.
void purple_debug(PurpleDebugLevel level, const char *category,
const char *format, ...) G_GNUC_PRINTF(3, 4);
* @category: The category (or %NULL).
* @format: The format string.
* @...: The parameters to insert into the format string.
* Outputs misc. level debug information.
* This is a wrapper for purple_debug(), and uses PURPLE_DEBUG_MISC as
void purple_debug_misc(const char *category, const char *format, ...) G_GNUC_PRINTF(2, 3);
* @category: The category (or %NULL).
* @format: The format string.
* @...: The parameters to insert into the format string.
* Outputs info level debug information.
* This is a wrapper for purple_debug(), and uses PURPLE_DEBUG_INFO as
void purple_debug_info(const char *category, const char *format, ...) G_GNUC_PRINTF(2, 3);
* @category: The category (or %NULL).
* @format: The format string.
* @...: The parameters to insert into the format string.
* Outputs warning level debug information.
* This is a wrapper for purple_debug(), and uses PURPLE_DEBUG_WARNING as
void purple_debug_warning(const char *category, const char *format, ...) G_GNUC_PRINTF(2, 3);
* @category: The category (or %NULL).
* @format: The format string.
* @...: The parameters to insert into the format string.
* Outputs error level debug information.
* This is a wrapper for purple_debug(), and uses PURPLE_DEBUG_ERROR as
void purple_debug_error(const char *category, const char *format, ...) G_GNUC_PRINTF(2, 3);
* @category: The category (or %NULL).
* @format: The format string.
* @...: The parameters to insert into the format string.
* Outputs fatal error level debug information.
* This is a wrapper for purple_debug(), and uses PURPLE_DEBUG_ERROR as
void purple_debug_fatal(const char *category, const char *format, ...) G_GNUC_PRINTF(2, 3);
* purple_debug_set_enabled:
* @enabled: TRUE to enable debug output or FALSE to disable it.
* Enable or disable printing debug output to the console.
void purple_debug_set_enabled(gboolean enabled);
* purple_debug_is_enabled:
* Check if console debug output is enabled.
* Returns: TRUE if debugging is enabled, FALSE if it is not.
gboolean purple_debug_is_enabled(void);
* purple_debug_set_verbose:
* @verbose: TRUE to enable verbose debugging or FALSE to disable it.
* Enable or disable verbose debugging. This ordinarily should only be called
* by #purple_debug_init, but there are cases where this can be useful for
void purple_debug_set_verbose(gboolean verbose);
* purple_debug_is_verbose:
* Check if verbose logging is enabled.
* Returns: TRUE if verbose debugging is enabled, FALSE if it is not.
gboolean purple_debug_is_verbose(void);
* purple_debug_set_unsafe:
* @unsafe: TRUE to enable debug logging of messages that could
* potentially contain passwords and other sensitive information.
* Enable or disable unsafe debugging. This ordinarily should only be called
* by #purple_debug_init, but there are cases where this can be useful for
void purple_debug_set_unsafe(gboolean unsafe);
* purple_debug_is_unsafe:
* Check if unsafe debugging is enabled. Defaults to FALSE.
* Returns: TRUE if the debug logging of all messages is enabled, FALSE
* if messages that could potentially contain passwords and other
* sensitive information are not logged.
gboolean purple_debug_is_unsafe(void);
* purple_debug_set_colored:
* @colored: TRUE to enable colored output, FALSE to disable it.
* Enable or disable colored output for bash console.
void purple_debug_set_colored(gboolean colored);
/**************************************************************************/
/* UI Registration Functions */
/**************************************************************************/
* @ops: The UI operations structure.
* Sets the UI operations structure to be used when outputting debug
void purple_debug_set_ui(PurpleDebugUi *ops);
* Returns the UI operations structure used when outputting debug
* Returns: (transfer none): The UI operations structure in use.
PurpleDebugUi *purple_debug_get_ui(void);
/**************************************************************************/
/**************************************************************************/
* Initializes the debug subsystem.
void purple_debug_init(void);
#endif /* PURPLE_DEBUG_H */