gecoder-with-gecode 0.9.0 → 0.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/CHANGES +6 -0
- data/README +1 -1
- data/THANKS +18 -0
- data/example/equation_system.rb +3 -1
- data/example/magic_sequence.rb +3 -1
- data/example/queens.rb +3 -1
- data/example/send_more_money.rb +24 -30
- data/example/send_most_money.rb +15 -26
- data/example/square_tiling.rb +3 -1
- data/example/sudoku-set.rb +3 -1
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/LICENSE +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/Makefile.contribs +0 -0
- data/ext/gecode-2.2.0/Makefile.dep +8056 -0
- data/ext/gecode-2.2.0/Makefile.in +1590 -0
- data/ext/gecode-2.2.0/changelog.in +2698 -0
- data/ext/gecode-2.2.0/configure +13112 -0
- data/ext/gecode-2.2.0/configure.ac +273 -0
- data/ext/gecode-2.2.0/configure.ac.in +269 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/README +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/Doxyfile +263 -0
- data/ext/gecode-2.2.0/contribs/qecode/Implicative.cc +267 -0
- data/ext/gecode-2.2.0/contribs/qecode/Implicative.hh +164 -0
- data/ext/gecode-2.2.0/contribs/qecode/Makefile.in.in +163 -0
- data/ext/gecode-2.2.0/contribs/qecode/OptVar.cc +82 -0
- data/ext/gecode-2.2.0/contribs/qecode/OptVar.hh +123 -0
- data/ext/gecode-2.2.0/contribs/qecode/Strategy.cc +131 -0
- data/ext/gecode-2.2.0/contribs/qecode/Strategy.hh +91 -0
- data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.cc +62 -0
- data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.hh +47 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/output.0 +2264 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/requests +115 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/traces.0 +57 -0
- data/ext/gecode-2.2.0/contribs/qecode/config.log +147 -0
- data/ext/gecode-2.2.0/contribs/qecode/config.status +817 -0
- data/ext/gecode-2.2.0/contribs/qecode/configure +2264 -0
- data/ext/gecode-2.2.0/contribs/qecode/configure.ac +23 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/COMPILING +13 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/MatrixGame.cpp +140 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/NimFibo.cpp +73 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/connect-5-3-3-3.cpp +842 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/network-pricing.cc +146 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/optim2.cc +149 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/stress_test.cpp +240 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/heap.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myDom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myspace.cc +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/myspace.hh +68 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/qecode.hh +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/qsolver.cc +268 -0
- data/ext/gecode-2.2.0/contribs/qecode/qsolver.hh +46 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/shortdesc.ac +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/vartype.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/doxygen/doxygen.conf.in +0 -0
- data/ext/gecode-2.2.0/doxygen/doxygen.hh.in +1112 -0
- data/ext/gecode-2.2.0/doxygen/reflection.hh +417 -0
- data/ext/gecode-2.2.0/examples/all-interval.cc +133 -0
- data/ext/gecode-2.2.0/examples/alpha.cc +137 -0
- data/ext/gecode-2.2.0/examples/bacp.cc +521 -0
- data/ext/gecode-2.2.0/examples/baseline.cc +87 -0
- data/ext/gecode-2.2.0/examples/bibd.cc +203 -0
- data/ext/gecode-2.2.0/examples/black-hole.cc +389 -0
- data/ext/gecode-2.2.0/examples/crew.cc +286 -0
- data/ext/gecode-2.2.0/examples/crowded-chess.cc +424 -0
- data/ext/gecode-2.2.0/examples/domino.cc +297 -0
- data/ext/gecode-2.2.0/examples/donald.cc +107 -0
- data/ext/gecode-2.2.0/examples/eq20.cc +125 -0
- data/ext/gecode-2.2.0/examples/golf.cc +297 -0
- data/ext/gecode-2.2.0/examples/golomb-ruler.cc +199 -0
- data/ext/gecode-2.2.0/examples/graph-color.cc +407 -0
- data/ext/gecode-2.2.0/examples/grocery.cc +113 -0
- data/ext/gecode-2.2.0/examples/hamming.cc +129 -0
- data/ext/gecode-2.2.0/examples/ind-set.cc +143 -0
- data/ext/gecode-2.2.0/examples/javascript.cc +163 -0
- data/ext/gecode-2.2.0/examples/kakuro.cc +686 -0
- data/ext/gecode-2.2.0/examples/knights.cc +220 -0
- data/ext/gecode-2.2.0/examples/langford-number.cc +225 -0
- data/ext/gecode-2.2.0/examples/magic-sequence.cc +146 -0
- data/ext/gecode-2.2.0/examples/magic-square.cc +138 -0
- data/ext/gecode-2.2.0/examples/minesweeper.cc +304 -0
- data/ext/gecode-2.2.0/examples/money.cc +105 -0
- data/ext/gecode-2.2.0/examples/nonogram.cc +492 -0
- data/ext/gecode-2.2.0/examples/ortho-latin.cc +172 -0
- data/ext/gecode-2.2.0/examples/partition.cc +141 -0
- data/ext/gecode-2.2.0/examples/pentominoes.cc +949 -0
- data/ext/gecode-2.2.0/examples/perfect-square.cc +311 -0
- data/ext/gecode-2.2.0/examples/photo.cc +170 -0
- data/ext/gecode-2.2.0/examples/queen-armies.cc +284 -0
- data/ext/gecode-2.2.0/examples/queens.cc +147 -0
- data/ext/gecode-2.2.0/examples/queens.js +57 -0
- data/ext/gecode-2.2.0/examples/sports-league.cc +342 -0
- data/ext/gecode-2.2.0/examples/steiner.cc +192 -0
- data/ext/gecode-2.2.0/examples/stress-distinct.cc +90 -0
- data/ext/gecode-2.2.0/examples/stress-domain.cc +99 -0
- data/ext/gecode-2.2.0/examples/stress-element.cc +112 -0
- data/ext/gecode-2.2.0/examples/stress-exec.cc +97 -0
- data/ext/gecode-2.2.0/examples/stress-extensional.cc +134 -0
- data/ext/gecode-2.2.0/examples/stress-linear-bool.cc +97 -0
- data/ext/gecode-2.2.0/examples/stress-min.cc +98 -0
- data/ext/gecode-2.2.0/examples/stress-search.cc +88 -0
- data/ext/gecode-2.2.0/examples/sudoku.cc +2341 -0
- data/ext/gecode-2.2.0/examples/support.hh +338 -0
- data/ext/gecode-2.2.0/examples/support/example.cc +64 -0
- data/ext/gecode-2.2.0/examples/support/example.icc +321 -0
- data/ext/gecode-2.2.0/examples/support/options.cc +226 -0
- data/ext/gecode-2.2.0/examples/support/options.icc +276 -0
- data/ext/gecode-2.2.0/examples/tsp.cc +317 -0
- data/ext/gecode-2.2.0/examples/warehouses.cc +191 -0
- data/ext/gecode-2.2.0/gecode.m4 +1046 -0
- data/ext/gecode-2.2.0/gecode/cpltset.hh +797 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/atmost.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/cardinality.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/distinct.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/dom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/partition.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rangeroots.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rel.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/select.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/singleton.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/binary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/naryone.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/narytwo.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/unary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/better.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.cc +281 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.hh +103 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.icc +70 -0
- data/ext/gecode-2.2.0/gecode/gist/gecodelogo.cc +672 -0
- data/ext/gecode-2.2.0/gecode/gist/gecodelogo.hh +64 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.icc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.cc +115 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.hh +75 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.icc +48 -0
- data/ext/gecode-2.2.0/gecode/gist/mainwindow.cc +274 -0
- data/ext/gecode-2.2.0/gecode/gist/mainwindow.hh +86 -0
- data/ext/gecode-2.2.0/gecode/gist/node.cc +148 -0
- data/ext/gecode-2.2.0/gecode/gist/node.hh +117 -0
- data/ext/gecode-2.2.0/gecode/gist/node.icc +99 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.cc +123 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.hh +147 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.icc +122 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.icc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/preferences.cc +120 -0
- data/ext/gecode-2.2.0/gecode/gist/preferences.hh +79 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.cc +468 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.hh +227 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.icc +170 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/test.cc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/textoutput.cc +134 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/textoutput.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/treecanvas.cc +1343 -0
- data/ext/gecode-2.2.0/gecode/gist/treecanvas.hh +361 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/ui_addchild.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/ui_addvisualisationdialog.hh +165 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.cc +192 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.hh +75 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.cc +235 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.hh +77 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/vararrayitem.hh +125 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayviewt.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.cc +474 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.hh +226 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.icc +198 -0
- data/ext/gecode-2.2.0/gecode/gist/zoomToFitIcon.icc +113 -0
- data/ext/gecode-2.2.0/gecode/int.hh +2116 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic.cc +237 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic.hh +827 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/abs.icc +278 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/divmod.icc +496 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/max.icc +474 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/mult.icc +858 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/sqr.icc +464 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/sqrt.icc +260 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/bool.cc +734 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/base.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eqv.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/lq.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/bool/or.icc +1000 -0
- data/ext/gecode-2.2.0/gecode/int/branch.cc +167 -0
- data/ext/gecode-2.2.0/gecode/int/branch.hh +587 -0
- data/ext/gecode-2.2.0/gecode/int/branch/create-branch.icc +190 -0
- data/ext/gecode-2.2.0/gecode/int/branch/select-val.icc +340 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/branch/select-view.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel.cc +165 -0
- data/ext/gecode-2.2.0/gecode/int/channel.hh +259 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/base.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel/dom.icc +348 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel/val.icc +278 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/circuit.hh +175 -0
- data/ext/gecode-2.2.0/gecode/int/circuit/base.icc +266 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit/dom.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/circuit/val.icc +126 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/count.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/count.hh +487 -0
- data/ext/gecode-2.2.0/gecode/int/count/int.icc +620 -0
- data/ext/gecode-2.2.0/gecode/int/count/rel.icc +144 -0
- data/ext/gecode-2.2.0/gecode/int/count/view.icc +449 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/cumulatives.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/cumulatives.hh +138 -0
- data/ext/gecode-2.2.0/gecode/int/cumulatives/val.icc +455 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct.hh +341 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bilink.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bnd.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/combptr.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct/dom.icc +752 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/edge.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/node.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct/ter-dom.icc +136 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/range.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/spec.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/element.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/element.hh +239 -0
- data/ext/gecode-2.2.0/gecode/int/element/int.icc +444 -0
- data/ext/gecode-2.2.0/gecode/int/element/view.icc +584 -0
- data/ext/gecode-2.2.0/gecode/int/exception.icc +174 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional.hh +415 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/base.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/basic.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/bitset.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional/dfa.cc +565 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/dfa.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/incremental.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/layered-graph.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional/tuple-set.cc +285 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/tuple-set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/gcc.hh +329 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/bnd.icc +660 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/dom.icc +531 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/gccbndsup.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/graphsup.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/lbc.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/occur.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/ubc.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/val.icc +400 -0
- data/ext/gecode-2.2.0/gecode/int/int-set.cc +157 -0
- data/ext/gecode-2.2.0/gecode/int/int-set.icc +195 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/limits.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear-bool.cc +235 -0
- data/ext/gecode-2.2.0/gecode/int/linear-int.cc +272 -0
- data/ext/gecode-2.2.0/gecode/int/linear.hh +1849 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-int.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/bool-post.cc +433 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-view.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-bin.icc +605 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-dom.icc +539 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-noview.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-post.cc +493 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-ter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/post.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/propagator.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/rel.cc +420 -0
- data/ext/gecode-2.2.0/gecode/int/rel.hh +627 -0
- data/ext/gecode-2.2.0/gecode/int/rel/eq.icc +885 -0
- data/ext/gecode-2.2.0/gecode/int/rel/lex.icc +275 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/rel/lq-le.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/rel/nq.icc +118 -0
- data/ext/gecode-2.2.0/gecode/int/sorted.cc +81 -0
- data/ext/gecode-2.2.0/gecode/int/sorted.hh +118 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/matching.icc +173 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/narrowing.icc +249 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/order.icc +212 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/propagate.icc +702 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/sortsup.icc +563 -0
- data/ext/gecode-2.2.0/gecode/int/support-values.hh +158 -0
- data/ext/gecode-2.2.0/gecode/int/support-values.icc +203 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/unshare.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp.icc +745 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp/bool.cc +105 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/delta.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp/int.cc +408 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/bool.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var/bool.icc +128 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/int.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var/int.icc +153 -0
- data/ext/gecode-2.2.0/gecode/int/view.icc +1918 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/constint.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/iter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/minus.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/rtest.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/zero.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter.hh +98 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-add.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-append.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-cache.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-compl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-diff.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-empty.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-inter.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-map.icc +260 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minmax.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minus.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-negative.icc +137 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-operations.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-positive.icc +139 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton-append.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-size.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-values.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-inter.icc +130 -0
- data/ext/gecode-2.2.0/gecode/iter/values-map.icc +136 -0
- data/ext/gecode-2.2.0/gecode/iter/values-minus.icc +130 -0
- data/ext/gecode-2.2.0/gecode/iter/values-negative.icc +116 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-offset.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-positive.icc +123 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-ranges.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-singleton.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-union.icc +137 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-unique.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-compl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-inter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel.hh +188 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/advisor.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/branching.icc +433 -0
- data/ext/gecode-2.2.0/gecode/kernel/core.cc +474 -0
- data/ext/gecode-2.2.0/gecode/kernel/core.icc +2311 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/macros.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/memory-manager.cc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/memory-manager.icc +454 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/modevent.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/propagator.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/reflection.cc +951 -0
- data/ext/gecode-2.2.0/gecode/kernel/reflection.icc +1213 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/shared-array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-imp.icc +433 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-map.cc +269 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-map.icc +230 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-traits.icc +79 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/var-type.cc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-type.icc +915 -0
- data/ext/gecode-2.2.0/gecode/kernel/var.icc +114 -0
- data/ext/gecode-2.2.0/gecode/kernel/view.icc +413 -0
- data/ext/gecode-2.2.0/gecode/minimodel.hh +1206 -0
- data/ext/gecode-2.2.0/gecode/minimodel/arithmetic.icc +118 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-rel.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-rel.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/matrix.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/reg.cc +0 -0
- data/ext/gecode-2.2.0/gecode/search.hh +759 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/engine-ctrl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.icc +0 -0
- data/ext/gecode-2.2.0/gecode/search/reco-stack.icc +277 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/restart.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/statistics.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.icc +0 -0
- data/ext/gecode-2.2.0/gecode/serialization.hh +149 -0
- data/ext/gecode-2.2.0/gecode/serialization/boost.cc +78 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/boost.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/flatzinc.cc +0 -0
- data/ext/gecode-2.2.0/gecode/serialization/javascript.cc +343 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/javascript.hh +0 -0
- data/ext/gecode-2.2.0/gecode/serialization/register.cc +8498 -0
- data/ext/gecode-2.2.0/gecode/set.hh +970 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/cardinality.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/dom.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/element.cc +135 -0
- data/ext/gecode-2.2.0/gecode/set/element.hh +233 -0
- data/ext/gecode-2.2.0/gecode/set/element/disjoint.cc +308 -0
- data/ext/gecode-2.2.0/gecode/set/element/disjoint.icc +75 -0
- data/ext/gecode-2.2.0/gecode/set/element/idxarray.hh +113 -0
- data/ext/gecode-2.2.0/gecode/set/element/idxarray.icc +155 -0
- data/ext/gecode-2.2.0/gecode/set/element/inter.icc +348 -0
- data/ext/gecode-2.2.0/gecode/set/element/union.icc +371 -0
- data/ext/gecode-2.2.0/gecode/set/element/unionConst.icc +334 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/card.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/match.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/minmax.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/weights.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/limits.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors-compiler.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/projectors.hh +438 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/compiler.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/projectors/formula.cc +312 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/formula.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/card.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/propagator.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op-const.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.hh +0 -0
- data/ext/gecode-2.2.0/gecode/set/rel-op/common.icc +613 -0
- data/ext/gecode-2.2.0/gecode/set/rel-op/inter.icc +452 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/partition.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/post.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/subofunion.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/superofinter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/common.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/eq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nosubset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/re-eq.icc +0 -0
- data/ext/gecode-2.2.0/gecode/set/rel/re-subset.icc +174 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/subset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/common.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/delta.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/iter.icc +0 -0
- data/ext/gecode-2.2.0/gecode/set/var-imp/set.cc +215 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var/set.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/var/set.icc +303 -0
- data/ext/gecode-2.2.0/gecode/set/view.icc +1451 -0
- data/ext/gecode-2.2.0/gecode/set/view/complement.icc +614 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/const.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support.hh +0 -0
- data/ext/gecode-2.2.0/gecode/support/block-allocator.icc +159 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/AUTHORS +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/ChangeLog +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/NEWS +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/README +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bdd.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddio.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddop.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddtree.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/config.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cppext.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/pairs.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/reorder.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/tree.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/cast.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/config.icc.in +83 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-stack.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/macros.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/map.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/marked-pointer.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/memory.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/random.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/sentinel-stack.icc +138 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/sort.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-pqueue.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-stack.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/symbol.cc +241 -0
- data/ext/gecode-2.2.0/gecode/support/symbol.icc +134 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/install-sh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/AppleHelpbookInfo.plist +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/allexamples.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/Makefile.am +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/changelog +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/control +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/copyright +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.info +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.install +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.spec +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/rules +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/back.png +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/footer.html +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/gecode-logo-100.png +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/header.html +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/stylesheet.css +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/fixproperties.sh +0 -0
- data/ext/gecode-2.2.0/misc/gecode-gist.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-minimodel.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-search.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-serialization.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode.pc.in +45 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genchangelog.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlcovmakefile.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlicense.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genregistry.perl +0 -0
- data/ext/gecode-2.2.0/misc/genstatistics.perl +179 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/gentxtchangelog.perl +0 -0
- data/ext/gecode-2.2.0/misc/genvariables.perl +905 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/getrevision.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/makedepend.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/svn-ignore.txt +0 -0
- data/ext/gecode-2.2.0/test/assign.cc +181 -0
- data/ext/gecode-2.2.0/test/assign.hh +93 -0
- data/ext/gecode-2.2.0/test/assign/bool.cc +61 -0
- data/ext/gecode-2.2.0/test/assign/int.cc +70 -0
- data/ext/gecode-2.2.0/test/branch.cc +563 -0
- data/ext/gecode-2.2.0/test/branch.hh +144 -0
- data/ext/gecode-2.2.0/test/branch/bool.cc +61 -0
- data/ext/gecode-2.2.0/test/branch/cpltset.cc +71 -0
- data/ext/gecode-2.2.0/test/branch/int.cc +70 -0
- data/ext/gecode-2.2.0/test/branch/set.cc +74 -0
- data/ext/gecode-2.2.0/test/cpltset.cc +568 -0
- data/ext/gecode-2.2.0/test/cpltset.hh +125 -0
- data/ext/gecode-2.2.0/test/cpltset/atmost.cc +155 -0
- data/ext/gecode-2.2.0/test/cpltset/cardinality.cc +138 -0
- data/ext/gecode-2.2.0/test/cpltset/dom.cc +137 -0
- data/ext/gecode-2.2.0/test/cpltset/partition.cc +210 -0
- data/ext/gecode-2.2.0/test/cpltset/rel.cc +158 -0
- data/ext/gecode-2.2.0/test/cpltset/select.cc +216 -0
- data/ext/gecode-2.2.0/test/int.cc +688 -0
- data/ext/gecode-2.2.0/test/int.hh +267 -0
- data/ext/gecode-2.2.0/test/int.icc +266 -0
- data/ext/gecode-2.2.0/test/int/arithmetic.cc +766 -0
- data/ext/gecode-2.2.0/test/int/basic.cc +77 -0
- data/ext/gecode-2.2.0/test/int/bool.cc +340 -0
- data/ext/gecode-2.2.0/test/int/channel.cc +238 -0
- data/ext/gecode-2.2.0/test/int/circuit.cc +100 -0
- data/ext/gecode-2.2.0/test/int/count.cc +357 -0
- data/ext/gecode-2.2.0/test/int/distinct.cc +248 -0
- data/ext/gecode-2.2.0/test/int/dom.cc +123 -0
- data/ext/gecode-2.2.0/test/int/element.cc +333 -0
- data/ext/gecode-2.2.0/test/int/extensional.cc +475 -0
- data/ext/gecode-2.2.0/test/int/gcc.cc +293 -0
- data/ext/gecode-2.2.0/test/int/linear.cc +383 -0
- data/ext/gecode-2.2.0/test/int/mm-arithmetic.cc +302 -0
- data/ext/gecode-2.2.0/test/int/mm-bool.cc +4342 -0
- data/ext/gecode-2.2.0/test/int/mm-count.cc +295 -0
- data/ext/gecode-2.2.0/test/int/mm-lin.cc +2035 -0
- data/ext/gecode-2.2.0/test/int/mm-rel.cc +136 -0
- data/ext/gecode-2.2.0/test/int/rel.cc +416 -0
- data/ext/gecode-2.2.0/test/int/scheduling.cc +276 -0
- data/ext/gecode-2.2.0/test/int/sorted.cc +165 -0
- data/ext/gecode-2.2.0/test/int/unshare.cc +109 -0
- data/ext/gecode-2.2.0/test/search.cc +618 -0
- data/ext/gecode-2.2.0/test/set.cc +753 -0
- data/ext/gecode-2.2.0/test/set.hh +286 -0
- data/ext/gecode-2.2.0/test/set.icc +108 -0
- data/ext/gecode-2.2.0/test/set/convex.cc +139 -0
- data/ext/gecode-2.2.0/test/set/distinct.cc +116 -0
- data/ext/gecode-2.2.0/test/set/dom.cc +292 -0
- data/ext/gecode-2.2.0/test/set/int.cc +473 -0
- data/ext/gecode-2.2.0/test/set/projection.cc +436 -0
- data/ext/gecode-2.2.0/test/set/rel-op-const.cc +368 -0
- data/ext/gecode-2.2.0/test/set/rel-op.cc +465 -0
- data/ext/gecode-2.2.0/test/set/rel.cc +125 -0
- data/ext/gecode-2.2.0/test/set/select.cc +299 -0
- data/ext/gecode-2.2.0/test/set/sequence.cc +125 -0
- data/ext/gecode-2.2.0/test/test.cc +287 -0
- data/ext/gecode-2.2.0/test/test.hh +175 -0
- data/ext/gecode-2.2.0/test/test.icc +93 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/variables.vsl +0 -0
- data/lib/gecoder/bindings.rb +7 -5
- data/lib/gecoder/bindings/bindings.rb +8 -8
- data/lib/gecoder/interface.rb +4 -2
- data/lib/gecoder/interface/binding_changes.rb +1 -1
- data/lib/gecoder/interface/branch.rb +1 -1
- data/lib/gecoder/interface/constraints/bool_enum_constraints.rb +4 -4
- data/lib/gecoder/interface/constraints/bool_var_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/extensional_regexp.rb +1 -1
- data/lib/gecoder/interface/constraints/fixnum_enum_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/int_enum/extensional.rb +5 -5
- data/lib/gecoder/interface/constraints/int_enum_constraints.rb +4 -4
- data/lib/gecoder/interface/constraints/int_var_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/selected_set/select.rb +8 -8
- data/lib/gecoder/interface/constraints/set_enum/element.rb +79 -0
- data/lib/gecoder/interface/constraints/set_enum_constraints.rb +5 -5
- data/lib/gecoder/interface/constraints/set_var_constraints.rb +2 -2
- data/lib/gecoder/interface/convenience.rb +99 -0
- data/lib/gecoder/interface/enum_wrapper.rb +1 -1
- data/lib/gecoder/interface/mixin.rb +486 -0
- data/lib/gecoder/interface/search.rb +23 -22
- data/lib/gecoder/version.rb +1 -1
- data/specs/branch.rb +5 -3
- data/specs/constraints/bool/boolean.rb +3 -1
- data/specs/constraints/bool/linear.rb +3 -1
- data/specs/constraints/bool_enum/bool_enum_relation.rb +3 -1
- data/specs/constraints/bool_enum/channel.rb +3 -1
- data/specs/constraints/fixnum_enum/element.rb +3 -1
- data/specs/constraints/int/arithmetic.rb +3 -1
- data/specs/constraints/int/channel.rb +3 -1
- data/specs/constraints/int/linear.rb +3 -1
- data/specs/constraints/int/linear_properties.rb +3 -1
- data/specs/constraints/int_enum/arithmetic.rb +3 -1
- data/specs/constraints/int_enum/channel.rb +3 -1
- data/specs/constraints/int_enum/count.rb +3 -1
- data/specs/constraints/int_enum/distinct.rb +3 -1
- data/specs/constraints/int_enum/element.rb +3 -1
- data/specs/constraints/int_enum/sort.rb +3 -1
- data/specs/constraints/property_helper.rb +10 -10
- data/specs/constraints/reification_sugar.rb +3 -1
- data/specs/constraints/selected_set/select.rb +6 -5
- data/specs/constraints/selected_set/select_properties.rb +12 -10
- data/specs/constraints/set/channel.rb +3 -1
- data/specs/constraints/set/domain.rb +4 -4
- data/specs/constraints/set/relation.rb +4 -4
- data/specs/constraints/set_enum/channel.rb +3 -1
- data/specs/constraints/set_enum/distinct.rb +3 -1
- data/specs/constraints/set_enum/element.rb +77 -0
- data/specs/enum_wrapper.rb +1 -1
- data/specs/mixin.rb +78 -0
- data/specs/model.rb +5 -5
- data/specs/search.rb +20 -14
- data/specs/selected_set.rb +3 -3
- data/specs/set_elements.rb +2 -2
- data/tasks/distribution.rake +25 -4
- metadata +739 -602
- data/example/money.rb +0 -36
- data/ext/gecode-2.1.1/Makefile.dep +0 -7622
- data/ext/gecode-2.1.1/Makefile.in +0 -1568
- data/ext/gecode-2.1.1/changelog.in +0 -2459
- data/ext/gecode-2.1.1/configure +0 -11631
- data/ext/gecode-2.1.1/configure.ac +0 -249
- data/ext/gecode-2.1.1/configure.ac.in +0 -245
- data/ext/gecode-2.1.1/contribs/qecode/Doxyfile +0 -263
- data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.cc +0 -82
- data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.hh +0 -37
- data/ext/gecode-2.1.1/contribs/qecode/Makefile.in.in +0 -162
- data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.cc +0 -172
- data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.hh +0 -63
- data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.cc +0 -37
- data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.hh +0 -35
- data/ext/gecode-2.1.1/contribs/qecode/configure +0 -2264
- data/ext/gecode-2.1.1/contribs/qecode/configure.ac +0 -23
- data/ext/gecode-2.1.1/contribs/qecode/examples/COMPILING +0 -13
- data/ext/gecode-2.1.1/contribs/qecode/examples/MatrixGame.cpp +0 -144
- data/ext/gecode-2.1.1/contribs/qecode/examples/NimFibo.cpp +0 -73
- data/ext/gecode-2.1.1/contribs/qecode/examples/stress_test.cpp +0 -179
- data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.cc +0 -34
- data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.hh +0 -46
- data/ext/gecode-2.1.1/contribs/qecode/implicative.cc +0 -595
- data/ext/gecode-2.1.1/contribs/qecode/implicative.hh +0 -184
- data/ext/gecode-2.1.1/contribs/qecode/myspace.hh +0 -69
- data/ext/gecode-2.1.1/contribs/qecode/qecore.cc +0 -145
- data/ext/gecode-2.1.1/contribs/qecode/qecore.hh +0 -247
- data/ext/gecode-2.1.1/contribs/qecode/qsolver.cc +0 -168
- data/ext/gecode-2.1.1/contribs/qecode/qsolver.hh +0 -73
- data/ext/gecode-2.1.1/contribs/qecode/valueHeuristic.hh +0 -91
- data/ext/gecode-2.1.1/contribs/qecode/warner.cc +0 -101
- data/ext/gecode-2.1.1/contribs/qecode/warner.hh +0 -83
- data/ext/gecode-2.1.1/doxygen/doxygen.hh.in +0 -1111
- data/ext/gecode-2.1.1/doxygen/reflection.hh +0 -417
- data/ext/gecode-2.1.1/gecode.m4 +0 -956
- data/ext/gecode-2.1.1/gecode/cpltset.hh +0 -797
- data/ext/gecode-2.1.1/gecode/gist/analysiscursor.cc +0 -115
- data/ext/gecode-2.1.1/gecode/gist/analysiscursor.hh +0 -77
- data/ext/gecode-2.1.1/gecode/gist/drawingcursor.cc +0 -245
- data/ext/gecode-2.1.1/gecode/gist/drawingcursor.hh +0 -101
- data/ext/gecode-2.1.1/gecode/gist/gecodelogo.icc +0 -522
- data/ext/gecode-2.1.1/gecode/gist/mainwindow.cc +0 -254
- data/ext/gecode-2.1.1/gecode/gist/mainwindow.hh +0 -86
- data/ext/gecode-2.1.1/gecode/gist/node.cc +0 -100
- data/ext/gecode-2.1.1/gecode/gist/node.hh +0 -89
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.cc +0 -124
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.hh +0 -122
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.icc +0 -79
- data/ext/gecode-2.1.1/gecode/gist/postscript.cc +0 -543
- data/ext/gecode-2.1.1/gecode/gist/postscript.hh +0 -56
- data/ext/gecode-2.1.1/gecode/gist/preferences.cc +0 -110
- data/ext/gecode-2.1.1/gecode/gist/preferences.hh +0 -76
- data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.cc +0 -55
- data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.hh +0 -58
- data/ext/gecode-2.1.1/gecode/gist/shapelist.cc +0 -331
- data/ext/gecode-2.1.1/gecode/gist/shapelist.hh +0 -140
- data/ext/gecode-2.1.1/gecode/gist/spacenode.cc +0 -531
- data/ext/gecode-2.1.1/gecode/gist/spacenode.hh +0 -224
- data/ext/gecode-2.1.1/gecode/gist/textoutput.cc +0 -114
- data/ext/gecode-2.1.1/gecode/gist/treecanvas.cc +0 -1140
- data/ext/gecode-2.1.1/gecode/gist/treecanvas.hh +0 -324
- data/ext/gecode-2.1.1/gecode/gist/ui_addvisualisationdialog.hh +0 -163
- data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.cc +0 -175
- data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.hh +0 -71
- data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.cc +0 -219
- data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.hh +0 -73
- data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayitem.hh +0 -123
- data/ext/gecode-2.1.1/gecode/gist/visualnode.cc +0 -303
- data/ext/gecode-2.1.1/gecode/gist/visualnode.hh +0 -166
- data/ext/gecode-2.1.1/gecode/int.hh +0 -2035
- data/ext/gecode-2.1.1/gecode/int/arithmetic.cc +0 -136
- data/ext/gecode-2.1.1/gecode/int/arithmetic.hh +0 -440
- data/ext/gecode-2.1.1/gecode/int/arithmetic/abs.icc +0 -279
- data/ext/gecode-2.1.1/gecode/int/arithmetic/max.icc +0 -253
- data/ext/gecode-2.1.1/gecode/int/arithmetic/mult.icc +0 -522
- data/ext/gecode-2.1.1/gecode/int/arithmetic/sqr.icc +0 -218
- data/ext/gecode-2.1.1/gecode/int/arithmetic/sqrt.icc +0 -138
- data/ext/gecode-2.1.1/gecode/int/bool.cc +0 -642
- data/ext/gecode-2.1.1/gecode/int/bool/or.icc +0 -1000
- data/ext/gecode-2.1.1/gecode/int/branch.cc +0 -301
- data/ext/gecode-2.1.1/gecode/int/branch.hh +0 -576
- data/ext/gecode-2.1.1/gecode/int/branch/select-val.icc +0 -338
- data/ext/gecode-2.1.1/gecode/int/channel.cc +0 -114
- data/ext/gecode-2.1.1/gecode/int/channel.hh +0 -259
- data/ext/gecode-2.1.1/gecode/int/channel/dom.icc +0 -347
- data/ext/gecode-2.1.1/gecode/int/channel/val.icc +0 -276
- data/ext/gecode-2.1.1/gecode/int/circuit.hh +0 -175
- data/ext/gecode-2.1.1/gecode/int/circuit/base.icc +0 -271
- data/ext/gecode-2.1.1/gecode/int/circuit/val.icc +0 -122
- data/ext/gecode-2.1.1/gecode/int/count.hh +0 -487
- data/ext/gecode-2.1.1/gecode/int/count/int.icc +0 -619
- data/ext/gecode-2.1.1/gecode/int/count/rel.icc +0 -144
- data/ext/gecode-2.1.1/gecode/int/count/view.icc +0 -449
- data/ext/gecode-2.1.1/gecode/int/cumulatives.hh +0 -141
- data/ext/gecode-2.1.1/gecode/int/cumulatives/val.icc +0 -429
- data/ext/gecode-2.1.1/gecode/int/distinct.hh +0 -341
- data/ext/gecode-2.1.1/gecode/int/distinct/dom.icc +0 -750
- data/ext/gecode-2.1.1/gecode/int/distinct/ter-dom.icc +0 -136
- data/ext/gecode-2.1.1/gecode/int/element.hh +0 -239
- data/ext/gecode-2.1.1/gecode/int/element/int.icc +0 -441
- data/ext/gecode-2.1.1/gecode/int/element/view.icc +0 -584
- data/ext/gecode-2.1.1/gecode/int/exception.icc +0 -163
- data/ext/gecode-2.1.1/gecode/int/extensional.hh +0 -415
- data/ext/gecode-2.1.1/gecode/int/extensional/dfa.cc +0 -565
- data/ext/gecode-2.1.1/gecode/int/extensional/tuple-set.cc +0 -311
- data/ext/gecode-2.1.1/gecode/int/gcc.hh +0 -329
- data/ext/gecode-2.1.1/gecode/int/gcc/bnd.icc +0 -660
- data/ext/gecode-2.1.1/gecode/int/gcc/dom.icc +0 -531
- data/ext/gecode-2.1.1/gecode/int/gcc/val.icc +0 -400
- data/ext/gecode-2.1.1/gecode/int/int-set.cc +0 -153
- data/ext/gecode-2.1.1/gecode/int/int-set.icc +0 -191
- data/ext/gecode-2.1.1/gecode/int/linear-bool.cc +0 -220
- data/ext/gecode-2.1.1/gecode/int/linear-int.cc +0 -240
- data/ext/gecode-2.1.1/gecode/int/linear.hh +0 -1849
- data/ext/gecode-2.1.1/gecode/int/linear/bool-post.cc +0 -433
- data/ext/gecode-2.1.1/gecode/int/linear/int-bin.icc +0 -605
- data/ext/gecode-2.1.1/gecode/int/linear/int-dom.icc +0 -539
- data/ext/gecode-2.1.1/gecode/int/linear/int-post.cc +0 -493
- data/ext/gecode-2.1.1/gecode/int/rel.cc +0 -431
- data/ext/gecode-2.1.1/gecode/int/rel.hh +0 -657
- data/ext/gecode-2.1.1/gecode/int/rel/eq.icc +0 -848
- data/ext/gecode-2.1.1/gecode/int/rel/lex.icc +0 -248
- data/ext/gecode-2.1.1/gecode/int/rel/nq.icc +0 -269
- data/ext/gecode-2.1.1/gecode/int/sorted.cc +0 -91
- data/ext/gecode-2.1.1/gecode/int/sorted.hh +0 -117
- data/ext/gecode-2.1.1/gecode/int/sorted/matching.icc +0 -182
- data/ext/gecode-2.1.1/gecode/int/sorted/narrowing.icc +0 -257
- data/ext/gecode-2.1.1/gecode/int/sorted/order.icc +0 -208
- data/ext/gecode-2.1.1/gecode/int/sorted/propagate.icc +0 -669
- data/ext/gecode-2.1.1/gecode/int/sorted/sortsup.icc +0 -596
- data/ext/gecode-2.1.1/gecode/int/var-imp.icc +0 -745
- data/ext/gecode-2.1.1/gecode/int/var-imp/bool.cc +0 -104
- data/ext/gecode-2.1.1/gecode/int/var-imp/int.cc +0 -407
- data/ext/gecode-2.1.1/gecode/int/var/bool.icc +0 -126
- data/ext/gecode-2.1.1/gecode/int/var/int.icc +0 -151
- data/ext/gecode-2.1.1/gecode/int/view.icc +0 -1894
- data/ext/gecode-2.1.1/gecode/iter.hh +0 -90
- data/ext/gecode-2.1.1/gecode/iter/values-minus.icc +0 -130
- data/ext/gecode-2.1.1/gecode/kernel.hh +0 -182
- data/ext/gecode-2.1.1/gecode/kernel/branching.icc +0 -447
- data/ext/gecode-2.1.1/gecode/kernel/core.cc +0 -473
- data/ext/gecode-2.1.1/gecode/kernel/core.icc +0 -2295
- data/ext/gecode-2.1.1/gecode/kernel/memory-manager.icc +0 -458
- data/ext/gecode-2.1.1/gecode/kernel/reflection.cc +0 -921
- data/ext/gecode-2.1.1/gecode/kernel/reflection.icc +0 -1012
- data/ext/gecode-2.1.1/gecode/kernel/var-imp.icc +0 -433
- data/ext/gecode-2.1.1/gecode/kernel/var-map.cc +0 -269
- data/ext/gecode-2.1.1/gecode/kernel/var-map.icc +0 -227
- data/ext/gecode-2.1.1/gecode/kernel/var-traits.icc +0 -72
- data/ext/gecode-2.1.1/gecode/kernel/var-type.icc +0 -915
- data/ext/gecode-2.1.1/gecode/kernel/var.icc +0 -120
- data/ext/gecode-2.1.1/gecode/kernel/view.icc +0 -611
- data/ext/gecode-2.1.1/gecode/minimodel.hh +0 -1165
- data/ext/gecode-2.1.1/gecode/minimodel/arithmetic.cc +0 -179
- data/ext/gecode-2.1.1/gecode/search.hh +0 -752
- data/ext/gecode-2.1.1/gecode/search/reco-stack.icc +0 -237
- data/ext/gecode-2.1.1/gecode/serialization.hh +0 -149
- data/ext/gecode-2.1.1/gecode/serialization/boost.cc +0 -78
- data/ext/gecode-2.1.1/gecode/serialization/javascript.cc +0 -340
- data/ext/gecode-2.1.1/gecode/serialization/register.cc +0 -8142
- data/ext/gecode-2.1.1/gecode/set.hh +0 -970
- data/ext/gecode-2.1.1/gecode/set/projectors.hh +0 -438
- data/ext/gecode-2.1.1/gecode/set/projectors/formula.cc +0 -312
- data/ext/gecode-2.1.1/gecode/set/rel-op/common.icc +0 -557
- data/ext/gecode-2.1.1/gecode/set/rel-op/inter.icc +0 -409
- data/ext/gecode-2.1.1/gecode/set/rel/re-subset.icc +0 -172
- data/ext/gecode-2.1.1/gecode/set/select.cc +0 -135
- data/ext/gecode-2.1.1/gecode/set/select.hh +0 -233
- data/ext/gecode-2.1.1/gecode/set/select/disjoint.cc +0 -308
- data/ext/gecode-2.1.1/gecode/set/select/disjoint.icc +0 -75
- data/ext/gecode-2.1.1/gecode/set/select/idxarray.hh +0 -113
- data/ext/gecode-2.1.1/gecode/set/select/idxarray.icc +0 -155
- data/ext/gecode-2.1.1/gecode/set/select/inter.icc +0 -349
- data/ext/gecode-2.1.1/gecode/set/select/union.icc +0 -371
- data/ext/gecode-2.1.1/gecode/set/select/unionConst.icc +0 -334
- data/ext/gecode-2.1.1/gecode/set/var-imp/set.cc +0 -214
- data/ext/gecode-2.1.1/gecode/set/var/set.icc +0 -303
- data/ext/gecode-2.1.1/gecode/set/view.icc +0 -1503
- data/ext/gecode-2.1.1/gecode/set/view/complement.icc +0 -629
- data/ext/gecode-2.1.1/gecode/support/block-allocator.icc +0 -158
- data/ext/gecode-2.1.1/gecode/support/config.icc.in +0 -80
- data/ext/gecode-2.1.1/gecode/support/sentinel-stack.icc +0 -122
- data/ext/gecode-2.1.1/gecode/support/symbol.cc +0 -226
- data/ext/gecode-2.1.1/gecode/support/symbol.icc +0 -130
- data/ext/gecode-2.1.1/misc/gecode-gist.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-minimodel.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-search.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-serialization.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/genstatistics.perl +0 -178
- data/ext/gecode-2.1.1/misc/genvariables.perl +0 -905
- data/lib/gecoder/interface/constraints/set_enum/select.rb +0 -79
- data/lib/gecoder/interface/model.rb +0 -453
- data/lib/gecoder/interface/model_sugar.rb +0 -84
- data/specs/constraints/set_enum/select.rb +0 -73
@@ -1,1012 +0,0 @@
|
|
1
|
-
/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
|
2
|
-
/*
|
3
|
-
* Main authors:
|
4
|
-
* Guido Tack <tack@gecode.org>
|
5
|
-
*
|
6
|
-
* Copyright:
|
7
|
-
* Guido Tack, 2007
|
8
|
-
*
|
9
|
-
* Last modified:
|
10
|
-
* $Date: 2008-03-05 09:20:52 +0100 (Wed, 05 Mar 2008) $ by $Author: tack $
|
11
|
-
* $Revision: 6414 $
|
12
|
-
*
|
13
|
-
* This file is part of Gecode, the generic constraint
|
14
|
-
* development environment:
|
15
|
-
* http://www.gecode.org
|
16
|
-
*
|
17
|
-
* Permission is hereby granted, free of charge, to any person obtaining
|
18
|
-
* a copy of this software and associated documentation files (the
|
19
|
-
* "Software"), to deal in the Software without restriction, including
|
20
|
-
* without limitation the rights to use, copy, modify, merge, publish,
|
21
|
-
* distribute, sublicense, and/or sell copies of the Software, and to
|
22
|
-
* permit persons to whom the Software is furnished to do so, subject to
|
23
|
-
* the following conditions:
|
24
|
-
*
|
25
|
-
* The above copyright notice and this permission notice shall be
|
26
|
-
* included in all copies or substantial portions of the Software.
|
27
|
-
*
|
28
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
29
|
-
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
30
|
-
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
31
|
-
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
32
|
-
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
33
|
-
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
34
|
-
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
35
|
-
*
|
36
|
-
*/
|
37
|
-
|
38
|
-
#include <iostream>
|
39
|
-
#include <cstring>
|
40
|
-
|
41
|
-
/**
|
42
|
-
* \namespace Gecode::Reflection
|
43
|
-
* \brief %Reflection support
|
44
|
-
*/
|
45
|
-
|
46
|
-
namespace Gecode { namespace Reflection {
|
47
|
-
|
48
|
-
/** \addtogroup TaskReflection
|
49
|
-
* @{
|
50
|
-
*/
|
51
|
-
|
52
|
-
/// Exception for errors during reflection
|
53
|
-
class GECODE_VTABLE_EXPORT ReflectionException : public Exception {
|
54
|
-
public:
|
55
|
-
/// Constructor
|
56
|
-
ReflectionException(const char* what) : Exception("Reflection", what) {}
|
57
|
-
};
|
58
|
-
|
59
|
-
/// Exception: no reflection defined
|
60
|
-
class GECODE_VTABLE_EXPORT NoReflectionDefinedException
|
61
|
-
: public ReflectionException {
|
62
|
-
public:
|
63
|
-
NoReflectionDefinedException(void)
|
64
|
-
: ReflectionException("No reflection defined") {}
|
65
|
-
};
|
66
|
-
|
67
|
-
//@}
|
68
|
-
|
69
|
-
class ArrayArg;
|
70
|
-
class IntArrayArg;
|
71
|
-
|
72
|
-
/**
|
73
|
-
* \brief Arguments for actor and variable specifications
|
74
|
-
*
|
75
|
-
* These arguments implement a simple term language. A term is
|
76
|
-
* an integer, a variable, an array of terms, an array of integers,
|
77
|
-
* a string, a pair, a shared object, or a reference to a shared object.
|
78
|
-
*
|
79
|
-
* Variables are represented by integers that correspond to indices in a
|
80
|
-
* VarMap.
|
81
|
-
*
|
82
|
-
* \ingroup TaskReflection
|
83
|
-
*/
|
84
|
-
class GECODE_KERNEL_EXPORT Arg {
|
85
|
-
protected:
|
86
|
-
/// The different types of arguments
|
87
|
-
enum argtype {
|
88
|
-
INT_ARG, ///< Integer argument
|
89
|
-
VAR_ARG, ///< Variable argument
|
90
|
-
ARRAY_ARG, ///< Array argument
|
91
|
-
INT_ARRAY_ARG, ///< Integer array argument
|
92
|
-
STRING_ARG, ///< String argument
|
93
|
-
PAIR_ARG, ///< Pair argument
|
94
|
-
SHARED_OBJECT_ARG, ///< Shared object argument
|
95
|
-
SHARED_REF_ARG ///< Reference to shared object argument
|
96
|
-
};
|
97
|
-
|
98
|
-
/// Argument type of this Arg
|
99
|
-
argtype t;
|
100
|
-
|
101
|
-
union {
|
102
|
-
/// The integer of an INT_ARG, the index of a VAR_ARG or SHARED_REF_ARG, or the size of an ARRAY_ARG or INT_ARRAY_ARG
|
103
|
-
int i;
|
104
|
-
/// The string of a STRING_ARG
|
105
|
-
char* s;
|
106
|
-
/// The first argument of a PAIR_ARG, or the object of a SHARED_OBJECT_ARG
|
107
|
-
Arg* first;
|
108
|
-
} arg1;
|
109
|
-
|
110
|
-
union {
|
111
|
-
/// The second argument of a PAIR_ARG
|
112
|
-
Arg* second;
|
113
|
-
/// The array of an ARRAY_ARG
|
114
|
-
Arg** aa;
|
115
|
-
/// The array of an INT_ARRAY_ARG
|
116
|
-
int* ia;
|
117
|
-
} arg2;
|
118
|
-
/// Constructor
|
119
|
-
Arg(argtype t);
|
120
|
-
|
121
|
-
public:
|
122
|
-
/// %Test if this represents an integer
|
123
|
-
bool isInt(void) const;
|
124
|
-
/// Return the integer that this argument represents
|
125
|
-
int toInt(void) const;
|
126
|
-
/// Create new int argument
|
127
|
-
static Arg* newInt(int i);
|
128
|
-
/// Initialize this as an int argument
|
129
|
-
void initInt(int i);
|
130
|
-
|
131
|
-
/// %Test if this represents a variable
|
132
|
-
bool isVar(void) const;
|
133
|
-
/// Return the variable index that this argument represents
|
134
|
-
int toVar(void) const;
|
135
|
-
/// Create new variable argument
|
136
|
-
static Arg* newVar(int i);
|
137
|
-
/// Initialize this as a variable argument
|
138
|
-
void initVar(int i);
|
139
|
-
|
140
|
-
/// %Test if this represents an array
|
141
|
-
bool isArray(void) const;
|
142
|
-
/// Return the array that this argument represents
|
143
|
-
ArrayArg* toArray(void);
|
144
|
-
/// Return the array that this argument represents
|
145
|
-
const ArrayArg* toArray(void) const;
|
146
|
-
/// Create new array argument with size \a n
|
147
|
-
static ArrayArg* newArray(int n);
|
148
|
-
/// Initialize this as an array argument with size \a n
|
149
|
-
void initArray(int n);
|
150
|
-
|
151
|
-
/// %Test if this represents an array
|
152
|
-
bool isIntArray(void) const;
|
153
|
-
/// Return the array that this argument represents
|
154
|
-
IntArrayArg* toIntArray(void);
|
155
|
-
/// Return the array that this argument represents
|
156
|
-
const IntArrayArg* toIntArray(void) const;
|
157
|
-
/// Create new integer array argument with size \a n
|
158
|
-
static IntArrayArg* newIntArray(int n);
|
159
|
-
/// Create new integer array argument from array \a a
|
160
|
-
template <class A>
|
161
|
-
static IntArrayArg* newIntArray(const A& a);
|
162
|
-
/// Initialize this as an int array argument with size \a n
|
163
|
-
void initIntArray(int n);
|
164
|
-
|
165
|
-
/// %Test if this represents a string
|
166
|
-
bool isString(void) const;
|
167
|
-
/// Return the string that this argument represents
|
168
|
-
const char* toString(void) const;
|
169
|
-
/// Create new string argument
|
170
|
-
static Arg* newString(const char* s);
|
171
|
-
/// Initialize this as a string argument
|
172
|
-
void initString(const char* s);
|
173
|
-
|
174
|
-
/// %Test if this represents a pair
|
175
|
-
bool isPair(void) const;
|
176
|
-
/// Return the first component of the pair that this argument represents
|
177
|
-
Arg* first(void);
|
178
|
-
/// Return the first component of the pair that this argument represents
|
179
|
-
const Arg* first(void) const;
|
180
|
-
/// Return the second component of the pair that this argument represents
|
181
|
-
Arg* second(void);
|
182
|
-
/// Return the second component of the pair that this argument represents
|
183
|
-
const Arg* second(void) const;
|
184
|
-
/// Create new pair argument from \a a and \a b
|
185
|
-
static Arg* newPair(Arg* a, Arg* b);
|
186
|
-
/// Initialize this as a pair argument from \a a and \a b
|
187
|
-
void initPair(Arg* a, Arg* b);
|
188
|
-
|
189
|
-
/// %Test if this represents a shared object
|
190
|
-
bool isSharedObject(void) const;
|
191
|
-
/// Return the shared object that this argument represents
|
192
|
-
Arg* toSharedObject(void);
|
193
|
-
/// Return the shared object that this argument represents
|
194
|
-
const Arg* toSharedObject(void) const;
|
195
|
-
/// Create new shared object
|
196
|
-
static Arg* newSharedObject(Arg* a);
|
197
|
-
/// Initialize this as a shared object
|
198
|
-
void initSharedObject(Arg* a);
|
199
|
-
|
200
|
-
/// %Test if this represents a shared object reference
|
201
|
-
bool isSharedReference(void) const;
|
202
|
-
/// Return the shared object that this argument represents
|
203
|
-
int toSharedReference(void) const;
|
204
|
-
/// Create new reference to shared object
|
205
|
-
static Arg* newSharedReference(int ref);
|
206
|
-
/// Initialize this as a reference to a shared object
|
207
|
-
void initSharedReference(int ref);
|
208
|
-
|
209
|
-
/// Destructor
|
210
|
-
GECODE_MSC_VIRTUAL ~Arg(void);
|
211
|
-
};
|
212
|
-
|
213
|
-
|
214
|
-
/**
|
215
|
-
* \brief Array arguments
|
216
|
-
*
|
217
|
-
* This is a convenience class that exposes an array interface
|
218
|
-
* for an Arg that was created via Arg::newArray.
|
219
|
-
*
|
220
|
-
* \ingroup TaskReflection
|
221
|
-
*/
|
222
|
-
class GECODE_KERNEL_EXPORT ArrayArg : public Arg {
|
223
|
-
private:
|
224
|
-
/// Use Arg::newArray instead
|
225
|
-
ArrayArg(void);
|
226
|
-
public:
|
227
|
-
/// Element access
|
228
|
-
const Arg* operator[](int i) const;
|
229
|
-
/// Element access
|
230
|
-
Arg*& operator[](int i);
|
231
|
-
/// Size of the array
|
232
|
-
int size(void) const;
|
233
|
-
};
|
234
|
-
|
235
|
-
/**
|
236
|
-
* \brief Integer array arguments
|
237
|
-
*
|
238
|
-
* This is a convenience class that exposes an array interface
|
239
|
-
* for an Arg that was created via Arg::newIntArray.
|
240
|
-
*
|
241
|
-
* \ingroup TaskReflection
|
242
|
-
*/
|
243
|
-
class GECODE_KERNEL_EXPORT IntArrayArg : public Arg {
|
244
|
-
private:
|
245
|
-
/// Use Arg::newIntArray instead
|
246
|
-
IntArrayArg(void);
|
247
|
-
public:
|
248
|
-
/// Element access
|
249
|
-
const int& operator[](int i) const;
|
250
|
-
/// Element access
|
251
|
-
int& operator[](int i);
|
252
|
-
/// Size of the array
|
253
|
-
int size(void) const;
|
254
|
-
};
|
255
|
-
|
256
|
-
/**
|
257
|
-
* \brief Iterate over an IntArrayArg, interpreting consecutive
|
258
|
-
* pairs of integers as ranges
|
259
|
-
*
|
260
|
-
* \ingroup TaskReflection
|
261
|
-
*/
|
262
|
-
class GECODE_KERNEL_EXPORT IntArrayArgRanges {
|
263
|
-
private:
|
264
|
-
/// The array
|
265
|
-
Reflection::IntArrayArg* a;
|
266
|
-
/// The current position
|
267
|
-
int n;
|
268
|
-
public:
|
269
|
-
/// Constructor
|
270
|
-
IntArrayArgRanges(Reflection::IntArrayArg* a0);
|
271
|
-
/// %Test whether iterator is still at a valid range
|
272
|
-
bool operator()(void);
|
273
|
-
/// Move iterator to next range
|
274
|
-
void operator++(void);
|
275
|
-
/// Minimum of current range
|
276
|
-
int min(void) const;
|
277
|
-
/// Maximum of current range
|
278
|
-
int max(void) const;
|
279
|
-
/// Width of current range
|
280
|
-
unsigned int width(void) const;
|
281
|
-
};
|
282
|
-
|
283
|
-
/**
|
284
|
-
* \brief %Variable specification
|
285
|
-
*
|
286
|
-
* A VarSpec contains an abstract specification of a variable
|
287
|
-
* implementation. These specifications are typically stored in a VarMap.
|
288
|
-
*
|
289
|
-
* The type of the variable is represented as a Symbol and called vti
|
290
|
-
* (variable type identifier). In order to find out what type of variable a
|
291
|
-
* VarSpec corresponds to, you can compare the vti with VarImp::vti of a
|
292
|
-
* concrete variable type (e.g. IntVarImp::vti).
|
293
|
-
*
|
294
|
-
* The domain of a variable is represented as an Arg. The concrete encoding
|
295
|
-
* depends on the variable type.
|
296
|
-
*
|
297
|
-
* \ingroup TaskReflection
|
298
|
-
*/
|
299
|
-
class GECODE_KERNEL_EXPORT VarSpec {
|
300
|
-
private:
|
301
|
-
class Domain;
|
302
|
-
/// A representation of the domain of this variable
|
303
|
-
Domain* _dom;
|
304
|
-
public:
|
305
|
-
/// Construct empty VarSpec
|
306
|
-
VarSpec(void);
|
307
|
-
/// Construct specification for a variable
|
308
|
-
VarSpec(Support::Symbol vti, Arg* domain);
|
309
|
-
/// Copy constructor
|
310
|
-
VarSpec(const VarSpec& s);
|
311
|
-
/// Assignment operator
|
312
|
-
const VarSpec& operator=(const VarSpec& s);
|
313
|
-
/// Destructor
|
314
|
-
GECODE_MSC_VIRTUAL ~VarSpec(void);
|
315
|
-
/// Set the name for this variable
|
316
|
-
void name(const Support::Symbol& n0);
|
317
|
-
/// Get the name of this variable
|
318
|
-
Support::Symbol name(void) const;
|
319
|
-
/// Return if variable has a name
|
320
|
-
bool hasName(void) const;
|
321
|
-
/// Get the domain of this variable
|
322
|
-
Arg* dom(void) const;
|
323
|
-
// Get the variable type identifier for this variable
|
324
|
-
Support::Symbol vti(void) const;
|
325
|
-
};
|
326
|
-
|
327
|
-
/**
|
328
|
-
* \brief %Actor specification
|
329
|
-
*
|
330
|
-
* An ActorSpec contains all the information that characterizes an Actor.
|
331
|
-
* The specifications for all the actors in a Space object can be accessed
|
332
|
-
* using an ActorSpecIter.
|
333
|
-
*
|
334
|
-
* Each ActorSpec describes either a Branching or a Propagator
|
335
|
-
* (reflected by ActorSpec::isBranching). As a user of the Reflection API,
|
336
|
-
* you can access the information describing an Actor as an array of
|
337
|
-
* arguments, represented as objects of the Arg class.
|
338
|
-
*
|
339
|
-
* Every propagator and branching must be able to return a specification
|
340
|
-
* through the virtual function Actor::spec. If you use one of the
|
341
|
-
* convenience classes like BinaryPropagator, have a look at the
|
342
|
-
* implementation of AbsBnd::spec. If you subclass Propagator directly, or
|
343
|
-
* you have additional arguments that have to be put into the ActorSpec,
|
344
|
-
* please look at BinaryPropagator::spec.
|
345
|
-
*
|
346
|
-
* \ingroup TaskReflection
|
347
|
-
*/
|
348
|
-
class GECODE_KERNEL_EXPORT ActorSpec {
|
349
|
-
friend class BranchingSpec;
|
350
|
-
private:
|
351
|
-
class Arguments;
|
352
|
-
/// The arguments of this actor
|
353
|
-
Arguments* _args;
|
354
|
-
/// Resize argument array
|
355
|
-
void resize(void);
|
356
|
-
friend class ActorSpecIter;
|
357
|
-
/// Set the queue of the actor to \a q
|
358
|
-
void queue(int q);
|
359
|
-
/** \brief Return identifier of the branching
|
360
|
-
* Only valid if isBranching returns true
|
361
|
-
*/
|
362
|
-
unsigned int branchingId(void) const;
|
363
|
-
public:
|
364
|
-
/// Construct empty ActorSpec
|
365
|
-
ActorSpec(void);
|
366
|
-
/// Construct actor specification with \a name
|
367
|
-
ActorSpec(const Support::Symbol& name);
|
368
|
-
/// Copy constructor
|
369
|
-
ActorSpec(const ActorSpec& s);
|
370
|
-
/// Assignment operator
|
371
|
-
const ActorSpec& operator=(const ActorSpec& s);
|
372
|
-
/// Destructor
|
373
|
-
GECODE_MSC_VIRTUAL ~ActorSpec(void);
|
374
|
-
|
375
|
-
/// \name Actor information
|
376
|
-
//@{
|
377
|
-
/// Return actor type identifier
|
378
|
-
Support::Symbol ati(void) const;
|
379
|
-
/// Return number of arguments
|
380
|
-
int noOfArgs(void) const;
|
381
|
-
/// Check that the number of arguments is \a n, throw exception otherwise
|
382
|
-
void checkArity(int n) const;
|
383
|
-
/// Return argument \a i
|
384
|
-
Arg* operator[](int i) const;
|
385
|
-
|
386
|
-
/// Return whether the actor is a branching
|
387
|
-
bool isBranching(void) const;
|
388
|
-
/** \brief Return queue where the actor is currently scheduled
|
389
|
-
* Only valid if isBranching returns false
|
390
|
-
*/
|
391
|
-
int queue(void) const;
|
392
|
-
//@}
|
393
|
-
|
394
|
-
/// \name Populating the specification
|
395
|
-
//@{
|
396
|
-
/// Add \a arg to the specification (as last argument)
|
397
|
-
void add(Arg* arg);
|
398
|
-
//@}
|
399
|
-
};
|
400
|
-
|
401
|
-
}}
|
402
|
-
|
403
|
-
/** \brief Add \a a to specification
|
404
|
-
* \relates Gecode::Reflection::ActorSpec
|
405
|
-
*/
|
406
|
-
Gecode::Reflection::ActorSpec
|
407
|
-
operator<<(Gecode::Reflection::ActorSpec s, Gecode::Reflection::Arg* arg);
|
408
|
-
|
409
|
-
|
410
|
-
/** \brief Add \a i to specification
|
411
|
-
* \relates Gecode::Reflection::ActorSpec
|
412
|
-
*/
|
413
|
-
Gecode::Reflection::ActorSpec
|
414
|
-
operator<<(Gecode::Reflection::ActorSpec s, int i);
|
415
|
-
|
416
|
-
/** \brief Add \a i to specification
|
417
|
-
* \relates Gecode::Reflection::ActorSpec
|
418
|
-
*/
|
419
|
-
Gecode::Reflection::ActorSpec
|
420
|
-
operator<<(Gecode::Reflection::ActorSpec s, unsigned int i);
|
421
|
-
|
422
|
-
/** \brief Add \a d to specification, where \a d is cast into an integer
|
423
|
-
* \relates Gecode::Reflection::ActorSpec
|
424
|
-
*/
|
425
|
-
Gecode::Reflection::ActorSpec
|
426
|
-
operator<<(Gecode::Reflection::ActorSpec s, double i);
|
427
|
-
|
428
|
-
/* Implementation of ActorSpec operators */
|
429
|
-
|
430
|
-
forceinline Gecode::Reflection::ActorSpec
|
431
|
-
operator<<(Gecode::Reflection::ActorSpec s, Gecode::Reflection::Arg* arg) {
|
432
|
-
s.add(arg);
|
433
|
-
return s;
|
434
|
-
}
|
435
|
-
forceinline Gecode::Reflection::ActorSpec
|
436
|
-
operator<<(Gecode::Reflection::ActorSpec s, int i) {
|
437
|
-
return s << Gecode::Reflection::Arg::newInt(i);
|
438
|
-
}
|
439
|
-
forceinline Gecode::Reflection::ActorSpec
|
440
|
-
operator<<(Gecode::Reflection::ActorSpec s, unsigned int i) {
|
441
|
-
return s << Gecode::Reflection::Arg::newInt(static_cast<int>(i));
|
442
|
-
}
|
443
|
-
forceinline Gecode::Reflection::ActorSpec
|
444
|
-
operator<<(Gecode::Reflection::ActorSpec s, double i) {
|
445
|
-
return s << Gecode::Reflection::Arg::newInt(static_cast<int>(i));
|
446
|
-
}
|
447
|
-
|
448
|
-
namespace Gecode { namespace Reflection {
|
449
|
-
|
450
|
-
/**
|
451
|
-
* \brief %Branching specification
|
452
|
-
*
|
453
|
-
* A BranchingSpec contains information about the alternatives of a Space.
|
454
|
-
* It is similar to a BranchingDesc, but not opaque: you can query the
|
455
|
-
* information.
|
456
|
-
*
|
457
|
-
* The specification for an alternative is an ArrayArg that may contain
|
458
|
-
* strings and references to variables. The concatenation of the strings
|
459
|
-
* and variables is a human-readable description of what constraints are
|
460
|
-
* posted for the given alternative.
|
461
|
-
*
|
462
|
-
* \ingroup TaskReflection
|
463
|
-
*/
|
464
|
-
class GECODE_KERNEL_EXPORT BranchingSpec {
|
465
|
-
private:
|
466
|
-
class Arguments;
|
467
|
-
/// The arguments of this branching
|
468
|
-
Arguments* _args;
|
469
|
-
public:
|
470
|
-
/// Default constructor
|
471
|
-
BranchingSpec(void);
|
472
|
-
/** \brief Construct spec for branching description \a d
|
473
|
-
*
|
474
|
-
* This constructor is used by a Branching to create a BranchingSpec.
|
475
|
-
* As a user of the reflection API, you have to query use the function
|
476
|
-
* Gecode::Space::branchingSpec instead.
|
477
|
-
*
|
478
|
-
*/
|
479
|
-
BranchingSpec(const BranchingDesc* d);
|
480
|
-
/// Copy constructor
|
481
|
-
BranchingSpec(const BranchingSpec& s);
|
482
|
-
/// Assignment operator
|
483
|
-
const BranchingSpec& operator=(const BranchingSpec& s);
|
484
|
-
/// Destructor
|
485
|
-
GECODE_MSC_VIRTUAL ~BranchingSpec(void);
|
486
|
-
|
487
|
-
///\name Branching information
|
488
|
-
//@{
|
489
|
-
/// Check if specification was created by \a b
|
490
|
-
bool createdBy(const ActorSpec& b) const;
|
491
|
-
/// Return number of alternatives
|
492
|
-
unsigned int alternatives(void) const;
|
493
|
-
/// Return specification of alternative \a i
|
494
|
-
Arg* operator[](int i) const;
|
495
|
-
|
496
|
-
/// Return specification of alternative \a i
|
497
|
-
Arg*& operator[](int i);
|
498
|
-
//@}
|
499
|
-
};
|
500
|
-
|
501
|
-
class VarMap;
|
502
|
-
|
503
|
-
/**
|
504
|
-
* \brief Iterating actor specifications
|
505
|
-
*
|
506
|
-
* Use this iterator to access specifications of all actors (propagators
|
507
|
-
* and branchings) of a space. The iterator also provides access to the
|
508
|
-
* corresponding variable map.
|
509
|
-
*
|
510
|
-
* \ingroup TaskReflection
|
511
|
-
*/
|
512
|
-
class GECODE_KERNEL_EXPORT ActorSpecIter {
|
513
|
-
private:
|
514
|
-
/// The variable map used by this iterator
|
515
|
-
VarMap* m;
|
516
|
-
/// The space for which to iterate the actors
|
517
|
-
const Space* s;
|
518
|
-
/// The queue to iterate
|
519
|
-
const ActorLink *active;
|
520
|
-
/// The current actor
|
521
|
-
const ActorLink *cur;
|
522
|
-
/// Whether the current actor is a branching
|
523
|
-
bool isBranching;
|
524
|
-
public:
|
525
|
-
/// Constructor
|
526
|
-
ActorSpecIter(const Space*, VarMap&);
|
527
|
-
/// %Test whether iterator still has actor specifications or is done
|
528
|
-
bool operator()(void) const;
|
529
|
-
/// Move iterator to next actor
|
530
|
-
void operator++(void);
|
531
|
-
/// Return actor specification for current iterator position
|
532
|
-
ActorSpec actor(void) const;
|
533
|
-
};
|
534
|
-
|
535
|
-
/**
|
536
|
-
* \brief Registry of constraint posting and variable creation functions
|
537
|
-
* \ingroup TaskReflection
|
538
|
-
*/
|
539
|
-
class Registry {
|
540
|
-
private:
|
541
|
-
class RegistryObject;
|
542
|
-
RegistryObject* ro;
|
543
|
-
public:
|
544
|
-
/// The type of constraint posting functions
|
545
|
-
typedef void (*poster) (Space*, VarMap&, const ActorSpec&);
|
546
|
-
/// The type of variable creation functions
|
547
|
-
typedef VarImpBase* (*varCreator) (Space*, VarSpec&);
|
548
|
-
/// The type of variable domain constraint functions
|
549
|
-
typedef void (*varConstrainer) (Space*, VarImpBase*, VarSpec&);
|
550
|
-
/// The type of variable update functions
|
551
|
-
typedef VarImpBase* (*varUpdater) (Space*, bool, VarImpBase*);
|
552
|
-
/// The type of variable printing functions
|
553
|
-
typedef std::ostream& (*varPrinter) (std::ostream&, VarImpBase*);
|
554
|
-
/// The type of variable reflection functions
|
555
|
-
typedef Arg* (*varSpec) (const Space* home, VarMap& m, VarImpBase*);
|
556
|
-
|
557
|
-
/// Constructor
|
558
|
-
GECODE_KERNEL_EXPORT Registry(void);
|
559
|
-
/// Destructor
|
560
|
-
GECODE_KERNEL_EXPORT GECODE_MSC_VIRTUAL ~Registry(void);
|
561
|
-
|
562
|
-
/// Create a new variable in \a home from \a spec and return it
|
563
|
-
GECODE_KERNEL_EXPORT VarImpBase*
|
564
|
-
createVar(Space* home, VarSpec& spec) const;
|
565
|
-
|
566
|
-
/// Constrain \a v to \a spec
|
567
|
-
GECODE_KERNEL_EXPORT void
|
568
|
-
constrainVar(Space* home, VarImpBase* v, VarSpec& spec) const;
|
569
|
-
|
570
|
-
/// Update variable \a v with type identifier \a vti during cloning
|
571
|
-
GECODE_KERNEL_EXPORT VarImpBase*
|
572
|
-
updateVariable(Space* home, bool share, VarImpBase* v,
|
573
|
-
const Support::Symbol& vti) const;
|
574
|
-
|
575
|
-
/// Print variable \a v with type identifier \a vti to \a os
|
576
|
-
GECODE_KERNEL_EXPORT std::ostream&
|
577
|
-
printVariable(std::ostream& os, VarImpBase* v,
|
578
|
-
const Support::Symbol& vti) const;
|
579
|
-
|
580
|
-
/// Reflection for variable \a v with type identifier \a vti
|
581
|
-
GECODE_KERNEL_EXPORT Arg*
|
582
|
-
spec(const Space* home, VarMap& vm,
|
583
|
-
VarImpBase* v, const Support::Symbol& vti) const;
|
584
|
-
|
585
|
-
/// Post constraint in \a home for \a spec using variables \a vars
|
586
|
-
GECODE_KERNEL_EXPORT void
|
587
|
-
post(Space* home, VarMap& vm, const ActorSpec& spec) const;
|
588
|
-
|
589
|
-
/// Register variable creation function for \a vti
|
590
|
-
GECODE_KERNEL_EXPORT void add(Support::Symbol vti, varCreator vc);
|
591
|
-
/// Register variable domain constraining function for \a vti
|
592
|
-
GECODE_KERNEL_EXPORT void add(Support::Symbol vti, varConstrainer vc);
|
593
|
-
/// Register variable update function for \a vti
|
594
|
-
GECODE_KERNEL_EXPORT void add(Support::Symbol vti, varUpdater vu);
|
595
|
-
/// Register variable print function for \a vti
|
596
|
-
GECODE_KERNEL_EXPORT void add(Support::Symbol vti, varPrinter vp);
|
597
|
-
/// Register variable reflection function for \a vti
|
598
|
-
GECODE_KERNEL_EXPORT void add(Support::Symbol vti, varSpec vp);
|
599
|
-
/// Register constraint posting function for actor type identifier \a ati
|
600
|
-
GECODE_KERNEL_EXPORT void add(const Support::Symbol& ati, poster p);
|
601
|
-
/// Print list of all registered posters to \a out
|
602
|
-
GECODE_KERNEL_EXPORT void print(std::ostream& out);
|
603
|
-
private:
|
604
|
-
/// Do not allow copying
|
605
|
-
Registry(const Registry&);
|
606
|
-
/// Do not allow assignment
|
607
|
-
Registry& operator=(const Registry&);
|
608
|
-
};
|
609
|
-
|
610
|
-
/// The registry object \ingroup TaskReflection
|
611
|
-
GECODE_KERNEL_EXPORT Registry& registry(void);
|
612
|
-
|
613
|
-
/** \brief Class used for registering actors
|
614
|
-
*
|
615
|
-
* \ingroup TaskReflection
|
616
|
-
*
|
617
|
-
* The registered Actor class \a P has to provide two functions:
|
618
|
-
* - static Support::Symbol ati(void)
|
619
|
-
* - static void post(Space*, const VarMap&, const ActorSpec&)
|
620
|
-
*/
|
621
|
-
template <class P>
|
622
|
-
class ActorRegistrar {
|
623
|
-
public:
|
624
|
-
/// Default constructor
|
625
|
-
ActorRegistrar(void);
|
626
|
-
};
|
627
|
-
|
628
|
-
template <class P>
|
629
|
-
ActorRegistrar<P>::ActorRegistrar(void) {
|
630
|
-
registry().add(P::ati(), &P::post);
|
631
|
-
}
|
632
|
-
|
633
|
-
/** \brief Class used for registering variable implementations
|
634
|
-
*
|
635
|
-
* \ingroup TaskReflection
|
636
|
-
*
|
637
|
-
* The registered variable implementation class \a V has to
|
638
|
-
* provide two functions:
|
639
|
-
* - static void create(Space*, Reflection::VarSpec&)
|
640
|
-
* - static void contrain(Space*, VarImpBase*, Reflection::VarSpec&)
|
641
|
-
*/
|
642
|
-
template <class V>
|
643
|
-
class VarImpRegistrar {
|
644
|
-
private:
|
645
|
-
static VarImpBase* updateVar(Space* home, bool share, VarImpBase* v);
|
646
|
-
static std::ostream& printVar(std::ostream& os, VarImpBase* v);
|
647
|
-
static Reflection::Arg* spec(const Space* home, Reflection::VarMap& m,
|
648
|
-
VarImpBase* v);
|
649
|
-
public:
|
650
|
-
/// Default constructor
|
651
|
-
VarImpRegistrar(void);
|
652
|
-
};
|
653
|
-
|
654
|
-
template <class V>
|
655
|
-
VarImpBase*
|
656
|
-
VarImpRegistrar<V>::updateVar(Space* home, bool share, VarImpBase* v) {
|
657
|
-
typedef typename VarImpVarTraits<V>::Var Var;
|
658
|
-
typedef typename VarViewTraits<Var>::View View;
|
659
|
-
View view(static_cast<V*>(v));
|
660
|
-
Var var(view);
|
661
|
-
Var varCopy;
|
662
|
-
varCopy.update(home, share, var);
|
663
|
-
View viewCopy(varCopy);
|
664
|
-
return viewCopy.var();
|
665
|
-
}
|
666
|
-
|
667
|
-
template <class V>
|
668
|
-
std::ostream&
|
669
|
-
VarImpRegistrar<V>::printVar(std::ostream& os, VarImpBase* v) {
|
670
|
-
typedef typename VarImpVarTraits<V>::Var Var;
|
671
|
-
typedef typename VarViewTraits<Var>::View View;
|
672
|
-
View view(static_cast<V*>(v));
|
673
|
-
Var var(view);
|
674
|
-
return os << var;
|
675
|
-
}
|
676
|
-
|
677
|
-
template <class V>
|
678
|
-
Reflection::Arg*
|
679
|
-
VarImpRegistrar<V>::spec(const Space* home, Reflection::VarMap& m,
|
680
|
-
VarImpBase* v) {
|
681
|
-
typedef typename VarImpVarTraits<V>::Var Var;
|
682
|
-
typedef typename VarViewTraits<Var>::View View;
|
683
|
-
View view(static_cast<V*>(v));
|
684
|
-
return view.spec(home, m);
|
685
|
-
}
|
686
|
-
|
687
|
-
template <class V>
|
688
|
-
VarImpRegistrar<V>::VarImpRegistrar(void) {
|
689
|
-
registry().add(V::vti, &V::create);
|
690
|
-
registry().add(V::vti, &V::constrain);
|
691
|
-
registry().add(V::vti, &VarImpRegistrar<V>::updateVar);
|
692
|
-
registry().add(V::vti, &VarImpRegistrar<V>::printVar);
|
693
|
-
registry().add(V::vti, &VarImpRegistrar<V>::spec);
|
694
|
-
}
|
695
|
-
|
696
|
-
/**
|
697
|
-
* \brief Generic variables
|
698
|
-
*
|
699
|
-
* \ingroup TaskReflection
|
700
|
-
*
|
701
|
-
* A generic variable can represent any Gecode variable. It can be
|
702
|
-
* used in VarArrays, and it supports generic update during cloning.
|
703
|
-
*
|
704
|
-
*/
|
705
|
-
class Var {
|
706
|
-
private:
|
707
|
-
/// The actual variable
|
708
|
-
VarImpBase* _var;
|
709
|
-
/// The variable type identifier
|
710
|
-
Support::Symbol _vti;
|
711
|
-
public:
|
712
|
-
/// Default constructor
|
713
|
-
Var(void);
|
714
|
-
/// Construct from \a v
|
715
|
-
template <class V> explicit Var(const V& v);
|
716
|
-
/// Construct from \a var with variable type identifier \a vti
|
717
|
-
Var(VarImpBase* var, const Support::Symbol& vti);
|
718
|
-
/// Update during cloning
|
719
|
-
GECODE_KERNEL_EXPORT void update(Space* home, bool share, Var& v);
|
720
|
-
/// Output to \a os
|
721
|
-
GECODE_KERNEL_EXPORT std::ostream& print(std::ostream& os) const;
|
722
|
-
/// Reflection
|
723
|
-
GECODE_KERNEL_EXPORT Arg* spec(const Space* home, VarMap& vm) const;
|
724
|
-
/// Cast to concrete variable type
|
725
|
-
template <class VarImp>
|
726
|
-
VarImp* var(void) const;
|
727
|
-
};
|
728
|
-
|
729
|
-
/**
|
730
|
-
* \brief Unreflection from VarSpec and ActorSpec
|
731
|
-
* \ingroup TaskReflection
|
732
|
-
*
|
733
|
-
* An Unreflector allows you to install variables and propagators in a
|
734
|
-
* Space using variable and actor specifications.
|
735
|
-
*
|
736
|
-
*/
|
737
|
-
class GECODE_KERNEL_EXPORT Unreflector {
|
738
|
-
private:
|
739
|
-
/// The space in which to create variables and post constraints
|
740
|
-
Space* home;
|
741
|
-
/// The VarMap that indicates which variables to reuse
|
742
|
-
Reflection::VarMap& m;
|
743
|
-
|
744
|
-
public:
|
745
|
-
/// Constructor
|
746
|
-
Unreflector(Space* home0, Reflection::VarMap& m0);
|
747
|
-
|
748
|
-
/// Destructor
|
749
|
-
GECODE_MSC_VIRTUAL ~Unreflector(void);
|
750
|
-
|
751
|
-
/// Return the VarMap
|
752
|
-
Reflection::VarMap& varMap(void) const;
|
753
|
-
|
754
|
-
/// Create a new variable from \a spec
|
755
|
-
void var(Reflection::VarSpec& spec);
|
756
|
-
|
757
|
-
/// Post the constraint defined by \a spec
|
758
|
-
void post(Reflection::ActorSpec& spec);
|
759
|
-
};
|
760
|
-
|
761
|
-
forceinline
|
762
|
-
Var::Var(void) {}
|
763
|
-
|
764
|
-
template <class V>
|
765
|
-
Var::Var(const V& v) {
|
766
|
-
typedef typename VarViewTraits<V>::View View;
|
767
|
-
View view(v);
|
768
|
-
_var = view.var();
|
769
|
-
_vti = view.var()->vti;
|
770
|
-
}
|
771
|
-
|
772
|
-
template <>
|
773
|
-
inline
|
774
|
-
Var::Var(const Var& v) : _var(v._var), _vti(v._vti) {}
|
775
|
-
|
776
|
-
inline
|
777
|
-
Var::Var(VarImpBase* var, const Support::Symbol& vti)
|
778
|
-
: _var(var), _vti(vti) {}
|
779
|
-
|
780
|
-
template <>
|
781
|
-
inline VarImpBase*
|
782
|
-
Var::var(void) const {
|
783
|
-
return static_cast<VarImpBase*>(_var);
|
784
|
-
}
|
785
|
-
|
786
|
-
template <class VarImp>
|
787
|
-
VarImp*
|
788
|
-
Var::var(void) const {
|
789
|
-
if (! (VarImp::vti == _vti))
|
790
|
-
throw ReflectionException("VTI mismatch");
|
791
|
-
return static_cast<VarImp*>(_var);
|
792
|
-
}
|
793
|
-
|
794
|
-
/** \addtogroup TaskReflection
|
795
|
-
* @{
|
796
|
-
*/
|
797
|
-
|
798
|
-
/// Register a propagator with zero or one template argument
|
799
|
-
#define GECODE_REGISTER1(P) \
|
800
|
-
::Gecode::Reflection::ActorRegistrar< P > GECODE_FRESH(r);
|
801
|
-
/// Register a propagator with two template arguments
|
802
|
-
#define GECODE_REGISTER2(P1,P2) \
|
803
|
-
::Gecode::Reflection::ActorRegistrar< P1,P2 > GECODE_FRESH(r);
|
804
|
-
/// Register a propagator with three template arguments
|
805
|
-
#define GECODE_REGISTER3(P1,P2,P3) \
|
806
|
-
::Gecode::Reflection::ActorRegistrar< P1,P2,P3 > GECODE_FRESH(r);
|
807
|
-
/// Register a propagator with four template arguments
|
808
|
-
#define GECODE_REGISTER4(P1,P2,P3,P4) \
|
809
|
-
::Gecode::Reflection::ActorRegistrar< P1,P2,P3,P4 > GECODE_FRESH(r);
|
810
|
-
/// Register a propagator with five template arguments
|
811
|
-
#define GECODE_REGISTER5(P1,P2,P3,P4,P5) \
|
812
|
-
::Gecode::Reflection::ActorRegistrar< P1,P2,P3,P4,P5 > GECODE_FRESH(r);
|
813
|
-
/// Register a propagator with six template arguments
|
814
|
-
#define GECODE_REGISTER6(P1,P2,P3,P4,P5,P6) \
|
815
|
-
::Gecode::Reflection::ActorRegistrar< P1,P2,P3,P4,P5,P6 > GECODE_FRESH(r);
|
816
|
-
|
817
|
-
//@}
|
818
|
-
|
819
|
-
/**************************************
|
820
|
-
* Implementations
|
821
|
-
**************************************/
|
822
|
-
|
823
|
-
template <class A>
|
824
|
-
IntArrayArg*
|
825
|
-
Arg::newIntArray(const A& a) {
|
826
|
-
IntArrayArg* ret = Arg::newIntArray(a.size());
|
827
|
-
for (int i=a.size(); i--;)
|
828
|
-
(*ret)[i] = a[i];
|
829
|
-
return ret;
|
830
|
-
}
|
831
|
-
|
832
|
-
/** \addtogroup TaskReflection
|
833
|
-
* @{
|
834
|
-
*/
|
835
|
-
|
836
|
-
/** \brief String representation for View types, used for name mangling
|
837
|
-
*/
|
838
|
-
template <class View>
|
839
|
-
class TypeOf {
|
840
|
-
public:
|
841
|
-
/// Return string representation
|
842
|
-
static Support::Symbol t(void) { return View::type(); }
|
843
|
-
};
|
844
|
-
|
845
|
-
/** \brief String representation for bool, used for name mangling
|
846
|
-
*/
|
847
|
-
template <>
|
848
|
-
class TypeOf<bool> {
|
849
|
-
public:
|
850
|
-
/// Return string representation
|
851
|
-
static Support::Symbol t(void) { return Support::Symbol("bool"); }
|
852
|
-
};
|
853
|
-
|
854
|
-
/** \brief String representation for ints, used for name mangling
|
855
|
-
*/
|
856
|
-
template <>
|
857
|
-
class TypeOf<int> {
|
858
|
-
public:
|
859
|
-
/// Return string representation
|
860
|
-
static Support::Symbol t(void) { return Support::Symbol("int"); }
|
861
|
-
};
|
862
|
-
|
863
|
-
/** \brief String representation for doubles, used for name mangling
|
864
|
-
*/
|
865
|
-
template <>
|
866
|
-
class TypeOf<double> {
|
867
|
-
public:
|
868
|
-
/// Return string representation
|
869
|
-
static Support::Symbol t(void) { return Support::Symbol("double"); }
|
870
|
-
};
|
871
|
-
|
872
|
-
//@}
|
873
|
-
|
874
|
-
}
|
875
|
-
class IntSet;
|
876
|
-
namespace Reflection {
|
877
|
-
|
878
|
-
/** \addtogroup TaskReflection
|
879
|
-
* @{
|
880
|
-
*/
|
881
|
-
|
882
|
-
/** \brief String representation for IntSets, used for name mangling
|
883
|
-
*/
|
884
|
-
template <>
|
885
|
-
class TypeOf<const IntSet> {
|
886
|
-
public:
|
887
|
-
/// Return string representation
|
888
|
-
static Support::Symbol t(void) { return Support::Symbol("IntSet"); }
|
889
|
-
};
|
890
|
-
|
891
|
-
/// Mangle ati with type information
|
892
|
-
template <class View0>
|
893
|
-
Support::Symbol
|
894
|
-
mangle(const Support::Symbol& ati) {
|
895
|
-
Support::Symbol mangled = ati.copy();
|
896
|
-
mangled += "<";
|
897
|
-
mangled += TypeOf<View0>::t();
|
898
|
-
mangled += ">";
|
899
|
-
return mangled;
|
900
|
-
}
|
901
|
-
/// Mangle ati with type information
|
902
|
-
template <class View0, bool b>
|
903
|
-
Support::Symbol
|
904
|
-
mangle(const Support::Symbol& ati) {
|
905
|
-
Support::Symbol mangled = ati.copy();
|
906
|
-
mangled += "<";
|
907
|
-
mangled += TypeOf<View0>::t();
|
908
|
-
mangled += ",";
|
909
|
-
mangled += (b ? "true" : "false");
|
910
|
-
mangled += ">";
|
911
|
-
return mangled;
|
912
|
-
}
|
913
|
-
/// Mangle ati with type information
|
914
|
-
template <class View0, class View1>
|
915
|
-
Support::Symbol
|
916
|
-
mangle(const Support::Symbol& ati) {
|
917
|
-
Support::Symbol mangled = ati.copy();
|
918
|
-
mangled += "<";
|
919
|
-
mangled += TypeOf<View0>::t();
|
920
|
-
mangled += ",";
|
921
|
-
mangled += TypeOf<View1>::t();
|
922
|
-
mangled += ">";
|
923
|
-
return mangled;
|
924
|
-
}
|
925
|
-
/// Mangle ati with type information
|
926
|
-
template <class View0, class View1, bool b>
|
927
|
-
Support::Symbol
|
928
|
-
mangle(const Support::Symbol& ati) {
|
929
|
-
Support::Symbol mangled = ati.copy();
|
930
|
-
mangled += "<";
|
931
|
-
mangled += TypeOf<View0>::t();
|
932
|
-
mangled += ",";
|
933
|
-
mangled += TypeOf<View1>::t();
|
934
|
-
mangled += ",";
|
935
|
-
mangled += (b ? "true" : "false");
|
936
|
-
mangled += ">";
|
937
|
-
return mangled;
|
938
|
-
}
|
939
|
-
/// Mangle ati with type information
|
940
|
-
template <class View0, class View1, class View2>
|
941
|
-
Support::Symbol
|
942
|
-
mangle(const Support::Symbol& ati) {
|
943
|
-
Support::Symbol mangled = ati.copy();
|
944
|
-
mangled += "<";
|
945
|
-
mangled += TypeOf<View0>::t();
|
946
|
-
mangled += ",";
|
947
|
-
mangled += TypeOf<View1>::t();
|
948
|
-
mangled += ",";
|
949
|
-
mangled += TypeOf<View2>::t();
|
950
|
-
mangled += ">";
|
951
|
-
return mangled;
|
952
|
-
}
|
953
|
-
/// Mangle ati with type information
|
954
|
-
template <class View0, class View1, class View2, bool b>
|
955
|
-
Support::Symbol
|
956
|
-
mangle(const Support::Symbol& ati) {
|
957
|
-
Support::Symbol mangled = ati.copy();
|
958
|
-
mangled += "<";
|
959
|
-
mangled += TypeOf<View0>::t();
|
960
|
-
mangled += ",";
|
961
|
-
mangled += TypeOf<View1>::t();
|
962
|
-
mangled += ",";
|
963
|
-
mangled += TypeOf<View2>::t();
|
964
|
-
mangled += ",";
|
965
|
-
mangled += (b ? "true" : "false");
|
966
|
-
mangled += ">";
|
967
|
-
return mangled;
|
968
|
-
}
|
969
|
-
/// Mangle ati with type information
|
970
|
-
template <class View0, class View1, class View2, class View3>
|
971
|
-
Support::Symbol
|
972
|
-
mangle(const Support::Symbol& ati) {
|
973
|
-
Support::Symbol mangled = ati.copy();
|
974
|
-
mangled += "<";
|
975
|
-
mangled += TypeOf<View0>::t();
|
976
|
-
mangled += ",";
|
977
|
-
mangled += TypeOf<View1>::t();
|
978
|
-
mangled += ",";
|
979
|
-
mangled += TypeOf<View2>::t();
|
980
|
-
mangled += ",";
|
981
|
-
mangled += TypeOf<View3>::t();
|
982
|
-
mangled += ">";
|
983
|
-
return mangled;
|
984
|
-
}
|
985
|
-
/// Mangle ati with type information
|
986
|
-
template <class View0, class View1, class View2, class View3, bool b>
|
987
|
-
Support::Symbol
|
988
|
-
mangle(const Support::Symbol& ati) {
|
989
|
-
Support::Symbol mangled = ati.copy();
|
990
|
-
mangled += "<";
|
991
|
-
mangled += TypeOf<View0>::t();
|
992
|
-
mangled += ",";
|
993
|
-
mangled += TypeOf<View1>::t();
|
994
|
-
mangled += ",";
|
995
|
-
mangled += TypeOf<View2>::t();
|
996
|
-
mangled += ",";
|
997
|
-
mangled += TypeOf<View3>::t();
|
998
|
-
mangled += ",";
|
999
|
-
mangled += (b ? "true" : "false");
|
1000
|
-
mangled += ">";
|
1001
|
-
return mangled;
|
1002
|
-
}
|
1003
|
-
|
1004
|
-
//@}
|
1005
|
-
|
1006
|
-
}}
|
1007
|
-
|
1008
|
-
/// Print \a v to \a os
|
1009
|
-
GECODE_KERNEL_EXPORT std::ostream&
|
1010
|
-
operator<<(std::ostream& os, const Gecode::Reflection::Var& v);
|
1011
|
-
|
1012
|
-
// STATISTICS: kernel-other
|