version 1.14, 2005/09/14 02:48:38 |
version 1.20, 2018/03/27 06:29:19 |
|
|
* 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/util.c,v 1.13 2005/02/08 18:06:05 saito Exp $ |
* $OpenXM: OpenXM_contrib2/asir2000/parse/util.c,v 1.19 2017/02/07 08:30:31 noro Exp $ |
*/ |
*/ |
#include "ca.h" |
#include "ca.h" |
#include "base.h" |
#include "base.h" |
#include "parse.h" |
#include "parse.h" |
#if defined(__GNUC__) || defined(VISUAL) || (defined(__MACH__) && defined(__ppc__)) || defined(__FreeBSD__) |
#if defined(__GNUC__) || defined(VISUAL) || defined(__MINGW32__) || (defined(__MACH__) && defined(__ppc__)) || defined(__FreeBSD__) |
#include <stdarg.h> |
#include <stdarg.h> |
#else |
#else |
#include <varargs.h> |
#include <varargs.h> |
Line 78 void stoarg(char *s,int *acp,char **av) |
|
Line 78 void stoarg(char *s,int *acp,char **av) |
|
int i; |
int i; |
|
|
for ( i = 0; ; i++ ) { |
for ( i = 0; ; i++ ) { |
for ( ; *s && isspace(*s); s++ ); |
for ( ; *s && isspace((unsigned char)*s); s++ ); |
if ( *s ) { |
if ( *s ) { |
for ( av[i] = s; *s && !isspace(*s); s++ ); |
for ( av[i] = s; *s && |
|
!isspace((unsigned char)*s); s++ ); |
if ( *s ) |
if ( *s ) |
*s++ = 0; |
*s++ = 0; |
} else { |
} else { |
|
|
return ( r ); |
return ( r ); |
} |
} |
|
|
#if defined(__GNUC__) || defined(VISUAL) || (defined(__MACH__) && defined(__ppc__)) || defined(__FreeBSD__) |
#if defined(__GNUC__) || defined(VISUAL) || defined(__MINGW32__) || (defined(__MACH__) && defined(__ppc__)) || defined(__FreeBSD__) |
NODE mknode(int ac,...) |
NODE mknode(int ac,...) |
{ |
{ |
va_list ap; |
va_list ap; |
Line 392 V searchvar(char *str) |
|
Line 393 V searchvar(char *str) |
|
{ |
{ |
VL vl; |
VL vl; |
|
|
for ( vl = CO; ;vl = NEXT(vl) ) |
for ( vl = CO; vl ;vl = NEXT(vl) ) |
if ( NAME(VR(vl)) && !strcmp(NAME(VR(vl)),str) ) |
if ( NAME(VR(vl)) && !strcmp(NAME(VR(vl)),str) ) |
return VR(vl); |
return VR(vl); |
return 0; |
return 0; |
} |
} |
|
|
|
void update_LASTCO() |
|
{ |
|
VL vl; |
|
|
|
for ( vl = CO; NEXT(vl); vl = NEXT(vl) ); |
|
LASTCO = vl; |
|
} |
|
|
void makevar(char *str,P *p) |
void makevar(char *str,P *p) |
{ |
{ |
VL vl; |
VL vl; |
Line 414 void makevar(char *str,P *p) |
|
Line 423 void makevar(char *str,P *p) |
|
strcpy(NAME(v),str); |
strcpy(NAME(v),str); |
NEWVL(NEXT(vl)); VR(NEXT(vl)) = v; NEXT(NEXT(vl)) = 0; |
NEWVL(NEXT(vl)); VR(NEXT(vl)) = v; NEXT(NEXT(vl)) = 0; |
MKV(v,t); *p = t; |
MKV(v,t); *p = t; |
|
LASTCO = NEXT(vl); |
return; |
return; |
} else |
} else |
vl = NEXT(vl); |
vl = NEXT(vl); |
Line 436 void makesrvar(FUNC f,P *p) |
|
Line 446 void makesrvar(FUNC f,P *p) |
|
NAME(v) = (char *)CALLOC(strlen(str)+1,sizeof(char)); |
NAME(v) = (char *)CALLOC(strlen(str)+1,sizeof(char)); |
strcpy(NAME(v),str); |
strcpy(NAME(v),str); |
NEWVL(NEXT(vl)); VR(NEXT(vl)) = v; NEXT(NEXT(vl)) = 0; |
NEWVL(NEXT(vl)); VR(NEXT(vl)) = v; NEXT(NEXT(vl)) = 0; |
|
LASTCO = NEXT(vl); |
MKV(v,t); *p = t; |
MKV(v,t); *p = t; |
return; |
return; |
} else |
} else |
Line 473 void appendvar(VL vl,V v) |
|
Line 484 void appendvar(VL vl,V v) |
|
return; |
return; |
else if ( !NEXT(vl) ) { |
else if ( !NEXT(vl) ) { |
NEWVL(NEXT(vl)); VR(NEXT(vl)) = v; NEXT(NEXT(vl)) = 0; |
NEWVL(NEXT(vl)); VR(NEXT(vl)) = v; NEXT(NEXT(vl)) = 0; |
|
LASTCO = NEXT(vl); |
return; |
return; |
} else |
} else |
vl = NEXT(vl); |
vl = NEXT(vl); |
} |
} |
|
|
void reallocarray(char **arrayp,int *sizep,int *indexp,int esize) |
void asir_reallocarray(char **arrayp,int *sizep,int *indexp,int esize) |
{ |
{ |
char *new; |
char *new; |
|
|