[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.27 and 1.28

version 1.27, 2003/05/20 06:15:01 version 1.28, 2003/05/24 10:42:18
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.26 2003/05/17 11:47:51 takayama Exp $   * $OpenXM: OpenXM_contrib2/asir2000/parse/eval.c,v 1.27 2003/05/20 06:15:01 noro Exp $
 */  */
 #include <ctype.h>  #include <ctype.h>
 #include "ca.h"  #include "ca.h"
Line 872  void appenduf(char *name,FUNC *r)
Line 872  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;
 }  }

Legend:
Removed from v.1.27  
changed lines
  Added in v.1.28

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