+/**
+ * collection4 - action_show_instance.c
+ * Copyright (C) 2010 Florian octo Forster
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301 USA
+ *
+ * Authors:
+ * Florian octo Forster <ff at octo.it>
+ **/
+
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
return (0); \
} while (0)
+#define MAX_SHOW_GRAPHS 10
+
struct show_graph_data_s
{
graph_config_t *cfg;
graph_instance_t *inst;
+ int graph_count;
};
typedef struct show_graph_data_s show_graph_data_t;
}
} /* }}} void show_breadcrump_field */
-static int show_breadcrump (show_graph_data_t *data) /* {{{ */
+static int show_breadcrump (graph_config_t *cfg, /* {{{ */
+ graph_instance_t *inst)
{
graph_ident_t *ident;
char *prefix;
- if (data->inst != NULL)
+ if (inst != NULL)
{
prefix = "Instance";
- ident = inst_get_selector (data->inst);
+ ident = inst_get_selector (inst);
}
else
{
prefix = "Graph";
- ident = graph_get_selector (data->cfg);
+ ident = graph_get_selector (cfg);
}
printf ("<div class=\"breadcrump\">%s: "", prefix);
show_breadcrump_field (ident_get_type_instance (ident), "type_instance");
printf (""</div>\n");
+ ident_destroy (ident);
return (0);
} /* }}} int show_breadcrump */
return (0);
} /* }}} int show_time_selector */
-static int show_instance_list_cb (graph_instance_t *inst, /* {{{ */
- void *user_data)
+static int left_menu (void *user_data) /* {{{ */
{
show_graph_data_t *data = user_data;
- char descr[128];
- char params[1024];
-
- memset (descr, 0, sizeof (descr));
- inst_describe (data->cfg, inst, descr, sizeof (descr));
- html_escape_buffer (descr, sizeof (descr));
-
- if (inst == data->inst)
- {
- printf (" <li class=\"instance\"><strong>%s</strong></li>\n", descr);
- return (0);
- }
-
- memset (params, 0, sizeof (params));
- inst_get_params (data->cfg, inst, params, sizeof (params));
- html_escape_buffer (params, sizeof (params));
-
- printf (" <li class=\"instance\">"
- "<a href=\"%s?action=show_graph;%s\">%s</a></li>\n",
- script_name (), params, descr);
-
- return (0);
-} /* }}} int show_instance_list_cb */
-
-static int show_instance_list (void *user_data) /* {{{ */
-{
- show_graph_data_t *data = user_data;
- char title[128];
char params[1024];
- memset (title, 0, sizeof (title));
- graph_get_title (data->cfg, title, sizeof (title));
- html_escape_buffer (title, sizeof (title));
-
memset (params, 0, sizeof (params));
graph_get_params (data->cfg, params, sizeof (params));
html_escape_buffer (params, sizeof (params));
- printf ("<ul class=\"graph_list\">\n"
- " <li class=\"graph\"><a href=\"%s?action=show_graph;%s\">%s</a>\n"
- " <ul class=\"instance_list\">\n",
- script_name (), params, title);
-
- graph_inst_foreach (data->cfg, show_instance_list_cb, user_data);
-
- printf (" </ul>\n"
- "</ul>\n");
+ printf ("\n<ul class=\"menu left\">\n"
+ " <li><a href=\"%s?action=show_graph;%s\">All instances</a></li>\n"
+ " <li><a href=\"%s?action=list_graphs\">All graphs</a></li>\n"
+ "</ul>\n",
+ script_name (), params,
+ script_name ());
return (0);
-} /* }}} int show_instance_list */
+} /* }}} int left_menu */
static int show_instance_cb (graph_config_t *cfg, /* {{{ */
graph_instance_t *inst,
- __attribute__((unused)) void *user_data)
+ void *user_data)
{
+ show_graph_data_t *data = user_data;
char title[128];
char descr[128];
char params[1024];
+ long begin;
+ long end;
+ char time_params[128];
+ int status;
+
memset (title, 0, sizeof (title));
graph_get_title (cfg, title, sizeof (title));
html_escape_buffer (title, sizeof (title));
inst_get_params (cfg, inst, params, sizeof (params));
html_escape_buffer (params, sizeof (params));
- printf ("<h3>Instance "%s"</h3>\n", descr);
- printf ("<div class=\"graph-img\"><img src=\"%s?action=graph;%s\" "
- "title=\"%s / %s\" /></div>\n",
- script_name (), params, title, descr);
+ time_params[0] = 0;
+ begin = 0;
+ end = 0;
+
+ status = get_time_args (&begin, &end, /* now = */ NULL);
+ if (status == 0)
+ {
+ snprintf (time_params, sizeof (time_params), ";begin=%li;end=%li",
+ begin, end);
+ time_params[sizeof (time_params) - 1] = 0;
+ }
+
+ printf ("<h2>Instance "%s"</h2>\n", descr);
+
+ show_breadcrump (cfg, inst);
+
+ if (data->graph_count < MAX_SHOW_GRAPHS)
+ printf ("<div class=\"graph-img\"><img src=\"%s?action=graph;%s%s\" "
+ "title=\"%s / %s\" /></div>\n",
+ script_name (), params, time_params, title, descr);
+ else
+ printf ("<a href=\"%s?action=show_instance;%s\">Show graph "
+ ""%s / %s"</a>\n",
+ script_name (), params, title, descr);
+
+ data->graph_count++;
return (0);
} /* }}} int show_instance_cb */
fprintf (stderr, "show_instance: Calling inst_get_all_selected()\n");
status = inst_get_all_selected (data->cfg,
- /* callback = */ show_instance_cb, /* user data = */ NULL);
+ /* callback = */ show_instance_cb, /* user data = */ data);
if (status != 0)
fprintf (stderr, "show_instance: inst_get_all_selected failed "
"with status %i\n", status);
return (0);
} /* }}} int show_instance */
-static int show_graph (void *user_data) /* {{{ */
-{
- show_graph_data_t *data = user_data;
-
- show_breadcrump (data);
- return (show_instance_list (user_data));
-} /* }}} int show_graph */
-
int action_show_instance (void) /* {{{ */
{
page_callbacks_t pg_callbacks = PAGE_CALLBACKS_INIT;
char tmp[128];
char title[128];
+ memset (&pg_data, 0, sizeof (pg_data));
pg_data.cfg = gl_graph_get_selected ();
if (pg_data.cfg == NULL)
OUTPUT_ERROR ("gl_graph_get_selected () failed.\n");
pg_callbacks.top_right = html_print_search_box;
pg_callbacks.middle_center = show_instance;
- pg_callbacks.middle_left = show_instance_list;
+ pg_callbacks.middle_left = left_menu;
pg_callbacks.middle_right = show_time_selector;
html_print_page (title, &pg_callbacks, &pg_data);