14#include <libxml/tree.h>
18static GHashTable *formatters = NULL;
20#if defined(PCMK__UNIT_TESTING)
23pcmk__output_formatters(
void) {
64 const char *filename,
char **argv)
73 if (fmt_name == NULL) {
74 create = g_hash_table_lookup(formatters,
"text");
76 create = g_hash_table_lookup(formatters, fmt_name);
89 (*out)->dest = stdout;
91 (*out)->dest = fopen(filename,
"w");
92 if ((*out)->dest == NULL) {
99 (*out)->quiet =
false;
102 if ((*out)->init(*out) ==
false) {
107 setenv(
"OCF_OUTPUT_FORMAT", (*out)->fmt_name, 1);
114 const char *filename,
char **argv)
129 const GOptionEntry *options)
131 char *name_copy = NULL;
137 name_copy = strdup(
name);
138 if (name_copy == NULL) {
142 if (formatters == NULL) {
146 if (options != NULL && group != NULL) {
147 g_option_group_add_entries(group, options);
150 g_hash_table_insert(formatters, name_copy, create);
158 if (formats == NULL) {
169 if (formatters != NULL) {
170 g_hash_table_destroy(formatters);
181 pcmk__assert((out != NULL) && !pcmk__str_empty(message_id));
183 fn = g_hash_table_lookup(out->
messages, message_id);
185 crm_debug(
"Called unknown output message '%s' for format '%s'",
190 va_start(args, message_id);
201 pcmk__assert((out != NULL) && !pcmk__str_empty(message_id) && (fn != NULL));
219 if (error == NULL || *error == NULL) {
224 out->
err(out,
"%s: %s", g_get_prgname(), (*error)->
message);
226 fprintf(stderr,
"%s: %s\n", g_get_prgname(), (*error)->message);
229 g_clear_error(error);
280 out->
finish(out, exit_status, FALSE, (
void **) xml);
296 const char* argv[] = {
"", NULL };
305 crm_err(
"Can't log certain messages due to internal error: %s",
325 const char* argv[] = {
"", NULL };
334 crm_err(
"Can't create text output object to internal error: %s",
G_GNUC_INTERNAL void pcmk__register_option_messages(pcmk__output_t *out)
G_GNUC_INTERNAL void pcmk__register_patchset_messages(pcmk__output_t *out)
#define crm_debug(fmt, args...)
#define crm_err(fmt, args...)
void pcmk__xml_output_finish(pcmk__output_t *out, crm_exit_t exit_status, xmlNodePtr *xml)
void pcmk__register_messages(pcmk__output_t *out, const pcmk__message_entry_t *table)
int pcmk__register_format(GOptionGroup *group, const char *name, pcmk__output_factory_t create, const GOptionEntry *options)
void pcmk__output_free(pcmk__output_t *out)
int pcmk__xml_output_new(pcmk__output_t **out, xmlNodePtr *xml)
void pcmk__register_formats(GOptionGroup *group, const pcmk__supported_format_t *formats)
int pcmk__output_new(pcmk__output_t **out, const char *fmt_name, const char *filename, char **argv)
int pcmk__call_message(pcmk__output_t *out, const char *message_id,...)
void pcmk__output_and_clear_error(GError **error, pcmk__output_t *out)
void pcmk__register_message(pcmk__output_t *out, const char *message_id, pcmk__message_fn_t fn)
int pcmk__log_output_new(pcmk__output_t **out)
int pcmk__text_output_new(pcmk__output_t **out, const char *filename)
int pcmk__bare_output_new(pcmk__output_t **out, const char *fmt_name, const char *filename, char **argv)
void pcmk__unregister_formats(void)
int(* pcmk__message_fn_t)(pcmk__output_t *out, va_list args)
#define PCMK__SUPPORTED_FORMAT_XML
#define PCMK__SUPPORTED_FORMAT_TEXT
#define PCMK__SUPPORTED_FORMAT_LOG
pcmk__output_t *(* pcmk__output_factory_t)(char **argv)
const char * pcmk_rc_str(int rc)
Get a user-friendly description of a return code.
enum crm_exit_e crm_exit_t
Exit status codes for tools and daemons.
#define pcmk__assert(expr)
GHashTable * pcmk__strkey_table(GDestroyNotify key_destroy_func, GDestroyNotify value_destroy_func)
bool pcmk__strcase_any_of(const char *s,...) G_GNUC_NULL_TERMINATED
#define pcmk__str_copy(str)
const char * message_id
The message to be handled.
This structure contains everything that makes up a single output formatter.
int(* message)(pcmk__output_t *out, const char *message_id,...)
GHashTable * messages
Custom messages that are currently registered on this formatter.
const char * fmt_name
The name of this output formatter.
int int void(* err)(pcmk__output_t *out, const char *format,...) G_GNUC_PRINTF(2
void(* finish)(pcmk__output_t *out, crm_exit_t exit_status, bool print, void **copy_dest)
void(* free_priv)(pcmk__output_t *out)
gchar * request
A copy of the request that generated this output.
Wrappers for and extensions to libxml2.
void pcmk__xml_free(xmlNode *xml)