version 1.27, 2003/05/20 06:15:01 |
version 1.29, 2003/05/30 00:47:24 |
|
|
* 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/eval.c,v 1.26 2003/05/17 11:47:51 takayama Exp $ |
* $OpenXM: OpenXM_contrib2/asir2000/parse/eval.c,v 1.28 2003/05/24 10:42:18 noro Exp $ |
*/ |
*/ |
#include <ctype.h> |
#include <ctype.h> |
#include "ca.h" |
#include "ca.h" |
Line 830 void searchuf(char *name,FUNC *r) |
|
Line 830 void searchuf(char *name,FUNC *r) |
|
void gen_searchf(char *name,FUNC *r) |
void gen_searchf(char *name,FUNC *r) |
{ |
{ |
FUNC val = 0; |
FUNC val = 0; |
|
int global = 0; |
if ( CUR_MODULE ) |
if ( *name == ':' ) { |
|
global = 1; |
|
name += 2; |
|
} |
|
if ( CUR_MODULE && !global ) |
searchf(CUR_MODULE->usrf_list,name,&val); |
searchf(CUR_MODULE->usrf_list,name,&val); |
if ( !val ) |
if ( !val ) |
searchf(sysf,name,&val); |
searchf(sysf,name,&val); |
Line 872 void appenduf(char *name,FUNC *r) |
|
Line 876 void appenduf(char *name,FUNC *r) |
|
f=(FUNC)MALLOC(sizeof(struct oFUNC)); |
f=(FUNC)MALLOC(sizeof(struct oFUNC)); |
f->id = A_UNDEF; f->argc = 0; f->f.binf = 0; |
f->id = A_UNDEF; f->argc = 0; f->f.binf = 0; |
if ( dot = strchr(name,'.') ) { |
if ( dot = strchr(name,'.') ) { |
/* undefined function in undefined module */ |
/* undefined function in a module */ |
len = dot-name; |
len = dot-name; |
modname = (char *)MALLOC_ATOMIC(len+1); |
modname = (char *)MALLOC_ATOMIC(len+1); |
strncpy(modname,name,len); modname[len] = 0; |
strncpy(modname,name,len); modname[len] = 0; |
mod = mkmodule(modname); |
|
fname = (char *)MALLOC_ATOMIC(strlen(name)-len+1); |
fname = (char *)MALLOC_ATOMIC(strlen(name)-len+1); |
strcpy(fname,dot+1); |
strcpy(fname,dot+1); |
f->name = fname; |
f->name = fname; |
f->fullname = name; |
f->fullname = name; |
MKNODE(mod->usrf_list,f,0); |
mod = searchmodule(modname); |
|
if ( !mod ) |
|
mod = mkmodule(modname); |
|
MKNODE(tn,f,mod->usrf_list); mod->usrf_list = tn; |
} else { |
} else { |
f->name = name; |
f->name = name; |
#if 0 |
|
if ( CUR_MODULE ) { |
|
f->fullname = |
|
(char *)MALLOC_ATOMIC(strlen(CUR_MODULE->name)+strlen(name)+1); |
|
sprintf(f->fullname,"%s.%s",CUR_MODULE->name,name); |
|
MKNODE(tn,f,CUR_MODULE->usrf_list); CUR_MODULE->usrf_list = tn; |
|
} else { |
|
f->fullname = name; |
|
MKNODE(tn,f,usrf); usrf = tn; |
|
} |
|
#else |
|
f->fullname = name; |
f->fullname = name; |
MKNODE(tn,f,usrf); usrf = tn; |
MKNODE(tn,f,usrf); usrf = tn; |
#endif |
|
} |
} |
*r = f; |
*r = f; |
} |
} |
Line 951 void mkuf(char *name,char *fname,NODE args,SNODE body, |
|
Line 945 void mkuf(char *name,char *fname,NODE args,SNODE body, |
|
char *longname; |
char *longname; |
int argc; |
int argc; |
|
|
|
if ( *name == ':' ) |
|
name += 2; |
if ( !module ) { |
if ( !module ) { |
searchf(sysf,name,&f); |
searchf(sysf,name,&f); |
if ( f ) { |
if ( f ) { |