%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % Adapter file for XVM 10.0.0 and later versions % Last updated on November 12, 2024 % % This file is part of Logtalk % SPDX-FileCopyrightText: 1998-2024 Paulo Moura % SPDX-License-Identifier: Apache-2.0 % % Licensed under the Apache License, Version 2.0 (the "License"); % you may not use this file except in compliance with the License. % You may obtain a copy of the License at % % http://www.apache.org/licenses/LICENSE-2.0 % % Unless required by applicable law or agreed to in writing, software % distributed under the License is distributed on an "AS IS" BASIS, % WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. % See the License for the specific language governing permissions and % limitations under the License. % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % ISO Prolog Standard predicates that we must define because they are % not built-in % % add a clause for '$lgt_iso_predicate'/1 declaring each ISO predicate that % we must define; there must be at least one clause for this predicate % whose call should fail if we don't define any ISO predicates % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_iso_predicate'(?callable). % % table of missing ISO predicates which are defined in this file % remove the following clause if you need to define any ISO predicate '$lgt_iso_predicate'(_) :- fail. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % de facto standard Prolog predicates that might be missing % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % between(+integer, +integer, ?integer) -- built-in % findall(?term, +callable, ?list, +list) -- built-in % forall(+callable, +callable) -- built-in % format(+stream_or_alias, +character_code_list_or_atom, +list) '$lgt_format'(Stream, Format, Arguments) :- format(Stream, Format, Arguments). % format(+character_code_list_or_atom, +list) '$lgt_format'(Format, Arguments) :- format(Format, Arguments). % numbervars(?term, +integer, ?integer) -- built-in %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % predicate properties % % this predicate must return at least static, dynamic, and built_in % properties for an existing predicate (and ideally meta_predicate/1 % properties for built-in predicates and library predicates) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_predicate_property'(+callable, ?predicate_property) '$lgt_predicate_property'(Pred, Prop) :- predicate_property(Pred, Prop). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % meta-predicates % % the setup_call_cleanup/3 meta-predicate is only strictly required if % the backend Prolog compiler supports a compatible multi-threading % implementation but the developer tools can also take advantage of it % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % setup_call_cleanup(+callable, +callable, +callable) -- built-in %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % Prolog non-standard built-in meta-predicates and meta-directives % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_prolog_meta_predicate'(@callable, ?callable, ?atom) % % table of meta-predicate patterns for proprietary built-in predicates; % the third argument, which must be either "predicate" or "control_construct", % is used to guide the compilation of these meta-predicates in debug mode '$lgt_prolog_meta_predicate'(Callable, Template, Kind) :- predicate_property(Callable, meta_predicate(Template)), predicate_property(Callable, built_in), ( predicate_property(Callable, control_construct) -> Kind = control_construct ; Kind = predicate ), !. % '$lgt_prolog_meta_directive'(@callable, -callable) '$lgt_prolog_meta_directive'(_, _) :- fail. % '$lgt_prolog_to_logtalk_meta_argument_specifier_hook'(@nonvar, -atom) '$lgt_prolog_to_logtalk_meta_argument_specifier_hook'(_, _) :- fail. % '$lgt_prolog_phrase_predicate'(@callable) % % table of predicates that call non-terminals % (other than the de facto standard phrase/2-3 predicates) '$lgt_prolog_phrase_predicate'(_) :- fail. % '$lgt_candidate_tautology_or_falsehood_goal_hook'(@callable) % % valid candidates are proprietary built-in predicates with no % side-effects when called with ground arguments '$lgt_candidate_tautology_or_falsehood_goal_hook'(?=(_, _)). '$lgt_candidate_tautology_or_falsehood_goal_hook'(atom_number(_, _)). '$lgt_candidate_tautology_or_falsehood_goal_hook'(attvar(_)). '$lgt_candidate_tautology_or_falsehood_goal_hook'(cyclic_term(_)). '$lgt_candidate_tautology_or_falsehood_goal_hook'(dif(_, _)). '$lgt_candidate_tautology_or_falsehood_goal_hook'(is_list(_)). '$lgt_candidate_tautology_or_falsehood_goal_hook'(is_list_or_partial_list(_)). '$lgt_candidate_tautology_or_falsehood_goal_hook'(is_partial_list(_)). '$lgt_candidate_tautology_or_falsehood_goal_hook'(plus(_, _, _)). '$lgt_candidate_tautology_or_falsehood_goal_hook'(succ(_, _)). % '$lgt_prolog_database_predicate'(@callable) % % table of non-standard database built-in predicates '$lgt_prolog_database_predicate'(assert(_)). '$lgt_prolog_database_predicate'(assert(_, _)). '$lgt_prolog_database_predicate'(asserta(_, _)). '$lgt_prolog_database_predicate'(assertz(_, _)). '$lgt_prolog_database_predicate'(clause(_, _, _)). '$lgt_prolog_database_predicate'(listing(_)). '$lgt_prolog_database_predicate'(listing(_, _)). % '$lgt_prolog_predicate_property'(?callable) % % table of proprietary predicate properties; used by the % compiler when checking if a predicate property is valid '$lgt_prolog_predicate_property'(control_construct). '$lgt_prolog_predicate_property'(discontiguous). '$lgt_prolog_predicate_property'(disk_predicate(_)). '$lgt_prolog_predicate_property'(file(_)). '$lgt_prolog_predicate_property'(foreign). '$lgt_prolog_predicate_property'(hidden_clauses). '$lgt_prolog_predicate_property'(indexed). '$lgt_prolog_predicate_property'(last_modified_generation(_)). '$lgt_prolog_predicate_property'(line_). '$lgt_prolog_predicate_property'(number_of_clauses(_)). '$lgt_prolog_predicate_property'(spy). % '$lgt_prolog_deprecated_built_in_predicate_hook'(?callable, ?callable) % % table of proprietary deprecated built-in predicates % when there's a Prolog system advised alternative '$lgt_prolog_deprecated_built_in_predicate_hook'(_, _) :- fail. % '$lgt_prolog_deprecated_built_in_predicate_hook'(?callable) % % table of proprietary deprecated built-in predicates without % a direct advised alternative '$lgt_prolog_deprecated_built_in_predicate_hook'(_) :- fail. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % file name extension predicates % % these extensions are used by Logtalk load/compile predicates % % you may want to change the extension for the intermediate files % generated by the Logtalk compiler ("object" files) to match the % extension expected by default by your Prolog compiler % % there should only a single extension defined for object files but % but multiple extensions can be defined for Logtalk and Prolog source % files and for backend specific temporary files % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_file_extension'(?atom, ?atom) '$lgt_file_extension'(logtalk, '.lgt'). '$lgt_file_extension'(logtalk, '.logtalk'). % there must be a single object file extension '$lgt_file_extension'(object, '.pl'). '$lgt_file_extension'(prolog, '.pl'). '$lgt_file_extension'(prolog, '.prolog'). '$lgt_file_extension'(prolog, '.pro'). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % backend Prolog compiler features % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_prolog_feature'(?atom, ?atom) % % backend Prolog compiler supported features (that are compatible with Logtalk) '$lgt_prolog_feature'(prolog_dialect, xvm). '$lgt_prolog_feature'(prolog_version, v(Major, Minor, Patch)) :- current_prolog_flag(version_data, xvm(Major, Minor, Patch, _)). '$lgt_prolog_feature'(prolog_compatible_version, '@>='(v(10, 0, 0))). '$lgt_prolog_feature'(encoding_directive, source). '$lgt_prolog_feature'(tabling, unsupported). '$lgt_prolog_feature'(engines, Engines) :- ( predicate_property(message_queue_create(_, _), built_in) -> Engines = supported ; Engines = unsupported ). '$lgt_prolog_feature'(threads, Threads) :- ( predicate_property(message_queue_create(_, _), built_in) -> Threads = supported ; Threads = unsupported ). '$lgt_prolog_feature'(modules, unsupported). '$lgt_prolog_feature'(coinduction, Coinduction) :- ( catch(current_prolog_flag(unify_applies_occurs_check, true), _, fail) -> Coinduction = supported ; Coinduction = unsupported ). '$lgt_prolog_feature'(unicode, full). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % default flag values % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_default_flag'(?atom, ?atom) % % default values for all flags % startup flags: '$lgt_default_flag'(settings_file, allow). % lint compilation flags: '$lgt_default_flag'(linter, default). '$lgt_default_flag'(general, warning). '$lgt_default_flag'(encodings, warning). '$lgt_default_flag'(unknown_entities, warning). '$lgt_default_flag'(unknown_predicates, warning). '$lgt_default_flag'(undefined_predicates, warning). '$lgt_default_flag'(singleton_variables, warning). '$lgt_default_flag'(steadfastness, silent). '$lgt_default_flag'(naming, silent). '$lgt_default_flag'(duplicated_clauses, silent). '$lgt_default_flag'(left_recursion, warning). '$lgt_default_flag'(tail_recursive, silent). '$lgt_default_flag'(disjunctions, warning). '$lgt_default_flag'(conditionals, warning). '$lgt_default_flag'(catchall_catch, silent). '$lgt_default_flag'(portability, silent). '$lgt_default_flag'(redefined_built_ins, silent). '$lgt_default_flag'(redefined_operators, warning). '$lgt_default_flag'(deprecated, warning). '$lgt_default_flag'(missing_directives, warning). '$lgt_default_flag'(duplicated_directives, warning). '$lgt_default_flag'(trivial_goal_fails, warning). '$lgt_default_flag'(always_true_or_false_goals, warning). '$lgt_default_flag'(lambda_variables, warning). '$lgt_default_flag'(grammar_rules, warning). '$lgt_default_flag'(arithmetic_expressions, warning). '$lgt_default_flag'(suspicious_calls, warning). '$lgt_default_flag'(underscore_variables, dont_care). % optional features compilation flags: '$lgt_default_flag'(complements, deny). '$lgt_default_flag'(dynamic_declarations, deny). '$lgt_default_flag'(events, deny). '$lgt_default_flag'(context_switching_calls, allow). % other compilation flags: '$lgt_default_flag'(scratch_directory, ScratchDirectory) :- ( getenv('COMSPEC', _) -> % Windows systems define this environment variable... ScratchDirectory = './lgt_tmp/' ; % ... but not POSIX systems ScratchDirectory = './.lgt_tmp/' ). '$lgt_default_flag'(report, Report) :- ( current_prolog_flag(verbose, false) -> Report = warnings ; Report = on ). '$lgt_default_flag'(clean, on). '$lgt_default_flag'(code_prefix, '$'). '$lgt_default_flag'(optimize, off). '$lgt_default_flag'(source_data, on). '$lgt_default_flag'(reload, changed). '$lgt_default_flag'(debug, off). % Prolog compiler and loader flags: '$lgt_default_flag'(prolog_compiler, []). '$lgt_default_flag'(prolog_loader, []). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % operating-system access predicates % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_prolog_os_file_name'(+atom, -atom) % '$lgt_prolog_os_file_name'(-atom, +atom) % % converts between Prolog internal file paths and operating-system paths '$lgt_prolog_os_file_name'(Path, Path). % '$lgt_expand_path'(+atom, -atom) % % expands a file path to a full path '$lgt_expand_path'(Path, ExpandedPath) :- absolute_file_name(Path, ExpandedPath). % '$lgt_file_exists'(+atom) % % checks if a file exists '$lgt_file_exists'(File) :- file_exists(File). % '$lgt_delete_file'(+atom) % % deletes a file '$lgt_delete_file'(File) :- delete_file(File). % '$lgt_directory_exists'(+atom) % % checks if a directory exists '$lgt_directory_exists'(Directory) :- directory_exists(Directory). % '$lgt_current_directory'(-atom) % % gets current working directory '$lgt_current_directory'(Directory) :- current_directory(Directory). % '$lgt_change_directory'(+atom) % % changes current working directory '$lgt_change_directory'(Directory) :- change_directory(Directory). % '$lgt_make_directory'(+atom) % % makes a new directory; succeeds if the directory already exists '$lgt_make_directory'(Directory) :- ( directory_exists(Directory) -> true ; make_directory(Directory) ). % '$lgt_directory_hashes'(+atom, -atom, -atom) % % returns the directory hash and dialect as an atom with the format _hash_dialect % plus the the directory hash and PID as an atom with the format _hash_pid '$lgt_directory_hashes'(Directory, HashDialect, HashPid) :- atom_hash(Directory, Hash), '$lgt_prolog_feature'(prolog_dialect, Dialect), pid(PID), atomic_list_concat(['_', Hash, '_', Dialect], HashDialect), atomic_list_concat(['_', Hash, '_', PID], HashPid). % '$lgt_compile_prolog_code'(+atom, +atom, +list) % % compile to disk a Prolog file, resulting from a % Logtalk source file, given a list of flags '$lgt_compile_prolog_code'(File, Source, Options) :- ( member(encrypt(true), Options) -> encrypt_program(File), decompose_file_name(File, FileDirectory, FileName, _), decompose_file_name(Source, SourceDirectory, SourceName, _), atomic_list_concat([FileDirectory, FileName, '.plx'], Encrypted0), atomic_list_concat([SourceDirectory, SourceName, '.plx'], Encrypted), rename_file(Encrypted0, Encrypted) ; true ). % '$lgt_load_prolog_code'(+atom, +atom, +list) % % compile and load a Prolog file, resulting from a % Logtalk source file, given a list of flags '$lgt_load_prolog_code'(File, _Source, Options) :- load_files(File, Options). % '$lgt_load_prolog_file'(+atom) % % compile and (re)load a Prolog file (used in standards compliance tests) '$lgt_load_prolog_file'(File) :- load_files(File). % '$lgt_file_modification_time'(+atom, -nonvar) % % gets a file modification time, assumed to be an opaque term but comparable '$lgt_file_modification_time'(File, Time) :- file_modification_time(File, Time). % '$lgt_environment_variable'(?atom, ?atom) % % access to operating-system environment variables '$lgt_environment_variable'(Variable, Value) :- getenv(Variable, Value). % '$lgt_decompose_file_name'(+atom, ?atom, ?atom, ?atom) % % decomposes a file path in its components; the directory must always end % with a slash; the extension must start with a "." when defined and must % be the empty atom when it does not exist '$lgt_decompose_file_name'(File, Directory, Name, Extension) :- decompose_file_name(File, Directory, Name, Extension). % '$lgt_directory_files'(+atom, -list(atom)) % % returns a list of files in the given directory '$lgt_directory_files'(Directory, ['.', '..'| Files]) :- directory_files(Directory, Files). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % getting stream current line number % (needed for improved compiler error messages) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_stream_current_line_number'(@stream, -integer) '$lgt_stream_current_line_number'(Stream, Line) :- line_count(Stream, Last), Line is Last + 1. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % abstraction of the standard open/4 and close/1 predicates for dealing % with required proprietary actions when opening and closing streams % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_open'(+atom, +atom, -stream, @list) '$lgt_open'(File, Mode, Stream, Options) :- open(File, Mode, Stream, Options). % '$lgt_close'(@stream) '$lgt_close'(Stream) :- close(Stream). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % customized version of the read_term/3 predicate for returning the term % position (start and end lines; needed for improved error messages) due % to the lack of a standard option for this purpose % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_read_term'(@stream, -term, +list, -pair(integer,integer)) '$lgt_read_term'(Stream, Term, Options, LineBegin-LineEnd) :- read_term(Stream, Term, [lines(LineBegin,LineEnd)| Options]). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % Prolog dialect specific term and goal expansion % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_prolog_term_expansion'(@callable, -callable) '$lgt_prolog_term_expansion'((:- Directive), Expanded) :- nonvar(Directive), % allow first-argument indexing catch('$lgt_xvm_directive_expansion'(Directive, Expanded), _, fail). '$lgt_xvm_directive_expansion'(disk_predicate(Template,Mode,Database), [{:- disk_predicate(CTemplate,Mode,Database)}, (:- dynamic(Functor/Arity))]) :- logtalk_load_context(entity_type, _), '$lgt_compile_predicate_heads'(Template, _, CTemplate, ignore), functor(Template, Functor, Arity). % '$lgt_prolog_goal_expansion'(@callable, -callable) '$lgt_prolog_goal_expansion'(load_foreign_library(Path), '$lgt_xvm_load_foreign_library'(Path)). '$lgt_prolog_goal_expansion'(add_csv(Predicate,File,Options), {add_csv(CPredicate,File,Options)}) :- logtalk_load_context(entity_type, object), !, '$lgt_compile_predicate_indicators'(Predicate, _, CPredicate). '$lgt_prolog_goal_expansion'( add_csv(Predicate,File,Options), (this(This), {'$lgt_compile_predicate_indicators'(Predicate, This, CPredicate), add_csv(CPredicate,File,Options)}) ) :- logtalk_load_context(entity_type, category). '$lgt_prolog_goal_expansion'(define_disk_predicate(Template,Mode,Database), {define_disk_predicate(CTemplate,Mode,Database)}) :- logtalk_load_context(entity_type, object), !, '$lgt_compile_predicate_heads'(Template, _, CTemplate, ignore). '$lgt_prolog_goal_expansion'( define_disk_predicate(Template,Mode,Database), (this(This), {'$lgt_compile_predicate_heads'(Template, This, CTemplate, ignore), define_disk_predicate(CTemplate,Mode,Database)}) ) :- logtalk_load_context(entity_type, category). '$lgt_prolog_goal_expansion'(destroy_disk_predicate(Functor/Arity), {destroy_disk_predicate(CFunctor/CArity)}) :- logtalk_load_context(entity_type, object), !, '$lgt_compile_predicate_indicators'(Functor/Arity, _, CFunctor/CArity). '$lgt_prolog_goal_expansion'( destroy_disk_predicate(Functor/Arity), (this(This), {'$lgt_compile_predicate_indicators'(Functor/Arity, This, CFunctor/CArity), destroy_disk_predicate(CFunctor/CArity)}) ) :- logtalk_load_context(entity_type, category). '$lgt_prolog_goal_expansion'( open_db(DB, DBFile), {open_db(DB, DBFile), '$lgt_xvm_add_disk_predicate_ddefs'(DB, Prefix)}) :- logtalk_load_context(entity_type, object), !, logtalk_load_context(entity_prefix, Prefix). '$lgt_prolog_goal_expansion'( open_db(DB, DBFile), (this(This), {open_db(DB, DBFile), '$lgt_current_object_'(This, Prefix, _, _, _, _, _, _, _, _, _), '$lgt_xvm_add_disk_predicate_ddefs'(DB, Prefix)}) ) :- logtalk_load_context(entity_type, category). '$lgt_xvm_load_foreign_library'(Path) :- % workaround embedding issue where a plug-in shared library may be already % pre-loaded from a directory different from the original plug-in directory ( decompose_file_name(Path, _, Basename, _), current_plugin(PlugIn), plugin_property(PlugIn, file(File)), decompose_file_name(File, _, Basename, _) -> true ; load_foreign_library(Path) ). '$lgt_xvm_add_disk_predicate_ddefs'(DB, Prefix) :- database_property(DB, predicates(CPIs)), atom_concat(Prefix, '_def', Def), atom_concat(Prefix, '_ddef', DDef), forall( member(CPI, CPIs), '$lgt_xvm_add_disk_predicate_ddef'(Def, DDef, CPI) ). '$lgt_xvm_add_disk_predicate_ddef'(Def, DDef, CFunctor/CArity) :- '$lgt_decompile_predicate_indicators'(CFunctor/CArity, _, _, Functor/Arity), !, functor(Template, Functor, Arity), Template =.. [Functor| Arguments], DefFact =.. [Def, Template, _], ( clause(DefFact, true) -> true ; DDefFact =.. [DDef, Template, Context, CTemplate], ( clause(DDefFact, true) -> true ; append(Arguments, [Context], CArguments), CTemplate =.. [CFunctor| CArguments], assertz(DDefFact) ) ). '$lgt_xvm_add_disk_predicate_ddef'(_, _, _). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % converts between Prolog stream encoding names and XML encoding names % (only necessary for Prolog compilers supporting different text encodings; % for others simply provide a dummy definition that always fail) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_logtalk_prolog_encoding'(?atom, ?atom, +stream) '$lgt_logtalk_prolog_encoding'('US-ASCII', 'US-ASCII', _). '$lgt_logtalk_prolog_encoding'('ISO-8859-1', 'ISO-8859-1', _). '$lgt_logtalk_prolog_encoding'('ISO-8859-2', 'ISO-8859-2', _). '$lgt_logtalk_prolog_encoding'('ISO-8859-4', 'ISO-8859-4', _). '$lgt_logtalk_prolog_encoding'('ISO-8859-5', 'ISO-8859-5', _). '$lgt_logtalk_prolog_encoding'('ISO-8859-9', 'ISO-8859-9', _). '$lgt_logtalk_prolog_encoding'('ISO-8859-10', 'ISO-8859-10', _). '$lgt_logtalk_prolog_encoding'('ISO-8859-15', 'ISO-8859-15', _). '$lgt_logtalk_prolog_encoding'('ISO-8859-16', 'ISO-8859-16', _). '$lgt_logtalk_prolog_encoding'('windows-1251', 'windows-1251', _). '$lgt_logtalk_prolog_encoding'('windows-1252', 'windows-1252', _). '$lgt_logtalk_prolog_encoding'('UTF-8', 'UTF-8', _). '$lgt_logtalk_prolog_encoding'('UTF-16', 'UTF-16', _). '$lgt_logtalk_prolog_encoding'('UTF-16BE', 'UTF-16BE', _). '$lgt_logtalk_prolog_encoding'('UTF-16LE', 'UTF-16LE', _). '$lgt_logtalk_prolog_encoding'('UTF-32', 'UTF-32', _). '$lgt_logtalk_prolog_encoding'('UTF-32BE', 'UTF-32BE', _). '$lgt_logtalk_prolog_encoding'('UTF-32LE', 'UTF-32LE', _). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % lambda expressions support predicates % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_copy_term_without_constraints'(@term, ?term) '$lgt_copy_term_without_constraints'(Term, Copy) :- copy_term_nat(Term, Copy). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % hooks predicates for writing and asserting compiled entity terms % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_write_compiled_term'(@stream, @callable, +atom, +atom, +integer) % % the third argument is the term type: runtime (internal runtime clause), % user (compiled user-defined term), or aux (auxiliary clause resulting % e.g. from term-expansion) '$lgt_write_compiled_term'(Stream, Term, _Kind, _Path, _Line) :- write_canonical(Stream, Term), write(Stream, '.\n'). % '$lgt_assertz_entity_clause'(@clause, +atom) '$lgt_assertz_entity_clause'(Clause, _Kind) :- assertz(Clause). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % error term normalization (when exception terms don't follow the ISO % Prolog standard) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_normalize_error_term'(@callable, -callable) '$lgt_normalize_error_term'( Error, Error ). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % message token printing % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %:- multifile('$logtalk#0.print_message_token#4'/5). %:- dynamic('$logtalk#0.print_message_token#4'/5). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % term hashing (not currently used in the compiler/runtime) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % term_hash(@callable, +integer, +integer, -integer) -- built-in %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % atomics concat (not currently used in the compiler/runtime) % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % atomic_concat(+atomic, +atomic, ?atom) -- built-in % atomic_list_concat(@list(atomic), ?atom) -- built-in % atomic_list_concat(@list(atomic), +atom, ?atom) -- built-in %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % string built-in type % % define these predicates to trivially fail if no string type is available % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_string'(@term) '$lgt_string'(_) :- fail. % '$lgt_string_codes'(+string, -list(codes)) % '$lgt_string_codes'(-string, +list(codes)) '$lgt_string_codes'(_, _) :- fail. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % module qualification to be used when calling Prolog meta-predicates % with meta-arguments that are calls to object or category predicates % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_user_module_qualification'(@callable, -callable) '$lgt_user_module_qualification'(Goal, Goal). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % auxiliary predicates for compiling modules as objects % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % '$lgt_find_module_predicate'(+atom, -atom, @callable) % % succeeds when Module:Predicate is visible in module Current '$lgt_find_visible_module_predicate'(_Current, _Module, _Predicate) :- fail. % '$lgt_current_module_predicate'(+atom, +predicate_indicator) % % succeeds when Module defines Predicate '$lgt_current_module_predicate'(_Module, _Predicate) :- fail. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % shortcuts to the Logtalk built-in predicates logtalk_load/1 and % logtalk_make/1 % % defined in the adapter files to make it easier to comment them out in case % of conflict with some Prolog native feature; they require conformance with % the ISO Prolog standard regarding the definition of the {}/1 syntax % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% {X} :- var(X), throw(error(instantiation_error, logtalk({X}, _))). {*} :- !, logtalk_make(all). {!} :- !, logtalk_make(clean). {?} :- !, logtalk_make(check). {@} :- !, logtalk_make(circular). {#} :- !, logtalk_make(documentation). {+d} :- !, logtalk_make(debug). {+n} :- !, logtalk_make(normal). {+o} :- !, logtalk_make(optimal). {$} :- !, logtalk_make(caches). {Files} :- '$lgt_conjunction_to_list'(Files, List), logtalk_load(List). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % end! % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%