diff examples/calculator/main.c @ 90:bd29780bf266

Reduce redundant code
author Thinker K.F. Li <thinker@branda.to>
date Sat, 23 Aug 2008 22:23:44 +0800
parents 90428161fc61
children 3f619ae03678
line wrap: on
line diff
--- a/examples/calculator/main.c	Sat Aug 23 15:39:29 2008 +0800
+++ b/examples/calculator/main.c	Sat Aug 23 22:23:44 2008 +0800
@@ -57,10 +57,10 @@
     return r;
 }
 
-static void show_text(ex_rt_t *ex_rt, int num) {
+static void show_text(ex_rt_t *ex_rt, int num, const char *prefix) {
     char buf[20];
 
-    sprintf(buf, "%d", num);
+    sprintf(buf, "%s%d", prefix, num);
     sh_text_set_text(ex_rt->code->screen_text, buf);
     rdman_shape_changed(ex_rt->rt->rdman, ex_rt->code->screen_text);
 }
@@ -69,8 +69,8 @@
     int i;
     coord_t **coord_p;
     static int num = 0;
-    static int saved = 0;
-    static int op = 0;
+    static int saved = 0, saved2 = 0;
+    static int op = 0, op1 = 0;
 
     for(i = 0; i < 16; i++) {
 	coord_p = (coord_t **)((void *)ex_rt->code + tgt_list[i].off);
@@ -81,45 +81,28 @@
 
     if(i < 10) {
 	num = num * 10 + i;
-	show_text(ex_rt, num);
+	show_text(ex_rt, num, "");
     } else {
 	switch(tgt_list[i].c) {
 	case 'c':
 	    saved = num = 0;
-	    show_text(ex_rt, 0);
+	    show_text(ex_rt, 0, "");
 	    break;
 
 	case '+':
-	    saved = real_compute(op, saved, num);
-	    show_text(ex_rt, saved);
-	    op = '+';
-	    num = 0;
-	    break;
-
 	case '-':
-	    saved = real_compute(op, saved, num);
-	    show_text(ex_rt, saved);
-	    op = '-';
-	    num = 0;
-	    break;
-
 	case '*':
-	    saved = real_compute(op, saved, num);
-	    show_text(ex_rt, saved);
-	    op = '*';
-	    num = 0;
-	    break;
-
 	case '/':
 	    saved = real_compute(op, saved, num);
-	    show_text(ex_rt, saved);
-	    op = '/';
+	    show_text(ex_rt, saved, "=");
+	    op = tgt_list[i].c;
+	    saved2 = num;
 	    num = 0;
 	    break;
 
 	case '=':
-	    saved = real_compute(op, saved, num);
-	    show_text(ex_rt, saved);
+	    saved = real_compute(op, saved, saved2);
+	    show_text(ex_rt, saved, "=");
 	    num = 0;
 	    break;
 	}
@@ -141,42 +124,19 @@
     calculator_scr_t *calculator_scr;
     ob_factory_t *factory;
     subject_t *subject;
+    coord_t *coord;
+    int off;
+    int i;
 
     calculator_scr = ex_rt->code;
     factory = rdman_get_ob_factory(ex_rt->rt->rdman);
 
-    subject = coord_get_mouse_event(calculator_scr->but_0);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_1);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_2);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_3);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_4);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_5);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_6);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_7);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_8);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_9);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_add);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_minus);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_mul);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_div);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_eq);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
-    subject = coord_get_mouse_event(calculator_scr->but_clr);
-    subject_add_observer(factory, subject, buttons_handler, ex_rt);
+    for(i = 0; i < 16; i++) {
+	off = tgt_list[i].off;
+	coord = *(coord_t **)((void *)calculator_scr + off);
+	subject = coord_get_mouse_event(coord);
+	subject_add_observer(factory, subject, buttons_handler, ex_rt);
+    }
 }
 
 int main(int argc, char * const argv[]) {