seq_runtime/
lib.rs

1//! Seq Runtime: A clean concatenative language foundation
2//!
3//! Key design principles:
4//! - Value: What the language talks about (Int, Bool, Variant, etc.)
5//! - StackValue: 40-byte tagged stack entry (discriminant + 4 payload slots)
6//! - Stack: Contiguous array of StackValue entries for efficient operations
7
8// Re-export core modules from seq-core (foundation for stack-based languages)
9pub use seq_core::arena;
10pub use seq_core::error;
11pub use seq_core::memory_stats;
12pub use seq_core::seqstring;
13pub use seq_core::son;
14pub use seq_core::stack;
15pub use seq_core::tagged_stack;
16pub use seq_core::value;
17
18// Seq-specific modules (always available - core runtime)
19pub mod args;
20pub mod arithmetic;
21pub mod channel;
22pub mod closures;
23pub mod cond;
24pub mod diagnostics;
25pub mod encoding;
26pub mod file;
27pub mod float_ops;
28pub mod io;
29pub mod list_ops;
30pub mod map_ops;
31pub mod os;
32pub mod quotations;
33pub mod scheduler;
34pub mod serialize;
35pub mod string_ops;
36pub mod tcp;
37pub mod tcp_test;
38pub mod test;
39pub mod time_ops;
40pub mod variant_ops;
41pub mod watchdog;
42pub mod weave;
43
44// Optional modules - gated by feature flags
45#[cfg(feature = "crypto")]
46pub mod crypto;
47#[cfg(not(feature = "crypto"))]
48pub mod crypto_stub;
49
50#[cfg(feature = "http")]
51pub mod http_client;
52#[cfg(not(feature = "http"))]
53pub mod http_stub;
54
55#[cfg(feature = "regex")]
56pub mod regex;
57#[cfg(not(feature = "regex"))]
58pub mod regex_stub;
59
60#[cfg(feature = "compression")]
61pub mod compress;
62#[cfg(not(feature = "compression"))]
63pub mod compress_stub;
64
65// Re-export key types and functions from seq-core
66pub use seq_core::{ChannelData, MapKey, Value, VariantData, WeaveChannelData, WeaveMessage};
67pub use seq_core::{
68    DISC_BOOL, DISC_CHANNEL, DISC_CLOSURE, DISC_FLOAT, DISC_INT, DISC_MAP, DISC_QUOTATION,
69    DISC_STRING, DISC_SYMBOL, DISC_VARIANT, DISC_WEAVECTX, Stack, alloc_stack, alloc_test_stack,
70    clone_stack, clone_stack_segment, clone_stack_value, clone_value, drop_op, drop_stack_value,
71    drop_top, dup, is_empty, nip, over, peek, peek_sv, pick_op, pop, pop_sv, push, push_sv,
72    push_value, roll, rot, set_stack_base, stack_dump, stack_value_to_value, swap, three_drop,
73    tuck, two_dup, value_to_stack_value,
74};
75
76// SON serialization (from seq-core)
77pub use seq_core::{son_dump, son_dump_pretty};
78
79// Error handling (from seq-core)
80pub use seq_core::{
81    clear_error, clear_runtime_error, get_error, has_error, has_runtime_error, set_runtime_error,
82    take_error, take_runtime_error,
83};
84
85// Serialization types (for persistence/exchange with external systems)
86pub use serialize::{SerializeError, TypedMapKey, TypedValue, ValueSerialize};
87
88// Arithmetic operations (exported for LLVM linking)
89pub use arithmetic::{
90    patch_seq_add as add, patch_seq_divide as divide, patch_seq_eq as eq, patch_seq_gt as gt,
91    patch_seq_gte as gte, patch_seq_lt as lt, patch_seq_lte as lte, patch_seq_multiply as multiply,
92    patch_seq_neq as neq, patch_seq_push_bool as push_bool, patch_seq_push_int as push_int,
93    patch_seq_subtract as subtract,
94};
95
96// Float operations (exported for LLVM linking)
97pub use float_ops::{
98    patch_seq_f_add as f_add, patch_seq_f_divide as f_divide, patch_seq_f_eq as f_eq,
99    patch_seq_f_gt as f_gt, patch_seq_f_gte as f_gte, patch_seq_f_lt as f_lt,
100    patch_seq_f_lte as f_lte, patch_seq_f_multiply as f_multiply, patch_seq_f_neq as f_neq,
101    patch_seq_f_subtract as f_subtract, patch_seq_float_to_int as float_to_int,
102    patch_seq_float_to_string as float_to_string, patch_seq_int_to_float as int_to_float,
103    patch_seq_push_float as push_float,
104};
105
106// I/O operations (exported for LLVM linking)
107pub use io::{
108    patch_seq_exit_op as exit_op, patch_seq_push_interned_symbol as push_interned_symbol,
109    patch_seq_push_string as push_string, patch_seq_push_symbol as push_symbol,
110    patch_seq_read_line as read_line, patch_seq_read_line_plus as read_line_plus,
111    patch_seq_read_n as read_n, patch_seq_string_to_symbol as string_to_symbol,
112    patch_seq_symbol_to_string as symbol_to_string, patch_seq_write_line as write_line,
113};
114
115// Scheduler operations (exported for LLVM linking)
116pub use scheduler::{
117    patch_seq_maybe_yield as maybe_yield, patch_seq_scheduler_init as scheduler_init,
118    patch_seq_scheduler_run as scheduler_run, patch_seq_scheduler_shutdown as scheduler_shutdown,
119    patch_seq_spawn_strand as spawn_strand, patch_seq_strand_spawn as strand_spawn,
120    patch_seq_wait_all_strands as wait_all_strands, patch_seq_yield_strand as yield_strand,
121};
122
123// Channel operations (exported for LLVM linking)
124// Note: All channel ops now return success flags (errors are values, not crashes)
125pub use channel::{
126    patch_seq_chan_receive as receive, patch_seq_chan_send as send,
127    patch_seq_close_channel as close_channel, patch_seq_make_channel as make_channel,
128};
129
130// Weave operations (generators/coroutines with yield/resume)
131pub use weave::{
132    patch_seq_resume as weave_resume, patch_seq_weave as weave_make,
133    patch_seq_weave_cancel as weave_cancel, patch_seq_yield as weave_yield,
134};
135
136// String operations (exported for LLVM linking)
137pub use io::patch_seq_int_to_string as int_to_string;
138pub use string_ops::{
139    patch_seq_json_escape as json_escape, patch_seq_string_chomp as string_chomp,
140    patch_seq_string_concat as string_concat, patch_seq_string_contains as string_contains,
141    patch_seq_string_empty as string_empty, patch_seq_string_length as string_length,
142    patch_seq_string_split as string_split, patch_seq_string_starts_with as string_starts_with,
143    patch_seq_string_to_int as string_to_int, patch_seq_string_to_lower as string_to_lower,
144    patch_seq_string_to_upper as string_to_upper, patch_seq_string_trim as string_trim,
145};
146
147// Encoding operations (exported for LLVM linking)
148pub use encoding::{
149    patch_seq_base64_decode as base64_decode, patch_seq_base64_encode as base64_encode,
150    patch_seq_base64url_decode as base64url_decode, patch_seq_base64url_encode as base64url_encode,
151    patch_seq_hex_decode as hex_decode, patch_seq_hex_encode as hex_encode,
152};
153
154// Crypto operations (exported for LLVM linking)
155#[cfg(feature = "crypto")]
156pub use crypto::{
157    patch_seq_constant_time_eq as constant_time_eq,
158    patch_seq_crypto_aes_gcm_decrypt as crypto_aes_gcm_decrypt,
159    patch_seq_crypto_aes_gcm_encrypt as crypto_aes_gcm_encrypt,
160    patch_seq_crypto_ed25519_keypair as crypto_ed25519_keypair,
161    patch_seq_crypto_ed25519_sign as crypto_ed25519_sign,
162    patch_seq_crypto_ed25519_verify as crypto_ed25519_verify,
163    patch_seq_crypto_pbkdf2_sha256 as crypto_pbkdf2_sha256, patch_seq_hmac_sha256 as hmac_sha256,
164    patch_seq_random_bytes as random_bytes, patch_seq_sha256 as sha256, patch_seq_uuid4 as uuid4,
165};
166#[cfg(not(feature = "crypto"))]
167pub use crypto_stub::{
168    patch_seq_constant_time_eq as constant_time_eq,
169    patch_seq_crypto_aes_gcm_decrypt as crypto_aes_gcm_decrypt,
170    patch_seq_crypto_aes_gcm_encrypt as crypto_aes_gcm_encrypt,
171    patch_seq_crypto_ed25519_keypair as crypto_ed25519_keypair,
172    patch_seq_crypto_ed25519_sign as crypto_ed25519_sign,
173    patch_seq_crypto_ed25519_verify as crypto_ed25519_verify,
174    patch_seq_crypto_pbkdf2_sha256 as crypto_pbkdf2_sha256, patch_seq_hmac_sha256 as hmac_sha256,
175    patch_seq_random_bytes as random_bytes, patch_seq_sha256 as sha256, patch_seq_uuid4 as uuid4,
176};
177
178// Regex operations (exported for LLVM linking)
179#[cfg(feature = "regex")]
180pub use regex::{
181    patch_seq_regex_captures as regex_captures, patch_seq_regex_find as regex_find,
182    patch_seq_regex_find_all as regex_find_all, patch_seq_regex_match as regex_match,
183    patch_seq_regex_replace as regex_replace, patch_seq_regex_replace_all as regex_replace_all,
184    patch_seq_regex_split as regex_split, patch_seq_regex_valid as regex_valid,
185};
186#[cfg(not(feature = "regex"))]
187pub use regex_stub::{
188    patch_seq_regex_captures as regex_captures, patch_seq_regex_find as regex_find,
189    patch_seq_regex_find_all as regex_find_all, patch_seq_regex_match as regex_match,
190    patch_seq_regex_replace as regex_replace, patch_seq_regex_replace_all as regex_replace_all,
191    patch_seq_regex_split as regex_split, patch_seq_regex_valid as regex_valid,
192};
193
194// Compression operations (exported for LLVM linking)
195#[cfg(feature = "compression")]
196pub use compress::{
197    patch_seq_compress_gunzip as compress_gunzip, patch_seq_compress_gzip as compress_gzip,
198    patch_seq_compress_gzip_level as compress_gzip_level,
199    patch_seq_compress_unzstd as compress_unzstd, patch_seq_compress_zstd as compress_zstd,
200    patch_seq_compress_zstd_level as compress_zstd_level,
201};
202#[cfg(not(feature = "compression"))]
203pub use compress_stub::{
204    patch_seq_compress_gunzip as compress_gunzip, patch_seq_compress_gzip as compress_gzip,
205    patch_seq_compress_gzip_level as compress_gzip_level,
206    patch_seq_compress_unzstd as compress_unzstd, patch_seq_compress_zstd as compress_zstd,
207    patch_seq_compress_zstd_level as compress_zstd_level,
208};
209
210// Quotation operations (exported for LLVM linking)
211pub use quotations::{
212    patch_seq_call as call, patch_seq_peek_is_quotation as peek_is_quotation,
213    patch_seq_peek_quotation_fn_ptr as peek_quotation_fn_ptr,
214    patch_seq_push_quotation as push_quotation, patch_seq_spawn as spawn, patch_seq_times as times,
215    patch_seq_until_loop as until_loop, patch_seq_while_loop as while_loop,
216};
217
218// Closure operations (exported for LLVM linking)
219pub use closures::{
220    patch_seq_create_env as create_env, patch_seq_env_get as env_get,
221    patch_seq_env_get_int as env_get_int, patch_seq_env_set as env_set,
222    patch_seq_make_closure as make_closure, patch_seq_push_closure as push_closure,
223};
224
225// Conditional combinator (exported for LLVM linking)
226pub use cond::patch_seq_cond as cond;
227
228// TCP operations (exported for LLVM linking)
229pub use tcp::{
230    patch_seq_tcp_accept as tcp_accept, patch_seq_tcp_close as tcp_close,
231    patch_seq_tcp_listen as tcp_listen, patch_seq_tcp_read as tcp_read,
232    patch_seq_tcp_write as tcp_write,
233};
234
235// OS operations (exported for LLVM linking)
236pub use os::{
237    patch_seq_current_dir as current_dir, patch_seq_exit as exit, patch_seq_getenv as getenv,
238    patch_seq_home_dir as home_dir, patch_seq_os_arch as os_arch, patch_seq_os_name as os_name,
239    patch_seq_path_exists as path_exists, patch_seq_path_filename as path_filename,
240    patch_seq_path_is_dir as path_is_dir, patch_seq_path_is_file as path_is_file,
241    patch_seq_path_join as path_join, patch_seq_path_parent as path_parent,
242};
243
244// Variant operations (exported for LLVM linking)
245pub use variant_ops::{
246    patch_seq_make_variant_0 as make_variant_0, patch_seq_make_variant_1 as make_variant_1,
247    patch_seq_make_variant_2 as make_variant_2, patch_seq_make_variant_3 as make_variant_3,
248    patch_seq_make_variant_4 as make_variant_4, patch_seq_unpack_variant as unpack_variant,
249    patch_seq_variant_field_at as variant_field_at,
250    patch_seq_variant_field_count as variant_field_count, patch_seq_variant_tag as variant_tag,
251};
252
253// Command-line argument operations (exported for LLVM linking)
254pub use args::{
255    patch_seq_arg_at as arg_at, patch_seq_arg_count as arg_count, patch_seq_args_init as args_init,
256};
257
258// File operations (exported for LLVM linking)
259pub use file::{
260    patch_seq_file_exists as file_exists,
261    patch_seq_file_for_each_line_plus as file_for_each_line_plus,
262    patch_seq_file_slurp as file_slurp,
263};
264
265// List operations (exported for LLVM linking)
266pub use list_ops::{
267    patch_seq_list_each as list_each, patch_seq_list_empty as list_empty,
268    patch_seq_list_filter as list_filter, patch_seq_list_fold as list_fold,
269    patch_seq_list_get as list_get, patch_seq_list_length as list_length,
270    patch_seq_list_make as list_make, patch_seq_list_map as list_map,
271    patch_seq_list_push as list_push, patch_seq_list_set as list_set,
272};
273
274// Map operations (exported for LLVM linking)
275pub use map_ops::{
276    patch_seq_make_map as make_map, patch_seq_map_empty as map_empty, patch_seq_map_get as map_get,
277    patch_seq_map_has as map_has, patch_seq_map_keys as map_keys,
278    patch_seq_map_remove as map_remove, patch_seq_map_set as map_set,
279    patch_seq_map_size as map_size, patch_seq_map_values as map_values,
280};
281
282// Test framework operations (exported for LLVM linking)
283pub use test::{
284    patch_seq_test_assert as test_assert, patch_seq_test_assert_eq as test_assert_eq,
285    patch_seq_test_assert_eq_str as test_assert_eq_str,
286    patch_seq_test_assert_not as test_assert_not, patch_seq_test_fail as test_fail,
287    patch_seq_test_fail_count as test_fail_count, patch_seq_test_finish as test_finish,
288    patch_seq_test_has_failures as test_has_failures, patch_seq_test_init as test_init,
289    patch_seq_test_pass_count as test_pass_count,
290};
291
292// Time operations (exported for LLVM linking)
293pub use time_ops::{
294    patch_seq_time_nanos as time_nanos, patch_seq_time_now as time_now,
295    patch_seq_time_sleep_ms as time_sleep_ms,
296};
297
298// HTTP client operations (exported for LLVM linking)
299#[cfg(feature = "http")]
300pub use http_client::{
301    patch_seq_http_delete as http_delete, patch_seq_http_get as http_get,
302    patch_seq_http_post as http_post, patch_seq_http_put as http_put,
303};
304#[cfg(not(feature = "http"))]
305pub use http_stub::{
306    patch_seq_http_delete as http_delete, patch_seq_http_get as http_get,
307    patch_seq_http_post as http_post, patch_seq_http_put as http_put,
308};