aboutsummaryrefslogtreecommitdiffstats
path: root/widget_text.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--widget_text.c601
1 files changed, 311 insertions, 290 deletions
diff --git a/widget_text.c b/widget_text.c
index 4275e99..f205a59 100644
--- a/widget_text.c
+++ b/widget_text.c
@@ -1,4 +1,4 @@
-/* $Id: widget_text.c,v 1.21 2005/01/18 06:30:24 reinelt Exp $
+/* $Id: widget_text.c,v 1.22 2005/05/08 04:32:45 reinelt Exp $
*
* simple text widget handling
*
@@ -21,6 +21,9 @@
*
*
* $Log: widget_text.c,v $
+ * Revision 1.22 2005/05/08 04:32:45 reinelt
+ * CodingStyle added and applied
+ *
* Revision 1.21 2005/01/18 06:30:24 reinelt
* added (C) to all copyright statements
*
@@ -147,317 +150,335 @@
#endif
-void widget_text_scroll (void *Self)
+void widget_text_scroll(void *Self)
{
- WIDGET *W = (WIDGET*)Self;
- WIDGET_TEXT *T = W->data;
-
- int num, len, width, pad;
- char *src, *dst;
-
- num = 0;
- len = strlen(T->value);
- width = T->width-strlen(T->preval)-strlen(T->postval);
- if (width<0) width=0;
-
- switch (T->align) {
- case ALIGN_LEFT:
- pad=0;
- break;
- case ALIGN_CENTER:
- pad=(width - len)/2;
- if (pad<0) pad=0;
- break;
- case ALIGN_RIGHT:
- pad=width - len;
- if (pad<0) pad=0;
- break;
- case ALIGN_MARQUEE:
- pad=width - T->scroll;
- T->scroll++;
- if (T->scroll >= width+len) T->scroll=0;
- break;
- default: /* not reached */
- pad=0;
- }
-
- dst=T->buffer;
-
- /* process prefix */
- src=T->preval;
- while (num < T->width) {
- if (*src=='\0') break;
- *(dst++)=*(src++);
- num++;
- }
-
- src=T->value;
-
- /* pad blanks on the beginning */
- while (pad > 0 && num < T->width) {
- *(dst++)=' ';
- num++;
- pad--;
- }
-
- /* skip src chars (marquee) */
- while (pad<0) {
- src++;
- pad++;
- }
-
- /* copy content */
- while (num < T->width) {
- if (*src=='\0') break;
- *(dst++)=*(src++);
- num++;
- }
-
- /* pad blanks on the end */
- src=T->postval;
- len=strlen(src);
- while (num < T->width-len) {
- *(dst++)=' ';
- num++;
- }
-
- /* process postfix */
- while (num < T->width) {
- if (*src=='\0') break;
- *(dst++)=*(src++);
- num++;
- }
-
- *dst='\0';
-
- /* finally, draw it! */
- if (W->class->draw)
- W->class->draw(W);
+ WIDGET *W = (WIDGET *) Self;
+ WIDGET_TEXT *T = W->data;
+
+ int num, len, width, pad;
+ char *src, *dst;
+
+ num = 0;
+ len = strlen(T->value);
+ width = T->width - strlen(T->preval) - strlen(T->postval);
+ if (width < 0)
+ width = 0;
+
+ switch (T->align) {
+ case ALIGN_LEFT:
+ pad = 0;
+ break;
+ case ALIGN_CENTER:
+ pad = (width - len) / 2;
+ if (pad < 0)
+ pad = 0;
+ break;
+ case ALIGN_RIGHT:
+ pad = width - len;
+ if (pad < 0)
+ pad = 0;
+ break;
+ case ALIGN_MARQUEE:
+ pad = width - T->scroll;
+ T->scroll++;
+ if (T->scroll >= width + len)
+ T->scroll = 0;
+ break;
+ default: /* not reached */
+ pad = 0;
+ }
+
+ dst = T->buffer;
+
+ /* process prefix */
+ src = T->preval;
+ while (num < T->width) {
+ if (*src == '\0')
+ break;
+ *(dst++) = *(src++);
+ num++;
+ }
+
+ src = T->value;
+
+ /* pad blanks on the beginning */
+ while (pad > 0 && num < T->width) {
+ *(dst++) = ' ';
+ num++;
+ pad--;
+ }
+
+ /* skip src chars (marquee) */
+ while (pad < 0) {
+ src++;
+ pad++;
+ }
+
+ /* copy content */
+ while (num < T->width) {
+ if (*src == '\0')
+ break;
+ *(dst++) = *(src++);
+ num++;
+ }
+
+ /* pad blanks on the end */
+ src = T->postval;
+ len = strlen(src);
+ while (num < T->width - len) {
+ *(dst++) = ' ';
+ num++;
+ }
+
+ /* process postfix */
+ while (num < T->width) {
+ if (*src == '\0')
+ break;
+ *(dst++) = *(src++);
+ num++;
+ }
+
+ *dst = '\0';
+
+ /* finally, draw it! */
+ if (W->class->draw)
+ W->class->draw(W);
}
-void widget_text_update (void *Self)
+void widget_text_update(void *Self)
{
- WIDGET *W = (WIDGET*)Self;
- WIDGET_TEXT *T = W->data;
- RESULT result = {0, 0, 0, NULL};
- char *preval, *postval, *value;
- int update;
-
- /* evaluate prefix */
- if (T->pretree!=NULL) {
- Eval(T->pretree, &result);
- preval=strdup(R2S(&result));
- DelResult (&result);
- } else {
- preval=strdup("");
- }
-
- /* evaluate postfix */
- if (T->posttree!=NULL) {
- Eval(T->posttree, &result);
- postval=strdup(R2S(&result));
- DelResult (&result);
- } else {
- postval=strdup("");
- }
-
- /* evaluate expression */
- Eval(T->tree, &result);
-
- /* string or number? */
- if (T->precision==0xC0DE) {
- value=strdup(R2S(&result));
- } else {
- double number=R2N(&result);
- int width=T->width-strlen(preval)-strlen(postval);
- int precision=T->precision;
- /* print zero bytes so we can specify NULL as target */
- /* and get the length of the resulting string */
- int size=snprintf (NULL, 0, "%.*f", precision, number);
- /* number does not fit into field width: try to reduce precision */
- if (width<0) width=0;
- if (size>width && precision>0) {
- int delta=size-width;
- if (delta>precision) delta=precision;
- precision-=delta;
- size-=delta;
- /* zero precision: omit decimal point, too */
- if (precision==0) size--;
+ WIDGET *W = (WIDGET *) Self;
+ WIDGET_TEXT *T = W->data;
+ RESULT result = { 0, 0, 0, NULL };
+ char *preval, *postval, *value;
+ int update;
+
+ /* evaluate prefix */
+ if (T->pretree != NULL) {
+ Eval(T->pretree, &result);
+ preval = strdup(R2S(&result));
+ DelResult(&result);
+ } else {
+ preval = strdup("");
+ }
+
+ /* evaluate postfix */
+ if (T->posttree != NULL) {
+ Eval(T->posttree, &result);
+ postval = strdup(R2S(&result));
+ DelResult(&result);
+ } else {
+ postval = strdup("");
}
- /* number still doesn't fit: display '*****' */
- if (size>width) {
- value=malloc(width+1);
- memset (value, '*', width);
- *(value+width)='\0';
+
+ /* evaluate expression */
+ Eval(T->tree, &result);
+
+ /* string or number? */
+ if (T->precision == 0xC0DE) {
+ value = strdup(R2S(&result));
} else {
- value=malloc(size+1);
- snprintf (value, size+1, "%.*f", precision, number);
+ double number = R2N(&result);
+ int width = T->width - strlen(preval) - strlen(postval);
+ int precision = T->precision;
+ /* print zero bytes so we can specify NULL as target */
+ /* and get the length of the resulting string */
+ int size = snprintf(NULL, 0, "%.*f", precision, number);
+ /* number does not fit into field width: try to reduce precision */
+ if (width < 0)
+ width = 0;
+ if (size > width && precision > 0) {
+ int delta = size - width;
+ if (delta > precision)
+ delta = precision;
+ precision -= delta;
+ size -= delta;
+ /* zero precision: omit decimal point, too */
+ if (precision == 0)
+ size--;
+ }
+ /* number still doesn't fit: display '*****' */
+ if (size > width) {
+ value = malloc(width + 1);
+ memset(value, '*', width);
+ *(value + width) = '\0';
+ } else {
+ value = malloc(size + 1);
+ snprintf(value, size + 1, "%.*f", precision, number);
+ }
}
- }
-
- DelResult (&result);
-
- update=0;
-
- /* prefix changed? */
- if (T->preval == NULL || strcmp(T->preval, preval)!=0) {
- update=1;
- if (T->preval) free (T->preval);
- T->preval=preval;
- T->scroll=0; /* reset marquee counter */
- } else {
- free (preval);
- }
-
- /* postfix changed? */
- if (T->postval == NULL || strcmp(T->postval, postval)!=0) {
- update=1;
- if (T->postval) free (T->postval);
- T->postval=postval;
- T->scroll=0; /* reset marquee counter */
- } else {
- free (postval);
- }
-
- /* value changed? */
- if (T->value == NULL || strcmp(T->value, value)!=0) {
- update=1;
- if (T->value) free (T->value);
- T->value=value;
- T->scroll=0; /* reset marquee counter */
- } else {
- free (value);
- }
-
- /* something has changed and should be updated */
- if (update) {
- /* if there's a marquee scroller active, it has its own */
- /* update callback timer, so we do nothing here; otherwise */
- /* we simply call this scroll callback directly */
- if (T->align!=ALIGN_MARQUEE) {
- widget_text_scroll (Self);
+
+ DelResult(&result);
+
+ update = 0;
+
+ /* prefix changed? */
+ if (T->preval == NULL || strcmp(T->preval, preval) != 0) {
+ update = 1;
+ if (T->preval)
+ free(T->preval);
+ T->preval = preval;
+ T->scroll = 0; /* reset marquee counter */
+ } else {
+ free(preval);
+ }
+
+ /* postfix changed? */
+ if (T->postval == NULL || strcmp(T->postval, postval) != 0) {
+ update = 1;
+ if (T->postval)
+ free(T->postval);
+ T->postval = postval;
+ T->scroll = 0; /* reset marquee counter */
+ } else {
+ free(postval);
+ }
+
+ /* value changed? */
+ if (T->value == NULL || strcmp(T->value, value) != 0) {
+ update = 1;
+ if (T->value)
+ free(T->value);
+ T->value = value;
+ T->scroll = 0; /* reset marquee counter */
+ } else {
+ free(value);
+ }
+
+ /* something has changed and should be updated */
+ if (update) {
+ /* if there's a marquee scroller active, it has its own */
+ /* update callback timer, so we do nothing here; otherwise */
+ /* we simply call this scroll callback directly */
+ if (T->align != ALIGN_MARQUEE) {
+ widget_text_scroll(Self);
+ }
}
- }
}
-int widget_text_init (WIDGET *Self)
+int widget_text_init(WIDGET * Self)
{
- char *section; char *c;
- WIDGET_TEXT *Text;
-
- /* prepare config section */
- /* strlen("Widget:")=7 */
- section=malloc(strlen(Self->name)+8);
- strcpy(section, "Widget:");
- strcat(section, Self->name);
-
- Text=malloc(sizeof(WIDGET_TEXT));
- memset (Text, 0, sizeof(WIDGET_TEXT));
-
- /* get raw pre- and postfix (we evaluate it ourselves) */
- Text->prefix = cfg_get_raw (section, "prefix", NULL);
- Text->postfix = cfg_get_raw (section, "postfix", NULL);
-
- /* compile pre- and postfix */
- Compile (Text->prefix, &Text->pretree);
- Compile (Text->postfix, &Text->posttree);
-
- /* get raw expression (we evaluate it ourselves) */
- Text->expression = cfg_get_raw (section, "expression", "''");
- Compile (Text->expression, &Text->tree);
-
- /* field width, default 10 */
- cfg_number (section, "width", 10, 0, -1, &(Text->width));
-
- /* precision: number of digits after the decimal point (default: none) */
- /* Note: this is the *maximum* precision on small values, */
- /* for larger values the precision may be reduced to fit into the field width. */
- /* The default value 0xC0DE is used to distinguish between numbers and strings: */
- /* if no precision is given, the result is always treated as a string. If a */
- /* precision is specified, the result is treated as a number. */
- cfg_number (section, "precision", 0xC0DE, 0, 80, &(Text->precision));
-
- /* field alignment: Left (default), Center, Right or Marquee */
- c = cfg_get (section, "align", "L");
- switch (toupper(*c)) {
- case 'L':
- Text->align=ALIGN_LEFT;
- break;
- case 'C':
- Text->align=ALIGN_CENTER;
- break;
- case 'R':
- Text->align=ALIGN_RIGHT;
- break;
- case 'M':
- Text->align=ALIGN_MARQUEE;
- break;
- default:
- error ("widget %s has unknown alignment '%s', using 'Left'", section, c);
- Text->align=ALIGN_LEFT;
- }
- free (c);
-
- /* update interval (msec), default 1 sec, 0 stands for never */
- cfg_number (section, "update", 1000, 0, -1, &(Text->update));
- /* limit update interval to min 10 msec */
- if (Text->update > 0 && Text->update < 10) Text->update = 10;
-
- /* marquee scroller speed: interval (msec), default 500msec */
- if (Text->align==ALIGN_MARQUEE) {
- cfg_number (section, "speed", 500, 10, -1, &(Text->speed));
- }
-
- /* buffer */
- Text->buffer=malloc(Text->width+1);
-
- free (section);
- Self->data=Text;
-
- /* add update timer, use one-shot if 'update' is zero */
- timer_add (widget_text_update, Self, Text->update, Text->update==0);
-
- /* a marquee scroller has its own timer and callback */
- if (Text->align==ALIGN_MARQUEE) {
- timer_add (widget_text_scroll, Self, Text->speed, 0);
- }
-
- return 0;
+ char *section;
+ char *c;
+ WIDGET_TEXT *Text;
+
+ /* prepare config section */
+ /* strlen("Widget:")=7 */
+ section = malloc(strlen(Self->name) + 8);
+ strcpy(section, "Widget:");
+ strcat(section, Self->name);
+
+ Text = malloc(sizeof(WIDGET_TEXT));
+ memset(Text, 0, sizeof(WIDGET_TEXT));
+
+ /* get raw pre- and postfix (we evaluate it ourselves) */
+ Text->prefix = cfg_get_raw(section, "prefix", NULL);
+ Text->postfix = cfg_get_raw(section, "postfix", NULL);
+
+ /* compile pre- and postfix */
+ Compile(Text->prefix, &Text->pretree);
+ Compile(Text->postfix, &Text->posttree);
+
+ /* get raw expression (we evaluate it ourselves) */
+ Text->expression = cfg_get_raw(section, "expression", "''");
+ Compile(Text->expression, &Text->tree);
+
+ /* field width, default 10 */
+ cfg_number(section, "width", 10, 0, -1, &(Text->width));
+
+ /* precision: number of digits after the decimal point (default: none) */
+ /* Note: this is the *maximum* precision on small values, */
+ /* for larger values the precision may be reduced to fit into the field width. */
+ /* The default value 0xC0DE is used to distinguish between numbers and strings: */
+ /* if no precision is given, the result is always treated as a string. If a */
+ /* precision is specified, the result is treated as a number. */
+ cfg_number(section, "precision", 0xC0DE, 0, 80, &(Text->precision));
+
+ /* field alignment: Left (default), Center, Right or Marquee */
+ c = cfg_get(section, "align", "L");
+ switch (toupper(*c)) {
+ case 'L':
+ Text->align = ALIGN_LEFT;
+ break;
+ case 'C':
+ Text->align = ALIGN_CENTER;
+ break;
+ case 'R':
+ Text->align = ALIGN_RIGHT;
+ break;
+ case 'M':
+ Text->align = ALIGN_MARQUEE;
+ break;
+ default:
+ error("widget %s has unknown alignment '%s', using 'Left'", section, c);
+ Text->align = ALIGN_LEFT;
+ }
+ free(c);
+
+ /* update interval (msec), default 1 sec, 0 stands for never */
+ cfg_number(section, "update", 1000, 0, -1, &(Text->update));
+ /* limit update interval to min 10 msec */
+ if (Text->update > 0 && Text->update < 10)
+ Text->update = 10;
+
+ /* marquee scroller speed: interval (msec), default 500msec */
+ if (Text->align == ALIGN_MARQUEE) {
+ cfg_number(section, "speed", 500, 10, -1, &(Text->speed));
+ }
+
+ /* buffer */
+ Text->buffer = malloc(Text->width + 1);
+
+ free(section);
+ Self->data = Text;
+
+ /* add update timer, use one-shot if 'update' is zero */
+ timer_add(widget_text_update, Self, Text->update, Text->update == 0);
+
+ /* a marquee scroller has its own timer and callback */
+ if (Text->align == ALIGN_MARQUEE) {
+ timer_add(widget_text_scroll, Self, Text->speed, 0);
+ }
+
+ return 0;
}
-int widget_text_quit (WIDGET *Self) {
- WIDGET_TEXT *Text;
- if (Self) {
- Text=Self->data;
- if (Self->data) {
- DelTree(Text->pretree);
- DelTree(Text->posttree);
- DelTree(Text->tree);
- if (Text->preval) free(Text->preval);
- if (Text->postval) free(Text->postval);
- if (Text->value) free(Text->value);
- if (Text->buffer) free(Text->buffer);
- free (Self->data);
- Self->data=NULL;
+int widget_text_quit(WIDGET * Self)
+{
+ WIDGET_TEXT *Text;
+ if (Self) {
+ Text = Self->data;
+ if (Self->data) {
+ DelTree(Text->pretree);
+ DelTree(Text->posttree);
+ DelTree(Text->tree);
+ if (Text->preval)
+ free(Text->preval);
+ if (Text->postval)
+ free(Text->postval);
+ if (Text->value)
+ free(Text->value);
+ if (Text->buffer)
+ free(Text->buffer);
+ free(Self->data);
+ Self->data = NULL;
+ }
+
}
-
- }
- return 0;
-
+ return 0;
+
}
WIDGET_CLASS Widget_Text = {
- name: "text",
- init: widget_text_init,
- draw: NULL,
- quit: widget_text_quit,
+ name:"text",
+ init:widget_text_init,
+ draw:NULL,
+ quit:widget_text_quit,
};
-
-