[BACK]Return to eval.c CVS log [TXT][DIR] Up to [local] / OpenXM_contrib2 / asir2000 / parse

Diff for /OpenXM_contrib2/asir2000/parse/eval.c between version 1.26 and 1.29

version 1.26, 2003/05/17 11:47:51 version 1.29, 2003/05/30 00:47:24
Line 45 
Line 45 
  * 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.25 2003/05/16 09:34:49 noro 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 908  void appenduf_local(char *name,FUNC *r)
Line 902  void appenduf_local(char *name,FUNC *r)
         FUNC f;          FUNC f;
         MODULE mod;          MODULE mod;
   
           for ( tn = CUR_MODULE->usrf_list; tn; tn = NEXT(tn) )
                   if ( !strcmp(((FUNC)BDY(tn))->name,name) )
                           break;
           if ( tn )
                   return;
   
         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;
         f->name = name;          f->name = name;
Line 933  void mkparif(char *name,FUNC *r)
Line 933  void mkparif(char *name,FUNC *r)
   
         *r = f =(FUNC)MALLOC(sizeof(struct oFUNC));          *r = f =(FUNC)MALLOC(sizeof(struct oFUNC));
         f->name = name; f->id = A_PARI; f->argc = 0; f->f.binf = 0;          f->name = name; f->id = A_PARI; f->argc = 0; f->f.binf = 0;
           f->fullname = name;
 }  }
   
 void mkuf(char *name,char *fname,NODE args,SNODE body,int startl,int endl,char *desc,MODULE module)  void mkuf(char *name,char *fname,NODE args,SNODE body,int startl,int endl,char *desc,MODULE module)
Line 944  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 ) {

Legend:
Removed from v.1.26  
changed lines
  Added in v.1.29

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>