#include <errno.h>
#include "graph_def.h"
+#include "graph.h"
#include "graph_config.h"
#include "common.h"
#include "oconfig.h"
char *ds_name;
char *legend;
uint32_t color;
+ _Bool stack;
+ _Bool area;
+ char *format;
graph_def_t *next;
};
graph_def_t *def;
int i;
- ident = gl_graph_get_selector (cfg);
+ ident = graph_get_selector (cfg);
if (ident == NULL)
{
- fprintf (stderr, "def_config_get_obj: gl_graph_get_selector failed");
+ fprintf (stderr, "def_config_get_obj: graph_get_selector failed");
return (NULL);
}
if ((cfg == NULL) || (ident == NULL) || (ds_name == NULL))
return (NULL);
- selector = gl_graph_get_selector (cfg);
+ selector = graph_get_selector (cfg);
if (selector == NULL)
return (NULL);
}
memset (ret, 0, sizeof (*ret));
ret->legend = NULL;
+ ret->format = NULL;
ret->ds_name = strdup (ds_name);
if (ret->ds_name == NULL)
ident_destroy (def->select);
free (def->ds_name);
+ free (def->legend);
+ free (def->format);
free (def);
graph_config_get_string (child, &def->legend);
else if (strcasecmp ("Color", child->key) == 0)
def_config_color (child, &def->color);
+ else if (strcasecmp ("Stack", child->key) == 0)
+ graph_config_get_bool (child, &def->stack);
+ else if (strcasecmp ("Area", child->key) == 0)
+ graph_config_get_bool (child, &def->area);
+ else if (strcasecmp ("Format", child->key) == 0)
+ graph_config_get_string (child, &def->format);
+ else
+ fprintf (stderr, "def_config: Ignoring unknown config option \"%s\"",
+ child->key);
}
- return (gl_graph_add_def (cfg, def));
+ return (graph_add_def (cfg, def));
} /* }}} int def_config */
int def_append (graph_def_t *head, graph_def_t *def) /* {{{ */
index, index);
/* Graph part */
- array_append_format (args, "LINE1:def_%04i_avg#%06"PRIx32":%s",
+ array_append_format (args, "%s:def_%04i_avg#%06"PRIx32":%s%s",
+ def->area ? "AREA" : "LINE1",
index, def->color,
- (def->legend != NULL) ? def->legend : def->ds_name);
- array_append_format (args, "GPRINT:vdef_%04i_min:%%lg min,", index);
- array_append_format (args, "GPRINT:vdef_%04i_avg:%%lg avg,", index);
- array_append_format (args, "GPRINT:vdef_%04i_max:%%lg max,", index);
- array_append_format (args, "GPRINT:vdef_%04i_lst:%%lg last\\l", index);
+ (def->legend != NULL) ? def->legend : def->ds_name,
+ def->stack ? ":STACK" : "");
+ array_append_format (args, "GPRINT:vdef_%04i_min:%s min,",
+ index, (def->format != NULL) ? def->format : "%lg");
+ array_append_format (args, "GPRINT:vdef_%04i_avg:%s avg,",
+ index, (def->format != NULL) ? def->format : "%lg");
+ array_append_format (args, "GPRINT:vdef_%04i_max:%s max,",
+ index, (def->format != NULL) ? def->format : "%lg");
+ array_append_format (args, "GPRINT:vdef_%04i_lst:%s last\\l",
+ index, (def->format != NULL) ? def->format : "%lg");
free (file);