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

Diff for /OpenXM_contrib2/asir2000/builtin/dp.c between version 1.80 and 1.81

version 1.80, 2010/01/19 06:17:22 version 1.81, 2010/04/16 07:13:42
Line 44 
Line 44 
  * 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/dp.c,v 1.79 2009/10/09 04:02:11 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/builtin/dp.c,v 1.80 2010/01/19 06:17:22 noro Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "base.h"  #include "base.h"
Line 2130  NODE arg;
Line 2130  NODE arg;
 LIST *rp;  LIST *rp;
 {  {
         LIST f,v;          LIST f,v;
         int m,homo;          int m,find;
           Obj homo;
         struct order_spec *ord;          struct order_spec *ord;
   
         do_weyl = 0;          do_weyl = 0;
Line 2144  LIST *rp;
Line 2145  LIST *rp;
         }          }
         m = QTOS((Q)ARG2(arg));          m = QTOS((Q)ARG2(arg));
         create_order_spec(0,ARG3(arg),&ord);          create_order_spec(0,ARG3(arg),&ord);
         nd_gr(f,v,m,1,ord,rp);          find = get_opt("homo",&homo);
           nd_gr(f,v,m,find&&homo,1,ord,rp);
 }  }
   
 void Pnd_gr(arg,rp)  void Pnd_gr(arg,rp)
Line 2152  NODE arg;
Line 2154  NODE arg;
 LIST *rp;  LIST *rp;
 {  {
         LIST f,v;          LIST f,v;
         int m,homo;          int m,find;
           Obj homo;
         struct order_spec *ord;          struct order_spec *ord;
   
         do_weyl = 0;          do_weyl = 0;
Line 2166  LIST *rp;
Line 2169  LIST *rp;
         }          }
         m = QTOS((Q)ARG2(arg));          m = QTOS((Q)ARG2(arg));
         create_order_spec(0,ARG3(arg),&ord);          create_order_spec(0,ARG3(arg),&ord);
         nd_gr(f,v,m,0,ord,rp);          find = get_opt("homo",&homo);
           nd_gr(f,v,m,find&&homo,0,ord,rp);
 }  }
   
 void Pnd_gr_postproc(arg,rp)  void Pnd_gr_postproc(arg,rp)
Line 2269  NODE arg;
Line 2273  NODE arg;
 LIST *rp;  LIST *rp;
 {  {
         LIST f,v;          LIST f,v;
         int m,homo;          int m,find;
           Obj homo;
         struct order_spec *ord;          struct order_spec *ord;
   
         do_weyl = 1;          do_weyl = 1;
Line 2283  LIST *rp;
Line 2288  LIST *rp;
         }          }
         m = QTOS((Q)ARG2(arg));          m = QTOS((Q)ARG2(arg));
         create_order_spec(0,ARG3(arg),&ord);          create_order_spec(0,ARG3(arg),&ord);
         nd_gr(f,v,m,0,ord,rp);          find = get_opt("homo",&homo);
           nd_gr(f,v,m,find&&homo,0,ord,rp);
         do_weyl = 0;          do_weyl = 0;
 }  }
   
Line 2790  int dpv_hp(DPV p)
Line 2796  int dpv_hp(DPV p)
                         break;                          break;
         }          }
 }  }
   
   int get_opt(char *key0,Obj *r) {
      NODE tt,p;
      char *key;
   
      if ( current_option ) {
        for ( tt = current_option; tt; tt = NEXT(tt) ) {
          p = BDY((LIST)BDY(tt));
          key = BDY((STRING)BDY(p));
          /*  value = (Obj)BDY(NEXT(p)); */
          if ( !strcmp(key,key0) )  {
                *r = (Obj)BDY(NEXT(p));
                return 1;
              }
        }
      }
      return 0;
   }
   

Legend:
Removed from v.1.80  
changed lines
  Added in v.1.81

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