- Documentation
- Reference manual
- Modules
- Why Use Modules?
- Defining a Module
- Importing Predicates into a Module
- Controlled autoloading for modules
- Defining a meta-predicate
- Overruling Module Boundaries
- Interacting with modules from the top level
- Composing modules from other modules
- Operators and modules
- Dynamic importing using import modules
- Reserved Modules and using the‘user’module
- An alternative import/export interface
- Dynamic Modules
- Transparent predicates: definition and context module
- Module properties
- Compatibility of the Module System
- Modules
- Packages
- Reference manual
6.15 Module properties
The following predicates can be used to query the module system for reflexive programming:
- [nondet]current_module(?Module)
- True if Module is a currently defined module. This predicate enumerates all modules, whether loaded from a file or created dynamically. Note that modules cannot be destroyed in the current version of SWI-Prolog.
- module_property(?Module, ?Property)
- True if Property is a property of Module. Defined
properties are:
- class(-Class)
- True when Class is the class of the module. Defined classes
are
- user
- Default for user-defined modules.
- system
- Module
system
and modules from<home>/boot
. - library
- Other modules from the system directories.
- temporary
- Module is temporary.
- test
- Modules that create tests.
- development
- Modules that only support the development environment.
- file(?File)
- True if Module was loaded from File.
- line_count(-Line)
- True if Module was loaded from the N-th line of file.
- exports(-ListOfPredicateIndicators)
- True if Module exports the given predicates. Predicate indicators are in canonical form (i.e., always using name/arity and never the DCG form name//arity). Future versions may also use the DCG form. See also predicate_property/2. Succeeds with an empty list if the module exports no predicates.
- exported_operators(-ListOfOperators)
- True if Module exports the given operators. Each exported
operator is represented as a term
op(Pri,Assoc,Name)
. Succeeds with an empty list if the module exports no operators. - size(-Bytes)
- Total size in bytes used to represent the module. This includes the
module itself, its (hash) tables and the summed size of all predicates
defined in this module. See also the
size(Bytes)
property in predicate_property/2. - program_size(-Bytes)
- Memory (in bytes) used for storing the predicates of this module. This figure includes the predicate header and clauses.
- program_space(-Bytes)
- If present, this number limits the
program_size
. See set_module/1. - last_modified_generation(-Generation)
- Integer expression the last database generation where a clause was added or removed from a predicate that is implemented in this module. See also predicate_property/2.
- set_module(:Property)
- Modify properties of the module. Currently, the following properties may
be modified:
- base(+Base)
- Set the default import module of the current module to Module.
Typically, Module is one of
user
orsystem
. See section 6.10. - class(+Class)
- Set the class of the module. See module_property/2.
- program_space(+Bytes)
- Maximum amount of memory used to store the predicates defined inside the
module. Raises a permission error if the current usage is above the
requested limit. Setting the limit to 0 (zero) removes the limit. An
attempt to assert clauses that causes the limit to be exceeded causes a
resource_error(program_space)
exception. See assertz/1 and module_property/2.