1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
|
-- Copyright 2006-2019 Mitchell mitchell.att.foicica.com. See License.txt.
-- Prolog LPeg lexer.
local lexer = require('lexer')
local token, word_match = lexer.token, lexer.word_match
local P, R, S = lpeg.P, lpeg.R, lpeg.S
local lex = lexer.new('prolog')
-- 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
]]))
-- Identifiers.
lex:add_rule('identifier', token(lexer.IDENTIFIER, lexer.word))
-- 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))
-- 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
|