]> granicus.if.org Git - postgresql/commitdiff
Got tired of waiting for spoonbill's compiler to get fixed. Let's
authorTom Lane <tgl@sss.pgh.pa.us>
Thu, 1 Jun 2006 02:39:59 +0000 (02:39 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Thu, 1 Jun 2006 02:39:59 +0000 (02:39 +0000)
see if using an intermediate variable avoids the gcc bug.

contrib/seg/segparse.y

index d4d739c621cd7412ea2522351e0f4436bd1ec16a..dc56fb580feecdd05b69d3405ae95bdde4a35e5b 100644 (file)
 
   extern int seg_yylex(void);
 
-  extern int significant_digits( char *str );    /* defined in seg.c */
+  extern int significant_digits(char *str);            /* defined in seg.c */
   
   void seg_yyerror(const char *message);
   int seg_yyparse(void *result);
 
-  float seg_atof( char *value );
+  static float seg_atof(char *value);
 
-  long threshold;
-  char strbuf[25] = {
+  static char strbuf[25] = {
     '0', '0', '0', '0', '0',
     '0', '0', '0', '0', '0',
     '0', '0', '0', '0', '0',
@@ -108,30 +107,39 @@ range:
 
 boundary:
           SEGFLOAT {
-             $$.ext = '\0';
-            $$.sigd = significant_digits($1);
-             $$.val = seg_atof($1);
+                       /* temp variable avoids a gcc 3.3.x bug on Sparc64 */
+                       float val = seg_atof($1);
+
+                       $$.ext = '\0';
+                       $$.sigd = significant_digits($1);
+                       $$.val = val;
          }
       | 
          EXTENSION SEGFLOAT {
-             $$.ext = $1[0];
-            $$.sigd = significant_digits($2);
-             $$.val = seg_atof($2);
+                       /* temp variable avoids a gcc 3.3.x bug on Sparc64 */
+                       float val = seg_atof($2);
+
+                       $$.ext = $1[0];
+                       $$.sigd = significant_digits($2);
+                       $$.val = val;
          }
       ;
 
 deviation:
           SEGFLOAT {
-             $$.ext = '\0';
-            $$.sigd = significant_digits($1);
-             $$.val = seg_atof($1);
+                       /* temp variable avoids a gcc 3.3.x bug on Sparc64 */
+                       float val = seg_atof($1);
+
+                       $$.ext = '\0';
+                       $$.sigd = significant_digits($1);
+                       $$.val = val;
          }
       ;
 
 %%
 
 
-float
+static float
 seg_atof(char *value)
 {
        Datum datum;