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

Diff for /OpenXM_contrib2/asir2000/builtin/strobj.c between version 1.59 and 1.64

version 1.59, 2005/09/21 23:39:32 version 1.64, 2005/09/29 08:55:26
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/builtin/strobj.c,v 1.58 2005/09/18 08:14:22 ohara Exp $   * $OpenXM: OpenXM_contrib2/asir2000/builtin/strobj.c,v 1.63 2005/09/28 08:08:34 noro Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "parse.h"  #include "parse.h"
Line 78  void Pquotetotex();
Line 78  void Pquotetotex();
 void Pquotetotex_env();  void Pquotetotex_env();
 void Pflatten_quote();  void Pflatten_quote();
 void Pquote_to_funargs(),Pfunargs_to_quote(),Pget_function_name();  void Pquote_to_funargs(),Pfunargs_to_quote(),Pget_function_name();
 void Pquote_unify();  void Pquote_unify(),Pget_quote_id();
   void Pquote_to_nary(),Pquote_to_bin();
 void do_assign(NODE arg);  void do_assign(NODE arg);
 void fnodetotex_tb(FNODE f,TB tb);  void fnodetotex_tb(FNODE f,TB tb);
 char *symbol_name(char *name);  char *symbol_name(char *name);
Line 105  struct ftab str_tab[] = {
Line 106  struct ftab str_tab[] = {
         {"clear_tb",Pclear_tb,1},          {"clear_tb",Pclear_tb,1},
         {"tb_to_string",Ptb_to_string,1},          {"tb_to_string",Ptb_to_string,1},
         {"string_to_tb",Pstring_to_tb,1},          {"string_to_tb",Pstring_to_tb,1},
         {"quotetotex_tb",Pquotetotex_tb,2,0x1},          {"get_quote_id",Pget_quote_id,1},
         {"quotetotex",Pquotetotex,1,0x1},          {"quote_to_nary",Pquote_to_nary,1},
         {"quotetotex_env",Pquotetotex_env,-99999999,0x1},          {"quote_to_bin",Pquote_to_bin,2},
         {"flatten_quote",Pflatten_quote,2,0x1},          {"quotetotex_tb",Pquotetotex_tb,2},
         {"quote_to_funargs",Pquote_to_funargs,1,0x1},          {"quotetotex",Pquotetotex,1},
         {"quote_unify",Pquote_unify,2,0x3},          {"quotetotex_env",Pquotetotex_env,-99999999},
           {"flatten_quote",Pflatten_quote,2},
           {"quote_to_funargs",Pquote_to_funargs,1},
           {"quote_unify",Pquote_unify,2},
         {"funargs_to_quote",Pfunargs_to_quote,1},          {"funargs_to_quote",Pfunargs_to_quote,1},
         {"get_function_name",Pget_function_name,1},          {"get_function_name",Pget_function_name,1},
         {0,0,0},          {0,0,0},
Line 508  void Pwrite_to_tb(NODE arg,Q *rp)
Line 512  void Pwrite_to_tb(NODE arg,Q *rp)
         *rp = 0;          *rp = 0;
 }  }
   
   FNODE partial_eval(FNODE), quote_to_nary(FNODE), quote_to_bin(FNODE,int);
   
   void Pquote_to_nary(NODE arg,QUOTE *rp)
   {
           FNODE f;
   
           f = quote_to_nary(BDY((QUOTE)ARG0(arg)));
           MKQUOTE(*rp,f);
   }
   
   void Pquote_to_bin(NODE arg,QUOTE *rp)
   {
           FNODE f;
           int direction;
   
           direction = QTOS((Q)ARG1(arg));
           f = quote_to_bin(BDY((QUOTE)ARG0(arg)),direction);
   
           MKQUOTE(*rp,f);
   }
   
 void Pquote_unify(NODE arg,Q *rp)  void Pquote_unify(NODE arg,Q *rp)
 {  {
           FNODE f,g;
           QUOTE q;
         NODE r;          NODE r;
         int ret;          int ret;
   
   #if 0
           g = partial_eval(BDY(((QUOTE)ARG0(arg))));
           MKQUOTE(q,g);
           ret = quote_unify((Obj)q,(Obj)ARG1(arg),&r);
   #else
         ret = quote_unify((Obj)ARG0(arg),(Obj)ARG1(arg),&r);          ret = quote_unify((Obj)ARG0(arg),(Obj)ARG1(arg),&r);
   #endif
         if ( ret ) {          if ( ret ) {
                 do_assign(r);                  do_assign(r);
                 *rp = ONE;                  *rp = ONE;
Line 607  int quote_unify(Obj f, Obj pat, NODE *rp)
Line 640  int quote_unify(Obj f, Obj pat, NODE *rp)
         int pid,id;          int pid,id;
         FUNC ff,pf;          FUNC ff,pf;
         int ret;          int ret;
           QUOTE q;
           FNODE g;
   
         if ( OID(pat) == O_LIST ) {          if ( OID(pat) == O_LIST ) {
                 if ( OID(f) == O_LIST )                  if ( OID(f) == O_LIST )
Line 645  int quote_unify(Obj f, Obj pat, NODE *rp)
Line 680  int quote_unify(Obj f, Obj pat, NODE *rp)
                                         else return merge_matching_node(head,body,rp);                                          else return merge_matching_node(head,body,rp);
                                 } else                                  } else
                                         return 0;                                          return 0;
   
                           case I_NARYOP:
                         case I_BOP:                          case I_BOP:
                         case I_FUNC:  
                                 /* X+Y = ... */                                  /* X+Y = ... */
                                   if ( compqa(CO,BDY(farg),BDY(parg)) ) return 0;
   
                                   /* XXX converting to I_BOP */
                                   if ( ((FNODE)BDY((QUOTE)pat))->id == I_NARYOP ) {
                                           g = quote_to_bin(BDY((QUOTE)pat),1);
                                           MKQUOTE(q,g);
                                           get_quote_id_arg((QUOTE)q,&pid,&parg);
                                   }
                                   if ( ((FNODE)BDY((QUOTE)f))->id == I_NARYOP ) {
                                           g = quote_to_bin(BDY((QUOTE)f),1);
                                           MKQUOTE(q,g);
                                           get_quote_id_arg((QUOTE)q,&id,&farg);
                                   }
                                   return quote_unify_node(NEXT(farg),NEXT(parg),rp);
                                   break;
   
                           case I_FUNC:
                                 /* f(...) = ... */                                  /* f(...) = ... */
                                 if ( compqa(CO,BDY(farg),BDY(parg)) ) return 0;                                  if ( compqa(CO,BDY(farg),BDY(parg)) ) return 0;
                                 return quote_unify_node(NEXT(farg),NEXT(parg),rp);                                  return quote_unify_node(NEXT(farg),NEXT(parg),rp);
Line 1512  void Pflatten_quote(NODE arg,Obj *rp)
Line 1565  void Pflatten_quote(NODE arg,Obj *rp)
                 MKQUOTE(q,f);                  MKQUOTE(q,f);
                 *rp = (Obj)q;                  *rp = (Obj)q;
         }          }
   }
   
   void Pget_quote_id(NODE arg,Q *rp)
   {
           FNODE f;
           QUOTE q;
   
           q = (QUOTE)ARG0(arg);
           if ( !q || OID(q) != O_QUOTE )
                   error("get_quote_id : invalid argument");
           f = BDY(q);
           STOQ((int)f->id,*rp);
 }  }
   
 void Pquote_to_funargs(NODE arg,LIST *rp)  void Pquote_to_funargs(NODE arg,LIST *rp)

Legend:
Removed from v.1.59  
changed lines
  Added in v.1.64

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