Got tired of waiting for spoonbill's compiler to get fixed. Let's

see if using an intermediate variable avoids the gcc bug.
This commit is contained in:
Tom Lane 2006-06-01 02:39:59 +00:00
parent 87e8014d31
commit d77df813c9
1 changed files with 22 additions and 14 deletions

View File

@ -11,15 +11,14 @@
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;