diff options
| author | Paul Buetow <paul@buetow.org> | 2026-02-28 16:15:57 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-02-28 16:15:57 +0200 |
| commit | 2a2227d529f3788b8e08752d37deb1a449f3b9bc (patch) | |
| tree | 09a840230ca824a3df5491a3cc9263b72955f1a9 /src/core/interpret.h | |
| parent | 5f557ebafb596755cb3047cbdafa6122166c26ac (diff) | |
Clean up scanner_run() and interpret_run(): narrow signatures, fix SoC [SoC/DIP]
Three issues resolved:
1. scanner_run() no longer takes Fype*. New signature:
scanner_run(List*, Tupel*, char **c_filename_out)
Verbose-mode list_iterate() and basename extraction moved to
fype_run() (the composition root), leaving scanner_run() as pure
tokenizer: open source -> tokenize -> post-process -> return filename.
2. interpret_run() no longer takes Fype*. New signature:
interpret_run(List *p_list_token, Hash *p_hash_syms)
Fype* unpacking happens in fype_run(); interpret.h no longer includes
fype.h. scanner.h no longer includes fype.h either.
3. _CODESTR_INDEX file-global (which made the scanner non-reentrant)
moved into the Scanner struct as i_codestr_index, initialized to 0
in scanner_new(). _scanner_has_next_char() and _scanner_get_next_char()
use p_scanner->i_codestr_index instead.
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
Diffstat (limited to 'src/core/interpret.h')
| -rw-r--r-- | src/core/interpret.h | 4 |
1 files changed, 1 insertions, 3 deletions
diff --git a/src/core/interpret.h b/src/core/interpret.h index 7c2eba8..9ab3016 100644 --- a/src/core/interpret.h +++ b/src/core/interpret.h @@ -40,8 +40,6 @@ #include "../data/stack.h" #include "../data/hash.h" -#include "../fype.h" - #include "garbage.h" #include "scope.h" #include "token.h" @@ -74,7 +72,7 @@ typedef struct { Interpret* interpret_new(List *p_list_token, Hash *p_hash_syms); void interpret_delete(Interpret *p_interpret); -void interpret_run(Fype *p_type); +void interpret_run(List *p_list_token, Hash *p_hash_syms); int interpret_process(Interpret *p_interpret); int interpret_subprocess(Interpret *p_interpret, List *p_list_token); |
