- swipl
- library
- error.pl
- debug.pl
- apply.pl
- lists.pl
- broadcast.pl -- Event service
- predicate_options.pl -- Access and analyse predicate options
- shlib.pl -- Utility library for loading foreign objects (DLLs, shared objects)
- option.pl -- Option list processing
- thread_pool.pl -- Resource bounded thread management
- gensym.pl -- Generate unique symbols
- settings.pl
- arithmetic.pl
- main.pl -- Provide entry point for scripts
- readutil.pl -- Read utilities
- operators.pl -- Manage operators
- pairs.pl -- Operations on key-value lists
- prolog_source.pl -- Examine Prolog source-files
- quasi_quotations.pl -- Define Quasi Quotation syntax
- url.pl -- Analysing and constructing URL
- www_browser.pl -- Open a URL in the users browser
- prolog_colour.pl -- Prolog syntax colouring support.
- record.pl -- Access compound arguments by name
- prolog_xref.pl -- Prolog cross-referencer data collection
- occurs.pl -- Finding and counting sub-terms
- ordsets.pl -- Ordered set manipulation
- assoc.pl -- Binary associations
- ugraphs.pl -- Graph manipulation library
- iostream.pl -- Utilities to deal with streams
- atom.pl -- Operations on atoms
- prolog_pack.pl -- A package manager for Prolog
- solution_sequences.pl -- Modify solution sequences
- git.pl -- Run GIT commands
- ctypes.pl -- Character code classification
- utf8.pl -- UTF-8 encoding/decoding on lists of character codes.
- base64.pl -- Base64 encoding and decoding
- persistency.pl -- Provide persistent dynamic predicates
- pure_input.pl -- Pure Input from files and streams
- nb_set.pl -- Non-backtrackable sets
- aggregate.pl -- Aggregation operators on backtrackable predicates
- csv.pl -- Process CSV (Comma-Separated Values) data
- dialect.pl -- Support multiple Prolog dialects
- apply_macros.pl -- Goal expansion rules to avoid meta-calling
- yall.pl -- Lambda expressions
- prolog_code.pl -- Utilities for reasoning about code
- dif.pl -- The dif/2 constraint
- thread.pl -- High level thread primitives
- rbtrees.pl -- Red black trees
- nb_rbtrees.pl -- Non-backtrackable operations on red black trees
- random.pl -- Random numbers
- sandbox.pl -- Sandboxed Prolog code
- prolog_format.pl -- Analyse format specifications
- pprint.pl -- Pretty Print Prolog terms
- modules.pl -- Module utility predicates
- lazy_lists.pl -- Lazy list handling
- edinburgh.pl -- Some traditional Edinburgh predicates
- prolog_clause.pl -- Get detailed source-information about a clause
- prolog_breakpoints.pl -- Manage Prolog break-points
- dicts.pl -- Dict utilities
- help.pl -- Text based manual
- tty.pl -- Terminal operations
- backcomp.pl -- Backward compatibility
- date.pl -- Process dates and times
- listing.pl -- List programs and pretty print clauses
- prolog_profile.pl -- Execution profiler
- quintus.pl -- Quintus compatibility
- charsio.pl -- I/O on Lists of Character Codes
- prolog_autoload.pl -- Autoload all dependencies
- check.pl -- Consistency checking
- optparse.pl -- command line parsing
- base32.pl -- Base32 encoding and decoding
- codesio.pl -- I/O on Lists of Character Codes
- coinduction.pl -- Co-Logic Programming
- heaps.pl -- heaps/priority queues
- sort.pl
- statistics.pl -- Get information about resource usage
- terms.pl -- Term manipulation
- varnumbers.pl -- Utilities for numbered terms
- when.pl -- Conditional coroutining
- ansi_term.pl -- Print decorated text to ANSI consoles
- strings.pl -- String utilities
- explain.pl -- Describe Prolog Terms
- threadutil.pl -- Interactive thread utilities
- prolog_stack.pl -- Examine the Prolog stack
- edit.pl -- Editor interface
- make.pl -- Reload modified source files
- prolog_codewalk.pl -- Prolog code walker
- prolog_metainference.pl -- Infer meta-predicate properties
- wfs.pl -- Well Founded Semantics interface
- prolog_config.pl -- Provide configuration information
- zip.pl -- Access resource ZIP archives
- oset.pl -- Ordered set manipulation
- tables.pl -- XSB interface to tables
- prolog_trace.pl -- Print access to predicates
- portray_text.pl -- Portray text
- shell.pl -- Elementary shell commands
- hashtable.pl -- Hash tables
- prolog_wrap.pl -- Wrapping predicates
- win_menu.pl -- Console window menu
- system.pl -- System utilities
- prolog_debug.pl -- User level debugging tools
- prolog_coverage.pl -- Coverage analysis tool
- files.pl
- rwlocks.pl -- Read/write locks
- macros.pl -- Macro expansion
- intercept.pl -- Intercept and signal interface
- prolog_versions.pl -- Demand specific (Prolog) versions
- writef.pl -- Old-style formatted write
- fastrw.pl -- Fast reading and writing of terms
- prolog_jiti.pl -- Just In Time Indexing (JITI) utilities
- qsave.pl -- Save current program as a state or executable
- increval.pl -- Incremental dynamic predicate modification
- streams.pl -- Manage Prolog streams
- prolog_history.pl -- Per-directory persistent commandline history
- library
- prolog_walk_code(+Options) is det
- Walk over all loaded (user) Prolog code. The following code is
processed:
- The bodies of all clauses in all user and library modules. This steps collects, but does not scan multifile predicates to avoid duplicate work.
- All multi-file predicates collected.
- All goals registered with initialization/1
Options processed:
- undefined(+Action)
- Action defines what happens if the analysis finds a
definitely undefined predicate. One of
ignore
orerror
(default isignore
). - autoload(+Boolean)
- Try to autoload code while walking. This is enabled by default to obtain as much as possible information about goals and find references from autoloaded libraries.
- clauses(+ListOfClauseReferences)
- Only process the given clauses. Can be used to find clauses
quickly using
source(false)
and then process only interesting clauses with source information. - module(+Module)
- Only process the given module
- module_class(+ModuleClassList)
- Limit processing to modules of the given classes. See
module_property/2 for details on module classes. Default
is to scan the classes
user
andlibrary
. - infer_meta_predicates(+BooleanOrAll)
- Use infer_meta_predicate/2 on predicates with clauses that
call known meta-predicates. The analysis is restarted until
a fixed point is reached. If
true
(default), analysis is only restarted if the inferred meta-predicate contains a callable argument. Ifall
, it will be restarted until no more new meta-predicates can be found. - walk_meta_predicates(Boolean)
- When
false
(defaulttrue
), do not analyse the arguments of meta predicates. Standard Prolog control structures are always analysed. - trace_reference(Callable)
- Print all calls to goals that subsume Callable. Goals are represented as Module:Callable (i.e., they are always qualified). See also subsumes_term/2.
- trace_condition(:Cond)
- Additional filter condition applied after
trace_reference
. Called ascall(Cond, Callee, Context)
, where Context is a dict containing the following keys:- caller:Context
- Qualified term representing the caller or the atom '<initialization>'.
- module:Context
- Module being processed
- clause:Context
- If we are processing a normal clause, the clause reference to this clause.
- initialization:Context
- If we are processing an initialization/1 directive, a term
File:Line
representing the location of the declaration.
- on_edge(:OnEdge)
- If a reference to
trace_reference
is found, callcall(OnEdge, Callee, Caller, Location)
, where Location is a dict containing a subset of the keysclause
,file
,character_count
,line_count
andline_position
. If full position information is available all keys are present. If the clause layout is unknown the only theclause
,file
andline_count
are available and the line is the start line of the clause. For a dynamic clause, only theclause
is present. If the position is associated to a directive, theclause
is missing. If nothing is known the Location is an empty dict. - on_trace(:OnTrace)
- As
on_edge
, but location is not translated and is one of these:clause_term_position(+ClauseRef, +TermPos)
clause(+ClauseRef)
file_term_position(+Path, +TermPos)
file(+File, +Line, -1, _)
- a variable (unknown)
Caller is the qualified head of the calling clause or the atom '<initialization>'.
- source(+Boolean)
- If
false
(defaulttrue
), to not try to obtain detailed source information for printed messages. - verbose(+Boolean)
- If
true
(defaultfalse
), report derived meta-predicates and iterations.@compat OnTrace was called using Caller-Location in older versions.