2 * sadf: System activity data formatter
3 * (C) 1999-2019 by Sebastien Godard (sysstat <at> orange.fr)
11 /* DTD version for XML output */
12 #define XML_DTD_VERSION "3.7"
14 /* Various constants */
18 #define IGNORE_NOTHING 0
19 #define IGNORE_RESTART 1
20 #define DONT_READ_CPU_NR 2
21 #define IGNORE_COMMENT 4
22 #define SET_TIMESTAMPS 8
25 ***************************************************************************
26 * Output format identification values.
27 ***************************************************************************
30 /* Number of output formats */
35 #define F_HEADER_OUTPUT 2
36 #define F_PPC_OUTPUT 3
37 #define F_XML_OUTPUT 4
38 #define F_JSON_OUTPUT 5
39 #define F_CONV_OUTPUT 6
40 #define F_SVG_OUTPUT 7
41 #define F_RAW_OUTPUT 8
42 #define F_PCP_OUTPUT 9
47 * Indicate that all statistics data for one activity should be displayed before
48 * displaying stats for next activity. This is what sar does in its report.
49 * Example: If stats for activities A and B at time t and t' have been collected,
50 * setting AO_GROUPED_STATS for a format will result in the following output:
51 * stats for activity A at t
52 * stats for activity A at t'
53 * stats for activity B at t
54 * stats for activity B at t'
55 * Without this option, output would be:
56 * stats for activity A at t
57 * stats for activity B at t
58 * stats for activity A at t'
59 * stats for activity B at t'
61 #define FO_GROUPED_STATS 0x01
64 * Indicate that output should stop after the header is displayed.
66 #define FO_HEADER_ONLY 0x02
69 * Indicate that a true sysstat activity file but with a bad
70 * format should not yield an error message.
72 #define FO_BAD_FILE_FORMAT 0x04
75 * Indicate that timestamp can be displayed in local time instead of UTC
76 * if option -T or -t has been used.
78 #define FO_LOCAL_TIME 0x08
81 * Indicate that all activities will be displayed horizontally
82 * if option -h is used.
84 #define FO_HORIZONTALLY 0x10
87 * Indicate that the timestamp can be displayed in seconds since the epoch
88 * if option -U has been used.
90 #define FO_SEC_EPOCH 0x20
93 * Indicate that the list of fields should be displayed before the first
96 #define FO_FIELD_LIST 0x40
99 * Indicate that flag AO_CLOSE_MARKUP (set for activities that need it)
100 * should be taken into account for this output format.
102 #define FO_TEST_MARKUP 0x80
105 * Indicate that timestamp cannot be displayed in the original local time
106 * of the data file creator.
108 #define FO_NO_TRUE_TIME 0x100
110 #define DISPLAY_GROUPED_STATS(m) (((m) & FO_GROUPED_STATS) == FO_GROUPED_STATS)
111 #define ACCEPT_HEADER_ONLY(m) (((m) & FO_HEADER_ONLY) == FO_HEADER_ONLY)
112 #define ACCEPT_BAD_FILE_FORMAT(m) (((m) & FO_BAD_FILE_FORMAT) == FO_BAD_FILE_FORMAT)
113 #define ACCEPT_LOCAL_TIME(m) (((m) & FO_LOCAL_TIME) == FO_LOCAL_TIME)
114 #define ACCEPT_HORIZONTALLY(m) (((m) & FO_HORIZONTALLY) == FO_HORIZONTALLY)
115 #define ACCEPT_SEC_EPOCH(m) (((m) & FO_SEC_EPOCH) == FO_SEC_EPOCH)
116 #define DISPLAY_FIELD_LIST(m) (((m) & FO_FIELD_LIST) == FO_FIELD_LIST)
117 #define TEST_MARKUP(m) (((m) & FO_TEST_MARKUP) == FO_TEST_MARKUP)
118 #define REJECT_TRUE_TIME(m) (((m) & FO_NO_TRUE_TIME) == FO_NO_TRUE_TIME)
122 ***************************************************************************
123 * Various function prototypes
124 ***************************************************************************
128 (char [], struct activity *[]);
131 * Prototypes used to display restart messages
133 __printf_funct_t print_db_restart
134 (int *, int, char *, char *, int, struct file_header *);
135 __printf_funct_t print_ppc_restart
136 (int *, int, char *, char *, int, struct file_header *);
137 __printf_funct_t print_xml_restart
138 (int *, int, char *, char *, int, struct file_header *);
139 __printf_funct_t print_json_restart
140 (int *, int, char *, char *, int, struct file_header *);
141 __printf_funct_t print_raw_restart
142 (int *, int, char *, char *, int, struct file_header *);
145 * Prototypes used to display comments
147 __printf_funct_t print_db_comment
148 (int *, int, char *, char *, int, char *, struct file_header *);
149 __printf_funct_t print_ppc_comment
150 (int *, int, char *, char *, int, char *, struct file_header *);
151 __printf_funct_t print_xml_comment
152 (int *, int, char *, char *, int, char *, struct file_header *);
153 __printf_funct_t print_json_comment
154 (int *, int, char *, char *, int, char *, struct file_header *);
155 __printf_funct_t print_sar_comment
156 (int *, int, char *, char *, int, char *, struct file_header *);
157 __printf_funct_t print_raw_comment
158 (int *, int, char *, char *, int, char *, struct file_header *);
161 * Prototypes used to display the statistics part of the report
163 __printf_funct_t print_xml_statistics
164 (int *, int, struct activity * [], unsigned int []);
165 __printf_funct_t print_json_statistics
166 (int *, int, struct activity * [], unsigned int []);
167 __printf_funct_t print_pcp_statistics
168 (int *, int, struct activity * [], unsigned int []);
171 * Prototypes used to display the timestamp part of the report
173 __tm_funct_t print_db_timestamp
174 (void *, int, char *, char *, unsigned long long, struct file_header *, unsigned int);
175 __tm_funct_t print_ppc_timestamp
176 (void *, int, char *, char *, unsigned long long, struct file_header *, unsigned int);
177 __tm_funct_t print_xml_timestamp
178 (void *, int, char *, char *, unsigned long long, struct file_header *, unsigned int);
179 __tm_funct_t print_json_timestamp
180 (void *, int, char *, char *, unsigned long long, struct file_header *, unsigned int);
181 __tm_funct_t print_raw_timestamp
182 (void *, int, char *, char *, unsigned long long, struct file_header *, unsigned int);
185 * Prototypes used to display the report header
187 __printf_funct_t print_xml_header
188 (void *, int, char *, struct file_magic *, struct file_header *,
189 struct activity * [], unsigned int [], struct file_activity *);
190 __printf_funct_t print_json_header
191 (void *, int, char *, struct file_magic *, struct file_header *,
192 struct activity * [], unsigned int [], struct file_activity *);
193 __printf_funct_t print_hdr_header
194 (void *, int, char *, struct file_magic *, struct file_header *,
195 struct activity * [], unsigned int [], struct file_activity *);
196 __printf_funct_t print_svg_header
197 (void *, int, char *, struct file_magic *, struct file_header *,
198 struct activity * [], unsigned int [], struct file_activity *);
199 __printf_funct_t print_pcp_header
200 (void *, int, char *, struct file_magic *, struct file_header *,
201 struct activity * [], unsigned int [], struct file_activity *);