[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.64 and 1.65

version 1.64, 2005/09/29 08:55:26 version 1.65, 2005/09/30 01:35:25
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.63 2005/09/28 08:08:34 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/builtin/strobj.c,v 1.64 2005/09/29 08:55:26 noro Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "parse.h"  #include "parse.h"
Line 112  struct ftab str_tab[] = {
Line 112  struct ftab str_tab[] = {
         {"quotetotex_tb",Pquotetotex_tb,2},          {"quotetotex_tb",Pquotetotex_tb,2},
         {"quotetotex",Pquotetotex,1},          {"quotetotex",Pquotetotex,1},
         {"quotetotex_env",Pquotetotex_env,-99999999},          {"quotetotex_env",Pquotetotex_env,-99999999},
         {"flatten_quote",Pflatten_quote,2},          {"flatten_quote",Pflatten_quote,-2},
         {"quote_to_funargs",Pquote_to_funargs,1},          {"quote_to_funargs",Pquote_to_funargs,1},
         {"quote_unify",Pquote_unify,2},          {"quote_unify",Pquote_unify,2},
         {"funargs_to_quote",Pfunargs_to_quote,1},          {"funargs_to_quote",Pfunargs_to_quote,1},
Line 536  void Pquote_to_bin(NODE arg,QUOTE *rp)
Line 536  void Pquote_to_bin(NODE arg,QUOTE *rp)
 void Pquote_unify(NODE arg,Q *rp)  void Pquote_unify(NODE arg,Q *rp)
 {  {
         FNODE f,g;          FNODE f,g;
           Obj obj;
         QUOTE q;          QUOTE q;
         NODE r;          NODE r;
         int ret;          int ret;
Line 545  void Pquote_unify(NODE arg,Q *rp)
Line 546  void Pquote_unify(NODE arg,Q *rp)
         MKQUOTE(q,g);          MKQUOTE(q,g);
         ret = quote_unify((Obj)q,(Obj)ARG1(arg),&r);          ret = quote_unify((Obj)q,(Obj)ARG1(arg),&r);
 #else  #else
         ret = quote_unify((Obj)ARG0(arg),(Obj)ARG1(arg),&r);          obj = (Obj)ARG0(arg);
           if ( !obj || OID(obj) != O_QUOTE) {
                   objtoquote(obj,&q); obj = (Obj)q;
           }
           ret = quote_unify(obj,(Obj)ARG1(arg),&r);
 #endif  #endif
         if ( ret ) {          if ( ret ) {
                 do_assign(r);                  do_assign(r);
Line 1560  void Pflatten_quote(NODE arg,Obj *rp)
Line 1565  void Pflatten_quote(NODE arg,Obj *rp)
   
         if ( !ARG0(arg) || OID((Obj)ARG0(arg)) != O_QUOTE )          if ( !ARG0(arg) || OID((Obj)ARG0(arg)) != O_QUOTE )
                 *rp = (Obj)ARG0(arg);                  *rp = (Obj)ARG0(arg);
         else {          else if ( argc(arg) == 1 ) {
                   f = flatten_fnode(BDY((QUOTE)ARG0(arg)),"+");
                   f = flatten_fnode(f,"*");
                   MKQUOTE(q,f);
                   *rp = (Obj)q;
           } else {
                 f = flatten_fnode(BDY((QUOTE)ARG0(arg)),BDY((STRING)ARG1(arg)));                  f = flatten_fnode(BDY((QUOTE)ARG0(arg)),BDY((STRING)ARG1(arg)));
                 MKQUOTE(q,f);                  MKQUOTE(q,f);
                 *rp = (Obj)q;                  *rp = (Obj)q;

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

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