version 1.7, 2001/06/04 02:49:48 |
version 1.12, 2004/12/18 16:50:10 |
|
|
* 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.6 2000/12/11 09:28:03 noro Exp $ |
* $OpenXM: OpenXM_contrib2/asir2000/parse/util.c,v 1.11 2004/06/21 00:58:32 noro Exp $ |
*/ |
*/ |
#include "ca.h" |
#include "ca.h" |
#include "base.h" |
#include "base.h" |
#include "parse.h" |
#include "parse.h" |
#if defined(VISUAL) || (defined(__MACH__) && defined(__ppc__)) |
#if defined(__GNUC__) || defined(VISUAL) || (defined(__MACH__) && defined(__ppc__)) || defined(__FreeBSD__) |
#include <stdarg.h> |
#include <stdarg.h> |
#else |
#else |
#include <varargs.h> |
#include <varargs.h> |
|
|
NODE ind; |
NODE ind; |
pointer *vp; |
pointer *vp; |
{ |
{ |
Obj len,row,col; |
Obj len,row,col,trg; |
int i,l; |
int i; |
NODE n,n0; |
NODE n,n0; |
VECT v; |
VECT v; |
Q q; |
Q q; |
|
|
a = (pointer)v; |
a = (pointer)v; |
} |
} |
break; |
break; |
|
case O_IMAT: |
|
row = (Obj)BDY(ind); |
|
ind = NEXT(ind); |
|
col = (Obj)BDY(ind); |
|
if ( ((IMAT)a)->row < QTOS((Q)row) || |
|
((IMAT)a)->col < QTOS((Q)col) || |
|
(QTOS((Q)row) < 0) || (QTOS((Q)col) < 0)) |
|
error("putarray : Out of range"); |
|
GetIbody((IMAT)a, QTOS((Q)row), QTOS((Q)col), (Obj)&trg); |
|
a = (pointer)trg; |
|
break; |
case O_LIST: |
case O_LIST: |
n0 = BDY((LIST)a); i = QTOS((Q)BDY(ind)); |
n0 = BDY((LIST)a); i = QTOS((Q)BDY(ind)); |
if ( i < 0 ) |
if ( i < 0 ) |
|
|
pointer b; |
pointer b; |
{ |
{ |
Obj len,row,col; |
Obj len,row,col; |
int i,l; |
int i; |
NODE n,n0; |
NODE n,n0; |
|
|
if ( a && OID(a) == O_BYTEARRAY ) { |
if ( a && OID(a) == O_BYTEARRAY ) { |
|
|
} else |
} else |
error("putarray : invalid assignment"); |
error("putarray : invalid assignment"); |
break; |
break; |
|
case O_IMAT: |
|
row = (Obj)BDY(ind); |
|
ind = NEXT(ind); |
|
col = (Obj)BDY(ind); |
|
if ( ((IMAT)a)->row < QTOS((Q)row) || |
|
((IMAT)a)->col < QTOS((Q)col) || |
|
(QTOS((Q)row) < 0) || (QTOS((Q)col) < 0)) |
|
error("putarray : Out of range"); |
|
PutIent((IMAT)a, QTOS((Q)row), QTOS((Q)col), (Obj)b); |
|
break; |
case O_LIST: |
case O_LIST: |
if ( NEXT(ind) ) { |
if ( NEXT(ind) ) { |
n0 = BDY((LIST)a); i = QTOS((Q)BDY(ind)); |
n0 = BDY((LIST)a); i = QTOS((Q)BDY(ind)); |
|
|
return ( r ); |
return ( r ); |
} |
} |
|
|
#if defined(VISUAL) || (defined(__MACH__) && defined(__ppc__)) |
#if defined(__GNUC__) || defined(VISUAL) || (defined(__MACH__) && defined(__ppc__)) || defined(__FreeBSD__) |
NODE mknode(int ac,...) |
NODE mknode(int ac,...) |
{ |
{ |
va_list ap; |
va_list ap; |
|
|
P t; |
P t; |
char *str; |
char *str; |
|
|
for ( vl = CO, str = NAME(f); ; ) |
for ( vl = CO, str = f->fullname; ; ) |
if ( NAME(VR(vl)) && !strcmp(NAME(VR(vl)),str) ) { |
if ( NAME(VR(vl)) && !strcmp(NAME(VR(vl)),str) ) { |
VR(vl)->attr = (pointer)V_SR; VR(vl)->priv = (pointer)f; |
VR(vl)->attr = (pointer)V_SR; VR(vl)->priv = (pointer)f; |
MKV(VR(vl),t); *p = t; |
MKV(VR(vl),t); *p = t; |