version 1.20, 2002/09/09 12:23:51 |
version 1.22, 2003/02/14 22:29:18 |
|
|
* DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, |
* DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, |
* PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. |
* PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. |
* |
* |
* $OpenXM: OpenXM_contrib2/asir2000/parse/lex.c,v 1.19 2001/12/21 08:23:15 noro Exp $ |
* $OpenXM: OpenXM_contrib2/asir2000/parse/lex.c,v 1.21 2002/09/09 23:52:45 noro Exp $ |
*/ |
*/ |
#include <ctype.h> |
#include <ctype.h> |
#include "ca.h" |
#include "ca.h" |
|
|
while ( ( c = Getc() ) == '0' ); |
while ( ( c = Getc() ) == '0' ); |
if ( c == '.' ) { |
if ( c == '.' ) { |
Ungetc(c); c = '0'; |
Ungetc(c); c = '0'; |
} else if ( c == 'x' ) { |
} else if ( c == 'x' || c == 'X' ) { |
for ( i = 0; i < 8; i++ ) |
for ( i = 0; i < 8; i++ ) |
nbuf[i] = '0'; |
nbuf[i] = '0'; |
READ_ALNUM_NBUF |
READ_ALNUM_NBUF |
|
|
NTOQ(n1,1,q); r = (Obj)q; |
NTOQ(n1,1,q); r = (Obj)q; |
yylvalp->p = (pointer)r; |
yylvalp->p = (pointer)r; |
return ( FORMULA ); |
return ( FORMULA ); |
} else if ( c == 'b' ) { |
} else if ( c == 'b' || c == 'B' ) { |
for ( i = 0; i < 32; i++ ) |
for ( i = 0; i < 32; i++ ) |
nbuf[i] = '0'; |
nbuf[i] = '0'; |
READ_ALNUM_NBUF |
READ_ALNUM_NBUF |
|
|
|
|
REALLOC_NBUF nbuf[i++] = c; |
REALLOC_NBUF nbuf[i++] = c; |
READ_DIGIT_NBUF |
READ_DIGIT_NBUF |
if ( c == 'e' ) { |
if ( c == 'e' || c == 'E' ) { |
REALLOC_NBUF nbuf[i++] = c; |
REALLOC_NBUF nbuf[i++] = c; |
c = Getc(); |
c = Getc(); |
if ( (c == '+') || (c == '-') ) { |
if ( (c == '+') || (c == '-') ) { |
|
|
Ungetc(c); |
Ungetc(c); |
READ_DIGIT_NBUF |
READ_DIGIT_NBUF |
} |
} |
} else if ( c == 'e' ) { |
} else if ( c == 'e' || c == 'E' ) { |
floatingpoint = 1; |
floatingpoint = 1; |
REALLOC_NBUF nbuf[i++] = c; |
REALLOC_NBUF nbuf[i++] = c; |
c = Getc(); |
c = Getc(); |
|
|
} |
} |
if ( floatingpoint ) { |
if ( floatingpoint ) { |
Ungetc(c); REALLOC_NBUF nbuf[i] = 0; |
Ungetc(c); REALLOC_NBUF nbuf[i] = 0; |
#if PARI |
#if defined(PARI) |
if ( !bigfloat ) { |
if ( !bigfloat ) { |
dbl = (double)atof(nbuf+DLENGTH); |
dbl = (double)atof(nbuf+DLENGTH); |
MKReal(dbl,real); r = (Obj)real; |
MKReal(dbl,real); r = (Obj)real; |
Line 531 int Egetc(FILE *fp) |
|
Line 531 int Egetc(FILE *fp) |
|
int c; |
int c; |
|
|
if ( fp ) { |
if ( fp ) { |
#if FEP |
#if defined(FEP) |
if ( do_fep && isatty(fileno(fp)) ) |
if ( do_fep && isatty(fileno(fp)) ) |
c = readline_getc(); |
c = readline_getc(); |
else |
else |
Line 570 void Eungetc(int c,FILE *fp) |
|
Line 570 void Eungetc(int c,FILE *fp) |
|
if ( fp ) { |
if ( fp ) { |
if ( asir_infile->encoded ) |
if ( asir_infile->encoded ) |
c = (int)encrypt_char((unsigned char)c); |
c = (int)encrypt_char((unsigned char)c); |
#if FEP |
#if defined(FEP) |
if ( do_fep && isatty(fileno(fp)) ) |
if ( do_fep && isatty(fileno(fp)) ) |
readline_ungetc(); |
readline_ungetc(); |
else |
else |
Line 628 static void Gets(char *s) |
|
Line 628 static void Gets(char *s) |
|
*s = 0; |
*s = 0; |
} |
} |
|
|
#if FEP |
#if defined(FEP) |
|
|
static char *readline_line; |
static char *readline_line; |
static int readline_nc,readline_index; |
static int readline_nc,readline_index; |