[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.66 and 1.67

version 1.66, 2005/09/30 02:20:06 version 1.67, 2005/10/03 00:06:40
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.65 2005/09/30 01:35:25 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/builtin/strobj.c,v 1.66 2005/09/30 02:20:06 noro Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "parse.h"  #include "parse.h"
Line 547  void Pquote_unify(NODE arg,Q *rp)
Line 547  void Pquote_unify(NODE arg,Q *rp)
         ret = quote_unify((Obj)q,(Obj)ARG1(arg),&r);          ret = quote_unify((Obj)q,(Obj)ARG1(arg),&r);
 #else  #else
         obj = (Obj)ARG0(arg);          obj = (Obj)ARG0(arg);
         if ( !obj || OID(obj) != O_QUOTE) {  
                 objtoquote(obj,&q); obj = (Obj)q;  
         }  
         ret = quote_unify(obj,(Obj)ARG1(arg),&r);          ret = quote_unify(obj,(Obj)ARG1(arg),&r);
 #endif  #endif
         if ( ret ) {          if ( ret ) {
Line 683  int quote_unify(Obj f, Obj pat, NODE *rp)
Line 680  int quote_unify(Obj f, Obj pat, NODE *rp)
         QUOTE q;          QUOTE q;
         FNODE g;          FNODE g;
   
         if ( OID(pat) == O_LIST ) {          if ( !f )
                   if ( !pat ) {
                           *rp = 0; return 1;
                   } else
                           return 0;
           else if ( OID(pat) == O_LIST ) {
                 if ( OID(f) == O_LIST )                  if ( OID(f) == O_LIST )
                         return quote_unify_node(BDY((LIST)f),BDY((LIST)pat),rp);                          return quote_unify_node(BDY((LIST)f),BDY((LIST)pat),rp);
                 else                  else
                         return 0;                          return 0;
         } else if ( OID(pat) == O_QUOTE ) {          } else if ( OID(pat) == O_QUOTE ) {
                 if ( OID(f) != O_QUOTE ) return 0;                  pid = ((FNODE)BDY((QUOTE)pat))->id;
                 get_quote_id_arg((QUOTE)pat,&pid,&parg);  
                 get_quote_id_arg((QUOTE)f,&id,&farg);  
                 switch ( pid ) {                  switch ( pid ) {
                         case I_FORMULA:                          case I_FORMULA:
                                 if ( compquote(CO,f,pat) )                                  if ( compquote(CO,f,pat) )
                                         return 0;                                          return 0;
                                 else {                                  else {
                                         *rp = 0;                                          *rp = 0; return 1;
                                         return 1;  
                                 }                                  }
                                 break;                                  break;
                         case I_LIST:  
                                 return quote_unify_node(BDY((LIST)BDY(farg)),                          case I_LIST: case I_CONS:
                                                         BDY((LIST)BDY(parg)),rp);                                  get_quote_id_arg((QUOTE)pat,&pid,&parg);
                         case I_CONS:                                  if ( OID(f) == O_LIST )
                                 tf = BDY((LIST)BDY(farg));                                          tf = BDY((LIST)f);
                                   else if ( OID(f) == O_QUOTE
                                           && ((FNODE)BDY((QUOTE)f))->id == pid ) {
                                           get_quote_id_arg((QUOTE)f,&id,&farg);
                                           tf = BDY((LIST)BDY(farg));
                                   } else
                                           return 0;
   
                                 tp = BDY((LIST)BDY(parg));                                  tp = BDY((LIST)BDY(parg));
                                 rpat = (Obj)BDY(NEXT(parg));                                  if ( pid == I_LIST )
                                 return quote_unify_cons(tf,tp,rpat,rp);                                          return quote_unify_node(tf,tp,rp);
                                   else {
                                           rpat = (Obj)BDY(NEXT(parg));
                                           return quote_unify_cons(tf,tp,rpat,rp);
                                   }
   
                         case I_PVAR:                          case I_PVAR:
                                 /* [[pat,f]] */                                  /* [[pat,f]] */
                                 r = mknode(2,pat,f); MKLIST(l,r);                                  r = mknode(2,pat,f); MKLIST(l,r);
                                 *rp =  mknode(1,l);                                  *rp =  mknode(1,l);
                                 return 1;                                  return 1;
   
                         case I_IFUNC:                          case I_IFUNC:
                                 /* F(X,Y,...) = ... */                                  /* F(X,Y,...) = ... */
                                   get_quote_id_arg((QUOTE)f,&id,&farg);
                                   get_quote_id_arg((QUOTE)pat,&pid,&parg);
                                 if ( id == I_FUNC ) {                                  if ( id == I_FUNC ) {
                                         r = mknode(2,BDY(parg),BDY(farg)); MKLIST(l,r);                                          r = mknode(2,BDY(parg),BDY(farg)); MKLIST(l,r);
                                         head = mknode(1,l);                                          head = mknode(1,l);
Line 726  int quote_unify(Obj f, Obj pat, NODE *rp)
Line 740  int quote_unify(Obj f, Obj pat, NODE *rp)
                                 } else                                  } else
                                         return 0;                                          return 0;
   
                         case I_NARYOP:                          case I_NARYOP: case I_BOP: case I_FUNC:
                         case I_BOP:  
                                 /* 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 ( OID(f) != O_QUOTE ) return 0;
                                   id = ((FNODE)BDY((QUOTE)f))->id;
                                   if ( pid == I_FUNC )
                                           ;
                                   else {
                                           /* XXX converting to I_BOP */
                                           if ( pid == I_NARYOP ) {
                                                   g = quote_to_bin(BDY((QUOTE)pat),1);
                                                   MKQUOTE(q,g); pat = (Obj)q;
                                           }
                                           if ( id == I_NARYOP ) {
                                                   g = quote_to_bin(BDY((QUOTE)f),1);
                                                   MKQUOTE(q,g); f = (Obj)q;
                                           }
                                   }
                                   get_quote_id_arg((QUOTE)pat,&pid,&parg);
                                   get_quote_id_arg((QUOTE)f,&id,&farg);
                                 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);
                                 break;  
                         default:                          default:
                                 if ( pid == id )                                  if ( OID(f) != O_QUOTE ) return 0;
                                         return quote_unify_node(farg,parg,rp);                                  id = ((FNODE)BDY((QUOTE)f))->id;
                                 else                                  if ( id != pid ) return 0;
                                         return 0;                                  get_quote_id_arg((QUOTE)pat,&pid,&parg);
                                   get_quote_id_arg((QUOTE)f,&id,&farg);
                                   return quote_unify_node(farg,parg,rp);
                 }                  }
         }          }
 }  }

Legend:
Removed from v.1.66  
changed lines
  Added in v.1.67

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