diff options
Diffstat (limited to 'math/gcalctool')
-rw-r--r-- | math/gcalctool/Makefile | 7 | ||||
-rw-r--r-- | math/gcalctool/distinfo | 4 | ||||
-rw-r--r-- | math/gcalctool/files/patch-gcalctool_ce_parser.h | 16 | ||||
-rw-r--r-- | math/gcalctool/files/patch-gcalctool_ce_parser.y | 86 | ||||
-rw-r--r-- | math/gcalctool/files/patch-gcalctool_functions.c | 60 | ||||
-rw-r--r-- | math/gcalctool/files/patch-gcalctool_gtk.c | 32 | ||||
-rw-r--r-- | math/gcalctool/files/patch-gcalctool_lr_parser.y | 74 | ||||
-rw-r--r-- | math/gcalctool/files/patch-gcalctool_mpmath.c | 24 |
8 files changed, 298 insertions, 5 deletions
diff --git a/math/gcalctool/Makefile b/math/gcalctool/Makefile index e2342d369..48112a92b 100644 --- a/math/gcalctool/Makefile +++ b/math/gcalctool/Makefile @@ -6,7 +6,7 @@ # PORTNAME= gcalctool -PORTVERSION= 4.4.8 +PORTVERSION= 5.5.0 PORTEPOCH= 1 CATEGORIES= math gnome MASTER_SITES= ${MASTER_SITE_GNOME} @@ -17,11 +17,12 @@ MAINTAINER= gnome@FreeBSD.org COMMENT= A GNOME 2 calculator tool based on the old calctool for OpenWindows USE_BZIP2= yes +USE_BISON= yes USE_X_PREFIX= yes USE_GMAKE= yes -USE_LIBTOOL_VER=13 +USE_LIBTOOL_VER=15 USE_REINPLACE= yes -USE_GNOME= gnomeprefix gnomehack lthack intlhack libgnomeui +USE_GNOME= gnomeprefix gnomehack intlhack libgnomeui CONFIGURE_ENV= CPPFLAGS="-I${LOCALBASE}/include" \ LDFLAGS="-L${LOCALBASE}/lib" diff --git a/math/gcalctool/distinfo b/math/gcalctool/distinfo index b69094217..b8ba0bea4 100644 --- a/math/gcalctool/distinfo +++ b/math/gcalctool/distinfo @@ -1,2 +1,2 @@ -MD5 (gnome2/gcalctool-4.4.8.tar.bz2) = c1adea7f8d1348a33c0734a0dfd8c643 -SIZE (gnome2/gcalctool-4.4.8.tar.bz2) = 882531 +MD5 (gnome2/gcalctool-5.5.0.tar.bz2) = b0391a744e09918e2953580963e0124c +SIZE (gnome2/gcalctool-5.5.0.tar.bz2) = 944570 diff --git a/math/gcalctool/files/patch-gcalctool_ce_parser.h b/math/gcalctool/files/patch-gcalctool_ce_parser.h new file mode 100644 index 000000000..660d59f3b --- /dev/null +++ b/math/gcalctool/files/patch-gcalctool_ce_parser.h @@ -0,0 +1,16 @@ +--- gcalctool/ce_parser.h.orig Mon Jul 26 22:11:59 2004 ++++ gcalctool/ce_parser.h Mon Jul 26 22:12:20 2004 +@@ -48,11 +48,12 @@ + static inline char * + ce_strndup(char *str, int len) + { ++ char *dup; + if (len < 1) { + return(NULL); + } + +- char *dup = malloc(len+1); ++ dup = malloc(len+1); + memset(dup, 0, len+1); + strncpy(dup, str, len); + diff --git a/math/gcalctool/files/patch-gcalctool_ce_parser.y b/math/gcalctool/files/patch-gcalctool_ce_parser.y new file mode 100644 index 000000000..9988661bf --- /dev/null +++ b/math/gcalctool/files/patch-gcalctool_ce_parser.y @@ -0,0 +1,86 @@ +--- gcalctool/ce_parser.y.orig Mon Jul 26 22:19:27 2004 ++++ gcalctool/ce_parser.y Mon Jul 26 22:25:49 2004 +@@ -111,10 +111,12 @@ + parser_state.error = EINVAL; + YYABORT; + } ++; + + seq: + udf + | seq udf ++; + + udf: + value '=' { +@@ -135,10 +137,12 @@ + initialise(); + show_display(v->MPdisp_val); + } ++; + + value: + lexp {cp($1, $$);} + | exp {cp($1, $$);} ++; + + lexp: + tINUMBER {cp($1, $$);} +@@ -147,6 +151,7 @@ + | lexp tXNOR lexp {calc_xnor($$, $1, $3);} + | lexp tXOR lexp {calc_xor($$, $1, $3);} + | '~' lexp {calc_not($2, $$);} ++; + + exp: + term {cp($1, $$);} +@@ -155,6 +160,7 @@ + + | exp '+' exp {mpadd($1, $3, $$);} + | exp '-' exp {mpsub($1, $3, $$);} ++; + + term: + number {cp($1, $$);} +@@ -171,15 +177,18 @@ + + | parenthesis {cp($1, $$);} + | constant {cp($1, $$);} ++; + + parenthesis: + '(' exp ')' {cp($2, $$);} ++ ; + + reg: +- tREG {do_rcl_reg($1, $$)}; ++ tREG {do_rcl_reg($1, $$);}; + + constant: + 'e' {do_e($$);} ++ ; + + func: + tLOG10 term %prec HIGH {mplog10($2, $$);} +@@ -216,6 +225,7 @@ + | tSLN %prec HIGH {calc_sln($$);} + | tSYD %prec HIGH {calc_syd($$);} + | tTERM %prec HIGH {calc_term($$);} ++; + + rcl: + tRCL '(' tINUMBER ')' { +@@ -223,11 +233,13 @@ + mpcmi($3, &val); + do_rcl_reg(val, $$); + } ++ ; + + number: + tINUMBER {cp($1, $$);} + | tDNUMBER {cp($1, $$);} + | tANS {cp(v->e.ans, $$);} ++; + + %% + diff --git a/math/gcalctool/files/patch-gcalctool_functions.c b/math/gcalctool/files/patch-gcalctool_functions.c new file mode 100644 index 000000000..7c715f063 --- /dev/null +++ b/math/gcalctool/files/patch-gcalctool_functions.c @@ -0,0 +1,60 @@ +--- gcalctool/functions.c.orig Mon Jul 26 22:13:14 2004 ++++ gcalctool/functions.c Mon Jul 26 22:15:30 2004 +@@ -99,7 +99,6 @@ + + char* + ch_trig(char *func) { +- assert(func); + + struct ch { + char *orig; +@@ -130,6 +129,8 @@ + + struct ch *ch = NULL; + ++ assert(func); ++ + switch (table) { + case 0: + break; +@@ -396,6 +397,7 @@ + int j = i+3; + char *prefix = malloc(i+1); + char *postfix = malloc(len-j+1); ++ char *print; + + assert(prefix && postfix); + memset(prefix, 0, i+1); +@@ -405,7 +407,7 @@ + + ans = make_number(v->e.ans, v->base, TRUE, FALSE); + assert(ans); +- char *print = malloc(strlen(ans)+i+len-j+1); ++ print = malloc(strlen(ans)+i+len-j+1); + sprintf(print, "%s%s%s", prefix, ans, postfix); + free(prefix); + free(postfix); +@@ -671,7 +673,6 @@ + int + do_tfunc(int s[MP_SIZE], int t[MP_SIZE], enum trig_func tfunc) + { +- if (!v->current) return -EINVAL; + + enum mode { + normal = 0, +@@ -680,8 +681,13 @@ + invhyp = 3, + } mode; + +- int inverse = (v->inverse) ? inv : 0; +- int hyperbolic = (v->hyperbolic) ? hyp : 0; ++ int inverse; ++ int hyperbolic; ++ ++ if (!v->current) return -EINVAL; ++ ++ inverse = (v->inverse) ? inv : 0; ++ hyperbolic = (v->hyperbolic) ? hyp : 0; + + mode = (inverse | hyperbolic); + diff --git a/math/gcalctool/files/patch-gcalctool_gtk.c b/math/gcalctool/files/patch-gcalctool_gtk.c new file mode 100644 index 000000000..e7d2e301e --- /dev/null +++ b/math/gcalctool/files/patch-gcalctool_gtk.c @@ -0,0 +1,32 @@ +--- gcalctool/gtk.c.orig Mon Jul 26 22:17:31 2004 ++++ gcalctool/gtk.c Mon Jul 26 22:18:21 2004 +@@ -441,10 +441,10 @@ + void + update_statusbar(gchar *text, const gchar *imagename) + { +- assert(text); +- assert(imagename); + + GtkImage *image = GTK_IMAGE(X->status_image); ++ assert(text); ++ assert(imagename); + assert(image); + gtk_image_set_from_stock(image, imagename, GTK_ICON_SIZE_BUTTON); + gtk_statusbar_pop(GTK_STATUSBAR(X->statusbar), 0); +@@ -1045,6 +1045,7 @@ + GError *error; + GtkWidget *event_box, *view_widget; + GtkTextBuffer *buffer; ++ GtkWidget *scrolledwindow; + + v->tool_label = NULL; + if (v->titleline == NULL) { +@@ -1099,7 +1100,7 @@ + gtk_box_pack_start(GTK_BOX(X->kvbox), X->menubar, FALSE, FALSE, 0); + + +- GtkWidget *scrolledwindow = gtk_scrolled_window_new(NULL, NULL); ++ scrolledwindow = gtk_scrolled_window_new(NULL, NULL); + gtk_widget_show(scrolledwindow); + gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW (scrolledwindow), + GTK_POLICY_ALWAYS, diff --git a/math/gcalctool/files/patch-gcalctool_lr_parser.y b/math/gcalctool/files/patch-gcalctool_lr_parser.y new file mode 100644 index 000000000..1e78125d7 --- /dev/null +++ b/math/gcalctool/files/patch-gcalctool_lr_parser.y @@ -0,0 +1,74 @@ +--- gcalctool/lr_parser.y.orig Mon Jul 26 22:23:06 2004 ++++ gcalctool/lr_parser.y Mon Jul 26 22:26:34 2004 +@@ -107,10 +107,12 @@ + parser_state.error = EINVAL; + YYABORT; + } ++; + + seq: + udf + | seq udf ++; + + udf: + value '=' { +@@ -131,9 +133,11 @@ + initialise(); + show_display(v->MPdisp_val); + } ++; + + value: + exp {cp($1, $$);} ++ ; + + exp: + term {cp($1, $$);} +@@ -164,10 +168,11 @@ + | exp '~' {calc_not($1, $$);} + | exp ']' {calc_u16($1, $$);} + | exp '[' {calc_u32($1, $$);} +-| exp '}' {calc_tenpowx($1, $$)} +-| exp '{' {mpexp($1, $$)} ++| exp '}' {calc_tenpowx($1, $$);} ++| exp '{' {mpexp($1, $$);} + + | func {cp($1, $$);} ++; + + func: + tLOG10 parenthesis {mplog10($2, $$);} +@@ -188,9 +193,11 @@ + | term tCOS {calc_trigfunc(cos_t, $1, $$);} + | tTAN parenthesis {calc_trigfunc(tan_t, $2, $$);} + | term tTAN {calc_trigfunc(tan_t, $1, $$);} ++; + + parenthesis: + '(' exp ')' {cp($2, $$);} ++ ; + + term: + number {cp($1, $$);} +@@ -198,6 +205,7 @@ + | parenthesis {cp($1, $$);} + | '-' term %prec POS {mpneg($2, $$);} + | '+' term %prec POS {cp($2, $$);} ++; + + rcl: + tRCL '(' tINUMBER ')' { +@@ -205,10 +213,12 @@ + mpcmi($3, &val); + do_rcl_reg(val, $$); + } ++ ; + + number: + tINUMBER {cp($1, $$);} + | tDNUMBER {cp($1, $$);} ++; + + %% + diff --git a/math/gcalctool/files/patch-gcalctool_mpmath.c b/math/gcalctool/files/patch-gcalctool_mpmath.c new file mode 100644 index 000000000..dd2920e2c --- /dev/null +++ b/math/gcalctool/files/patch-gcalctool_mpmath.c @@ -0,0 +1,24 @@ +--- gcalctool/mpmath.c.orig Mon Jul 26 22:16:10 2004 ++++ gcalctool/mpmath.c Mon Jul 26 22:16:46 2004 +@@ -750,17 +750,18 @@ + * boolean means BINARY representation + */ + +- assert(times >= 0); +- + double dval; ++ BOOLEAN temp; + mpcmd(s, &dval); +- BOOLEAN temp = ibool(dval); ++ temp = ibool(dval); + + /* There is a reason to do shift like this. Reason is that + * processors define shift only in a certain range. i386 uses only 5 + * bits to describe shiftable amount. So, shift 32 times gives original + * number. That can cause very strange results (and bugs). + */ ++ ++ assert(times >= 0); + + while (times--) { + temp = (dir == right) ? temp >> 1 : temp << 1; |