14 #include <libxml/HTMLtree.h>
26 typedef struct private_data_s {
33 const char *proc_stdout,
const char *proc_stderr) {
45 g_queue_free(priv->prefixes);
53 if (out->
priv != NULL) {
58 if (out->
priv == NULL) {
81 crm_info(
"Pacemaker %s (Build: %s): %s",
85 crm_info(
"Written by Andrew Beekhof");
100 len = vasprintf(&buffer, format, ap);
111 xmlNodePtr node = NULL;
123 log_begin_list(
pcmk__output_t *out, const
char *singular_noun, const
char *plural_noun,
124 const
char *format, ...) {
131 va_start(ap, format);
132 len = vasprintf(&buffer, format, ap);
139 if(strcmp(buffer,
"") == 0) {
143 g_queue_push_tail(priv->prefixes, buffer);
148 log_list_item(
pcmk__output_t *out, const
char *name, const
char *format, ...) {
152 char prefix[LINE_MAX] = { 0 };
158 for (GList* gIter = priv->prefixes->head; gIter; gIter = gIter->next) {
159 if (strcmp(prefix,
"") != 0) {
160 offset += snprintf(prefix + offset, LINE_MAX - offset,
": %s", (
char *)gIter->data);
162 offset = snprintf(prefix, LINE_MAX,
"%s", (
char *)gIter->data);
166 va_start(ap, format);
167 len = vasprintf(&buffer, format, ap);
171 if (strcmp(buffer,
"") != 0) {
172 if ((name != NULL) && (strcmp(name,
"") != 0)) {
173 if (strcmp(prefix,
"") != 0) {
174 crm_info(
"%s: %s: %s", prefix, name, buffer);
179 if (strcmp(prefix,
"") != 0) {
193 if (priv->prefixes == NULL) {
198 free((
char *)priv->prefixes->tail->data);
199 g_queue_pop_tail(priv->prefixes);
209 va_start(ap, format);
210 len = vasprintf(&buffer, format, ap);
223 if (retval == NULL) {
228 retval->
request = argv == NULL ? NULL : g_strjoinv(
" ", argv);
231 retval->
init = log_init;
233 retval->
finish = log_finish;
234 retval->
reset = log_reset;
241 retval->
info = log_info;
242 retval->
err = log_err;
bool(* init)(pcmk__output_t *out)
Formatted output for pacemaker tools.
void(* register_message)(pcmk__output_t *out, const char *message_id, pcmk__message_fn_t fn)
const char * fmt_name
The name of this output formatter.
void(* reset)(pcmk__output_t *out)
void(*) void(* err)(pcmk__output_t *out, const char *format,...) G_GNUC_PRINTF(2
bool supports_quiet
Does this formatter support a special quiet mode?
int(* message)(pcmk__output_t *out, const char *message_id,...)
enum crm_exit_e crm_exit_t
#define PACEMAKER_VERSION
void * priv
Implementation-specific private data.
int pcmk__call_message(pcmk__output_t *out, const char *message_id,...)
void(* end_list)(pcmk__output_t *out)
void(* begin_list)(pcmk__output_t *out, const char *singular_noun, const char *plural_noun, const char *format,...) G_GNUC_PRINTF(4
struct private_data_s private_data_t
void(* subprocess_output)(pcmk__output_t *out, int exit_status, const char *proc_stdout, const char *proc_stderr)
Wrappers for and extensions to libxml2.
xmlNode * create_xml_node(xmlNode *parent, const char *name)
const xmlChar * pcmkXmlStr
void(* info)(pcmk__output_t *out, const char *format,...) G_GNUC_PRINTF(2
#define crm_err(fmt, args...)
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.
This structure contains everything that makes up a single output formatter.
#define crm_log_xml_info(xml, text)
void(* version)(pcmk__output_t *out, bool extended)
GOptionEntry pcmk__log_output_entries[]
void(*) void(*) void(* output_xml)(pcmk__output_t *out, const char *name, const char *buf)
pcmk__output_t * pcmk__mk_log_output(char **argv)
void pcmk__register_message(pcmk__output_t *out, const char *message_id, pcmk__message_fn_t fn)
#define crm_info(fmt, args...)
void(*) void(* list_item)(pcmk__output_t *out, const char *name, const char *format,...) G_GNUC_PRINTF(3