int-noview.hpp /usr/include/gecode/int/linear/int-nary.hpp Gecode::Int::Linear::NoView Gecode::ViewArray< Int::Linear::NoView > Gecode Gecode::Int Gecode::Int::Linear /*-*-mode:C++;c-basic-offset:2;indent-tabs-mode:nil-*-*/ /* *Mainauthors: *ChristianSchulte<schulte@gecode.org> * *Copyright: *ChristianSchulte,2002 * *Lastmodified: *$Date:2013-02-1416:29:11+0100(Thu,14Feb2013)$by$Author:schulte$ *$Revision:13292$ * *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. * */ namespaceGecode{ namespaceInt{namespaceLinear{ classNoView:publicConstView<IntView>{ public: NoView(void){} intmin(void)const{return0;} intmax(void)const{return0;} intmed(void)const{return0;} intval(void)const{return0;} unsignedintsize(void)const{return1;} unsignedintwidth(void)const{return1;} unsignedintregret_min(void)const{return0;} unsignedintregret_max(void)const{return0;} boolrange(void)const{returntrue;} boolassigned(void)const{returntrue;} boolin(intn)const{(void)n;returnfalse;} boolin(longlongintn)const{(void)n;returnfalse;} ModEventlq(Space&home,intn){ (void)home;(void)n; returnME_INT_NONE; } ModEventlq(Space&home,longlongintn){ (void)home;(void)n; returnME_INT_NONE; } ModEventle(Space&home,intn){ (void)home;(void)n; returnME_INT_NONE; } ModEventle(Space&home,longlongintn){ (void)home;(void)n; returnME_INT_NONE; } ModEventgq(Space&home,intn){ (void)home;(void)n; returnME_INT_NONE; } ModEventgq(Space&home,longlongintn){ (void)home;(void)n; returnME_INT_NONE; } ModEventgr(Space&home,intn){ (void)home;(void)n; returnME_INT_NONE; } ModEventgr(Space&home,longlongintn){ (void)home;(void)n; returnME_INT_NONE; } ModEventnq(Space&home,intn){ (void)home;(void)n; returnME_INT_NONE; } ModEventnq(Space&home,longlongintn){ (void)home;(void)n; returnME_INT_NONE; } ModEventeq(Space&home,intn){ (void)home;(void)n; returnME_INT_NONE; } ModEventeq(Space&home,longlongintn){ (void)home;(void)n; returnME_INT_NONE; } }; template<classChar,classTraits> std::basic_ostream<Char,Traits>& operator<<(std::basic_ostream<Char,Traits>&os,constNoView&){returnos;} }} template<> classViewArray<Int::Linear::NoView>{ public: ViewArray(void){} ViewArray(Space&home,intm){(void)home;(void)m;} ViewArray(constViewArray<Int::Linear::NoView>&){} ViewArray(Space&,constViewArray<Int::Linear::NoView>&){} constViewArray<Int::Linear::NoView>&operator =(constViewArray<Int::Linear::NoView>&){return*this;} intsize(void)const{return0;} voidsize(intn){(void)n;} Int::Linear::NoViewoperator [](inti){ (void)i; Int::Linear::NoViewn; returnn; } constInt::Linear::NoViewoperator [](inti)const{ (void)i; Int::Linear::NoViewn; returnn; } voidsubscribe(Space&,Propagator&p,PropCondpc,boolprocess=true){ (void)p;(void)pc;(void)process; } voidcancel(Space&home,Propagator&p,PropCondpc){ (void)home;(void)p;(void)pc; } voidupdate(Space&,boolshare,ViewArray<Int::Linear::NoView>&a){ (void)share;(void)a; } voidmove_fst(inti){(void)i;} voidmove_lst(inti){(void)i;} private: staticvoid*operatornew(size_t); staticvoidoperatordelete(void*,size_t); }; } //STATISTICS:int-prop