pacemaker  2.0.5-ba59be7122
Scalable High-Availability cluster resource manager
output_internal.h
Go to the documentation of this file.
1 /*
2  * Copyright 2019-2020 the Pacemaker project contributors
3  *
4  * The version control history for this file may have further details.
5  *
6  * This source code is licensed under the GNU Lesser General Public License
7  * version 2.1 or later (LGPLv2.1+) WITHOUT ANY WARRANTY.
8  */
9 
10 #ifndef CRM_OUTPUT__H
11 # define CRM_OUTPUT__H
12 
13 #ifdef __cplusplus
14 extern "C" {
15 #endif
16 
22 # include <stdbool.h>
23 # include <stdio.h>
24 # include <libxml/tree.h>
25 # include <libxml/HTMLtree.h>
26 
27 # include <glib.h>
28 # include <crm/common/results.h>
29 
30 # define PCMK__API_VERSION "2.3"
31 
32 #if defined(PCMK__WITH_ATTRIBUTE_OUTPUT_ARGS)
33 # define PCMK__OUTPUT_ARGS(ARGS...) __attribute__((output_args(ARGS)))
34 #else
35 # define PCMK__OUTPUT_ARGS(ARGS...)
36 #endif
37 
38 typedef struct pcmk__output_s pcmk__output_t;
39 
50 typedef pcmk__output_t * (*pcmk__output_factory_t)(char **argv);
51 
66 typedef int (*pcmk__message_fn_t)(pcmk__output_t *out, va_list args);
67 
89 typedef struct pcmk__message_entry_s {
96  const char *message_id;
97 
106  const char *fmt_name;
107 
114 
120 typedef struct pcmk__supported_format_s {
125  const char *name;
126 
131 
136  GOptionEntry *options;
138 
139 /* The following three blocks need to be updated each time a new base formatter
140  * is added.
141  */
142 
143 extern GOptionEntry pcmk__html_output_entries[];
144 extern GOptionEntry pcmk__log_output_entries[];
145 extern GOptionEntry pcmk__none_output_entries[];
146 extern GOptionEntry pcmk__text_output_entries[];
147 extern GOptionEntry pcmk__xml_output_entries[];
148 
150 pcmk__output_t *pcmk__mk_log_output(char **argv);
153 pcmk__output_t *pcmk__mk_xml_output(char **argv);
154 
155 #define PCMK__SUPPORTED_FORMAT_HTML { "html", pcmk__mk_html_output, pcmk__html_output_entries }
156 #define PCMK__SUPPORTED_FORMAT_LOG { "log", pcmk__mk_log_output, pcmk__log_output_entries }
157 #define PCMK__SUPPORTED_FORMAT_NONE { "none", pcmk__mk_none_output, pcmk__none_output_entries }
158 #define PCMK__SUPPORTED_FORMAT_TEXT { "text", pcmk__mk_text_output, pcmk__text_output_entries }
159 #define PCMK__SUPPORTED_FORMAT_XML { "xml", pcmk__mk_xml_output, pcmk__xml_output_entries }
160 
173  const char *fmt_name;
174 
183  bool quiet;
184 
191  gchar *request;
192 
199  FILE *dest;
200 
207  GHashTable *messages;
208 
216  void *priv;
217 
232  bool (*init) (pcmk__output_t *out);
233 
243  void (*free_priv) (pcmk__output_t *out);
244 
279  void (*finish) (pcmk__output_t *out, crm_exit_t exit_status, bool print,
280  void **copy_dest);
281 
297  void (*reset) (pcmk__output_t *out);
298 
310  void (*register_message) (pcmk__output_t *out, const char *message_id,
311  pcmk__message_fn_t fn);
312 
328  int (*message) (pcmk__output_t *out, const char *message_id, ...);
329 
339  void (*subprocess_output) (pcmk__output_t *out, int exit_status,
340  const char *proc_stdout, const char *proc_stderr);
341 
350  void (*version) (pcmk__output_t *out, bool extended);
351 
364  void (*info) (pcmk__output_t *out, const char *format, ...) G_GNUC_PRINTF(2, 3);
365 
378  void (*err) (pcmk__output_t *out, const char *format, ...) G_GNUC_PRINTF(2, 3);
379 
388  void (*output_xml) (pcmk__output_t *out, const char *name, const char *buf);
389 
409  void (*begin_list) (pcmk__output_t *out, const char *singular_noun,
410  const char *plural_noun, const char *format, ...)
411  G_GNUC_PRINTF(4, 5);
412 
422  void (*list_item) (pcmk__output_t *out, const char *name, const char *format, ...)
423  G_GNUC_PRINTF(3, 4);
424 
438 
449  void (*end_list) (pcmk__output_t *out);
450 
462  bool (*is_quiet) (pcmk__output_t *out);
463 };
464 
477 int
478 pcmk__call_message(pcmk__output_t *out, const char *message_id, ...);
479 
493 
508 int pcmk__output_new(pcmk__output_t **out, const char *fmt_name,
509  const char *filename, char **argv);
510 
527 int
528 pcmk__register_format(GOptionGroup *group, const char *name,
529  pcmk__output_factory_t create, GOptionEntry *options);
530 
542 void
543 pcmk__register_formats(GOptionGroup *group, pcmk__supported_format_t *table);
544 
550 void
552 
564 void
565 pcmk__register_message(pcmk__output_t *out, const char *message_id,
566  pcmk__message_fn_t fn);
567 
579 void
581 
582 /* Functions that are useful for implementing custom message formatters */
583 
594 void
595 pcmk__indented_printf(pcmk__output_t *out, const char *format, ...) G_GNUC_PRINTF(2, 3);
596 
609 void
610 pcmk__indented_vprintf(pcmk__output_t *out, const char *format, va_list args) G_GNUC_PRINTF(2, 0);
611 
622 xmlNodePtr
624 
633 void
634 pcmk__output_xml_add_node(pcmk__output_t *out, xmlNodePtr node);
635 
644 xmlNodePtr
646 
656 xmlNodePtr
657 pcmk__output_create_xml_text_node(pcmk__output_t *out, const char *name, const char *content);
658 
673 void
674 pcmk__output_xml_push_parent(pcmk__output_t *out, xmlNodePtr node);
675 
690 void
692 
707 xmlNodePtr
709 
723 xmlNodePtr
724 pcmk__output_create_html_node(pcmk__output_t *out, const char *element_name, const char *id,
725  const char *class_name, const char *text);
726 
742 void
743 pcmk__html_add_header(const char *name, ...)
744 G_GNUC_NULL_TERMINATED;
745 
746 #define PCMK__OUTPUT_SPACER_IF(out_obj, cond) \
747  if (cond) { \
748  out_obj->info(out_obj, "%s", ""); \
749  }
750 
751 #define PCMK__OUTPUT_LIST_HEADER(out_obj, cond, retcode, title...) \
752  if (retcode == pcmk_rc_no_output) { \
753  PCMK__OUTPUT_SPACER_IF(out_obj, cond); \
754  retcode = pcmk_rc_ok; \
755  out_obj->begin_list(out_obj, NULL, NULL, title); \
756  }
757 
758 #define PCMK__OUTPUT_LIST_FOOTER(out_obj, retcode) \
759  if (retcode == pcmk_rc_ok) { \
760  out_obj->end_list(out_obj); \
761  }
762 
763 #ifdef __cplusplus
764 }
765 #endif
766 
767 #endif
results.h
Function and executable result codes.
pcmk__output_s::finish
void(* finish)(pcmk__output_t *out, crm_exit_t exit_status, bool print, void **copy_dest)
Definition: output_internal.h:279
pcmk__html_add_header
void pcmk__html_add_header(const char *name,...) G_GNUC_NULL_TERMINATED
Definition: output_html.c:423
pcmk__output_s::init
bool(* init)(pcmk__output_t *out)
Definition: output_internal.h:232
pcmk__output_s::output_xml
void(*) void(*) void(* output_xml)(pcmk__output_t *out, const char *name, const char *buf)
Definition: output_internal.h:388
pcmk__message_entry_t
struct pcmk__message_entry_s pcmk__message_entry_t
pcmk__mk_none_output
pcmk__output_t * pcmk__mk_none_output(char **argv)
Definition: output_none.c:99
pcmk__register_formats
void pcmk__register_formats(GOptionGroup *group, pcmk__supported_format_t *table)
Definition: output.c:101
pcmk__output_s::quiet
bool quiet
Should this formatter supress most output?
Definition: output_internal.h:183
pcmk__output_s::free_priv
void(* free_priv)(pcmk__output_t *out)
Definition: output_internal.h:243
pcmk__output_free
void pcmk__output_free(pcmk__output_t *out)
Definition: output.c:22
pcmk__output_xml_add_node
void pcmk__output_xml_add_node(pcmk__output_t *out, xmlNodePtr node)
Definition: output_xml.c:422
pcmk__output_s::subprocess_output
void(* subprocess_output)(pcmk__output_t *out, int exit_status, const char *proc_stdout, const char *proc_stderr)
Definition: output_internal.h:339
pcmk__output_s::messages
GHashTable * messages
Custom messages that are currently registered on this formatter.
Definition: output_internal.h:207
pcmk__output_s::priv
void * priv
Implementation-specific private data.
Definition: output_internal.h:216
pcmk__supported_format_t
struct pcmk__supported_format_s pcmk__supported_format_t
pcmk__register_format
int pcmk__register_format(GOptionGroup *group, const char *name, pcmk__output_factory_t create, GOptionEntry *options)
Definition: output.c:82
pcmk__output_xml_peek_parent
xmlNodePtr pcmk__output_xml_peek_parent(pcmk__output_t *out)
Definition: output_xml.c:468
pcmk__message_entry_s::fmt_name
const char * fmt_name
The format type this handler is for.
Definition: output_internal.h:106
pcmk__register_messages
void pcmk__register_messages(pcmk__output_t *out, pcmk__message_entry_t *table)
Definition: output.c:145
pcmk__output_s::version
void(* version)(pcmk__output_t *out, bool extended)
Definition: output_internal.h:350
pcmk__output_s::list_item
void(*) void(* list_item)(pcmk__output_t *out, const char *name, const char *format,...) G_GNUC_PRINTF(3
Definition: output_internal.h:422
pcmk__mk_html_output
pcmk__output_t * pcmk__mk_html_output(char **argv)
Definition: output_html.c:372
pcmk__text_output_entries
GOptionEntry pcmk__text_output_entries[]
Definition: output_text.c:19
pcmk__output_s::message
int(* message)(pcmk__output_t *out, const char *message_id,...)
Definition: output_internal.h:328
pcmk__output_create_xml_text_node
xmlNodePtr pcmk__output_create_xml_text_node(pcmk__output_t *out, const char *name, const char *content)
Definition: output_xml.c:441
pcmk__unregister_formats
void pcmk__unregister_formats(void)
Definition: output.c:114
pcmk__output_create_html_node
xmlNodePtr pcmk__output_create_html_node(pcmk__output_t *out, const char *element_name, const char *id, const char *class_name, const char *text)
Definition: output_html.c:407
pcmk__output_xml_create_parent
void void xmlNodePtr pcmk__output_xml_create_parent(pcmk__output_t *out, const char *name)
Definition: output_xml.c:415
pcmk__output_xml_pop_parent
void pcmk__output_xml_pop_parent(pcmk__output_t *out)
Definition: output_xml.c:458
pcmk__output_s::err
void(*) void(* err)(pcmk__output_t *out, const char *format,...) G_GNUC_PRINTF(2
Definition: output_internal.h:378
pcmk__output_factory_t
pcmk__output_t *(* pcmk__output_factory_t)(char **argv)
Definition: output_internal.h:50
pcmk__register_message
void pcmk__register_message(pcmk__output_t *out, const char *message_id, pcmk__message_fn_t fn)
Definition: output.c:139
pcmk__log_output_entries
GOptionEntry pcmk__log_output_entries[]
Definition: output_log.c:23
pcmk__output_s::end_list
void(* end_list)(pcmk__output_t *out)
Definition: output_internal.h:449
pcmk__html_output_entries
GOptionEntry pcmk__html_output_entries[]
Definition: output_html.c:42
pcmk__xml_output_entries
GOptionEntry pcmk__xml_output_entries[]
Definition: output_xml.c:33
pcmk__output_s::increment_list
void(*) void(*) void(* increment_list)(pcmk__output_t *out)
Definition: output_internal.h:437
pcmk__mk_log_output
pcmk__output_t * pcmk__mk_log_output(char **argv)
Definition: output_log.c:230
pcmk__indented_printf
void pcmk__indented_printf(pcmk__output_t *out, const char *format,...) G_GNUC_PRINTF(2
pcmk__output_s::begin_list
void(* begin_list)(pcmk__output_t *out, const char *singular_noun, const char *plural_noun, const char *format,...) G_GNUC_PRINTF(4
Definition: output_internal.h:409
pcmk__output_s::is_quiet
bool(* is_quiet)(pcmk__output_t *out)
Definition: output_internal.h:462
pcmk__output_s::reset
void(* reset)(pcmk__output_t *out)
Definition: output_internal.h:297
pcmk__output_new
int pcmk__output_new(pcmk__output_t **out, const char *fmt_name, const char *filename, char **argv)
Definition: output.c:34
pcmk__output_s
This structure contains everything that makes up a single output formatter.
Definition: output_internal.h:169
pcmk__message_fn_t
int(* pcmk__message_fn_t)(pcmk__output_t *out, va_list args)
Definition: output_internal.h:66
pcmk__output_create_xml_node
xmlNodePtr pcmk__output_create_xml_node(pcmk__output_t *out, const char *name)
Definition: output_xml.c:432
pcmk__supported_format_s::options
GOptionEntry * options
Format-specific command line options. This can be NULL if no command line options should be supported...
Definition: output_internal.h:136
pcmk__message_entry_s
Definition: output_internal.h:89
pcmk__output_s::fmt_name
const char * fmt_name
The name of this output formatter.
Definition: output_internal.h:173
crm_exit_t
enum crm_exit_e crm_exit_t
pcmk__mk_xml_output
pcmk__output_t * pcmk__mk_xml_output(char **argv)
Definition: output_xml.c:380
pcmk__call_message
int pcmk__call_message(pcmk__output_t *out, const char *message_id,...)
Definition: output.c:121
pcmk__message_entry_s::fn
pcmk__message_fn_t fn
The function to be called for message_id given a match on fmt_name. See comments on pcmk__message_fn_...
Definition: output_internal.h:112
pcmk__output_s::dest
FILE * dest
Where output should be written.
Definition: output_internal.h:199
pcmk__supported_format_s::create
pcmk__output_factory_t create
A function that creates a pcmk__output_t.
Definition: output_internal.h:130
pcmk__supported_format_s
Definition: output_internal.h:120
pcmk__output_s::info
void(* info)(pcmk__output_t *out, const char *format,...) G_GNUC_PRINTF(2
Definition: output_internal.h:364
pcmk__supported_format_s::name
const char * name
The name of this output formatter, which should match the fmt_name parameter in some pcmk__output_t s...
Definition: output_internal.h:125
pcmk__message_entry_s::message_id
const char * message_id
The message to be handled.
Definition: output_internal.h:96
pcmk__mk_text_output
pcmk__output_t * pcmk__mk_text_output(char **argv)
Definition: output_text.c:248
name
char * name
Definition: pcmk_fence.c:31
pcmk__output_s::request
gchar * request
A copy of the request that generated this output.
Definition: output_internal.h:191
pcmk__indented_vprintf
void void pcmk__indented_vprintf(pcmk__output_t *out, const char *format, va_list args) G_GNUC_PRINTF(2
pcmk__none_output_entries
GOptionEntry pcmk__none_output_entries[]
Definition: output_none.c:16
pcmk__output_xml_push_parent
void pcmk__output_xml_push_parent(pcmk__output_t *out, xmlNodePtr node)
Definition: output_xml.c:448
pcmk__output_s::register_message
void(* register_message)(pcmk__output_t *out, const char *message_id, pcmk__message_fn_t fn)
Definition: output_internal.h:310