src/utils_cgi.c: Change shortcut name to "C₄" (from "c⁴").
[collection4.git] / src / action_show_graph.c
index 8cde5c2..9b9f5da 100644 (file)
@@ -1,3 +1,26 @@
+/**
+ * collection4 - action_show_graph.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;
 };
 typedef struct show_graph_data_s show_graph_data_t;
 
-static void show_breadcrump_field (const char *str, /* {{{ */
-    const char *field_name)
-{
-  if ((str == NULL) || (str[0] == 0))
-    printf ("<em>none</em>");
-  else if (IS_ANY (str))
-    printf ("<em>any</em>");
-  else if (IS_ALL (str))
-    printf ("<em>all</em>");
-  else
-  {
-    char *str_html = html_escape (str);
-
-    if (field_name != NULL)
-      printf ("<a href=\"%s?action=list_graphs;q=%s:%s\">%s</a>",
-          script_name (), field_name, str_html, str_html);
-    else
-      printf ("<a href=\"%s?action=list_graphs;q=%s\">%s</a>",
-          script_name (), str_html, str_html);
-
-    free (str_html);
-  }
-} /* }}} void show_breadcrump_field */
-
-static int show_breadcrump (show_graph_data_t *data) /* {{{ */
-{
-  graph_ident_t *ident;
-  char *prefix;
-
-  if (data->inst != NULL)
-  {
-    prefix = "Instance";
-    ident = inst_get_selector (data->inst);
-  }
-  else
-  {
-    prefix = "Graph";
-    ident = graph_get_selector (data->cfg);
-  }
-
-  printf ("<div class=\"breadcrump\">%s: &quot;", prefix);
-  show_breadcrump_field (ident_get_host (ident), "host");
-  printf ("&nbsp;/ ");
-  show_breadcrump_field (ident_get_plugin (ident), "plugin");
-  printf ("&nbsp;&ndash; ");
-  show_breadcrump_field (ident_get_plugin_instance (ident), "plugin_instance");
-  printf ("&nbsp;/ ");
-  show_breadcrump_field (ident_get_type (ident), "type");
-  printf ("&nbsp;&ndash; ");
-  show_breadcrump_field (ident_get_type_instance (ident), "type_instance");
-  printf ("&quot;</div>\n");
-
-  return (0);
-} /* }}} int show_breadcrump */
-
 static int show_time_selector (__attribute__((unused)) void *user_data) /* {{{ */
 {
   param_list_t *pl;
@@ -114,110 +83,48 @@ static int show_time_selector (__attribute__((unused)) void *user_data) /* {{{ *
   return (0);
 } /* }}} int show_time_selector */
 
-static int show_instance_list_cb (graph_instance_t *inst, /* {{{ */
-    void *user_data)
+static int left_menu (__attribute__((unused)) 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);
+  printf ("\n<ul class=\"menu left\">\n"
+      "  <li><a href=\"%s?action=list_graphs\">All graphs</a></li>\n"
+      "</ul>\n",
+      script_name ());
 
   return (0);
-} /* }}} int show_instance_list_cb */
+} /* }}} int left_menu */
 
-static int show_instance_list (void *user_data) /* {{{ */
+static int show_instance_cb (graph_instance_t *inst, /* {{{ */
+    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");
-
-  return (0);
-} /* }}} int show_instance_list */
-
-static int show_instance_cb (graph_config_t *cfg, /* {{{ */
-    graph_instance_t *inst,
-    __attribute__((unused)) void *user_data)
-{
-  char title[128];
   char descr[128];
   char params[1024];
 
-  memset (title, 0, sizeof (title));
-  graph_get_title (cfg, title, sizeof (title));
-  html_escape_buffer (title, sizeof (title));
-
   memset (descr, 0, sizeof (descr));
-  inst_describe (cfg, inst, descr, sizeof (descr));
+  inst_describe (data->cfg, inst, descr, sizeof (descr));
   html_escape_buffer (descr, sizeof (descr));
 
   memset (params, 0, sizeof (params));
-  inst_get_params (cfg, inst, params, sizeof (params));
+  inst_get_params (data->cfg, inst, params, sizeof (params));
   html_escape_buffer (params, sizeof (params));
 
-  printf ("<h3>Instance &quot;%s&quot;</h3>\n", descr);
-  printf ("<div class=\"graph-img\"><img src=\"%s?action=graph;%s\" "
-      "title=\"%s / %s\" /></div>\n",
-      script_name (), params, title, descr);
+  printf ("  <li class=\"instance\"><a href=\"%s?action=show_instance;%s\">"
+      "%s</a></li>\n",
+      script_name (), params, descr);
 
   return (0);
 } /* }}} int show_instance_cb */
 
-static int show_instance (void *user_data) /* {{{ */
+static int show_graph (void *user_data) /* {{{ */
 {
   show_graph_data_t *data = user_data;
-  int status;
 
-  fprintf (stderr, "show_instance: Calling inst_get_all_selected()\n");
-  status = inst_get_all_selected (data->cfg,
-      /* callback = */ show_instance_cb, /* user data = */ NULL);
-  if (status != 0)
-    fprintf (stderr, "show_instance: inst_get_all_selected failed "
-        "with status %i\n", status);
+  printf ("<h2>Available instances</h2>\n");
+  printf ("<ul class=\"instance_list\">\n");
+  graph_inst_foreach (data->cfg, show_instance_cb, data);
+  printf ("</ul>\n");
 
   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_graph (void) /* {{{ */
@@ -228,6 +135,7 @@ int action_show_graph (void) /* {{{ */
   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");
@@ -238,13 +146,13 @@ int action_show_graph (void) /* {{{ */
   title[sizeof (title) - 1] = 0;
 
   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_center = show_graph;
   pg_callbacks.middle_right = show_time_selector;
 
   html_print_page (title, &pg_callbacks, &pg_data);
 
   return (0);
-} /* }}} int action_graph */
+} /* }}} int action_show_graph */
 
 /* vim: set sw=2 sts=2 et fdm=marker : */