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.