gensym
The gensym
library implements predicates for generating unique
atoms. The public predicates are declared synchronized to prevent race
conditions when using a backend Prolog compiler with multi-threading
support.
API documentation
Open the ../../docs/library_index.html#gensym link in a web browser.
Loading
To load all entities in this library, load the loader.lgt
file:
| ?- logtalk_load(gensym(loader)).
Testing
To test this library predicates, load the tester.lgt
file:
| ?- logtalk_load(gensym(tester)).
Usage
The gensym_core
category implements the library predicates. This
category is imported by the default gensym
object to provide
application global generators. To make the generators local and thus
minimize the potential for generator name clashes, the category can be
imported by one or more application objects. Use protected or private
import to restrict the scope of the library predicates. For example:
:- object(foo,
imports(private::gensym_core)).
bar :-
^^gensym(p, S),
...
:- end_object.