summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorJosh Essman <68349992+joshessman-llnl@users.noreply.github.com>2021-02-23 17:46:37 -0600
committerGitHub <noreply@github.com>2021-02-23 23:46:37 +0000
commit93ed1a410c4a202eab3a68769fd8c0d4ff8b1c8e (patch)
tree459c4073521172e78dd0f0fb17e2ba53bf10ef8b /lib
parent6622856076920cf7b0baa7e5e33e7bc00a85fc32 (diff)
downloadspack-93ed1a410c4a202eab3a68769fd8c0d4ff8b1c8e.tar.gz
spack-93ed1a410c4a202eab3a68769fd8c0d4ff8b1c8e.tar.bz2
spack-93ed1a410c4a202eab3a68769fd8c0d4ff8b1c8e.tar.xz
spack-93ed1a410c4a202eab3a68769fd8c0d4ff8b1c8e.zip
Updates to support clingo-cffi (#20657)
* Support clingo when used with cffi Clingo recently merged in a new Python module option based on cffi. Compatibility with this module requires a few changes to spack - it does not automatically convert strings/ints/etc to Symbol and clingo.Symbol.string throws on failure. manually convert str/int to clingo.Symbol types catch stringify exceptions add job for clingo-cffi to Spack CI switch to potassco-vendored wheel for clingo-cffi CI on_unsat argument when cffi
Diffstat (limited to 'lib')
-rw-r--r--lib/spack/spack/solver/asp.py28
1 files changed, 19 insertions, 9 deletions
diff --git a/lib/spack/spack/solver/asp.py b/lib/spack/spack/solver/asp.py
index 3c00f4a968..661a4582ae 100644
--- a/lib/spack/spack/solver/asp.py
+++ b/lib/spack/spack/solver/asp.py
@@ -18,6 +18,8 @@ import archspec.cpu
try:
import clingo
+ # There may be a better way to detect this
+ clingo_cffi = hasattr(clingo.Symbol, '_rep')
except ImportError:
clingo = None # type: ignore
@@ -119,11 +121,11 @@ class AspFunction(AspObject):
def symbol(self, positive=True):
def argify(arg):
if isinstance(arg, bool):
- return str(arg)
+ return clingo.String(str(arg))
elif isinstance(arg, int):
- return arg
+ return clingo.Number(arg)
else:
- return str(arg)
+ return clingo.String(str(arg))
return clingo.Function(
self.name, [argify(arg) for arg in self.args], positive=positive)
@@ -318,18 +320,26 @@ class PyclingoDriver(object):
def on_model(model):
models.append((model.cost, model.symbols(shown=True, terms=True)))
- solve_result = self.control.solve(
- assumptions=self.assumptions,
- on_model=on_model,
- on_core=cores.append
- )
+ solve_kwargs = {"assumptions": self.assumptions,
+ "on_model": on_model,
+ "on_core": cores.append}
+ if clingo_cffi:
+ solve_kwargs["on_unsat"] = cores.append
+ solve_result = self.control.solve(**solve_kwargs)
timer.phase("solve")
# once done, construct the solve result
result.satisfiable = solve_result.satisfiable
def stringify(x):
- return x.string or str(x)
+ if clingo_cffi:
+ # Clingo w/ CFFI will throw an exception on failure
+ try:
+ return x.string
+ except RuntimeError:
+ return str(x)
+ else:
+ return x.string or str(x)
if result.satisfiable:
builder = SpecBuilder(specs)