SWI-Prolog runtime may need to be built as well.
* TODO Prolog initialization and cleanup
+:PROPERTIES:
+:CUSTOM_ID: prolog-init
+:END:
#+VINDEX: sweep-init-on-load
#+VINDEX: sweep-init-args
Prolog bindings created by the query.
** Conversion of Elisp objects to Prolog terms
+:PROPERTIES:
+:CUSTOM_ID: elisp-to-prolog
+:END:
=sweep= converts Elisp objects into Prolog terms to allow the Elisp
programmers to specify arguments for Prolog predicates invocations (see
are the Prolog representations of the =car= and the =cdr= of the cons.
** Conversion of Prolog terms to Elisp objects
+:PROPERTIES:
+:CUSTOM_ID: prolog-to-elisp
+:END:
=sweep= converts Prolog terms into Elisp object to allow efficient
processing of Prolog query results in Elisp (see =sweep-next-solution=).
+ Prolog dicts are converted to the symbol =dict=.
** Example - counting solutions for a Prolog predicate in Elisp
+:PROPERTIES:
+:CUSTOM_ID: count-permutations
+:END:
As an example of using the =sweep= interface for executing Prolog
queries, we show an invocation of the non-deterministic predicate
* The Prolog top-level
+:PROPERTIES:
+:CUSTOM_ID: prolog-top-level
+:END:
#+FINDEX: sweep-top-level
=sweep= provides a classic Prolog top-level interface for interacting
loaded or auto-loadable Prolog predicate.
* Installing Prolog packages
+:PROPERTIES:
+:CUSTOM_ID: prolog-packages
+:END:
#+FINDEX: sweep-pack-install
The command =M-x sweep-pack-install= can be used to install