Annotation of embedaddon/bmon/src/graph.c, revision 1.1
1.1 ! misho 1: /*
! 2: * graph.c Graph creation utility
! 3: *
! 4: * Copyright (c) 2001-2005 Thomas Graf <tgraf@suug.ch>
! 5: *
! 6: * Permission is hereby granted, free of charge, to any person obtaining a
! 7: * copy of this software and associated documentation files (the "Software"),
! 8: * to deal in the Software without restriction, including without limitation
! 9: * the rights to use, copy, modify, merge, publish, distribute, sublicense,
! 10: * and/or sell copies of the Software, and to permit persons to whom the
! 11: * Software is furnished to do so, subject to the following conditions:
! 12: *
! 13: * The above copyright notice and this permission notice shall be included
! 14: * in all copies or substantial portions of the Software.
! 15: *
! 16: * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
! 17: * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
! 18: * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
! 19: * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
! 20: * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
! 21: * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
! 22: * DEALINGS IN THE SOFTWARE.
! 23: */
! 24:
! 25: #include <bmon/bmon.h>
! 26: #include <bmon/graph.h>
! 27: #include <bmon/input.h>
! 28: #include <bmon/conf.h>
! 29: #include <bmon/item.h>
! 30: #include <bmon/node.h>
! 31: #include <bmon/conf.h>
! 32: #include <bmon/utils.h>
! 33:
! 34:
! 35: static void put_col(table_t *t, int data_idx, hist_data_t *src, int hist_idx,
! 36: double half_step)
! 37: {
! 38: int i;
! 39: char *col = D_AT_COL(t->t_data, data_idx);
! 40:
! 41: rate_cnt_t tot = src->hd_data[hist_idx];
! 42:
! 43: if (tot == UNK_DATA) {
! 44: for (i = 0; i < t->t_height; i++)
! 45: *(D_AT_ROW(col, i)) = get_unk_char();
! 46: } else if (tot) {
! 47: *(D_AT_ROW(col, 0)) = ':';
! 48:
! 49: for (i = 0; i < t->t_height; i++)
! 50: if (tot >= (t->t_y_scale[i] - half_step))
! 51: *(D_AT_ROW(col, i)) = get_fg_char();
! 52: }
! 53: }
! 54:
! 55: static void create_table(table_t *t, hist_data_t *src, int index, int height,
! 56: int unit)
! 57: {
! 58: int i, di;
! 59: size_t dsize = height * (HISTORY_SIZE + 1);
! 60: rate_cnt_t max = 0;
! 61: double half_step, step;
! 62:
! 63: t->t_index = index;
! 64: t->t_height = height;
! 65: t->t_y_scale = xcalloc(height, sizeof(double));
! 66: t->t_data = xcalloc(dsize, sizeof(char));
! 67:
! 68: memset(t->t_data, get_bg_char(), dsize);
! 69:
! 70: for (i = 0; i < height; i++)
! 71: *(D_AT_COL(D_AT_ROW(t->t_data, i), HISTORY_SIZE)) = '\0';
! 72:
! 73: for (i = 0; i < HISTORY_SIZE; i++)
! 74: if (max < src->hd_data[i] && src->hd_data[i] != UNK_DATA)
! 75: max = src->hd_data[i];
! 76:
! 77: step = (double) max / (double) height;
! 78: half_step = step / 2.0f;
! 79:
! 80: for (i = 0; i < height; i++)
! 81: t->t_y_scale[i] = (double) (i + 1) * step;
! 82:
! 83: for (di = 0, i = (index - 1); i >= 0; di++, i--)
! 84: put_col(t, di, src, i, half_step);
! 85:
! 86: for (i = (HISTORY_SIZE - 1); di < HISTORY_SIZE; di++, i--)
! 87: put_col(t, di, src, i, half_step);
! 88:
! 89: {
! 90: b_cnt_t div;
! 91: int h = (height / 3) * 2;
! 92:
! 93: if (h >= height)
! 94: h = (height - 1);
! 95:
! 96: div = get_divisor(t->t_y_scale[h], unit, &t->t_y_unit, NULL);
! 97:
! 98: for (i = 0; i < height; i++)
! 99: t->t_y_scale[i] /= (double) div;
! 100: }
! 101: }
! 102:
! 103: graph_t * create_graph(hist_elem_t *src, int height, int unit)
! 104: {
! 105: graph_t *g;
! 106:
! 107: g = xcalloc(1, sizeof(graph_t));
! 108:
! 109: create_table(&g->g_rx, &src->he_rx, src->he_index, height, unit);
! 110: create_table(&g->g_tx, &src->he_tx, src->he_index, height, unit);
! 111:
! 112: return g;
! 113: }
! 114:
! 115: graph_t * create_configued_graph(history_t *src, int height, int unit,
! 116: int x_unit)
! 117: {
! 118: graph_t *g;
! 119: hist_elem_t *e = NULL;
! 120: char *u = "s";
! 121: int h = 0;
! 122:
! 123: switch (x_unit) {
! 124: case X_SEC: u = "s"; e = &src->h_sec; break;
! 125: case X_MIN: u = "m"; e = &src->h_min; break;
! 126: case X_HOUR: u = "h"; e = &src->h_hour; break;
! 127: case X_DAY: u = "d"; e = &src->h_day; break;
! 128: case X_READ: {
! 129: if (get_read_interval() != 1.0f) {
! 130: char buf[32];
! 131: float ri = get_read_interval();
! 132:
! 133: snprintf(buf, sizeof(buf), "(%.2fs)", ri);
! 134: u = strdup(buf);
! 135: h = 1;
! 136: e = &src->h_read;
! 137: } else {
! 138: u = "s";
! 139: e = &src->h_sec;
! 140: }
! 141: }
! 142: break;
! 143: }
! 144:
! 145: if (NULL == e)
! 146: BUG();
! 147:
! 148: g = create_graph(e, height, unit);
! 149:
! 150: if (h)
! 151: g->g_flags |= GRAPH_HAS_FREEABLE_X_UNIT;
! 152:
! 153: g->g_rx.t_x_unit = u;
! 154: g->g_tx.t_x_unit = u;
! 155:
! 156: return g;
! 157: }
! 158:
! 159: static void free_table(table_t *t)
! 160: {
! 161: xfree(t->t_y_scale);
! 162: xfree(t->t_data);
! 163: }
! 164:
! 165: void free_graph(graph_t *g)
! 166: {
! 167: if (g->g_flags & GRAPH_HAS_FREEABLE_X_UNIT)
! 168: xfree(g->g_rx.t_x_unit);
! 169:
! 170: free_table(&g->g_rx);
! 171: free_table(&g->g_tx);
! 172: xfree(g);
! 173: }
! 174:
! 175: void new_graph(void)
! 176: {
! 177: if (get_ngraphs() >= (MAX_GRAPHS - 1))
! 178: return;
! 179: set_ngraphs(get_ngraphs() + 1);
! 180: }
! 181:
! 182: void del_graph(void)
! 183: {
! 184: if (get_ngraphs() <= 1)
! 185: return;
! 186: set_ngraphs(get_ngraphs() - 1);
! 187: }
! 188:
! 189: int next_graph(void)
! 190: {
! 191: item_t *it = get_current_item();
! 192: if (it == NULL)
! 193: return EMPTY_LIST;
! 194:
! 195: if (it->i_graph_sel >= (get_ngraphs() - 1))
! 196: it->i_graph_sel = 0;
! 197: else
! 198: it->i_graph_sel++;
! 199:
! 200: return 0;
! 201: }
! 202:
! 203: int prev_graph(void)
! 204: {
! 205: item_t *it = get_current_item();
! 206: if (it == NULL)
! 207: return EMPTY_LIST;
! 208:
! 209: if (it->i_graph_sel <= 0)
! 210: it->i_graph_sel = get_ngraphs() - 1;
! 211: else
! 212: it->i_graph_sel--;
! 213:
! 214: return 0;
! 215: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>