aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--lexlua/logtalk.lua84
-rw-r--r--lexlua/prolog.lua444
2 files changed, 390 insertions, 138 deletions
diff --git a/lexlua/logtalk.lua b/lexlua/logtalk.lua
index 61f7d98ef..27b41b107 100644
--- a/lexlua/logtalk.lua
+++ b/lexlua/logtalk.lua
@@ -7,32 +7,64 @@ local P, R, S = lpeg.P, lpeg.R, lpeg.S
local lex = lexer.new('logtalk', {inherit = lexer.load('prolog')})
--- Add logtalk keywords to the prolog ones.
-lex:modify_rule('keyword', token(lexer.KEYWORD, word_match[[
- -- Logtalk "keywords" generated from Vim syntax highlighting file with Prolog
- -- keywords stripped since were building up on the Prolog lexer.
- abolish_category abolish_events abolish_object abolish_protocol after alias as
- before built_in calls category category_property coinductive complements
- complements_object conforms_to_protocol context create_category create_object
- create_protocol create_logtalk_flag current current_category current_event
- current_logtalk_flag current_object current_protocol define_events domain_error
- encoding end_category end_class end_object end_protocol evaluation_error
- existence_error extends extends_category extends_object extends_protocol forward
- implements implements_protocol imports imports_category include info instantiates
- instantiates_class instantiation_error is logtalk_compile logtalk_library_path
- logtalk_load logtalk_load_context logtalk_make logtalk_make_target_action
- meta_non_terminal mode object object_property parameter permission_error private
- protected protocol_property representation_error resource_error self sender
- set_logtalk_flag specializes specializes_class synchronized syntax_error
- system_error this threaded threaded_call threaded_cancel threaded_engine
- threaded_engine_create threaded_engine_destroy threaded_engine_fetch
- threaded_engine_next threaded_engine_next_reified threaded_engine_post
- threaded_engine_self threaded_engine_yield threaded_exit threaded_ignore
- threaded_notify threaded_once threaded_peek threaded_wait type_error uses
- -- info/1 and info/2 predicates have their own keywords manually extracted
- -- from documentation.
+-- add logtalk keywords to prolog ones
+local directives = [[
+ set_logtalk_flag object info built_in threaded uses alias use_module
+ coinductive export reexport public metapredicate mode meta_non_terminal
+ protected synchronized private module if elif else endif category protocol
+ end_object end_category end_protocol meta_predicate
+]]
+lex:modify_rule('directive',
+ (
+ token(lexer.WHITESPACE, lexer.starts_line(S(' \t'))^0) *
+ token(lexer.OPERATOR, P':-') *
+ token(lexer.WHITESPACE, (S(' \t')^0)) *
+ token(lexer.PREPROCESSOR, P(word_match(directives)))
+ ) +
+ lex:get_rule('directive')
+)
+
+-- Whitespace.
+lex:modify_rule('whitespace', token(lexer.WHITESPACE, lexer.space^1))
+
+local zero_arity_keywords = [[
+ -- extracted from test document in logtalk distribution
comment argnames arguments author version date parameters parnames copyright
- license remarks see_also
-]]) + lex:get_rule('keyword'))
+ license remarks see_also as logtalk_make instantiation_error system_error
+]]
+local one_plus_arity_keywords = [[
+ -- extracted from test document in logtalk distribution
+ implements imports extends instantiates specializes number_chars number_code
+ current_category current_object current_protocol create_category
+ create_object create_protocol abolish_category abolish_object
+ abolish_protocol category_property object_property protocol_property
+ extends_category extends_object extends_protocol implements_protocol
+ imports_category instantiates_class specializes_class complements_object
+ conforms_to_protocol abolish_events current_event define_events threaded
+ threaded_call threaded_call threaded_once threaded_ignore threaded_exit
+ threaded_peek threaded_cancel threaded_wait threaded_notify threaded_engine
+ threaded_engine_create threaded_engine_destroy threaded_engine_self
+ threaded_engine_next threaded_engine_next_reified threaded_engine_yield
+ threaded_engine_post threaded_engine_fetch logtalk_compile logtalk_load
+ logtalk_library_path logtalk_load_context logtalk_make_target_action
+ current_logtalk_flag set_logtalk_flag create_logtalk_flag context parameter
+ self sender this type_error domain_error existence_error permission_error
+ representation_error evaluation_error resource_error syntax_error bagof
+ findall forall setof before after forward phrase expand_term expand_goal
+ term_expansion goal_expansion numbervars put_code put_byte current_op op
+ ignore repeat number_codes current_prolog_flag set_prolog_flag keysort sort
+]]
+lex:modify_rule('keyword', token(lexer.KEYWORD,
+ word_match(zero_arity_keywords) +
+ (word_match(one_plus_arity_keywords) * #(P'('))) +
+ lex:get_rule('keyword')
+)
+
+local operators = [[
+ -- extracted from test document in logtalk distribution
+ as
+]]
+lex:modify_rule('operator', token(lexer.OPERATOR, word_match(operators)) +
+ lex:get_rule('operator'))
return lex
diff --git a/lexlua/prolog.lua b/lexlua/prolog.lua
index 373361b5a..3e8d69baa 100644
--- a/lexlua/prolog.lua
+++ b/lexlua/prolog.lua
@@ -1,137 +1,357 @@
-- Copyright 2006-2019 Mitchell mitchell.att.foicica.com. See License.txt.
+-- Lexer enhanced to conform to the realities of Prologs on the ground by
+-- Michael T. Richter. Copyright is explicitly assigned back to Mitchell.
-- Prolog LPeg lexer.
+--[[
+ Prologs are notoriously fractious with many barely-compatible dialects. To
+ make Textadept more useful for these cases, directives and keywords are
+ grouped by dialect. Selecting a dialect is a simple matter of setting the
+ buffer/lexer property "prolog.dialect" in init.lua. Dialects currently in
+ the lexer file are:
+ - 'iso': the generic ISO standard without modules.
+ - 'gprolog': GNU Prolog.
+ - 'swipl': SWI-Prolog.
+
+ The default dialect is 'iso' if none is defined. (You probably don't want
+ this.)
+
+ Note that there will be undoubtedly duplicated entries in various categories
+ because of the flexibility of Prolog and the automated tools used to gather
+ most information. This is not an issue, however, because directives override
+ arity-0 predicates which override arity-1+ predicates which override bifs
+ which override operators.
+]]
+
local lexer = require('lexer')
+
local token, word_match = lexer.token, lexer.word_match
-local P, R, S = lpeg.P, lpeg.R, lpeg.S
+local P, R, S, B, V, C = lpeg.P, lpeg.R, lpeg.S, lpeg.B, lpeg.V, lpeg.C
local lex = lexer.new('prolog')
+local dialects = setmetatable({gprolog = 'gprolog', swipl = 'swipl'},
+ {__index = function(_, _) return 'iso' end})
+local dialect = dialects[lexer.property['prolog.dialect']]
+
+print(lexer.property['prolog.dialect'])
+
+-- Directives.
+local directives = {}
+directives.iso = [[
+ -- Gathered by inspection of GNU Prolog documentation.
+ dynamic multifile discontiguous include ensure_loaded op char_conversion
+ set_prolog_flag initialization
+]]
+directives.gprolog = directives.iso .. [[
+ -- Gathered by inspection of GNU Prolog documentation.
+ public ensure_linked built_in if else endif elif foreign
+]]
+directives.swipl = directives.iso .. [[
+ -- Gathered by liberal use of grep on the SWI source and libraries.
+ coinductive current_predicate_option expects_dialect http_handler listen
+ module multifile use_foreign_library use_module dynamic http_handler
+ initialization json_object multifile record use_module abolish
+ arithmetic_function asserta at_halt begin_tests chr_constraint chr_option
+ chr_type clear_cache constraints consult create_prolog_flag
+ current_prolog_flag debug discontiguous dynamic elif else encoding end_tests
+ endif expects_dialect export forall format format_predicate html_meta
+ html_resource http_handler http_request_expansion if include
+ init_color_term_flag init_options initialization json_object
+ lazy_list_iterator license listen load_extensions load_files
+ load_foreign_library meta_predicate mode module module_transparent multifile
+ noprofile op pce_begin_class pce_end_class pce_global pce_group persistent
+ pop_operators pred predicate_options print_message prolog_load_context prompt
+ public push_hprolog_library push_ifprolog_library, push_operators
+ push_sicstus_library push_xsb_library push_yap_library, quasi_quotation_syntax
+ record redefine_system_predicate reexport register_iri_scheme residual_goals
+ retract set_module set_prolog_flag set_script_dir set_test_options setenv
+ setting style_check table thread_local thread_local message type
+ use_class_template use_foreign_library use_module utter volatile build_schema
+ chr_constraint chr_option chr_type cql_option determinate discontiguous
+ dynamic endif format_predicate if initialization license meta_predicate mode
+ module multifile op reexport thread_local use_module volatile
+]]
+lex:add_rule('directive',
+ token(lexer.WHITESPACE, lexer.starts_line(S(' \t'))^0) *
+ token(lexer.OPERATOR, P':-') *
+ token(lexer.WHITESPACE, S(' \t')^0) *
+ token(lexer.PREPROCESSOR, P(word_match(directives[dialect]))))
+
-- Whitespace.
lex:add_rule('whitespace', token(lexer.WHITESPACE, lexer.space^1))
-- Keywords.
-lex:add_rule('keyword', token(lexer.KEYWORD, word_match[[
- -- Directives by manual scanning of SWI-Prolog source code
- abolish arithmetic_function at_halt create_prolog_flag discontiguous dynamic
- elif else endif format_predicate if initialization lazy_list_iterator listing
- load_extensions meta_predicate mode module module_transparent multifile op
- persistent pop_operators pred predicate_options prolog_load_context public
- push_operators record redefine_system_predicate reexport set_prolog_flag
- setting thread_local type use_foreign_library use_module volatile
- -- Built-in predicates generated in SWI-Prolog via current_predictate/1.
- abolish abort absolute_file_name access_file acyclic_term add_import_module
- append apply arg assert asserta assertz at_end_of_stream at_halt atom
- atom_chars atom_codes atom_concat atomic atomic_concat atomic_list_concat
- atomics_to_string atom_length atom_number atom_prefix atom_string atom_to_term
- attach_packs attvar autoload_path bagof between b_getval blob break b_set_dict
- b_setval byte_count call callable call_cleanup call_continuation call_dcg
- call_residue_vars call_shared_object_function call_with_depth_limit
- call_with_inference_limit cancel_halt catch character_count char_code
- char_conversion char_type clause clause_property close close_shared_object
- code_type collation_key compare compile_aux_clauses compile_predicates
- compiling compound compound_name_arguments compound_name_arity consult
- context_module copy_predicate_clauses copy_stream_data copy_term copy_term_nat
- create_prolog_flag current_arithmetic_function current_atom current_blob
- current_char_conversion current_engine current_flag current_format_predicate
- current_functor current_input current_key current_locale current_module
- current_op current_output current_predicate current_prolog_flag
- current_resource current_signal current_trie cwd cyclic_term date_time_stamp
- dcg_translate_rule debugging default_module del_attr del_attrs del_dict
- delete_directory delete_file delete_import_module deterministic dict_create
- dict_pairs directory_files divmod downcase_atom duplicate_term dwim_match
- dwim_predicate engine_create engine_destroy engine_fetch engine_next
- engine_next_reified engine_post engine_self engine_yield ensure_loaded erase
- exception exists_directory exists_file expand_answer expand_file_name
- expand_file_search_path expand_goal expand_query expand_term export
- extern_indirect fail false fast_read fast_term_serialized fast_write
- file_base_name file_directory_name file_name_extension file_search_path
- fill_buffer findall findnsols flag float flush_output forall format
- format_predicate format_time freeze frozen functor garbage_collect
- garbage_collect_atoms garbage_collect_clauses gc_file_search_cache get0 get
- get_attr get_attrs get_byte get_char get_code get_dict getenv get_flag
- get_single_char get_string_code get_time goal_expansion ground halt ignore
- import import_module instance integer intern_indirect is_absolute_file_name
- is_dict is_engine is_list is_stream is_thread keysort known_licenses leash
- length library_directory license line_count line_position load_files
- locale_create locale_destroy locale_property make_directory make_library_index
- memberchk message_hook message_property message_queue_create
- message_queue_destroy message_queue_property message_to_string module
- module_property msort mutex_create mutex_destroy mutex_lock mutex_property
- mutex_statistics mutex_trylock mutex_unlock mutex_unlock_all name nb_current
- nb_delete nb_getval nb_linkarg nb_link_dict nb_linkval nb_setarg nb_set_dict
- nb_setval nl nonvar noprofile noprotocol normalize_space nospy nospyall not
- notrace nth_clause nth_integer_root_and_remainder number number_chars
- number_codes number_string numbervars once on_signal op open open_null_stream
- open_resource open_shared_object open_string open_xterm peek_byte peek_char
- peek_code peek_string phrase plus portray predicate_option_mode
- predicate_option_type predicate_property print print_message
- print_message_lines print_toplevel_variables profiler prolog
- prolog_choice_attribute prolog_current_choice prolog_current_frame
- prolog_cut_to prolog_debug prolog_event_hook prolog_file_type
- prolog_frame_attribute prolog_list_goal prolog_load_context prolog_load_file
- prolog_nodebug prolog_skip_frame prolog_skip_level prolog_stack_property
- prolog_to_os_filename prompt1 prompt protocol protocola protocolling put
- put_attr put_attrs put_byte put_char put_code put_dict pwd qcompile
- random_property rational read read_clause read_history read_link
- read_pending_chars read_pending_codes read_string read_term
- read_term_from_atom recorda recorded recordz redefine_system_predicate
- reexport reload_library_index rename_file repeat require reset reset_profiler
- residual_goals resource retract retractall same_file same_term see seeing seek
- seen select_dict setarg set_end_of_stream setenv set_flag set_input set_locale
- setlocale set_module setof set_output set_prolog_flag set_prolog_IO
- set_prolog_stack set_random set_stream set_stream_position
- setup_call_catcher_cleanup setup_call_cleanup shell shift size_file skip sleep
- sort source_file source_file_property source_location split_string spy
- stamp_date_time statistics stream_pair stream_position_data stream_property
- string string_chars string_code string_codes string_concat string_length
- string_lower string_upper strip_module style_check sub_atom sub_atom_icasechk
- sub_string subsumes_term succ swiplrc tab tell telling term_attvars
- term_expansion term_hash term_string term_to_atom term_variables
- text_to_string thread_at_exit thread_create thread_detach thread_exit
- thread_get_message thread_join thread_message_hook thread_peek_message
- thread_property thread_self thread_send_message thread_setconcurrency
- thread_signal thread_statistics throw time_file tmp_file tmp_file_stream told
- trace tracing trie_destroy trie_gen trie_insert trie_insert_new trie_lookup
- trie_new trie_property trie_term trim_stacks true ttyflush tty_get_capability
- tty_goto tty_put tty_size unifiable unify_with_occurs_check unload_file
- unsetenv upcase_atom use_module var variant_hash variant_sha1 var_number
- var_property verbose_expansion version visible wait_for_input wildcard_match
- with_mutex with_output_to working_directory write write_canonical write_length
- writeln writeq write_term
- -- Built-in functions generated in SWI-Prolog via current_arithmetic_function/1.
- xor rem rdiv mod div abs acos acosh asin asinh atan2 atan atanh ceil ceiling
- copysign cos cosh cputime e epsilon erf erfc eval exp float
- float_fractional_part float_integer_part floor gcd getbit inf integer lgamma
- log10 log lsb max min msb nan pi popcount powm random random_float rational
- rationalize round sign sin sinh sqrt tan tanh truncate
-]]))
+local zero_arity_keywords = {}
+zero_arity_keywords.iso = [[
+ -- eyeballed from GNU Prolog documentation
+ true fail pi float_overflow int_overflow int_underflow undefined asserta
+ assertz retract retractall clause abolish current_predicate findall bagof
+ setof at_end_of_stream flush_output nl halt false
+]]
+zero_arity_keywords.gprolog = [[
+ -- Collected automatically via current_predicate/1 with some cleanup.
+ at_end_of_stream wam_debug listing flush_output fail told false top_level
+ shell trace debugging seen repeat abort nl statistics halt notrace randomize
+ true nospyall nodebug debug stop break
+]]
+zero_arity_keywords.swipl = [[
+ -- Collected automatically via current_predicate/1 with some cleanup.
+ noprotocol compiling ttyflush true abort license known_licenses
+ print_toplevel_variables initialize mutex_statistics break reset_profiler
+ win_has_menu version prolog abolish_nonincremental_tables false halt undefined
+ abolish_all_tables reload_library_index garbage_collect repeat nospyall
+ tracing trace notrace trim_stacks garbage_collect_clauses
+ garbage_collect_atoms mutex_unlock_all seen told nl debugging fail
+ at_end_of_stream attach_packs flush_output true
+]]
+local one_plus_arity_keywords = {}
+one_plus_arity_keywords.iso = [[
+ -- eyeballed from GNU Prolog documentation
+ call catch throw var nonvar atom integer float number atomic compound
+ callable ground unify_with_occurs_check compare functor arg copy_term
+ term_variables subsumes_term acyclic_term predicate_property current_input
+ current_output set_input set_output open close current_stream stream_property
+ set_stream_position get_char get_code is peek_char peek_code put_char putcode
+ get_byte peek_byte read_term read write_term write writeq write_canonical
+ char_conversion current_char_conversion call once repeat atom_length
+ atom_concat sub_atom char_code atom_chars atom_codes
+]]
+one_plus_arity_keywords.gprolog = [[
+ -- Collected automatically via current_predicate/1 with some cleanup.
+ abolish absolute_file_name acyclic_term add_linedit_completion
+ add_stream_alias add_stream_mirror append architecture arg argument_counter
+ argument_list argument_value asserta assertz at_end_of_stream atom atom_chars
+ atom_codes atom_concat atom_length atom_property atomic bagof between
+ bind_variables call call_det call_with_args callable catch change_directory
+ char_code char_conversion character_count clause close close_input_atom_stream
+ close_input_chars_stream close_input_codes_stream close_output_atom_stream
+ close_output_chars_stream close_output_codes_stream compare compound consult
+ copy_term cpu_time create_pipe current_alias current_atom current_bip_name
+ current_char_conversion current_input current_mirror current_op current_output
+ current_predicate current_prolog_flag current_stream date_time
+ decompose_file_name delete delete_directory delete_file directory_files
+ display display_to_atom display_to_chars display_to_codes environ exec
+ expand_term fd_all_different fd_at_least_one fd_at_most_one fd_atleast
+ fd_atmost fd_cardinality fd_dom fd_domain fd_domain_bool fd_element
+ fd_element_var fd_exactly fd_has_extra_cstr fd_has_vector fd_labeling
+ fd_labelingff fd_max fd_max_integer fd_maximize fd_min fd_minimize
+ fd_not_prime fd_only_one fd_prime fd_reified_in fd_relation fd_relationc
+ fd_set_vector_max fd_size fd_use_vector fd_var fd_vector_max file_exists
+ file_permission file_property find_linedit_completion findall flatten float
+ flush_output for forall fork_prolog format format_to_atom format_to_chars
+ format_to_codes functor g_array_size g_assign g_assignb g_dec g_deco g_inc
+ g_inco g_link g_read g_reset_bit g_set_bit g_test_reset_bit g_test_set_bit
+ generic_var get get_byte get_char get_code get_key get_key_no_echo
+ get_linedit_prompt get_print_stream get_seed get0 ground halt host_name
+ hostname_address integer is_absolute_file_name is_list is_relative_file_name
+ keysort last last_read_start_line_column leash length line_count line_position
+ list list_or_partial_list listing load lower_upper make_directory maplist
+ max_list member memberchk min_list msort name name_query_vars
+ name_singleton_vars new_atom nl non_fd_var non_generic_var nonvar nospy nth
+ nth0 nth1 number number_atom number_chars number_codes numbervars once op open
+ open_input_atom_stream open_input_chars_stream open_input_codes_stream
+ open_output_atom_stream open_output_chars_stream open_output_codes_stream
+ os_version partial_list peek_byte peek_char peek_code permutation phrase popen
+ portray_clause predicate_property prefix print print_to_atom print_to_chars
+ print_to_codes prolog_file_name prolog_pid put put_byte put_char put_code
+ random read read_atom read_from_atom read_from_chars read_from_codes
+ read_integer read_number read_pl_state_file read_term read_term_from_atom
+ read_term_from_chars read_term_from_codes read_token read_token_from_atom
+ read_token_from_chars read_token_from_codes real_time remove_stream_mirror
+ rename_file retract retractall reverse see seeing seek select send_signal
+ set_bip_name set_input set_linedit_prompt set_output set_prolog_flag set_seed
+ set_stream_buffering set_stream_eof_action set_stream_line_column
+ set_stream_position set_stream_type setarg setof shell skip sleep socket
+ socket_accept socket_bind socket_close socket_connect socket_listen sort spawn
+ spy spypoint_condition sr_change_options sr_close sr_current_descriptor
+ sr_error_from_exception sr_get_error_counters sr_get_file_name
+ sr_get_include_list sr_get_include_stream_list sr_get_module sr_get_position
+ sr_get_size_counters sr_get_stream sr_new_pass sr_open sr_read_term
+ sr_set_error_counters sr_write_error sr_write_message statistics
+ stream_line_column stream_position stream_property sub_atom sublist
+ subsumes_term subtract succ suffix sum_list syntax_error_info system
+ system_time tab tell telling temporary_file temporary_name term_hash term_ref
+ term_variables throw unget_byte unget_char unget_code unify_with_occurs_check
+ unlink user_time var wait working_directory write write_canonical
+ write_canonical_to_atom write_canonical_to_chars write_canonical_to_codes
+ write_pl_state_file write_term write_term_to_atom write_term_to_chars
+ write_term_to_codes write_to_atom write_to_chars write_to_codes writeq
+ writeq_to_atom writeq_to_chars writeq_to_codes
+]]
+one_plus_arity_keywords.swipl = [[
+ -- Collected automatically via current_predicate/1 with some cleanup.
+ prolog_exception_hook term_expansion expand_answer message_property resource
+ help goal_expansion file_search_path prolog_clause_name thread_message_hook
+ prolog_file_type goal_expansion prolog_predicate_name exception writeln
+ term_expansion expand_query url_path message_hook library_directory resource
+ portray prolog_load_file prolog_list_goal ansi_format source_file_property
+ asserta call_dcg source_location wait_for_input locale_destroy set_locale
+ read_pending_codes thread_join open_dde_conversation win_folder protocol
+ copy_stream_data current_locale read_pending_chars win_add_dll_directory
+ protocola thread_property win_shell goal_expansion phrase gc_file_search_cache
+ dcg_translate_rule protocolling win_registry_get_value term_expansion
+ dcg_translate_rule assert copy_stream_data once bagof prompt1 tnot assertz
+ phrase sort ignore thread_statistics assert locale_create
+ win_remove_dll_directory term_expansion read_term asserta clause assertz
+ predicate_option_type is_thread get_single_char set_prolog_IO expand_goal
+ ground message_queue_create locale_property close_dde_conversation
+ goal_expansion clause zipper_open_new_file_in_zip term_to_atom with_output_to
+ module expand_term redefine_system_predicate thread_detach dde_execute
+ term_string read_clause compile_predicates predicate_option_mode noprofile
+ read_term_from_atom cancel_halt non_terminal atom_to_term line_position frozen
+ dde_request findnsols prolog_skip_level prolog_current_choice get get_attrs
+ license var_property nb_delete unwrap_predicate zipper_open_current put_attrs
+ dde_poke set_stream read_term zip_file_info_ memberchk seek expand_goal get0
+ call var integer attach_packs byte_count zipper_goto findnsols character_count
+ expand_term get_flag atom line_count set_flag atomic tab create_prolog_flag
+ copy_term import_module verbose_expansion b_setval duplicate_term
+ prolog_load_context attach_packs prolog_listen b_getval prolog_frame_attribute
+ prompt copy_term_nat nb_linkval tab prolog_choice_attribute set_prolog_flag
+ nb_getval prolog_skip_frame del_attrs skip sort license open_null_stream
+ nb_current prolog_listen msort is_list is_stream get keysort win_shell
+ prolog_unlisten notrace get0 add_import_module wildcard_match profiler
+ delete_directory trie_gen_compiled expand_file_name file_name_extension
+ delete_file writeq win_module_file call write get_dict win_exec
+ directory_files trie_insert make_directory engine_next_reified del_dict sleep
+ getenv call_continuation trie_gen_compiled prolog_to_os_filename
+ is_absolute_file_name trie_insert engine_fetch engine_create strip_module call
+ delete_import_module write_canonical compile_aux_clauses setenv callable
+ is_engine write_term call set_module call halt catch findall trie_gen
+ trie_destroy rename_file shift unify_with_occurs_check engine_yield forall
+ unsetenv trie_term file_directory_name version current_engine file_base_name
+ engine_self import trie_gen trie_lookup write_term trie_update freeze
+ engine_post export put_dict same_file trie_new call trie_delete start_tabling
+ is_trie residual_goals thread_peek_message thread_get_message dict_pairs
+ set_end_of_stream call_cleanup current_predicate arg dict_create
+ thread_setconcurrency read_link is_dict at_halt tmp_file not put_dict
+ setup_call_cleanup abolish_nonincremental_tables time_file
+ start_subsumptive_tabling char_conversion compound sub_atom access_file call
+ call_cleanup abolish nonvar current_functor abolish_module_tables
+ subsumes_term engine_post call retractall compare engine_next prolog_cut_to
+ size_file current_char_conversion predicate_property nonground engine_destroy
+ message_queue_property format abolish qcompile thread_send_message stream_pair
+ message_queue_create same_term number select_dict catch_with_backtrace
+ thread_get_message thread_send_message win_insert_menu_item message_queue_set
+ <meta-call> exists_directory copy_term nb_set_dict prolog_nodebug functor
+ current_table cyclic_term untable read exists_file thread_peek_message
+ b_set_dict engine_create prolog_debug acyclic_term writeln get_dict
+ compound_name_arity abolish_table_subgoals start_tabling trie_insert
+ nb_link_dict message_queue_destroy thread_get_message is_dict nth_clause
+ absolute_file_name term_singletons make_library_index set_output retract
+ context_module current_trie term_attvars load_files get_char ensure_loaded
+ current_input prolog_current_frame make_library_index term_variables
+ compound_name_arguments reexport autoload_path get_code set_input flag
+ thread_create use_module findall thread_join call_with_inference_limit
+ var_number dwim_match consult peek_code close nospy print_message
+ term_variables trie_property read_history get_byte default_module get_byte
+ print on_signal get_char call_residue_vars dwim_match atom_prefix unifiable
+ use_module numbervars load_files get_code open format_time
+ copy_predicate_clauses reexport leash current_output sub_string close
+ format_time atom_codes stamp_date_time require name open_shared_object open
+ atom_chars current_predicate format tmp_file_stream term_hash rational
+ source_file reset atom_concat atom_length current_prolog_flag rational
+ dwim_predicate date_time_stamp stream_property string_upper setlocale format
+ writeln current_module normalize_space writeq current_flag shell upcase_atom
+ qcompile char_code atomic_concat read string_lower write term_string
+ numbervars working_directory number_codes set_prolog_gc_thread downcase_atom
+ format_predicate number_string open_shared_object style_check char_type print
+ stream_position_data code_type write_canonical number_chars length
+ current_arithmetic_function atomic_list_concat del_attr read_string zip_unlock
+ open_resource string_length zip_lock see erase open_resource setof
+ atomic_list_concat current_format_predicate current_resource with_mutex
+ atomics_to_string term_hash absolute_file_name deterministic current_atom
+ thread_create collation_key get_attr variant_hash string_concat atom_number
+ put put_attr variant_sha1 thread_signal mutex_unlock tty_size current_key
+ mutex_create fill_buffer expand_file_search_path blob shell
+ register_iri_scheme skip fast_read divmod mutex_trylock thread_self put
+ mutex_property fast_write mutex_lock current_blob sub_atom_icasechk
+ mutex_destroy fast_term_serialized split_string set_stream_position recorda
+ telling setarg thread_exit zip_open_stream instance mutex_create statistics
+ append get_time zip_close_ tell atomics_to_string clause_property attvar
+ zip_clone seeing nth_integer_root_and_remainder recorda put_byte string_chars
+ spy recordz print_message_lines current_op put_char nl source_file
+ string_codes op setup_call_catcher_cleanup nb_linkarg recorded put_code
+ peek_byte apply module_property atom_string nb_setarg succ recordz
+ message_to_string close_shared_object peek_char between recorded visible plus
+ call_shared_object_function peek_code peek_byte set_prolog_stack float throw
+ at_end_of_stream get_string_code call_with_depth_limit random_property
+ flush_output peek_string open_xterm peek_char open_string string_code
+ set_random prolog_stack_property put_char unload_file nb_setval put_byte
+ current_signal put_code write_length string read_string text_to_string
+]]
+lex:add_rule('keyword',
+ token(lexer.KEYWORD, word_match(zero_arity_keywords[dialect]) +
+ (word_match(one_plus_arity_keywords[dialect]) *
+ #(P'('))))
--- Identifiers.
-lex:add_rule('identifier', token(lexer.IDENTIFIER, lexer.word))
+-- BIFs.
+local bifs = {}
+bifs.iso = [[
+ -- eyeballed from GNU Prolog documentation
+ xor abs sign min max sqrt tan atan atan2 cos acos sin asin exp log float
+ ceiling floor round truncate float_fractional_part float_integer_part rem div
+ mod
+]]
+bifs.gprolog = bifs.iso .. [[
+ -- eyeballed from GNU Prolog documentation
+ inc dec lsb msb popcount gcd tanh atanh cosh acosh sinh asinh log10 rnd
+]]
+bifs.swipl = [[
+ -- Collected automatically via current_arithmetic_function/1 with some
+ -- cleanup.
+ abs acos acosh asinh atan atan atanh atan2 ceil ceiling copysign cos cosh
+ cputime div getbit e epsilon erf erfc eval exp float float_fractional_part
+ float_integer_part floor gcd inf integer lgamma log log10 lsb max min mod msb
+ nan pi popcount powm random random_float rational rationalize rdiv rem round
+ sign sin sinh sqrt tan tanh truncate xor
+]]
+lex:add_rule('bif', token(lexer.FUNCTION, word_match(bifs[dialect]) * #(P'(')))
+
+-- Numbers.
+local decimal_group = S('+-')^-1 * (lexer.digit + '_')^1
+local binary_number = '0b' * (S('01') + '_')^1
+local character_code = '0\'' * S('\\')^-1 * (lexer.print - lexer.space)
+local decimal_number = decimal_group * ('.' * decimal_group)^-1 *
+ ('e' * decimal_group)^-1
+local hexadecimal_number = '0x' * (lexer.xdigit + '_')^1
+local octal_number = '0o' * (S('01234567') + '_')^1
+lex:add_rule('number', token(lexer.NUMBER, character_code + binary_number +
+ hexadecimal_number + octal_number +
+ decimal_number))
-- Comments.
local line_comment = '%' * lexer.nonnewline^0
local block_comment = '/*' * (lexer.any - '*/')^0 * P('*/')^-1
lex:add_rule('comment', token(lexer.COMMENT, line_comment + block_comment))
--- Numbers.
-local binary_number = '0b' * S('01')^1
-local character_code = '0\'' * S('\\')^-1 * (lexer.print - lexer.space)
-local decimal_number = lexer.digit^1 * ('.' * lexer.digit)^-1
-local hexadecimal_number = '0x' * lexer.xdigit^1
-local octal_number = '0o' * S('01234567')^1
-lex:add_rule('number', token(lexer.NUMBER, character_code +
- binary_number +
- hexadecimal_number +
- octal_number +
- decimal_number))
+-- Operators.
+local operators = {}
+operators.iso = [[
+ -- Collected automatically via current_op/3 with some cleanup and comparison
+ -- to docs.
+ rem div mod is
+]]
+operators.gprolog = operators.iso -- GNU Prolog's textual operators are the same
+operators.swipl = [[
+ -- Collected automatically via current_op/3 with some cleanup.
+ is as volatile mod discontiguous div rdiv meta_predicate public xor
+ module_transparent multifile table dynamic thread_initialization thread_local
+ initialization rem
+]]
+lex:add_rule('operator', token(lexer.OPERATOR, word_match(operators[dialect]) +
+ S('-!+\\|=:;&<>()[]{}/*^@?.')))
+
+-- Variables.
+lex:add_rule('variable',
+ token(lexer.VARIABLE, (lexer.upper + '_') *
+ (lexer.word^1 + lexer.digit^1 + P('_')^1)^0))
+
+-- Identifiers.
+lex:add_rule('identifier', token(lexer.IDENTIFIER, lexer.word))
-- Strings.
lex:add_rule('string', token(lexer.STRING, lexer.delimited_range("'", true) +
lexer.delimited_range('"', true)))
--- Operators.
-lex:add_rule('operator', token(lexer.OPERATOR, S('-!+\\|=:;&<>()[]{}/*^@?')))
-
return lex