graph: use array instead of linked list

Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
Julien Danjou 2008-10-21 12:04:19 +02:00
parent a5640330d9
commit 96929faa69
1 changed files with 37 additions and 33 deletions

View File

@ -34,10 +34,8 @@ typedef enum
Line_Style Line_Style
} plot_style_t; } plot_style_t;
typedef struct plot_t plot_t;
/** The plot data structure. */ /** The plot data structure. */
struct plot_t typedef struct
{ {
/** Grapht title of the plot sections */ /** Grapht title of the plot sections */
char *title; char *title;
@ -67,20 +65,17 @@ struct plot_t
xcolor_t pcolor_end; xcolor_t pcolor_end;
/** Create a vertical color gradient */ /** Create a vertical color gradient */
bool vertical_gradient; bool vertical_gradient;
/** Next and previous graph */ } plot_t;
plot_t *next, *prev;
};
static void static void
plot_delete(plot_t **g) plot_delete(plot_t *g)
{ {
p_delete(&(*g)->title); p_delete(&g->title);
p_delete(&(*g)->lines); p_delete(&g->lines);
p_delete(&(*g)->values); p_delete(&g->values);
p_delete(g);
} }
DO_SLIST(plot_t, plot, plot_delete) DO_ARRAY(plot_t, plot, plot_delete)
/** The private graph data structure */ /** The private graph data structure */
typedef struct typedef struct
@ -104,7 +99,7 @@ typedef struct
/** Preparation/tmp array for draw_graph(); */ /** Preparation/tmp array for draw_graph(); */
int *draw_to; int *draw_to;
/** Graph list */ /** Graph list */
plot_t *plots; plot_array_t plots;
} graph_data_t; } graph_data_t;
/** Add a plot to a graph. /** Add a plot to a graph.
@ -115,18 +110,17 @@ typedef struct
static plot_t * static plot_t *
graph_plot_add(graph_data_t *d, const char *title) graph_plot_add(graph_data_t *d, const char *title)
{ {
plot_t *plot = p_new(plot_t, 1); plot_t plot;
plot->title = a_strdup(title); plot.title = a_strdup(title);
plot->values = p_new(float, d->size); plot.values = p_new(float, d->size);
plot->lines = p_new(int, d->size); plot.lines = p_new(int, d->size);
plot->max_value = 100.0; plot.max_value = 100.0;
plot->color_start = globalconf.colors.fg; plot.color_start = globalconf.colors.fg;
plot->vertical_gradient = true; plot.vertical_gradient = true;
plot_list_append(&d->plots, plot); plot_array_append(&d->plots, plot);
return &d->plots.tab[d->plots.len - 1];
return plot;
} }
/** Draw a graph widget. /** Draw a graph widget.
@ -150,9 +144,8 @@ graph_draw(draw_context_t *ctx,
graph_data_t *d = w->widget->data; graph_data_t *d = w->widget->data;
area_t rectangle; area_t rectangle;
vector_t color_gradient; vector_t color_gradient;
plot_t *plot;
if(!d->plots) if(!d->plots.len)
return 0; return 0;
w->area.x = widget_calculate_offset(ctx->width, w->area.x = widget_calculate_offset(ctx->width,
@ -185,7 +178,10 @@ graph_draw(draw_context_t *ctx,
else else
color_gradient.x = rectangle.x; color_gradient.x = rectangle.x;
for(plot = d->plots; plot; plot = plot->next) for(int i = 0; i < d->plots.len; i++)
{
plot_t *plot = &d->plots.tab[i];
switch(plot->draw_style) switch(plot->draw_style)
{ {
case Top_Style: case Top_Style:
@ -255,6 +251,7 @@ graph_draw(draw_context_t *ctx,
&plot->color_start, &plot->pcolor_center, &plot->pcolor_end); &plot->color_start, &plot->pcolor_center, &plot->pcolor_end);
break; break;
} }
}
/* draw border (after line-drawing, what paints 0-values to the border) */ /* draw border (after line-drawing, what paints 0-values to the border) */
rectangle.x = w->area.x; rectangle.x = w->area.x;
@ -284,16 +281,20 @@ luaA_graph_plot_properties_set(lua_State *L)
float max_value; float max_value;
const char *title, *buf; const char *title, *buf;
size_t len; size_t len;
plot_t *plot; plot_t *plot = NULL;
xcolor_init_request_t reqs[3]; xcolor_init_request_t reqs[3];
int8_t i, reqs_nbr = -1; int8_t i, reqs_nbr = -1;
title = luaL_checkstring(L, 2); title = luaL_checkstring(L, 2);
luaA_checktable(L, 3); luaA_checktable(L, 3);
for(plot = d->plots; plot; plot = plot->next) for(int j = 0; j < d->plots.len; j++)
{
plot = &d->plots.tab[j];
if(!a_strcmp(title, plot->title)) if(!a_strcmp(title, plot->title))
break; break;
}
/* no plot found -> create one */ /* no plot found -> create one */
if(!plot) if(!plot)
plot = graph_plot_add(d, title); plot = graph_plot_add(d, title);
@ -351,14 +352,17 @@ luaA_graph_plot_data_add(lua_State *L)
{ {
widget_t **widget = luaA_checkudata(L, 1, "widget"); widget_t **widget = luaA_checkudata(L, 1, "widget");
graph_data_t *d = (*widget)->data; graph_data_t *d = (*widget)->data;
plot_t *plot; plot_t *plot = NULL;
const char *title = luaL_checkstring(L, 2); const char *title = luaL_checkstring(L, 2);
float value; float value;
int i; int i;
for(plot = d->plots; plot; plot = plot->next) for(int j = 0; j < d->plots.len; j++)
{
plot = &d->plots.tab[j];
if(!a_strcmp(title, plot->title)) if(!a_strcmp(title, plot->title))
break; break;
}
/* no plot found -> create one */ /* no plot found -> create one */
if(!plot) if(!plot)
@ -485,7 +489,6 @@ luaA_graph_newindex(lua_State *L, awesome_token_t token)
graph_data_t *d = (*widget)->data; graph_data_t *d = (*widget)->data;
const char *buf; const char *buf;
int width; int width;
plot_t *plot;
position_t pos; position_t pos;
xcolor_t color; xcolor_t color;
@ -500,8 +503,9 @@ luaA_graph_newindex(lua_State *L, awesome_token_t token)
{ {
d->width = width; d->width = width;
d->size = d->width - 2; d->size = d->width - 2;
for(plot = d->plots; plot; plot = plot->next) for(int i = 0; i < d->plots.len; i++)
{ {
plot_t *plot = &d->plots.tab[i];
p_realloc(&plot->values, d->size); p_realloc(&plot->values, d->size);
p_realloc(&plot->lines, d->size); p_realloc(&plot->lines, d->size);
p_clear(plot->values, d->size); p_clear(plot->values, d->size);
@ -561,7 +565,7 @@ graph_destructor(widget_t *widget)
{ {
graph_data_t *d = widget->data; graph_data_t *d = widget->data;
plot_list_wipe(&d->plots); plot_array_wipe(&d->plots);
p_delete(&d->draw_from); p_delete(&d->draw_from);
p_delete(&d->draw_to); p_delete(&d->draw_to);
p_delete(&d); p_delete(&d);