[ Obsolete | Reference Manual | Alphabetic Index ]
autoload(+Library, ++ListOfPredSpecList)
Declares the predicates in ListOfPredSpec to be autoloading from the module
Library, which is in the file Library.pl in one of the library directories.
- Library
- Atom.
- ListOfPredSpecList
- of expressions of the form Atom/Integer.
This built-in predicate is obsolete!
Description
Declares the predicates in the list ListOfPredSpec as defined in the
file Library. If any of the specified predicates is called, the system
looks in the library_path directories for the file Library.pl, compiles
it using lib/2 and then re-calls the predicate. The file is supposed to
contain a module_interface/1 or begin_module/1 directive at its
beginning but it can be omitted and then Library is used as the module
name.
Predicates declared as autoloaded are always defined as global but note
that the module directive in a file erases the module completely so that
the autoloaded procedure (and its visibility) are removed completely
before being recompiled. This means that the global declaration must be
present in the file.
The predicate autoload_tool/2 is the same except that all the predicates
are declared to be tools, using tool/1.
Modes and Determinism
Exceptions
- (4) instantiation fault
- Library or ListOfPredSpec is not instantiated.
- (5) type error
- Library is instantiated, but not to an atom.
- (5) type error
- ListOfPredSpec is instantiated, but not to list a of expressions of the form Atom/Integer.
- (173) library not found
- Library file Library.pl not found. (when calling an autoloaded predicate)
Examples
Success:
[eclipse]: get_flag(library_path, Path),
get_flag(cwd, Cwd),
set_flag(library_path, [Cwd | Path]).
Cwd = "/home/user/"
Path = ["/usr/local/ECLIPSE/lib"]
yes.
[eclipse]: open("my_lib.pl", write, s),
write(s, ":- module(my_lib).\n"),
write(s, ":- global p/0.\n"),
write(s, "p :- write(hello).\n"),
close(s).
yes.
[eclipse]: autoload(my_lib, [p/0]).
yes.
[eclipse]: p. % when p/0 is called, the library is
% compiled first, ie. autoloaded.
loading the library /home/user/my_lib.pl
hello
yes.
[eclipse]: p. % p/0 is not an autoloaded pred anymore
hello
yes.
Error:
autoload(Lib, [p/0]). (Error 4).
autoload(a_lib, L). (Error 4).
autoload(a_lib, [1]). (Error 5).
autoload(a_lib, p/0). (Error 5).
autoload("a_lib", [p/0]). (Error 5).
autoload(no_file, [p/0]). (Error 173).
See Also
ensure_loaded / 1, autoload_tool / 2, lib / 1, lib / 2, tool / 1