common.hpp /usr/include/gecode/set/rel.hh Gecode Gecode::Set Gecode::Set::Rel GECODE_SET_ME_CHECK_VAL p f { \ ModEvent __me__ ## __LINE__ = (p); \ if (me_failed(__me__ ## __LINE__)) return ES_FAILED; \ if (ME_GEN_ASSIGNED==(__me__ ## __LINE__))f=true; } GECODE_SET_ME_CHECK_VAL_B modified tell f { \ ModEvent me = (tell); \ modified |= me_modified(me); \ if (ME_GEN_ASSIGNED==(me))f=true; \ GECODE_ME_CHECK(me); \ } /*-*-mode:C++;c-basic-offset:2;indent-tabs-mode:nil-*-*/ /* *Mainauthors: *GuidoTack<tack@gecode.org> *ChristianSchulte<schulte@gecode.org> * *Contributingauthors: *GaborSzokoli<szokoli@gecode.org> * *Copyright: *GuidoTack,2004 *ChristianSchulte,2004 *GaborSzokoli,2004 * *Lastmodified: *$Date:2010-06-0211:00:04+0200(Wed,02Jun2010)$by$Author:schulte$ *$Revision:11004$ * *ThisfileispartofGecode,thegenericconstraint *developmentenvironment: *http://www.gecode.org * *Permissionisherebygranted,freeofcharge,toanypersonobtaining *acopyofthissoftwareandassociateddocumentationfiles(the *"Software"),todealintheSoftwarewithoutrestriction,including *withoutlimitationtherightstouse,copy,modify,merge,publish, *distribute,sublicense,and/orsellcopiesoftheSoftware,andto *permitpersonstowhomtheSoftwareisfurnishedtodoso,subjectto *thefollowingconditions: * *Theabovecopyrightnoticeandthispermissionnoticeshallbe *includedinallcopiesorsubstantialportionsoftheSoftware. * *THESOFTWAREISPROVIDED"ASIS",WITHOUTWARRANTYOFANYKIND, *EXPRESSORIMPLIED,INCLUDINGBUTNOTLIMITEDTOTHEWARRANTIESOF *MERCHANTABILITY,FITNESSFORAPARTICULARPURPOSEAND *NONINFRINGEMENT.INNOEVENTSHALLTHEAUTHORSORCOPYRIGHTHOLDERSBE *LIABLEFORANYCLAIM,DAMAGESOROTHERLIABILITY,WHETHERINANACTION *OFCONTRACT,TORTOROTHERWISE,ARISINGFROM,OUTOFORINCONNECTION *WITHTHESOFTWAREORTHEUSEOROTHERDEALINGSINTHESOFTWARE. * */ #defineGECODE_SET_ME_CHECK_VAL(p,f){\ ModEvent__me__##__LINE__=(p);\ if(me_failed(__me__##__LINE__))returnES_FAILED;\ if(ME_GEN_ASSIGNED==(__me__##__LINE__))f=true;} #defineGECODE_SET_ME_CHECK_VAL_B(modified,tell,f)\ {\ ModEventme=(tell);\ modified|=me_modified(me);\ if(ME_GEN_ASSIGNED==(me))f=true;\ GECODE_ME_CHECK(me);\ } namespaceGecode{namespaceSet{namespaceRel{ forceinline boolsubsumesME(ModEventme0,ModEventme1,ModEventme2,ModEventme){ ModEventcme=SetVarImp::me_combine(me0,SetVarImp::me_combine(me1,me2)); returnSetVarImp::me_combine(cme,me)==cme; } forceinline boolsubsumesME(ModEventme0,ModEventme1,ModEventme){ ModEventcme=SetVarImp::me_combine(me0,me1); returnSetVarImp::me_combine(cme,me)==cme; } forceinline boolsubsumesME(ModEventme0,ModEventme){ returnSetVarImp::me_combine(me0,me)==me0; } forceinline booltestSetEventLB(ModEventme0,ModEventme1,ModEventme2){ returnsubsumesME(me0,me1,me2,ME_SET_GLB); } forceinline booltestSetEventUB(ModEventme0,ModEventme1,ModEventme2){ returnsubsumesME(me0,me1,me2,ME_SET_LUB); } forceinline booltestSetEventAnyB(ModEventme0,ModEventme1,ModEventme2){ return(me0!=ME_SET_CARD||me1!=ME_SET_CARD||me2!=ME_SET_CARD); } forceinline booltestSetEventCard(ModEventme0,ModEventme1,ModEventme2){ returnsubsumesME(me0,me1,me2,ME_SET_CARD); } forceinline booltestSetEventLB(ModEventme0,ModEventme1){ returnsubsumesME(me0,me1,ME_SET_GLB); } forceinline booltestSetEventUB(ModEventme0,ModEventme1){ returnsubsumesME(me0,me1,ME_SET_LUB); } forceinline booltestSetEventAnyB(ModEventme0,ModEventme1){ return(me0!=ME_SET_CARD||me1!=ME_SET_CARD); } forceinline booltestSetEventCard(ModEventme0,ModEventme1){ returnsubsumesME(me0,me1,ME_SET_CARD); } forceinline booltestSetEventLB(ModEventme0){ returnsubsumesME(me0,ME_SET_GLB); } forceinline booltestSetEventUB(ModEventme0){ returnsubsumesME(me0,ME_SET_LUB); } forceinline booltestSetEventAnyB(ModEventme0){ return(me0!=ME_SET_CARD); } forceinline booltestSetEventCard(ModEventme0){ returnsubsumesME(me0,ME_SET_CARD); } }}} //STATISTICS:set-prop