version 1.3, 2000/08/22 05:04:28 |
version 1.5, 2000/12/05 01:24:57 |
|
|
* 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.2 2000/08/21 08:31:47 noro Exp $ |
* $OpenXM: OpenXM_contrib2/asir2000/parse/util.c,v 1.4 2000/11/08 08:02:52 noro Exp $ |
*/ |
*/ |
#include "ca.h" |
#include "ca.h" |
#include "base.h" |
#include "base.h" |
#include "parse.h" |
#include "parse.h" |
#if defined(THINK_C) || defined(VISUAL) |
#if defined(VISUAL) |
#include <stdarg.h> |
#include <stdarg.h> |
#else |
#else |
#include <varargs.h> |
#include <varargs.h> |
|
|
int i,l; |
int i,l; |
NODE n,n0; |
NODE n,n0; |
VECT v; |
VECT v; |
|
Q q; |
|
|
|
if ( a && OID(a) == O_BYTEARRAY ) { |
|
len = (Obj)BDY(ind); |
|
if ( !rangecheck(len,((BYTEARRAY)a)->len) ) |
|
error("getarray : Out of range"); |
|
else if ( NEXT(ind) ) |
|
error("getarray : invalid index"); |
|
else { |
|
i = (int)BDY((BYTEARRAY)a)[QTOS((Q)len)]; |
|
STOQ(i,q); |
|
*vp = (pointer)q; |
|
} |
|
return; |
|
} |
for ( ; ind; ind = NEXT(ind) ) { |
for ( ; ind; ind = NEXT(ind) ) { |
if ( !a ) |
if ( !a ) |
error("getarray : array or list expected"); |
error("getarray : array or list expected"); |
|
|
int i,l; |
int i,l; |
NODE n,n0; |
NODE n,n0; |
|
|
|
if ( a && OID(a) == O_BYTEARRAY ) { |
|
len = (Obj)BDY(ind); |
|
if ( !rangecheck(len,((BYTEARRAY)a)->len) ) |
|
error("putarray : Out of range"); |
|
else if ( NEXT(ind) ) |
|
error("putarray : invalid index"); |
|
else |
|
BDY((BYTEARRAY)a)[QTOS((Q)len)] = (unsigned char)QTOS((Q)b); |
|
return; |
|
} |
for ( ; ind; ind = NEXT(ind) ) { |
for ( ; ind; ind = NEXT(ind) ) { |
if ( !a ) |
if ( !a ) |
error("putarray : array expected"); |
error("putarray : array expected"); |
|
|
return ( r ); |
return ( r ); |
} |
} |
|
|
#if defined(THINK_C) || defined(VISUAL) |
#if defined(VISUAL) |
NODE mknode(int ac,...) |
NODE mknode(int ac,...) |
{ |
{ |
va_list ap; |
va_list ap; |
|
|
*arrayp = new; |
*arrayp = new; |
} |
} |
} |
} |
|
|
#if defined(THINK_C) |
|
void bzero(p,len) |
|
register char *p; |
|
register int len; |
|
{ |
|
for ( ; len; len-- ) |
|
*p++ = 0; |
|
} |
|
|
|
void bcopy(s,d,len) |
|
register char *s; |
|
register char *d; |
|
int len; |
|
{ |
|
for ( ; len; len-- ) |
|
*d++ = *s++; |
|
} |
|
|
|
char *index(char *s,char c) |
|
{ |
|
for ( ; *s && *s != c; s++ ); |
|
if ( *s ) |
|
return s; |
|
else |
|
return 0; |
|
} |
|
|
|
void printap(p) |
|
P p; |
|
{ |
|
DCP dc; |
|
|
|
for ( dc = DC(p); dc; dc = NEXT(dc) ) { |
|
printf("(c=0x%lx c->nm=0x%lx c->nm->p=%ld) ", |
|
(int *)dc->c,(int *)((Q)dc->c)->nm,(int)((Q)dc->c)->nm->p); |
|
} |
|
printf("\n"); |
|
} |
|
#endif |
|