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.
Files changed (919) hide show
  1. data/CHANGES +6 -0
  2. data/README +1 -1
  3. data/THANKS +18 -0
  4. data/example/equation_system.rb +3 -1
  5. data/example/magic_sequence.rb +3 -1
  6. data/example/queens.rb +3 -1
  7. data/example/send_more_money.rb +24 -30
  8. data/example/send_most_money.rb +15 -26
  9. data/example/square_tiling.rb +3 -1
  10. data/example/sudoku-set.rb +3 -1
  11. data/ext/{gecode-2.1.1 → gecode-2.2.0}/LICENSE +0 -0
  12. data/ext/{gecode-2.1.1 → gecode-2.2.0}/Makefile.contribs +0 -0
  13. data/ext/gecode-2.2.0/Makefile.dep +8056 -0
  14. data/ext/gecode-2.2.0/Makefile.in +1590 -0
  15. data/ext/gecode-2.2.0/changelog.in +2698 -0
  16. data/ext/gecode-2.2.0/configure +13112 -0
  17. data/ext/gecode-2.2.0/configure.ac +273 -0
  18. data/ext/gecode-2.2.0/configure.ac.in +269 -0
  19. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/README +0 -0
  20. data/ext/gecode-2.2.0/contribs/qecode/Doxyfile +263 -0
  21. data/ext/gecode-2.2.0/contribs/qecode/Implicative.cc +267 -0
  22. data/ext/gecode-2.2.0/contribs/qecode/Implicative.hh +164 -0
  23. data/ext/gecode-2.2.0/contribs/qecode/Makefile.in.in +163 -0
  24. data/ext/gecode-2.2.0/contribs/qecode/OptVar.cc +82 -0
  25. data/ext/gecode-2.2.0/contribs/qecode/OptVar.hh +123 -0
  26. data/ext/gecode-2.2.0/contribs/qecode/Strategy.cc +131 -0
  27. data/ext/gecode-2.2.0/contribs/qecode/Strategy.hh +91 -0
  28. data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.cc +62 -0
  29. data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.hh +47 -0
  30. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/output.0 +2264 -0
  31. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/requests +115 -0
  32. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/traces.0 +57 -0
  33. data/ext/gecode-2.2.0/contribs/qecode/config.log +147 -0
  34. data/ext/gecode-2.2.0/contribs/qecode/config.status +817 -0
  35. data/ext/gecode-2.2.0/contribs/qecode/configure +2264 -0
  36. data/ext/gecode-2.2.0/contribs/qecode/configure.ac +23 -0
  37. data/ext/gecode-2.2.0/contribs/qecode/examples/COMPILING +13 -0
  38. data/ext/gecode-2.2.0/contribs/qecode/examples/MatrixGame.cpp +140 -0
  39. data/ext/gecode-2.2.0/contribs/qecode/examples/NimFibo.cpp +73 -0
  40. data/ext/gecode-2.2.0/contribs/qecode/examples/connect-5-3-3-3.cpp +842 -0
  41. data/ext/gecode-2.2.0/contribs/qecode/examples/network-pricing.cc +146 -0
  42. data/ext/gecode-2.2.0/contribs/qecode/examples/optim2.cc +149 -0
  43. data/ext/gecode-2.2.0/contribs/qecode/examples/stress_test.cpp +240 -0
  44. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/heap.cc +0 -0
  45. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myDom.cc +0 -0
  46. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myspace.cc +0 -0
  47. data/ext/gecode-2.2.0/contribs/qecode/myspace.hh +68 -0
  48. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/qecode.hh +0 -0
  49. data/ext/gecode-2.2.0/contribs/qecode/qsolver.cc +268 -0
  50. data/ext/gecode-2.2.0/contribs/qecode/qsolver.hh +46 -0
  51. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/shortdesc.ac +0 -0
  52. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/vartype.hh +0 -0
  53. data/ext/{gecode-2.1.1 → gecode-2.2.0}/doxygen/doxygen.conf.in +0 -0
  54. data/ext/gecode-2.2.0/doxygen/doxygen.hh.in +1112 -0
  55. data/ext/gecode-2.2.0/doxygen/reflection.hh +417 -0
  56. data/ext/gecode-2.2.0/examples/all-interval.cc +133 -0
  57. data/ext/gecode-2.2.0/examples/alpha.cc +137 -0
  58. data/ext/gecode-2.2.0/examples/bacp.cc +521 -0
  59. data/ext/gecode-2.2.0/examples/baseline.cc +87 -0
  60. data/ext/gecode-2.2.0/examples/bibd.cc +203 -0
  61. data/ext/gecode-2.2.0/examples/black-hole.cc +389 -0
  62. data/ext/gecode-2.2.0/examples/crew.cc +286 -0
  63. data/ext/gecode-2.2.0/examples/crowded-chess.cc +424 -0
  64. data/ext/gecode-2.2.0/examples/domino.cc +297 -0
  65. data/ext/gecode-2.2.0/examples/donald.cc +107 -0
  66. data/ext/gecode-2.2.0/examples/eq20.cc +125 -0
  67. data/ext/gecode-2.2.0/examples/golf.cc +297 -0
  68. data/ext/gecode-2.2.0/examples/golomb-ruler.cc +199 -0
  69. data/ext/gecode-2.2.0/examples/graph-color.cc +407 -0
  70. data/ext/gecode-2.2.0/examples/grocery.cc +113 -0
  71. data/ext/gecode-2.2.0/examples/hamming.cc +129 -0
  72. data/ext/gecode-2.2.0/examples/ind-set.cc +143 -0
  73. data/ext/gecode-2.2.0/examples/javascript.cc +163 -0
  74. data/ext/gecode-2.2.0/examples/kakuro.cc +686 -0
  75. data/ext/gecode-2.2.0/examples/knights.cc +220 -0
  76. data/ext/gecode-2.2.0/examples/langford-number.cc +225 -0
  77. data/ext/gecode-2.2.0/examples/magic-sequence.cc +146 -0
  78. data/ext/gecode-2.2.0/examples/magic-square.cc +138 -0
  79. data/ext/gecode-2.2.0/examples/minesweeper.cc +304 -0
  80. data/ext/gecode-2.2.0/examples/money.cc +105 -0
  81. data/ext/gecode-2.2.0/examples/nonogram.cc +492 -0
  82. data/ext/gecode-2.2.0/examples/ortho-latin.cc +172 -0
  83. data/ext/gecode-2.2.0/examples/partition.cc +141 -0
  84. data/ext/gecode-2.2.0/examples/pentominoes.cc +949 -0
  85. data/ext/gecode-2.2.0/examples/perfect-square.cc +311 -0
  86. data/ext/gecode-2.2.0/examples/photo.cc +170 -0
  87. data/ext/gecode-2.2.0/examples/queen-armies.cc +284 -0
  88. data/ext/gecode-2.2.0/examples/queens.cc +147 -0
  89. data/ext/gecode-2.2.0/examples/queens.js +57 -0
  90. data/ext/gecode-2.2.0/examples/sports-league.cc +342 -0
  91. data/ext/gecode-2.2.0/examples/steiner.cc +192 -0
  92. data/ext/gecode-2.2.0/examples/stress-distinct.cc +90 -0
  93. data/ext/gecode-2.2.0/examples/stress-domain.cc +99 -0
  94. data/ext/gecode-2.2.0/examples/stress-element.cc +112 -0
  95. data/ext/gecode-2.2.0/examples/stress-exec.cc +97 -0
  96. data/ext/gecode-2.2.0/examples/stress-extensional.cc +134 -0
  97. data/ext/gecode-2.2.0/examples/stress-linear-bool.cc +97 -0
  98. data/ext/gecode-2.2.0/examples/stress-min.cc +98 -0
  99. data/ext/gecode-2.2.0/examples/stress-search.cc +88 -0
  100. data/ext/gecode-2.2.0/examples/sudoku.cc +2341 -0
  101. data/ext/gecode-2.2.0/examples/support.hh +338 -0
  102. data/ext/gecode-2.2.0/examples/support/example.cc +64 -0
  103. data/ext/gecode-2.2.0/examples/support/example.icc +321 -0
  104. data/ext/gecode-2.2.0/examples/support/options.cc +226 -0
  105. data/ext/gecode-2.2.0/examples/support/options.icc +276 -0
  106. data/ext/gecode-2.2.0/examples/tsp.cc +317 -0
  107. data/ext/gecode-2.2.0/examples/warehouses.cc +191 -0
  108. data/ext/gecode-2.2.0/gecode.m4 +1046 -0
  109. data/ext/gecode-2.2.0/gecode/cpltset.hh +797 -0
  110. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.cc +0 -0
  111. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.icc +0 -0
  112. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.cc +0 -0
  113. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.icc +0 -0
  114. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.cc +0 -0
  115. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.hh +0 -0
  116. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-val.icc +0 -0
  117. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-view.icc +0 -0
  118. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/atmost.cc +0 -0
  119. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/cardinality.cc +0 -0
  120. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/distinct.cc +0 -0
  121. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/dom.cc +0 -0
  122. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/partition.cc +0 -0
  123. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rangeroots.cc +0 -0
  124. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rel.cc +0 -0
  125. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/select.cc +0 -0
  126. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/singleton.cc +0 -0
  127. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/exception.icc +0 -0
  128. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators.hh +0 -0
  129. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/binary.icc +0 -0
  130. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/nary.icc +0 -0
  131. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/naryone.icc +0 -0
  132. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/narytwo.icc +0 -0
  133. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/singleton.icc +0 -0
  134. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/unary.icc +0 -0
  135. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.cc +0 -0
  136. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.icc +0 -0
  137. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp.icc +0 -0
  138. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.cc +0 -0
  139. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.icc +0 -0
  140. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.vis +0 -0
  141. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.cc +0 -0
  142. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.icc +0 -0
  143. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view.icc +0 -0
  144. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/cpltset.icc +0 -0
  145. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/print.cc +0 -0
  146. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist.hh +0 -0
  147. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.cc +0 -0
  148. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.hh +0 -0
  149. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.cc +0 -0
  150. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.hh +0 -0
  151. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/better.hh +0 -0
  152. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.cc +0 -0
  153. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.hh +0 -0
  154. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.cc +281 -0
  155. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.hh +103 -0
  156. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.icc +70 -0
  157. data/ext/gecode-2.2.0/gecode/gist/gecodelogo.cc +672 -0
  158. data/ext/gecode-2.2.0/gecode/gist/gecodelogo.hh +64 -0
  159. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.cc +0 -0
  160. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.icc +0 -0
  161. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.cc +115 -0
  162. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.hh +75 -0
  163. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.icc +48 -0
  164. data/ext/gecode-2.2.0/gecode/gist/mainwindow.cc +274 -0
  165. data/ext/gecode-2.2.0/gecode/gist/mainwindow.hh +86 -0
  166. data/ext/gecode-2.2.0/gecode/gist/node.cc +148 -0
  167. data/ext/gecode-2.2.0/gecode/gist/node.hh +117 -0
  168. data/ext/gecode-2.2.0/gecode/gist/node.icc +99 -0
  169. data/ext/gecode-2.2.0/gecode/gist/nodecursor.cc +123 -0
  170. data/ext/gecode-2.2.0/gecode/gist/nodecursor.hh +147 -0
  171. data/ext/gecode-2.2.0/gecode/gist/nodecursor.icc +122 -0
  172. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.hh +0 -0
  173. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.icc +0 -0
  174. data/ext/gecode-2.2.0/gecode/gist/preferences.cc +120 -0
  175. data/ext/gecode-2.2.0/gecode/gist/preferences.hh +79 -0
  176. data/ext/gecode-2.2.0/gecode/gist/spacenode.cc +468 -0
  177. data/ext/gecode-2.2.0/gecode/gist/spacenode.hh +227 -0
  178. data/ext/gecode-2.2.0/gecode/gist/spacenode.icc +170 -0
  179. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/test.cc +0 -0
  180. data/ext/gecode-2.2.0/gecode/gist/textoutput.cc +134 -0
  181. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/textoutput.hh +0 -0
  182. data/ext/gecode-2.2.0/gecode/gist/treecanvas.cc +1343 -0
  183. data/ext/gecode-2.2.0/gecode/gist/treecanvas.hh +361 -0
  184. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/ui_addchild.hh +0 -0
  185. data/ext/gecode-2.2.0/gecode/gist/ui_addvisualisationdialog.hh +165 -0
  186. data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.cc +192 -0
  187. data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.hh +75 -0
  188. data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.cc +235 -0
  189. data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.hh +77 -0
  190. data/ext/gecode-2.2.0/gecode/gist/visualisation/vararrayitem.hh +125 -0
  191. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.cc +0 -0
  192. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.hh +0 -0
  193. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayviewt.hh +0 -0
  194. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.cc +0 -0
  195. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.hh +0 -0
  196. data/ext/gecode-2.2.0/gecode/gist/visualnode.cc +474 -0
  197. data/ext/gecode-2.2.0/gecode/gist/visualnode.hh +226 -0
  198. data/ext/gecode-2.2.0/gecode/gist/visualnode.icc +198 -0
  199. data/ext/gecode-2.2.0/gecode/gist/zoomToFitIcon.icc +113 -0
  200. data/ext/gecode-2.2.0/gecode/int.hh +2116 -0
  201. data/ext/gecode-2.2.0/gecode/int/arithmetic.cc +237 -0
  202. data/ext/gecode-2.2.0/gecode/int/arithmetic.hh +827 -0
  203. data/ext/gecode-2.2.0/gecode/int/arithmetic/abs.icc +278 -0
  204. data/ext/gecode-2.2.0/gecode/int/arithmetic/divmod.icc +496 -0
  205. data/ext/gecode-2.2.0/gecode/int/arithmetic/max.icc +474 -0
  206. data/ext/gecode-2.2.0/gecode/int/arithmetic/mult.icc +858 -0
  207. data/ext/gecode-2.2.0/gecode/int/arithmetic/sqr.icc +464 -0
  208. data/ext/gecode-2.2.0/gecode/int/arithmetic/sqrt.icc +260 -0
  209. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.cc +0 -0
  210. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.icc +0 -0
  211. data/ext/gecode-2.2.0/gecode/int/bool.cc +734 -0
  212. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool.hh +0 -0
  213. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/base.icc +0 -0
  214. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eq.icc +0 -0
  215. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eqv.icc +0 -0
  216. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/lq.icc +0 -0
  217. data/ext/gecode-2.2.0/gecode/int/bool/or.icc +1000 -0
  218. data/ext/gecode-2.2.0/gecode/int/branch.cc +167 -0
  219. data/ext/gecode-2.2.0/gecode/int/branch.hh +587 -0
  220. data/ext/gecode-2.2.0/gecode/int/branch/create-branch.icc +190 -0
  221. data/ext/gecode-2.2.0/gecode/int/branch/select-val.icc +340 -0
  222. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/branch/select-view.icc +0 -0
  223. data/ext/gecode-2.2.0/gecode/int/channel.cc +165 -0
  224. data/ext/gecode-2.2.0/gecode/int/channel.hh +259 -0
  225. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/base.icc +0 -0
  226. data/ext/gecode-2.2.0/gecode/int/channel/dom.icc +348 -0
  227. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.cc +0 -0
  228. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.icc +0 -0
  229. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.cc +0 -0
  230. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.icc +0 -0
  231. data/ext/gecode-2.2.0/gecode/int/channel/val.icc +278 -0
  232. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit.cc +0 -0
  233. data/ext/gecode-2.2.0/gecode/int/circuit.hh +175 -0
  234. data/ext/gecode-2.2.0/gecode/int/circuit/base.icc +266 -0
  235. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit/dom.icc +0 -0
  236. data/ext/gecode-2.2.0/gecode/int/circuit/val.icc +126 -0
  237. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/count.cc +0 -0
  238. data/ext/gecode-2.2.0/gecode/int/count.hh +487 -0
  239. data/ext/gecode-2.2.0/gecode/int/count/int.icc +620 -0
  240. data/ext/gecode-2.2.0/gecode/int/count/rel.icc +144 -0
  241. data/ext/gecode-2.2.0/gecode/int/count/view.icc +449 -0
  242. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/cumulatives.cc +0 -0
  243. data/ext/gecode-2.2.0/gecode/int/cumulatives.hh +138 -0
  244. data/ext/gecode-2.2.0/gecode/int/cumulatives/val.icc +455 -0
  245. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct.cc +0 -0
  246. data/ext/gecode-2.2.0/gecode/int/distinct.hh +341 -0
  247. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bilink.icc +0 -0
  248. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bnd.icc +0 -0
  249. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/combptr.icc +0 -0
  250. data/ext/gecode-2.2.0/gecode/int/distinct/dom.icc +752 -0
  251. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/edge.icc +0 -0
  252. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/node.icc +0 -0
  253. data/ext/gecode-2.2.0/gecode/int/distinct/ter-dom.icc +136 -0
  254. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/val.icc +0 -0
  255. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.cc +0 -0
  256. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.hh +0 -0
  257. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/range.icc +0 -0
  258. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/spec.icc +0 -0
  259. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/element.cc +0 -0
  260. data/ext/gecode-2.2.0/gecode/int/element.hh +239 -0
  261. data/ext/gecode-2.2.0/gecode/int/element/int.icc +444 -0
  262. data/ext/gecode-2.2.0/gecode/int/element/view.icc +584 -0
  263. data/ext/gecode-2.2.0/gecode/int/exception.icc +174 -0
  264. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional.cc +0 -0
  265. data/ext/gecode-2.2.0/gecode/int/extensional.hh +415 -0
  266. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/base.icc +0 -0
  267. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/basic.icc +0 -0
  268. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/bitset.icc +0 -0
  269. data/ext/gecode-2.2.0/gecode/int/extensional/dfa.cc +565 -0
  270. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/dfa.icc +0 -0
  271. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/incremental.icc +0 -0
  272. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/layered-graph.icc +0 -0
  273. data/ext/gecode-2.2.0/gecode/int/extensional/tuple-set.cc +285 -0
  274. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/tuple-set.icc +0 -0
  275. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc.cc +0 -0
  276. data/ext/gecode-2.2.0/gecode/int/gcc.hh +329 -0
  277. data/ext/gecode-2.2.0/gecode/int/gcc/bnd.icc +660 -0
  278. data/ext/gecode-2.2.0/gecode/int/gcc/dom.icc +531 -0
  279. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/gccbndsup.icc +0 -0
  280. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/graphsup.icc +0 -0
  281. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/lbc.icc +0 -0
  282. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/occur.icc +0 -0
  283. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/ubc.icc +0 -0
  284. data/ext/gecode-2.2.0/gecode/int/gcc/val.icc +400 -0
  285. data/ext/gecode-2.2.0/gecode/int/int-set.cc +157 -0
  286. data/ext/gecode-2.2.0/gecode/int/int-set.icc +195 -0
  287. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/limits.icc +0 -0
  288. data/ext/gecode-2.2.0/gecode/int/linear-bool.cc +235 -0
  289. data/ext/gecode-2.2.0/gecode/int/linear-int.cc +272 -0
  290. data/ext/gecode-2.2.0/gecode/int/linear.hh +1849 -0
  291. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-int.icc +0 -0
  292. data/ext/gecode-2.2.0/gecode/int/linear/bool-post.cc +433 -0
  293. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-scale.icc +0 -0
  294. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-view.icc +0 -0
  295. data/ext/gecode-2.2.0/gecode/int/linear/int-bin.icc +605 -0
  296. data/ext/gecode-2.2.0/gecode/int/linear/int-dom.icc +539 -0
  297. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-nary.icc +0 -0
  298. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-noview.icc +0 -0
  299. data/ext/gecode-2.2.0/gecode/int/linear/int-post.cc +493 -0
  300. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-ter.icc +0 -0
  301. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/post.icc +0 -0
  302. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/propagator.icc +0 -0
  303. data/ext/gecode-2.2.0/gecode/int/rel.cc +420 -0
  304. data/ext/gecode-2.2.0/gecode/int/rel.hh +627 -0
  305. data/ext/gecode-2.2.0/gecode/int/rel/eq.icc +885 -0
  306. data/ext/gecode-2.2.0/gecode/int/rel/lex.icc +275 -0
  307. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/rel/lq-le.icc +0 -0
  308. data/ext/gecode-2.2.0/gecode/int/rel/nq.icc +118 -0
  309. data/ext/gecode-2.2.0/gecode/int/sorted.cc +81 -0
  310. data/ext/gecode-2.2.0/gecode/int/sorted.hh +118 -0
  311. data/ext/gecode-2.2.0/gecode/int/sorted/matching.icc +173 -0
  312. data/ext/gecode-2.2.0/gecode/int/sorted/narrowing.icc +249 -0
  313. data/ext/gecode-2.2.0/gecode/int/sorted/order.icc +212 -0
  314. data/ext/gecode-2.2.0/gecode/int/sorted/propagate.icc +702 -0
  315. data/ext/gecode-2.2.0/gecode/int/sorted/sortsup.icc +563 -0
  316. data/ext/gecode-2.2.0/gecode/int/support-values.hh +158 -0
  317. data/ext/gecode-2.2.0/gecode/int/support-values.icc +203 -0
  318. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/unshare.cc +0 -0
  319. data/ext/gecode-2.2.0/gecode/int/var-imp.icc +745 -0
  320. data/ext/gecode-2.2.0/gecode/int/var-imp/bool.cc +105 -0
  321. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.icc +0 -0
  322. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.vis +0 -0
  323. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/delta.icc +0 -0
  324. data/ext/gecode-2.2.0/gecode/int/var-imp/int.cc +408 -0
  325. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.icc +0 -0
  326. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.vis +0 -0
  327. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/bool.cc +0 -0
  328. data/ext/gecode-2.2.0/gecode/int/var/bool.icc +128 -0
  329. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/int.cc +0 -0
  330. data/ext/gecode-2.2.0/gecode/int/var/int.icc +153 -0
  331. data/ext/gecode-2.2.0/gecode/int/view.icc +1918 -0
  332. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/bool.icc +0 -0
  333. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/constint.icc +0 -0
  334. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/int.icc +0 -0
  335. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/iter.icc +0 -0
  336. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/minus.icc +0 -0
  337. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/offset.icc +0 -0
  338. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/print.cc +0 -0
  339. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/rtest.icc +0 -0
  340. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/scale.icc +0 -0
  341. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/zero.icc +0 -0
  342. data/ext/gecode-2.2.0/gecode/iter.hh +98 -0
  343. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-add.icc +0 -0
  344. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-append.icc +0 -0
  345. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-array.icc +0 -0
  346. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-cache.icc +0 -0
  347. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-compl.icc +0 -0
  348. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-diff.icc +0 -0
  349. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-empty.icc +0 -0
  350. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-inter.icc +0 -0
  351. data/ext/gecode-2.2.0/gecode/iter/ranges-map.icc +260 -0
  352. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minmax.icc +0 -0
  353. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minus.icc +0 -0
  354. data/ext/gecode-2.2.0/gecode/iter/ranges-negative.icc +137 -0
  355. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-offset.icc +0 -0
  356. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-operations.icc +0 -0
  357. data/ext/gecode-2.2.0/gecode/iter/ranges-positive.icc +139 -0
  358. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-scale.icc +0 -0
  359. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton-append.icc +0 -0
  360. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton.icc +0 -0
  361. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-size.icc +0 -0
  362. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-union.icc +0 -0
  363. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-values.icc +0 -0
  364. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-array.icc +0 -0
  365. data/ext/gecode-2.2.0/gecode/iter/values-inter.icc +130 -0
  366. data/ext/gecode-2.2.0/gecode/iter/values-map.icc +136 -0
  367. data/ext/gecode-2.2.0/gecode/iter/values-minus.icc +130 -0
  368. data/ext/gecode-2.2.0/gecode/iter/values-negative.icc +116 -0
  369. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-offset.icc +0 -0
  370. data/ext/gecode-2.2.0/gecode/iter/values-positive.icc +123 -0
  371. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-ranges.icc +0 -0
  372. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-singleton.icc +0 -0
  373. data/ext/gecode-2.2.0/gecode/iter/values-union.icc +137 -0
  374. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-unique.icc +0 -0
  375. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-compl.icc +0 -0
  376. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-inter.icc +0 -0
  377. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-union.icc +0 -0
  378. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges.icc +0 -0
  379. data/ext/gecode-2.2.0/gecode/kernel.hh +188 -0
  380. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/advisor.icc +0 -0
  381. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/array.icc +0 -0
  382. data/ext/gecode-2.2.0/gecode/kernel/branching.icc +433 -0
  383. data/ext/gecode-2.2.0/gecode/kernel/core.cc +474 -0
  384. data/ext/gecode-2.2.0/gecode/kernel/core.icc +2311 -0
  385. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/exception.icc +0 -0
  386. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/macros.icc +0 -0
  387. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/memory-manager.cc +0 -0
  388. data/ext/gecode-2.2.0/gecode/kernel/memory-manager.icc +454 -0
  389. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/modevent.icc +0 -0
  390. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/propagator.icc +0 -0
  391. data/ext/gecode-2.2.0/gecode/kernel/reflection.cc +951 -0
  392. data/ext/gecode-2.2.0/gecode/kernel/reflection.icc +1213 -0
  393. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/shared-array.icc +0 -0
  394. data/ext/gecode-2.2.0/gecode/kernel/var-imp.icc +433 -0
  395. data/ext/gecode-2.2.0/gecode/kernel/var-map.cc +269 -0
  396. data/ext/gecode-2.2.0/gecode/kernel/var-map.icc +230 -0
  397. data/ext/gecode-2.2.0/gecode/kernel/var-traits.icc +79 -0
  398. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/var-type.cc +0 -0
  399. data/ext/gecode-2.2.0/gecode/kernel/var-type.icc +915 -0
  400. data/ext/gecode-2.2.0/gecode/kernel/var.icc +114 -0
  401. data/ext/gecode-2.2.0/gecode/kernel/view.icc +413 -0
  402. data/ext/gecode-2.2.0/gecode/minimodel.hh +1206 -0
  403. data/ext/gecode-2.2.0/gecode/minimodel/arithmetic.icc +118 -0
  404. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.cc +0 -0
  405. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.icc +0 -0
  406. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-rel.icc +0 -0
  407. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/exception.icc +0 -0
  408. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-expr.icc +0 -0
  409. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-rel.icc +0 -0
  410. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/matrix.icc +0 -0
  411. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/reg.cc +0 -0
  412. data/ext/gecode-2.2.0/gecode/search.hh +759 -0
  413. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.cc +0 -0
  414. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.icc +0 -0
  415. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.cc +0 -0
  416. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.icc +0 -0
  417. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/engine-ctrl.icc +0 -0
  418. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.cc +0 -0
  419. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.icc +0 -0
  420. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.cc +0 -0
  421. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.icc +0 -0
  422. data/ext/gecode-2.2.0/gecode/search/reco-stack.icc +277 -0
  423. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/restart.icc +0 -0
  424. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/statistics.icc +0 -0
  425. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.cc +0 -0
  426. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.icc +0 -0
  427. data/ext/gecode-2.2.0/gecode/serialization.hh +149 -0
  428. data/ext/gecode-2.2.0/gecode/serialization/boost.cc +78 -0
  429. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/boost.icc +0 -0
  430. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/flatzinc.cc +0 -0
  431. data/ext/gecode-2.2.0/gecode/serialization/javascript.cc +343 -0
  432. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/javascript.hh +0 -0
  433. data/ext/gecode-2.2.0/gecode/serialization/register.cc +8498 -0
  434. data/ext/gecode-2.2.0/gecode/set.hh +970 -0
  435. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.cc +0 -0
  436. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.icc +0 -0
  437. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.cc +0 -0
  438. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.hh +0 -0
  439. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-val.icc +0 -0
  440. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-view.icc +0 -0
  441. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/cardinality.cc +0 -0
  442. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.cc +0 -0
  443. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.hh +0 -0
  444. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.cc +0 -0
  445. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.icc +0 -0
  446. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.cc +0 -0
  447. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.icc +0 -0
  448. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.cc +0 -0
  449. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.hh +0 -0
  450. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.cc +0 -0
  451. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.icc +0 -0
  452. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/dom.cc +0 -0
  453. data/ext/gecode-2.2.0/gecode/set/element.cc +135 -0
  454. data/ext/gecode-2.2.0/gecode/set/element.hh +233 -0
  455. data/ext/gecode-2.2.0/gecode/set/element/disjoint.cc +308 -0
  456. data/ext/gecode-2.2.0/gecode/set/element/disjoint.icc +75 -0
  457. data/ext/gecode-2.2.0/gecode/set/element/idxarray.hh +113 -0
  458. data/ext/gecode-2.2.0/gecode/set/element/idxarray.icc +155 -0
  459. data/ext/gecode-2.2.0/gecode/set/element/inter.icc +348 -0
  460. data/ext/gecode-2.2.0/gecode/set/element/union.icc +371 -0
  461. data/ext/gecode-2.2.0/gecode/set/element/unionConst.icc +334 -0
  462. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/exception.icc +0 -0
  463. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.cc +0 -0
  464. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.hh +0 -0
  465. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/card.icc +0 -0
  466. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-bool.icc +0 -0
  467. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-int.icc +0 -0
  468. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/match.icc +0 -0
  469. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/minmax.icc +0 -0
  470. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/weights.icc +0 -0
  471. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/limits.icc +0 -0
  472. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors-compiler.hh +0 -0
  473. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors.cc +0 -0
  474. data/ext/gecode-2.2.0/gecode/set/projectors.hh +438 -0
  475. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/compiler.cc +0 -0
  476. data/ext/gecode-2.2.0/gecode/set/projectors/formula.cc +312 -0
  477. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/formula.icc +0 -0
  478. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.cc +0 -0
  479. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.icc +0 -0
  480. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.cc +0 -0
  481. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.icc +0 -0
  482. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator.hh +0 -0
  483. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/card.icc +0 -0
  484. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/nary.icc +0 -0
  485. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.cc +0 -0
  486. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.icc +0 -0
  487. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.cc +0 -0
  488. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.icc +0 -0
  489. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/propagator.icc +0 -0
  490. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op-const.cc +0 -0
  491. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.cc +0 -0
  492. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.hh +0 -0
  493. data/ext/gecode-2.2.0/gecode/set/rel-op/common.icc +613 -0
  494. data/ext/gecode-2.2.0/gecode/set/rel-op/inter.icc +452 -0
  495. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/partition.icc +0 -0
  496. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/post.icc +0 -0
  497. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/subofunion.icc +0 -0
  498. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/superofinter.icc +0 -0
  499. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/union.icc +0 -0
  500. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.cc +0 -0
  501. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.hh +0 -0
  502. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/common.icc +0 -0
  503. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/eq.icc +0 -0
  504. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nosubset.icc +0 -0
  505. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nq.icc +0 -0
  506. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/re-eq.icc +0 -0
  507. data/ext/gecode-2.2.0/gecode/set/rel/re-subset.icc +174 -0
  508. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/subset.icc +0 -0
  509. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.cc +0 -0
  510. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.hh +0 -0
  511. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/common.icc +0 -0
  512. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.cc +0 -0
  513. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.icc +0 -0
  514. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.cc +0 -0
  515. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.icc +0 -0
  516. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp.icc +0 -0
  517. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/delta.icc +0 -0
  518. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.cc +0 -0
  519. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.icc +0 -0
  520. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/iter.icc +0 -0
  521. data/ext/gecode-2.2.0/gecode/set/var-imp/set.cc +215 -0
  522. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.icc +0 -0
  523. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.vis +0 -0
  524. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var/set.cc +0 -0
  525. data/ext/gecode-2.2.0/gecode/set/var/set.icc +303 -0
  526. data/ext/gecode-2.2.0/gecode/set/view.icc +1451 -0
  527. data/ext/gecode-2.2.0/gecode/set/view/complement.icc +614 -0
  528. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/const.icc +0 -0
  529. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/offset.icc +0 -0
  530. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/print.cc +0 -0
  531. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/set.icc +0 -0
  532. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/singleton.icc +0 -0
  533. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support.hh +0 -0
  534. data/ext/gecode-2.2.0/gecode/support/block-allocator.icc +159 -0
  535. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/AUTHORS +0 -0
  536. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/ChangeLog +0 -0
  537. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/NEWS +0 -0
  538. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/README +0 -0
  539. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bdd.h +0 -0
  540. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddio.c +0 -0
  541. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddop.c +0 -0
  542. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddtree.h +0 -0
  543. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.c +0 -0
  544. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.h +0 -0
  545. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.c +0 -0
  546. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.h +0 -0
  547. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/config.h +0 -0
  548. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cppext.cc +0 -0
  549. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.c +0 -0
  550. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.h +0 -0
  551. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.c +0 -0
  552. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.h +0 -0
  553. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.c +0 -0
  554. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.h +0 -0
  555. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/pairs.c +0 -0
  556. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.c +0 -0
  557. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.h +0 -0
  558. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/reorder.c +0 -0
  559. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/tree.c +0 -0
  560. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/cast.icc +0 -0
  561. data/ext/gecode-2.2.0/gecode/support/config.icc.in +83 -0
  562. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-array.icc +0 -0
  563. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-stack.icc +0 -0
  564. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.cc +0 -0
  565. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.icc +0 -0
  566. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/macros.icc +0 -0
  567. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/map.icc +0 -0
  568. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/marked-pointer.icc +0 -0
  569. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/memory.icc +0 -0
  570. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/random.icc +0 -0
  571. data/ext/gecode-2.2.0/gecode/support/sentinel-stack.icc +138 -0
  572. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/sort.icc +0 -0
  573. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-pqueue.icc +0 -0
  574. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-stack.icc +0 -0
  575. data/ext/gecode-2.2.0/gecode/support/symbol.cc +241 -0
  576. data/ext/gecode-2.2.0/gecode/support/symbol.icc +134 -0
  577. data/ext/{gecode-2.1.1 → gecode-2.2.0}/install-sh +0 -0
  578. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/AppleHelpbookInfo.plist +0 -0
  579. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/allexamples.perl +0 -0
  580. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/Makefile.am +0 -0
  581. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/changelog +0 -0
  582. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/control +0 -0
  583. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/copyright +0 -0
  584. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.info +0 -0
  585. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.install +0 -0
  586. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.spec +0 -0
  587. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/rules +0 -0
  588. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/back.png +0 -0
  589. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/footer.html +0 -0
  590. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/gecode-logo-100.png +0 -0
  591. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/header.html +0 -0
  592. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/stylesheet.css +0 -0
  593. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/fixproperties.sh +0 -0
  594. data/ext/gecode-2.2.0/misc/gecode-gist.pc.in +45 -0
  595. data/ext/gecode-2.2.0/misc/gecode-minimodel.pc.in +45 -0
  596. data/ext/gecode-2.2.0/misc/gecode-search.pc.in +45 -0
  597. data/ext/gecode-2.2.0/misc/gecode-serialization.pc.in +45 -0
  598. data/ext/gecode-2.2.0/misc/gecode.pc.in +45 -0
  599. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genchangelog.perl +0 -0
  600. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlcovmakefile.perl +0 -0
  601. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlicense.perl +0 -0
  602. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genregistry.perl +0 -0
  603. data/ext/gecode-2.2.0/misc/genstatistics.perl +179 -0
  604. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/gentxtchangelog.perl +0 -0
  605. data/ext/gecode-2.2.0/misc/genvariables.perl +905 -0
  606. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/getrevision.perl +0 -0
  607. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/makedepend.perl +0 -0
  608. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/svn-ignore.txt +0 -0
  609. data/ext/gecode-2.2.0/test/assign.cc +181 -0
  610. data/ext/gecode-2.2.0/test/assign.hh +93 -0
  611. data/ext/gecode-2.2.0/test/assign/bool.cc +61 -0
  612. data/ext/gecode-2.2.0/test/assign/int.cc +70 -0
  613. data/ext/gecode-2.2.0/test/branch.cc +563 -0
  614. data/ext/gecode-2.2.0/test/branch.hh +144 -0
  615. data/ext/gecode-2.2.0/test/branch/bool.cc +61 -0
  616. data/ext/gecode-2.2.0/test/branch/cpltset.cc +71 -0
  617. data/ext/gecode-2.2.0/test/branch/int.cc +70 -0
  618. data/ext/gecode-2.2.0/test/branch/set.cc +74 -0
  619. data/ext/gecode-2.2.0/test/cpltset.cc +568 -0
  620. data/ext/gecode-2.2.0/test/cpltset.hh +125 -0
  621. data/ext/gecode-2.2.0/test/cpltset/atmost.cc +155 -0
  622. data/ext/gecode-2.2.0/test/cpltset/cardinality.cc +138 -0
  623. data/ext/gecode-2.2.0/test/cpltset/dom.cc +137 -0
  624. data/ext/gecode-2.2.0/test/cpltset/partition.cc +210 -0
  625. data/ext/gecode-2.2.0/test/cpltset/rel.cc +158 -0
  626. data/ext/gecode-2.2.0/test/cpltset/select.cc +216 -0
  627. data/ext/gecode-2.2.0/test/int.cc +688 -0
  628. data/ext/gecode-2.2.0/test/int.hh +267 -0
  629. data/ext/gecode-2.2.0/test/int.icc +266 -0
  630. data/ext/gecode-2.2.0/test/int/arithmetic.cc +766 -0
  631. data/ext/gecode-2.2.0/test/int/basic.cc +77 -0
  632. data/ext/gecode-2.2.0/test/int/bool.cc +340 -0
  633. data/ext/gecode-2.2.0/test/int/channel.cc +238 -0
  634. data/ext/gecode-2.2.0/test/int/circuit.cc +100 -0
  635. data/ext/gecode-2.2.0/test/int/count.cc +357 -0
  636. data/ext/gecode-2.2.0/test/int/distinct.cc +248 -0
  637. data/ext/gecode-2.2.0/test/int/dom.cc +123 -0
  638. data/ext/gecode-2.2.0/test/int/element.cc +333 -0
  639. data/ext/gecode-2.2.0/test/int/extensional.cc +475 -0
  640. data/ext/gecode-2.2.0/test/int/gcc.cc +293 -0
  641. data/ext/gecode-2.2.0/test/int/linear.cc +383 -0
  642. data/ext/gecode-2.2.0/test/int/mm-arithmetic.cc +302 -0
  643. data/ext/gecode-2.2.0/test/int/mm-bool.cc +4342 -0
  644. data/ext/gecode-2.2.0/test/int/mm-count.cc +295 -0
  645. data/ext/gecode-2.2.0/test/int/mm-lin.cc +2035 -0
  646. data/ext/gecode-2.2.0/test/int/mm-rel.cc +136 -0
  647. data/ext/gecode-2.2.0/test/int/rel.cc +416 -0
  648. data/ext/gecode-2.2.0/test/int/scheduling.cc +276 -0
  649. data/ext/gecode-2.2.0/test/int/sorted.cc +165 -0
  650. data/ext/gecode-2.2.0/test/int/unshare.cc +109 -0
  651. data/ext/gecode-2.2.0/test/search.cc +618 -0
  652. data/ext/gecode-2.2.0/test/set.cc +753 -0
  653. data/ext/gecode-2.2.0/test/set.hh +286 -0
  654. data/ext/gecode-2.2.0/test/set.icc +108 -0
  655. data/ext/gecode-2.2.0/test/set/convex.cc +139 -0
  656. data/ext/gecode-2.2.0/test/set/distinct.cc +116 -0
  657. data/ext/gecode-2.2.0/test/set/dom.cc +292 -0
  658. data/ext/gecode-2.2.0/test/set/int.cc +473 -0
  659. data/ext/gecode-2.2.0/test/set/projection.cc +436 -0
  660. data/ext/gecode-2.2.0/test/set/rel-op-const.cc +368 -0
  661. data/ext/gecode-2.2.0/test/set/rel-op.cc +465 -0
  662. data/ext/gecode-2.2.0/test/set/rel.cc +125 -0
  663. data/ext/gecode-2.2.0/test/set/select.cc +299 -0
  664. data/ext/gecode-2.2.0/test/set/sequence.cc +125 -0
  665. data/ext/gecode-2.2.0/test/test.cc +287 -0
  666. data/ext/gecode-2.2.0/test/test.hh +175 -0
  667. data/ext/gecode-2.2.0/test/test.icc +93 -0
  668. data/ext/{gecode-2.1.1 → gecode-2.2.0}/variables.vsl +0 -0
  669. data/lib/gecoder/bindings.rb +7 -5
  670. data/lib/gecoder/bindings/bindings.rb +8 -8
  671. data/lib/gecoder/interface.rb +4 -2
  672. data/lib/gecoder/interface/binding_changes.rb +1 -1
  673. data/lib/gecoder/interface/branch.rb +1 -1
  674. data/lib/gecoder/interface/constraints/bool_enum_constraints.rb +4 -4
  675. data/lib/gecoder/interface/constraints/bool_var_constraints.rb +2 -2
  676. data/lib/gecoder/interface/constraints/extensional_regexp.rb +1 -1
  677. data/lib/gecoder/interface/constraints/fixnum_enum_constraints.rb +2 -2
  678. data/lib/gecoder/interface/constraints/int_enum/extensional.rb +5 -5
  679. data/lib/gecoder/interface/constraints/int_enum_constraints.rb +4 -4
  680. data/lib/gecoder/interface/constraints/int_var_constraints.rb +2 -2
  681. data/lib/gecoder/interface/constraints/selected_set/select.rb +8 -8
  682. data/lib/gecoder/interface/constraints/set_enum/element.rb +79 -0
  683. data/lib/gecoder/interface/constraints/set_enum_constraints.rb +5 -5
  684. data/lib/gecoder/interface/constraints/set_var_constraints.rb +2 -2
  685. data/lib/gecoder/interface/convenience.rb +99 -0
  686. data/lib/gecoder/interface/enum_wrapper.rb +1 -1
  687. data/lib/gecoder/interface/mixin.rb +486 -0
  688. data/lib/gecoder/interface/search.rb +23 -22
  689. data/lib/gecoder/version.rb +1 -1
  690. data/specs/branch.rb +5 -3
  691. data/specs/constraints/bool/boolean.rb +3 -1
  692. data/specs/constraints/bool/linear.rb +3 -1
  693. data/specs/constraints/bool_enum/bool_enum_relation.rb +3 -1
  694. data/specs/constraints/bool_enum/channel.rb +3 -1
  695. data/specs/constraints/fixnum_enum/element.rb +3 -1
  696. data/specs/constraints/int/arithmetic.rb +3 -1
  697. data/specs/constraints/int/channel.rb +3 -1
  698. data/specs/constraints/int/linear.rb +3 -1
  699. data/specs/constraints/int/linear_properties.rb +3 -1
  700. data/specs/constraints/int_enum/arithmetic.rb +3 -1
  701. data/specs/constraints/int_enum/channel.rb +3 -1
  702. data/specs/constraints/int_enum/count.rb +3 -1
  703. data/specs/constraints/int_enum/distinct.rb +3 -1
  704. data/specs/constraints/int_enum/element.rb +3 -1
  705. data/specs/constraints/int_enum/sort.rb +3 -1
  706. data/specs/constraints/property_helper.rb +10 -10
  707. data/specs/constraints/reification_sugar.rb +3 -1
  708. data/specs/constraints/selected_set/select.rb +6 -5
  709. data/specs/constraints/selected_set/select_properties.rb +12 -10
  710. data/specs/constraints/set/channel.rb +3 -1
  711. data/specs/constraints/set/domain.rb +4 -4
  712. data/specs/constraints/set/relation.rb +4 -4
  713. data/specs/constraints/set_enum/channel.rb +3 -1
  714. data/specs/constraints/set_enum/distinct.rb +3 -1
  715. data/specs/constraints/set_enum/element.rb +77 -0
  716. data/specs/enum_wrapper.rb +1 -1
  717. data/specs/mixin.rb +78 -0
  718. data/specs/model.rb +5 -5
  719. data/specs/search.rb +20 -14
  720. data/specs/selected_set.rb +3 -3
  721. data/specs/set_elements.rb +2 -2
  722. data/tasks/distribution.rake +25 -4
  723. metadata +739 -602
  724. data/example/money.rb +0 -36
  725. data/ext/gecode-2.1.1/Makefile.dep +0 -7622
  726. data/ext/gecode-2.1.1/Makefile.in +0 -1568
  727. data/ext/gecode-2.1.1/changelog.in +0 -2459
  728. data/ext/gecode-2.1.1/configure +0 -11631
  729. data/ext/gecode-2.1.1/configure.ac +0 -249
  730. data/ext/gecode-2.1.1/configure.ac.in +0 -245
  731. data/ext/gecode-2.1.1/contribs/qecode/Doxyfile +0 -263
  732. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.cc +0 -82
  733. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.hh +0 -37
  734. data/ext/gecode-2.1.1/contribs/qecode/Makefile.in.in +0 -162
  735. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.cc +0 -172
  736. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.hh +0 -63
  737. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.cc +0 -37
  738. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.hh +0 -35
  739. data/ext/gecode-2.1.1/contribs/qecode/configure +0 -2264
  740. data/ext/gecode-2.1.1/contribs/qecode/configure.ac +0 -23
  741. data/ext/gecode-2.1.1/contribs/qecode/examples/COMPILING +0 -13
  742. data/ext/gecode-2.1.1/contribs/qecode/examples/MatrixGame.cpp +0 -144
  743. data/ext/gecode-2.1.1/contribs/qecode/examples/NimFibo.cpp +0 -73
  744. data/ext/gecode-2.1.1/contribs/qecode/examples/stress_test.cpp +0 -179
  745. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.cc +0 -34
  746. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.hh +0 -46
  747. data/ext/gecode-2.1.1/contribs/qecode/implicative.cc +0 -595
  748. data/ext/gecode-2.1.1/contribs/qecode/implicative.hh +0 -184
  749. data/ext/gecode-2.1.1/contribs/qecode/myspace.hh +0 -69
  750. data/ext/gecode-2.1.1/contribs/qecode/qecore.cc +0 -145
  751. data/ext/gecode-2.1.1/contribs/qecode/qecore.hh +0 -247
  752. data/ext/gecode-2.1.1/contribs/qecode/qsolver.cc +0 -168
  753. data/ext/gecode-2.1.1/contribs/qecode/qsolver.hh +0 -73
  754. data/ext/gecode-2.1.1/contribs/qecode/valueHeuristic.hh +0 -91
  755. data/ext/gecode-2.1.1/contribs/qecode/warner.cc +0 -101
  756. data/ext/gecode-2.1.1/contribs/qecode/warner.hh +0 -83
  757. data/ext/gecode-2.1.1/doxygen/doxygen.hh.in +0 -1111
  758. data/ext/gecode-2.1.1/doxygen/reflection.hh +0 -417
  759. data/ext/gecode-2.1.1/gecode.m4 +0 -956
  760. data/ext/gecode-2.1.1/gecode/cpltset.hh +0 -797
  761. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.cc +0 -115
  762. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.hh +0 -77
  763. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.cc +0 -245
  764. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.hh +0 -101
  765. data/ext/gecode-2.1.1/gecode/gist/gecodelogo.icc +0 -522
  766. data/ext/gecode-2.1.1/gecode/gist/mainwindow.cc +0 -254
  767. data/ext/gecode-2.1.1/gecode/gist/mainwindow.hh +0 -86
  768. data/ext/gecode-2.1.1/gecode/gist/node.cc +0 -100
  769. data/ext/gecode-2.1.1/gecode/gist/node.hh +0 -89
  770. data/ext/gecode-2.1.1/gecode/gist/nodecursor.cc +0 -124
  771. data/ext/gecode-2.1.1/gecode/gist/nodecursor.hh +0 -122
  772. data/ext/gecode-2.1.1/gecode/gist/nodecursor.icc +0 -79
  773. data/ext/gecode-2.1.1/gecode/gist/postscript.cc +0 -543
  774. data/ext/gecode-2.1.1/gecode/gist/postscript.hh +0 -56
  775. data/ext/gecode-2.1.1/gecode/gist/preferences.cc +0 -110
  776. data/ext/gecode-2.1.1/gecode/gist/preferences.hh +0 -76
  777. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.cc +0 -55
  778. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.hh +0 -58
  779. data/ext/gecode-2.1.1/gecode/gist/shapelist.cc +0 -331
  780. data/ext/gecode-2.1.1/gecode/gist/shapelist.hh +0 -140
  781. data/ext/gecode-2.1.1/gecode/gist/spacenode.cc +0 -531
  782. data/ext/gecode-2.1.1/gecode/gist/spacenode.hh +0 -224
  783. data/ext/gecode-2.1.1/gecode/gist/textoutput.cc +0 -114
  784. data/ext/gecode-2.1.1/gecode/gist/treecanvas.cc +0 -1140
  785. data/ext/gecode-2.1.1/gecode/gist/treecanvas.hh +0 -324
  786. data/ext/gecode-2.1.1/gecode/gist/ui_addvisualisationdialog.hh +0 -163
  787. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.cc +0 -175
  788. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.hh +0 -71
  789. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.cc +0 -219
  790. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.hh +0 -73
  791. data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayitem.hh +0 -123
  792. data/ext/gecode-2.1.1/gecode/gist/visualnode.cc +0 -303
  793. data/ext/gecode-2.1.1/gecode/gist/visualnode.hh +0 -166
  794. data/ext/gecode-2.1.1/gecode/int.hh +0 -2035
  795. data/ext/gecode-2.1.1/gecode/int/arithmetic.cc +0 -136
  796. data/ext/gecode-2.1.1/gecode/int/arithmetic.hh +0 -440
  797. data/ext/gecode-2.1.1/gecode/int/arithmetic/abs.icc +0 -279
  798. data/ext/gecode-2.1.1/gecode/int/arithmetic/max.icc +0 -253
  799. data/ext/gecode-2.1.1/gecode/int/arithmetic/mult.icc +0 -522
  800. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqr.icc +0 -218
  801. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqrt.icc +0 -138
  802. data/ext/gecode-2.1.1/gecode/int/bool.cc +0 -642
  803. data/ext/gecode-2.1.1/gecode/int/bool/or.icc +0 -1000
  804. data/ext/gecode-2.1.1/gecode/int/branch.cc +0 -301
  805. data/ext/gecode-2.1.1/gecode/int/branch.hh +0 -576
  806. data/ext/gecode-2.1.1/gecode/int/branch/select-val.icc +0 -338
  807. data/ext/gecode-2.1.1/gecode/int/channel.cc +0 -114
  808. data/ext/gecode-2.1.1/gecode/int/channel.hh +0 -259
  809. data/ext/gecode-2.1.1/gecode/int/channel/dom.icc +0 -347
  810. data/ext/gecode-2.1.1/gecode/int/channel/val.icc +0 -276
  811. data/ext/gecode-2.1.1/gecode/int/circuit.hh +0 -175
  812. data/ext/gecode-2.1.1/gecode/int/circuit/base.icc +0 -271
  813. data/ext/gecode-2.1.1/gecode/int/circuit/val.icc +0 -122
  814. data/ext/gecode-2.1.1/gecode/int/count.hh +0 -487
  815. data/ext/gecode-2.1.1/gecode/int/count/int.icc +0 -619
  816. data/ext/gecode-2.1.1/gecode/int/count/rel.icc +0 -144
  817. data/ext/gecode-2.1.1/gecode/int/count/view.icc +0 -449
  818. data/ext/gecode-2.1.1/gecode/int/cumulatives.hh +0 -141
  819. data/ext/gecode-2.1.1/gecode/int/cumulatives/val.icc +0 -429
  820. data/ext/gecode-2.1.1/gecode/int/distinct.hh +0 -341
  821. data/ext/gecode-2.1.1/gecode/int/distinct/dom.icc +0 -750
  822. data/ext/gecode-2.1.1/gecode/int/distinct/ter-dom.icc +0 -136
  823. data/ext/gecode-2.1.1/gecode/int/element.hh +0 -239
  824. data/ext/gecode-2.1.1/gecode/int/element/int.icc +0 -441
  825. data/ext/gecode-2.1.1/gecode/int/element/view.icc +0 -584
  826. data/ext/gecode-2.1.1/gecode/int/exception.icc +0 -163
  827. data/ext/gecode-2.1.1/gecode/int/extensional.hh +0 -415
  828. data/ext/gecode-2.1.1/gecode/int/extensional/dfa.cc +0 -565
  829. data/ext/gecode-2.1.1/gecode/int/extensional/tuple-set.cc +0 -311
  830. data/ext/gecode-2.1.1/gecode/int/gcc.hh +0 -329
  831. data/ext/gecode-2.1.1/gecode/int/gcc/bnd.icc +0 -660
  832. data/ext/gecode-2.1.1/gecode/int/gcc/dom.icc +0 -531
  833. data/ext/gecode-2.1.1/gecode/int/gcc/val.icc +0 -400
  834. data/ext/gecode-2.1.1/gecode/int/int-set.cc +0 -153
  835. data/ext/gecode-2.1.1/gecode/int/int-set.icc +0 -191
  836. data/ext/gecode-2.1.1/gecode/int/linear-bool.cc +0 -220
  837. data/ext/gecode-2.1.1/gecode/int/linear-int.cc +0 -240
  838. data/ext/gecode-2.1.1/gecode/int/linear.hh +0 -1849
  839. data/ext/gecode-2.1.1/gecode/int/linear/bool-post.cc +0 -433
  840. data/ext/gecode-2.1.1/gecode/int/linear/int-bin.icc +0 -605
  841. data/ext/gecode-2.1.1/gecode/int/linear/int-dom.icc +0 -539
  842. data/ext/gecode-2.1.1/gecode/int/linear/int-post.cc +0 -493
  843. data/ext/gecode-2.1.1/gecode/int/rel.cc +0 -431
  844. data/ext/gecode-2.1.1/gecode/int/rel.hh +0 -657
  845. data/ext/gecode-2.1.1/gecode/int/rel/eq.icc +0 -848
  846. data/ext/gecode-2.1.1/gecode/int/rel/lex.icc +0 -248
  847. data/ext/gecode-2.1.1/gecode/int/rel/nq.icc +0 -269
  848. data/ext/gecode-2.1.1/gecode/int/sorted.cc +0 -91
  849. data/ext/gecode-2.1.1/gecode/int/sorted.hh +0 -117
  850. data/ext/gecode-2.1.1/gecode/int/sorted/matching.icc +0 -182
  851. data/ext/gecode-2.1.1/gecode/int/sorted/narrowing.icc +0 -257
  852. data/ext/gecode-2.1.1/gecode/int/sorted/order.icc +0 -208
  853. data/ext/gecode-2.1.1/gecode/int/sorted/propagate.icc +0 -669
  854. data/ext/gecode-2.1.1/gecode/int/sorted/sortsup.icc +0 -596
  855. data/ext/gecode-2.1.1/gecode/int/var-imp.icc +0 -745
  856. data/ext/gecode-2.1.1/gecode/int/var-imp/bool.cc +0 -104
  857. data/ext/gecode-2.1.1/gecode/int/var-imp/int.cc +0 -407
  858. data/ext/gecode-2.1.1/gecode/int/var/bool.icc +0 -126
  859. data/ext/gecode-2.1.1/gecode/int/var/int.icc +0 -151
  860. data/ext/gecode-2.1.1/gecode/int/view.icc +0 -1894
  861. data/ext/gecode-2.1.1/gecode/iter.hh +0 -90
  862. data/ext/gecode-2.1.1/gecode/iter/values-minus.icc +0 -130
  863. data/ext/gecode-2.1.1/gecode/kernel.hh +0 -182
  864. data/ext/gecode-2.1.1/gecode/kernel/branching.icc +0 -447
  865. data/ext/gecode-2.1.1/gecode/kernel/core.cc +0 -473
  866. data/ext/gecode-2.1.1/gecode/kernel/core.icc +0 -2295
  867. data/ext/gecode-2.1.1/gecode/kernel/memory-manager.icc +0 -458
  868. data/ext/gecode-2.1.1/gecode/kernel/reflection.cc +0 -921
  869. data/ext/gecode-2.1.1/gecode/kernel/reflection.icc +0 -1012
  870. data/ext/gecode-2.1.1/gecode/kernel/var-imp.icc +0 -433
  871. data/ext/gecode-2.1.1/gecode/kernel/var-map.cc +0 -269
  872. data/ext/gecode-2.1.1/gecode/kernel/var-map.icc +0 -227
  873. data/ext/gecode-2.1.1/gecode/kernel/var-traits.icc +0 -72
  874. data/ext/gecode-2.1.1/gecode/kernel/var-type.icc +0 -915
  875. data/ext/gecode-2.1.1/gecode/kernel/var.icc +0 -120
  876. data/ext/gecode-2.1.1/gecode/kernel/view.icc +0 -611
  877. data/ext/gecode-2.1.1/gecode/minimodel.hh +0 -1165
  878. data/ext/gecode-2.1.1/gecode/minimodel/arithmetic.cc +0 -179
  879. data/ext/gecode-2.1.1/gecode/search.hh +0 -752
  880. data/ext/gecode-2.1.1/gecode/search/reco-stack.icc +0 -237
  881. data/ext/gecode-2.1.1/gecode/serialization.hh +0 -149
  882. data/ext/gecode-2.1.1/gecode/serialization/boost.cc +0 -78
  883. data/ext/gecode-2.1.1/gecode/serialization/javascript.cc +0 -340
  884. data/ext/gecode-2.1.1/gecode/serialization/register.cc +0 -8142
  885. data/ext/gecode-2.1.1/gecode/set.hh +0 -970
  886. data/ext/gecode-2.1.1/gecode/set/projectors.hh +0 -438
  887. data/ext/gecode-2.1.1/gecode/set/projectors/formula.cc +0 -312
  888. data/ext/gecode-2.1.1/gecode/set/rel-op/common.icc +0 -557
  889. data/ext/gecode-2.1.1/gecode/set/rel-op/inter.icc +0 -409
  890. data/ext/gecode-2.1.1/gecode/set/rel/re-subset.icc +0 -172
  891. data/ext/gecode-2.1.1/gecode/set/select.cc +0 -135
  892. data/ext/gecode-2.1.1/gecode/set/select.hh +0 -233
  893. data/ext/gecode-2.1.1/gecode/set/select/disjoint.cc +0 -308
  894. data/ext/gecode-2.1.1/gecode/set/select/disjoint.icc +0 -75
  895. data/ext/gecode-2.1.1/gecode/set/select/idxarray.hh +0 -113
  896. data/ext/gecode-2.1.1/gecode/set/select/idxarray.icc +0 -155
  897. data/ext/gecode-2.1.1/gecode/set/select/inter.icc +0 -349
  898. data/ext/gecode-2.1.1/gecode/set/select/union.icc +0 -371
  899. data/ext/gecode-2.1.1/gecode/set/select/unionConst.icc +0 -334
  900. data/ext/gecode-2.1.1/gecode/set/var-imp/set.cc +0 -214
  901. data/ext/gecode-2.1.1/gecode/set/var/set.icc +0 -303
  902. data/ext/gecode-2.1.1/gecode/set/view.icc +0 -1503
  903. data/ext/gecode-2.1.1/gecode/set/view/complement.icc +0 -629
  904. data/ext/gecode-2.1.1/gecode/support/block-allocator.icc +0 -158
  905. data/ext/gecode-2.1.1/gecode/support/config.icc.in +0 -80
  906. data/ext/gecode-2.1.1/gecode/support/sentinel-stack.icc +0 -122
  907. data/ext/gecode-2.1.1/gecode/support/symbol.cc +0 -226
  908. data/ext/gecode-2.1.1/gecode/support/symbol.icc +0 -130
  909. data/ext/gecode-2.1.1/misc/gecode-gist.pc.in +0 -45
  910. data/ext/gecode-2.1.1/misc/gecode-minimodel.pc.in +0 -45
  911. data/ext/gecode-2.1.1/misc/gecode-search.pc.in +0 -45
  912. data/ext/gecode-2.1.1/misc/gecode-serialization.pc.in +0 -45
  913. data/ext/gecode-2.1.1/misc/gecode.pc.in +0 -45
  914. data/ext/gecode-2.1.1/misc/genstatistics.perl +0 -178
  915. data/ext/gecode-2.1.1/misc/genvariables.perl +0 -905
  916. data/lib/gecoder/interface/constraints/set_enum/select.rb +0 -79
  917. data/lib/gecoder/interface/model.rb +0 -453
  918. data/lib/gecoder/interface/model_sugar.rb +0 -84
  919. data/specs/constraints/set_enum/select.rb +0 -73
@@ -0,0 +1,1213 @@
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-07-11 09:39:08 +0200 (Fri, 11 Jul 2008) $ by $Author: tack $
11
+ * $Revision: 7297 $
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, bool assigned=false);
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
+ /// Return whether variable is assigned
324
+ bool assigned(void) const;
325
+ // Get the variable type identifier for this variable
326
+ Support::Symbol vti(void) const;
327
+ };
328
+
329
+ /**
330
+ * \brief %Actor specification
331
+ *
332
+ * An ActorSpec contains all the information that characterizes an Actor.
333
+ * The specifications for all the actors in a Space object can be accessed
334
+ * using an ActorSpecIter.
335
+ *
336
+ * Each ActorSpec describes either a Branching or a Propagator
337
+ * (reflected by ActorSpec::isBranching). As a user of the Reflection API,
338
+ * you can access the information describing an Actor as an array of
339
+ * arguments, represented as objects of the Arg class.
340
+ *
341
+ * Every propagator and branching must be able to return a specification
342
+ * through the virtual function Actor::spec. If you use one of the
343
+ * convenience classes like BinaryPropagator, have a look at the
344
+ * implementation of AbsBnd::spec. If you subclass Propagator directly, or
345
+ * you have additional arguments that have to be put into the ActorSpec,
346
+ * please look at BinaryPropagator::spec.
347
+ *
348
+ * \ingroup TaskReflection
349
+ */
350
+ class GECODE_KERNEL_EXPORT ActorSpec {
351
+ friend class BranchingSpec;
352
+ private:
353
+ class Arguments;
354
+ /// The arguments of this actor
355
+ Arguments* _args;
356
+ /// Resize argument array
357
+ void resize(void);
358
+ friend class ActorSpecIter;
359
+ /// Set the queue of the actor to \a q
360
+ void queue(int q);
361
+ /** \brief Return identifier of the branching
362
+ * Only valid if isBranching returns true
363
+ */
364
+ unsigned int branchingId(void) const;
365
+ public:
366
+ /// Construct empty ActorSpec
367
+ ActorSpec(void);
368
+ /// Construct actor specification with \a name
369
+ ActorSpec(const Support::Symbol& name);
370
+ /// Copy constructor
371
+ ActorSpec(const ActorSpec& s);
372
+ /// Assignment operator
373
+ const ActorSpec& operator=(const ActorSpec& s);
374
+ /// Destructor
375
+ GECODE_MSC_VIRTUAL ~ActorSpec(void);
376
+
377
+ /// \name Actor information
378
+ //@{
379
+ /// Return actor type identifier
380
+ Support::Symbol ati(void) const;
381
+ /// Return number of arguments
382
+ int noOfArgs(void) const;
383
+ /// Check that the number of arguments is \a n, throw exception otherwise
384
+ void checkArity(int n) const;
385
+ /// Return argument \a i
386
+ Arg* operator[](int i) const;
387
+
388
+ /// Return whether the actor is a branching
389
+ bool isBranching(void) const;
390
+ /** \brief Return queue where the actor is currently scheduled
391
+ * Only valid if isBranching returns false
392
+ */
393
+ int queue(void) const;
394
+ //@}
395
+
396
+ /// \name Populating the specification
397
+ //@{
398
+ /// Add \a arg to the specification (as last argument)
399
+ void add(Arg* arg);
400
+ //@}
401
+ };
402
+
403
+ }}
404
+
405
+ /** \brief Add \a a to specification
406
+ * \relates Gecode::Reflection::ActorSpec
407
+ */
408
+ Gecode::Reflection::ActorSpec
409
+ operator<<(Gecode::Reflection::ActorSpec s, Gecode::Reflection::Arg* arg);
410
+
411
+
412
+ /** \brief Add \a i to specification
413
+ * \relates Gecode::Reflection::ActorSpec
414
+ */
415
+ Gecode::Reflection::ActorSpec
416
+ operator<<(Gecode::Reflection::ActorSpec s, int i);
417
+
418
+ /** \brief Add \a i to specification
419
+ * \relates Gecode::Reflection::ActorSpec
420
+ */
421
+ Gecode::Reflection::ActorSpec
422
+ operator<<(Gecode::Reflection::ActorSpec s, unsigned int i);
423
+
424
+ /** \brief Add \a d to specification, where \a d is cast into an integer
425
+ * \relates Gecode::Reflection::ActorSpec
426
+ */
427
+ Gecode::Reflection::ActorSpec
428
+ operator<<(Gecode::Reflection::ActorSpec s, double i);
429
+
430
+ /* Implementation of ActorSpec operators */
431
+
432
+ forceinline Gecode::Reflection::ActorSpec
433
+ operator<<(Gecode::Reflection::ActorSpec s, Gecode::Reflection::Arg* arg) {
434
+ s.add(arg);
435
+ return s;
436
+ }
437
+ forceinline Gecode::Reflection::ActorSpec
438
+ operator<<(Gecode::Reflection::ActorSpec s, int i) {
439
+ return s << Gecode::Reflection::Arg::newInt(i);
440
+ }
441
+ forceinline Gecode::Reflection::ActorSpec
442
+ operator<<(Gecode::Reflection::ActorSpec s, unsigned int i) {
443
+ return s << Gecode::Reflection::Arg::newInt(static_cast<int>(i));
444
+ }
445
+ forceinline Gecode::Reflection::ActorSpec
446
+ operator<<(Gecode::Reflection::ActorSpec s, double i) {
447
+ return s << Gecode::Reflection::Arg::newInt(static_cast<int>(i));
448
+ }
449
+
450
+ namespace Gecode { namespace Reflection {
451
+
452
+ /**
453
+ * \brief %Branching specification
454
+ *
455
+ * A BranchingSpec contains information about the alternatives of a Space.
456
+ * It is similar to a BranchingDesc, but not opaque: you can query the
457
+ * information.
458
+ *
459
+ * The specification for an alternative is an ArrayArg that may contain
460
+ * strings and references to variables. The concatenation of the strings
461
+ * and variables is a human-readable description of what constraints are
462
+ * posted for the given alternative.
463
+ *
464
+ * \ingroup TaskReflection
465
+ */
466
+ class GECODE_KERNEL_EXPORT BranchingSpec {
467
+ private:
468
+ class Arguments;
469
+ /// The arguments of this branching
470
+ Arguments* _args;
471
+ public:
472
+ /// Default constructor
473
+ BranchingSpec(void);
474
+ /** \brief Construct spec for branching description \a d
475
+ *
476
+ * This constructor is used by a Branching to create a BranchingSpec.
477
+ * As a user of the reflection API, you have to query use the function
478
+ * Gecode::Space::branchingSpec instead.
479
+ *
480
+ */
481
+ BranchingSpec(const BranchingDesc* d);
482
+ /// Copy constructor
483
+ BranchingSpec(const BranchingSpec& s);
484
+ /// Assignment operator
485
+ const BranchingSpec& operator=(const BranchingSpec& s);
486
+ /// Destructor
487
+ GECODE_MSC_VIRTUAL ~BranchingSpec(void);
488
+
489
+ ///\name Branching information
490
+ //@{
491
+ /// Check if specification was created by \a b
492
+ bool createdBy(const ActorSpec& b) const;
493
+ /// Return number of alternatives
494
+ unsigned int alternatives(void) const;
495
+ /// Return specification of alternative \a i
496
+ Arg* operator[](int i) const;
497
+
498
+ /// Return specification of alternative \a i
499
+ Arg*& operator[](int i);
500
+ //@}
501
+ };
502
+
503
+ class VarMap;
504
+
505
+ /**
506
+ * \brief Iterating actor specifications
507
+ *
508
+ * Use this iterator to access specifications of all actors (propagators
509
+ * and branchings) of a space. The iterator also provides access to the
510
+ * corresponding variable map.
511
+ *
512
+ * \ingroup TaskReflection
513
+ */
514
+ class GECODE_KERNEL_EXPORT ActorSpecIter {
515
+ private:
516
+ /// The variable map used by this iterator
517
+ VarMap* m;
518
+ /// The space for which to iterate the actors
519
+ const Space* s;
520
+ /// The queue to iterate
521
+ const ActorLink *active;
522
+ /// The current actor
523
+ const ActorLink *cur;
524
+ /// Whether the current actor is a branching
525
+ bool isBranching;
526
+ public:
527
+ /// Constructor
528
+ ActorSpecIter(const Space*, VarMap&);
529
+ /// %Test whether iterator still has actor specifications or is done
530
+ bool operator()(void) const;
531
+ /// Move iterator to next actor
532
+ void operator++(void);
533
+ /// Return actor specification for current iterator position
534
+ ActorSpec actor(void) const;
535
+ };
536
+
537
+ /**
538
+ * \brief Registry of constraint posting and variable creation functions
539
+ * \ingroup TaskReflection
540
+ */
541
+ class Registry {
542
+ private:
543
+ class RegistryObject;
544
+ RegistryObject* ro;
545
+ public:
546
+ /// The type of constraint posting functions
547
+ typedef void (*poster) (Space*, VarMap&, const ActorSpec&);
548
+ /// The type of variable creation functions
549
+ typedef VarImpBase* (*varCreator) (Space*, VarSpec&);
550
+ /// The type of variable domain constraint functions
551
+ typedef void (*varConstrainer) (Space*, VarImpBase*, VarSpec&);
552
+ /// The type of variable update functions
553
+ typedef VarImpBase* (*varUpdater) (Space*, bool, VarImpBase*);
554
+ /// The type of variable printing functions
555
+ typedef std::ostream& (*varPrinter) (std::ostream&, VarImpBase*);
556
+ /// The type of variable reflection functions
557
+ typedef Arg* (*varSpec) (const Space* home, VarMap& m, VarImpBase*);
558
+
559
+ /// Constructor
560
+ GECODE_KERNEL_EXPORT Registry(void);
561
+ /// Destructor
562
+ GECODE_KERNEL_EXPORT GECODE_MSC_VIRTUAL ~Registry(void);
563
+
564
+ /// Create a new variable in \a home from \a spec and return it
565
+ GECODE_KERNEL_EXPORT VarImpBase*
566
+ createVar(Space* home, VarSpec& spec) const;
567
+
568
+ /// Constrain \a v to \a spec
569
+ GECODE_KERNEL_EXPORT void
570
+ constrainVar(Space* home, VarImpBase* v, VarSpec& spec) const;
571
+
572
+ /// Update variable \a v with type identifier \a vti during cloning
573
+ GECODE_KERNEL_EXPORT VarImpBase*
574
+ updateVariable(Space* home, bool share, VarImpBase* v,
575
+ const Support::Symbol& vti) const;
576
+
577
+ /// Print variable \a v with type identifier \a vti to \a os
578
+ GECODE_KERNEL_EXPORT std::ostream&
579
+ printVariable(std::ostream& os, VarImpBase* v,
580
+ const Support::Symbol& vti) const;
581
+
582
+ /// Reflection for variable \a v with type identifier \a vti
583
+ GECODE_KERNEL_EXPORT Arg*
584
+ spec(const Space* home, VarMap& vm,
585
+ VarImpBase* v, const Support::Symbol& vti) const;
586
+
587
+ /// Post constraint in \a home for \a spec using variables \a vars
588
+ GECODE_KERNEL_EXPORT void
589
+ post(Space* home, VarMap& vm, const ActorSpec& spec) const;
590
+
591
+ /// Register variable creation function for \a vti
592
+ GECODE_KERNEL_EXPORT void add(Support::Symbol vti, varCreator vc);
593
+ /// Register variable domain constraining function for \a vti
594
+ GECODE_KERNEL_EXPORT void add(Support::Symbol vti, varConstrainer vc);
595
+ /// Register variable update function for \a vti
596
+ GECODE_KERNEL_EXPORT void add(Support::Symbol vti, varUpdater vu);
597
+ /// Register variable print function for \a vti
598
+ GECODE_KERNEL_EXPORT void add(Support::Symbol vti, varPrinter vp);
599
+ /// Register variable reflection function for \a vti
600
+ GECODE_KERNEL_EXPORT void add(Support::Symbol vti, varSpec vp);
601
+ /// Register constraint posting function for actor type identifier \a ati
602
+ GECODE_KERNEL_EXPORT void add(const Support::Symbol& ati, poster p);
603
+ /// Print list of all registered posters to \a out
604
+ GECODE_KERNEL_EXPORT void print(std::ostream& out);
605
+ private:
606
+ /// Do not allow copying
607
+ Registry(const Registry&);
608
+ /// Do not allow assignment
609
+ Registry& operator=(const Registry&);
610
+ };
611
+
612
+ /// The registry object \ingroup TaskReflection
613
+ GECODE_KERNEL_EXPORT Registry& registry(void);
614
+
615
+ /** \brief Class used for registering actors
616
+ *
617
+ * \ingroup TaskReflection
618
+ *
619
+ * The registered Actor class \a P has to provide two functions:
620
+ * - static Support::Symbol ati(void)
621
+ * - static void post(Space*, const VarMap&, const ActorSpec&)
622
+ */
623
+ template <class P>
624
+ class ActorRegistrar {
625
+ public:
626
+ /// Default constructor
627
+ ActorRegistrar(void);
628
+ };
629
+
630
+ template <class P>
631
+ ActorRegistrar<P>::ActorRegistrar(void) {
632
+ registry().add(P::ati(), &P::post);
633
+ }
634
+
635
+ /** \brief Class used for registering variable implementations
636
+ *
637
+ * \ingroup TaskReflection
638
+ *
639
+ * The registered variable implementation class \a V has to
640
+ * provide two functions:
641
+ * - static void create(Space*, Reflection::VarSpec&)
642
+ * - static void contrain(Space*, VarImpBase*, Reflection::VarSpec&)
643
+ */
644
+ template <class V>
645
+ class VarImpRegistrar {
646
+ private:
647
+ static VarImpBase* updateVar(Space* home, bool share, VarImpBase* v);
648
+ static std::ostream& printVar(std::ostream& os, VarImpBase* v);
649
+ static Reflection::Arg* spec(const Space* home, Reflection::VarMap& m,
650
+ VarImpBase* v);
651
+ public:
652
+ /// Default constructor
653
+ VarImpRegistrar(void);
654
+ };
655
+
656
+ template <class V>
657
+ VarImpBase*
658
+ VarImpRegistrar<V>::updateVar(Space* home, bool share, VarImpBase* v) {
659
+ typedef typename VarImpVarTraits<V>::Var Var;
660
+ typedef typename VarViewTraits<Var>::View View;
661
+ View view(static_cast<V*>(v));
662
+ Var var(view);
663
+ Var varCopy;
664
+ varCopy.update(home, share, var);
665
+ View viewCopy(varCopy);
666
+ return viewCopy.var();
667
+ }
668
+
669
+ template <class V>
670
+ std::ostream&
671
+ VarImpRegistrar<V>::printVar(std::ostream& os, VarImpBase* v) {
672
+ typedef typename VarImpVarTraits<V>::Var Var;
673
+ typedef typename VarViewTraits<Var>::View View;
674
+ View view(static_cast<V*>(v));
675
+ Var var(view);
676
+ return os << var;
677
+ }
678
+
679
+ template <class V>
680
+ Reflection::Arg*
681
+ VarImpRegistrar<V>::spec(const Space* home, Reflection::VarMap& m,
682
+ VarImpBase* v) {
683
+ typedef typename VarImpVarTraits<V>::Var Var;
684
+ typedef typename VarViewTraits<Var>::View View;
685
+ View view(static_cast<V*>(v));
686
+ return view.spec(home, m);
687
+ }
688
+
689
+ template <class V>
690
+ VarImpRegistrar<V>::VarImpRegistrar(void) {
691
+ registry().add(V::vti, &V::create);
692
+ registry().add(V::vti, &V::constrain);
693
+ registry().add(V::vti, &VarImpRegistrar<V>::updateVar);
694
+ registry().add(V::vti, &VarImpRegistrar<V>::printVar);
695
+ registry().add(V::vti, &VarImpRegistrar<V>::spec);
696
+ }
697
+
698
+ /**
699
+ * \brief Generic variables
700
+ *
701
+ * \ingroup TaskReflection
702
+ *
703
+ * A generic variable can represent any Gecode variable. It can be
704
+ * used in VarArrays, and it supports generic update during cloning.
705
+ *
706
+ */
707
+ class Var {
708
+ private:
709
+ /// The actual variable
710
+ VarImpBase* _var;
711
+ /// The variable type identifier
712
+ Support::Symbol _vti;
713
+ public:
714
+ /// Default constructor
715
+ Var(void);
716
+ /// Construct from \a v
717
+ template <class VarImp> explicit Var(const VarBase<VarImp>& v);
718
+ /// Construct from \a v
719
+ Var(const Var& v);
720
+ /// Construct from \a var with variable type identifier \a vti
721
+ Var(VarImpBase* var, const Support::Symbol& vti);
722
+ /// Update during cloning
723
+ GECODE_KERNEL_EXPORT void update(Space* home, bool share, Var& v);
724
+ /// Output to \a os
725
+ GECODE_KERNEL_EXPORT std::ostream& print(std::ostream& os) const;
726
+ /// Reflection
727
+ GECODE_KERNEL_EXPORT Arg* spec(const Space* home, VarMap& vm) const;
728
+ /// Cast to variable implementation base
729
+ VarImpBase* varImpBase(void) const;
730
+ /// Cast to concrete variable type
731
+ template <class VarImp>
732
+ VarImp* var(void) const;
733
+ };
734
+
735
+ /**
736
+ * \brief Unreflection from VarSpec and ActorSpec
737
+ * \ingroup TaskReflection
738
+ *
739
+ * An Unreflector allows you to install variables and propagators in a
740
+ * Space using variable and actor specifications.
741
+ *
742
+ */
743
+ class GECODE_KERNEL_EXPORT Unreflector {
744
+ private:
745
+ /// The space in which to create variables and post constraints
746
+ Space* home;
747
+ /// The VarMap that indicates which variables to reuse
748
+ Reflection::VarMap& m;
749
+
750
+ public:
751
+ /// Constructor
752
+ Unreflector(Space* home0, Reflection::VarMap& m0);
753
+
754
+ /// Destructor
755
+ GECODE_MSC_VIRTUAL ~Unreflector(void);
756
+
757
+ /// Return the VarMap
758
+ Reflection::VarMap& varMap(void) const;
759
+
760
+ /// Create a new variable from \a spec
761
+ void var(Reflection::VarSpec& spec);
762
+
763
+ /// Post the constraint defined by \a spec
764
+ void post(Reflection::ActorSpec& spec);
765
+ };
766
+
767
+ forceinline
768
+ Var::Var(void) {}
769
+
770
+ template <class VarImp>
771
+ forceinline
772
+ Var::Var(const VarBase<VarImp>& v) {
773
+ _var = v.var();
774
+ _vti = v.var()->vti;
775
+ }
776
+
777
+ forceinline
778
+ Var::Var(const Var& v) : _var(v._var), _vti(v._vti) {}
779
+
780
+ forceinline
781
+ Var::Var(VarImpBase* var, const Support::Symbol& vti)
782
+ : _var(var), _vti(vti) {}
783
+
784
+ forceinline VarImpBase*
785
+ Var::varImpBase(void) const {
786
+ return static_cast<VarImpBase*>(_var);
787
+ }
788
+
789
+ template <class VarImp>
790
+ inline VarImp*
791
+ Var::var(void) const {
792
+ if (! (VarImp::vti == _vti))
793
+ throw ReflectionException("VTI mismatch");
794
+ return static_cast<VarImp*>(_var);
795
+ }
796
+
797
+ /** \addtogroup TaskReflection
798
+ * @{
799
+ */
800
+
801
+ /// Register a propagator with zero or one template argument
802
+ #define GECODE_REGISTER1(P) \
803
+ ::Gecode::Reflection::ActorRegistrar< P > GECODE_FRESH(r)
804
+ /// Register a propagator with two template arguments
805
+ #define GECODE_REGISTER2(P1,P2) \
806
+ ::Gecode::Reflection::ActorRegistrar< P1,P2 > GECODE_FRESH(r)
807
+ /// Register a propagator with three template arguments
808
+ #define GECODE_REGISTER3(P1,P2,P3) \
809
+ ::Gecode::Reflection::ActorRegistrar< P1,P2,P3 > GECODE_FRESH(r)
810
+ /// Register a propagator with four template arguments
811
+ #define GECODE_REGISTER4(P1,P2,P3,P4) \
812
+ ::Gecode::Reflection::ActorRegistrar< P1,P2,P3,P4 > GECODE_FRESH(r)
813
+ /// Register a propagator with five template arguments
814
+ #define GECODE_REGISTER5(P1,P2,P3,P4,P5) \
815
+ ::Gecode::Reflection::ActorRegistrar< P1,P2,P3,P4,P5 > GECODE_FRESH(r)
816
+ /// Register a propagator with six template arguments
817
+ #define GECODE_REGISTER6(P1,P2,P3,P4,P5,P6) \
818
+ ::Gecode::Reflection::ActorRegistrar< P1,P2,P3,P4,P5,P6 > GECODE_FRESH(r)
819
+
820
+ //@}
821
+
822
+ /**************************************
823
+ * Implementations
824
+ **************************************/
825
+
826
+ template <class A>
827
+ IntArrayArg*
828
+ Arg::newIntArray(const A& a) {
829
+ IntArrayArg* ret = Arg::newIntArray(a.size());
830
+ for (int i=a.size(); i--;)
831
+ (*ret)[i] = a[i];
832
+ return ret;
833
+ }
834
+
835
+ /** \addtogroup TaskReflection
836
+ * @{
837
+ */
838
+
839
+ /** \brief String representation for View types, used for name mangling
840
+ */
841
+ template <class View>
842
+ class TypeOf {
843
+ public:
844
+ /// Return string representation
845
+ static Support::Symbol t(void) { return View::type(); }
846
+ };
847
+
848
+ /** \brief String representation for bool, used for name mangling
849
+ */
850
+ template <>
851
+ class TypeOf<bool> {
852
+ public:
853
+ /// Return string representation
854
+ static Support::Symbol t(void) { return Support::Symbol("bool"); }
855
+ };
856
+
857
+ /** \brief String representation for ints, used for name mangling
858
+ */
859
+ template <>
860
+ class TypeOf<int> {
861
+ public:
862
+ /// Return string representation
863
+ static Support::Symbol t(void) { return Support::Symbol("int"); }
864
+ };
865
+
866
+ /** \brief String representation for doubles, used for name mangling
867
+ */
868
+ template <>
869
+ class TypeOf<double> {
870
+ public:
871
+ /// Return string representation
872
+ static Support::Symbol t(void) { return Support::Symbol("double"); }
873
+ };
874
+
875
+ //@}
876
+
877
+ }
878
+ class IntSet;
879
+ namespace Reflection {
880
+
881
+ /** \addtogroup TaskReflection
882
+ * @{
883
+ */
884
+
885
+ /** \brief String representation for IntSets, used for name mangling
886
+ */
887
+ template <>
888
+ class TypeOf<const IntSet> {
889
+ public:
890
+ /// Return string representation
891
+ static Support::Symbol t(void) { return Support::Symbol("IntSet"); }
892
+ };
893
+
894
+ /// Mangle ati with type information
895
+ template <class View0>
896
+ Support::Symbol
897
+ mangle(const Support::Symbol& ati) {
898
+ Support::Symbol mangled = ati.copy();
899
+ mangled += "<";
900
+ mangled += TypeOf<View0>::t();
901
+ mangled += ">";
902
+ return mangled;
903
+ }
904
+ /// Mangle ati with type information
905
+ template <class View0>
906
+ Support::Symbol
907
+ mangle(const Support::Symbol& ati, bool b) {
908
+ Support::Symbol mangled = ati.copy();
909
+ mangled += "<";
910
+ mangled += TypeOf<View0>::t();
911
+ mangled += ",";
912
+ mangled += Support::Symbol(b);
913
+ mangled += ">";
914
+ return mangled;
915
+ }
916
+ /// Mangle ati with type information
917
+ template <class View0>
918
+ Support::Symbol
919
+ mangle(const Support::Symbol& ati, int i) {
920
+ Support::Symbol mangled = ati.copy();
921
+ mangled += "<";
922
+ mangled += TypeOf<View0>::t();
923
+ mangled += ",";
924
+ mangled += Support::Symbol(i);
925
+ mangled += ">";
926
+ return mangled;
927
+ }
928
+ /// Mangle ati with type information
929
+ template <class View0>
930
+ Support::Symbol
931
+ mangle(const Support::Symbol& ati, unsigned int i) {
932
+ Support::Symbol mangled = ati.copy();
933
+ mangled += "<";
934
+ mangled += TypeOf<View0>::t();
935
+ mangled += ",";
936
+ mangled += Support::Symbol(i);
937
+ mangled += ">";
938
+ return mangled;
939
+ }
940
+ /// Mangle ati with type information
941
+ template <class View0, class View1>
942
+ Support::Symbol
943
+ mangle(const Support::Symbol& ati) {
944
+ Support::Symbol mangled = ati.copy();
945
+ mangled += "<";
946
+ mangled += TypeOf<View0>::t();
947
+ mangled += ",";
948
+ mangled += TypeOf<View1>::t();
949
+ mangled += ">";
950
+ return mangled;
951
+ }
952
+ /// Mangle ati with type information
953
+ template <class View0, class View1>
954
+ Support::Symbol
955
+ mangle(const Support::Symbol& ati, bool b) {
956
+ Support::Symbol mangled = ati.copy();
957
+ mangled += "<";
958
+ mangled += TypeOf<View0>::t();
959
+ mangled += ",";
960
+ mangled += TypeOf<View1>::t();
961
+ mangled += ",";
962
+ mangled += Support::Symbol(b);
963
+ mangled += ">";
964
+ return mangled;
965
+ }
966
+ /// Mangle ati with type information
967
+ template <class View0, class View1>
968
+ Support::Symbol
969
+ mangle(const Support::Symbol& ati, int i) {
970
+ Support::Symbol mangled = ati.copy();
971
+ mangled += "<";
972
+ mangled += TypeOf<View0>::t();
973
+ mangled += ",";
974
+ mangled += TypeOf<View1>::t();
975
+ mangled += ",";
976
+ mangled += Support::Symbol(i);
977
+ mangled += ">";
978
+ return mangled;
979
+ }
980
+ /// Mangle ati with type information
981
+ template <class View0, class View1>
982
+ Support::Symbol
983
+ mangle(const Support::Symbol& ati, unsigned int i) {
984
+ Support::Symbol mangled = ati.copy();
985
+ mangled += "<";
986
+ mangled += TypeOf<View0>::t();
987
+ mangled += ",";
988
+ mangled += TypeOf<View1>::t();
989
+ mangled += ",";
990
+ mangled += Support::Symbol(i);
991
+ mangled += ">";
992
+ return mangled;
993
+ }
994
+ /// Mangle ati with type information
995
+ template <class View0, class View1, class View2>
996
+ Support::Symbol
997
+ mangle(const Support::Symbol& ati) {
998
+ Support::Symbol mangled = ati.copy();
999
+ mangled += "<";
1000
+ mangled += TypeOf<View0>::t();
1001
+ mangled += ",";
1002
+ mangled += TypeOf<View1>::t();
1003
+ mangled += ",";
1004
+ mangled += TypeOf<View2>::t();
1005
+ mangled += ">";
1006
+ return mangled;
1007
+ }
1008
+ /// Mangle ati with type information
1009
+ template <class View0, class View1, class View2>
1010
+ Support::Symbol
1011
+ mangle(const Support::Symbol& ati, bool b) {
1012
+ Support::Symbol mangled = ati.copy();
1013
+ mangled += "<";
1014
+ mangled += TypeOf<View0>::t();
1015
+ mangled += ",";
1016
+ mangled += TypeOf<View1>::t();
1017
+ mangled += ",";
1018
+ mangled += TypeOf<View2>::t();
1019
+ mangled += ",";
1020
+ mangled += Support::Symbol(b);
1021
+ mangled += ">";
1022
+ return mangled;
1023
+ }
1024
+ /// Mangle ati with type information
1025
+ template <class View0, class View1, class View2>
1026
+ Support::Symbol
1027
+ mangle(const Support::Symbol& ati, int i) {
1028
+ Support::Symbol mangled = ati.copy();
1029
+ mangled += "<";
1030
+ mangled += TypeOf<View0>::t();
1031
+ mangled += ",";
1032
+ mangled += TypeOf<View1>::t();
1033
+ mangled += ",";
1034
+ mangled += TypeOf<View2>::t();
1035
+ mangled += ",";
1036
+ mangled += Support::Symbol(i);
1037
+ mangled += ">";
1038
+ return mangled;
1039
+ }
1040
+ /// Mangle ati with type information
1041
+ template <class View0, class View1, class View2>
1042
+ Support::Symbol
1043
+ mangle(const Support::Symbol& ati, unsigned int i) {
1044
+ Support::Symbol mangled = ati.copy();
1045
+ mangled += "<";
1046
+ mangled += TypeOf<View0>::t();
1047
+ mangled += ",";
1048
+ mangled += TypeOf<View1>::t();
1049
+ mangled += ",";
1050
+ mangled += TypeOf<View2>::t();
1051
+ mangled += ",";
1052
+ mangled += Support::Symbol(i);
1053
+ mangled += ">";
1054
+ return mangled;
1055
+ }
1056
+ /// Mangle ati with type information
1057
+ template <class View0, class View1, class View2, class View3>
1058
+ Support::Symbol
1059
+ mangle(const Support::Symbol& ati) {
1060
+ Support::Symbol mangled = ati.copy();
1061
+ mangled += "<";
1062
+ mangled += TypeOf<View0>::t();
1063
+ mangled += ",";
1064
+ mangled += TypeOf<View1>::t();
1065
+ mangled += ",";
1066
+ mangled += TypeOf<View2>::t();
1067
+ mangled += ",";
1068
+ mangled += TypeOf<View3>::t();
1069
+ mangled += ">";
1070
+ return mangled;
1071
+ }
1072
+ /// Mangle ati with type information
1073
+ template <class View0, class View1, class View2, class View3>
1074
+ Support::Symbol
1075
+ mangle(const Support::Symbol& ati, bool b) {
1076
+ Support::Symbol mangled = ati.copy();
1077
+ mangled += "<";
1078
+ mangled += TypeOf<View0>::t();
1079
+ mangled += ",";
1080
+ mangled += TypeOf<View1>::t();
1081
+ mangled += ",";
1082
+ mangled += TypeOf<View2>::t();
1083
+ mangled += ",";
1084
+ mangled += TypeOf<View3>::t();
1085
+ mangled += ",";
1086
+ mangled += Support::Symbol(b);
1087
+ mangled += ">";
1088
+ return mangled;
1089
+ }
1090
+ /// Mangle ati with type information
1091
+ template <class View0, class View1, class View2, class View3>
1092
+ Support::Symbol
1093
+ mangle(const Support::Symbol& ati, int i) {
1094
+ Support::Symbol mangled = ati.copy();
1095
+ mangled += "<";
1096
+ mangled += TypeOf<View0>::t();
1097
+ mangled += ",";
1098
+ mangled += TypeOf<View1>::t();
1099
+ mangled += ",";
1100
+ mangled += TypeOf<View2>::t();
1101
+ mangled += ",";
1102
+ mangled += TypeOf<View3>::t();
1103
+ mangled += ",";
1104
+ mangled += Support::Symbol(i);
1105
+ mangled += ">";
1106
+ return mangled;
1107
+ }
1108
+ /// Mangle ati with type information
1109
+ template <class View0, class View1, class View2, class View3>
1110
+ Support::Symbol
1111
+ mangle(const Support::Symbol& ati, unsigned int i) {
1112
+ Support::Symbol mangled = ati.copy();
1113
+ mangled += "<";
1114
+ mangled += TypeOf<View0>::t();
1115
+ mangled += ",";
1116
+ mangled += TypeOf<View1>::t();
1117
+ mangled += ",";
1118
+ mangled += TypeOf<View2>::t();
1119
+ mangled += ",";
1120
+ mangled += TypeOf<View3>::t();
1121
+ mangled += ",";
1122
+ mangled += Support::Symbol(i);
1123
+ mangled += ">";
1124
+ return mangled;
1125
+ }
1126
+
1127
+ /// Mangle ati with type information
1128
+ template <class View0, class View1, class View2, class View3, class View4>
1129
+ Support::Symbol
1130
+ mangle(const Support::Symbol& ati) {
1131
+ Support::Symbol mangled = ati.copy();
1132
+ mangled += "<";
1133
+ mangled += TypeOf<View0>::t();
1134
+ mangled += ",";
1135
+ mangled += TypeOf<View1>::t();
1136
+ mangled += ",";
1137
+ mangled += TypeOf<View2>::t();
1138
+ mangled += ",";
1139
+ mangled += TypeOf<View3>::t();
1140
+ mangled += ",";
1141
+ mangled += TypeOf<View4>::t();
1142
+ mangled += ">";
1143
+ return mangled;
1144
+ }
1145
+ /// Mangle ati with type information
1146
+ template <class View0, class View1, class View2, class View3, class View4>
1147
+ Support::Symbol
1148
+ mangle(const Support::Symbol& ati, bool b) {
1149
+ Support::Symbol mangled = ati.copy();
1150
+ mangled += "<";
1151
+ mangled += TypeOf<View0>::t();
1152
+ mangled += ",";
1153
+ mangled += TypeOf<View1>::t();
1154
+ mangled += ",";
1155
+ mangled += TypeOf<View2>::t();
1156
+ mangled += ",";
1157
+ mangled += TypeOf<View3>::t();
1158
+ mangled += ",";
1159
+ mangled += TypeOf<View4>::t();
1160
+ mangled += ",";
1161
+ mangled += Support::Symbol(b);
1162
+ mangled += ">";
1163
+ return mangled;
1164
+ }
1165
+ /// Mangle ati with type information
1166
+ template <class View0, class View1, class View2, class View3, class View4>
1167
+ Support::Symbol
1168
+ mangle(const Support::Symbol& ati, int i) {
1169
+ Support::Symbol mangled = ati.copy();
1170
+ mangled += "<";
1171
+ mangled += TypeOf<View0>::t();
1172
+ mangled += ",";
1173
+ mangled += TypeOf<View1>::t();
1174
+ mangled += ",";
1175
+ mangled += TypeOf<View2>::t();
1176
+ mangled += ",";
1177
+ mangled += TypeOf<View3>::t();
1178
+ mangled += ",";
1179
+ mangled += TypeOf<View4>::t();
1180
+ mangled += ",";
1181
+ mangled += Support::Symbol(i);
1182
+ mangled += ">";
1183
+ return mangled;
1184
+ }
1185
+ /// Mangle ati with type information
1186
+ template <class View0, class View1, class View2, class View3, class View4>
1187
+ Support::Symbol
1188
+ mangle(const Support::Symbol& ati, unsigned int i) {
1189
+ Support::Symbol mangled = ati.copy();
1190
+ mangled += "<";
1191
+ mangled += TypeOf<View0>::t();
1192
+ mangled += ",";
1193
+ mangled += TypeOf<View1>::t();
1194
+ mangled += ",";
1195
+ mangled += TypeOf<View2>::t();
1196
+ mangled += ",";
1197
+ mangled += TypeOf<View3>::t();
1198
+ mangled += ",";
1199
+ mangled += TypeOf<View4>::t();
1200
+ mangled += ",";
1201
+ mangled += Support::Symbol(i);
1202
+ mangled += ">";
1203
+ return mangled;
1204
+ }
1205
+ //@}
1206
+
1207
+ }}
1208
+
1209
+ /// Print \a v to \a os
1210
+ GECODE_KERNEL_EXPORT std::ostream&
1211
+ operator<<(std::ostream& os, const Gecode::Reflection::Var& v);
1212
+
1213
+ // STATISTICS: kernel-other