Skip to content

Commit

Permalink
expose some more internals
Browse files Browse the repository at this point in the history
  • Loading branch information
digama0 committed Nov 14, 2024
1 parent 8abc7c0 commit 1d8ef02
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 30 deletions.
12 changes: 12 additions & 0 deletions tools/Holmake/HolParser.sig
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,19 @@ structure ToSML: sig
strcode: int * substring -> unit,
strstr: int * substring -> unit
}
val strstr: (string -> unit) -> int * substring -> unit
val strcode: (string -> unit) -> int * substring -> unit
val mkStrcode: (string -> unit) -> strcode

val mkPushTranslatorCore:
{read: int -> string, filename: string, parseError: int * int -> string -> unit} ->
strcode -> {
doDecl: bool -> int -> Simple.decl -> int,
feed: unit -> Simple.topdecl,
finishThmVal: unit -> unit,
regular: int * int -> unit
}

val mkPushTranslator:
{read: int -> string, filename: string, parseError: int * int -> string -> unit} ->
strcode -> unit -> bool
Expand Down
75 changes: 45 additions & 30 deletions tools/Holmake/HolParser.sml
Original file line number Diff line number Diff line change
Expand Up @@ -263,8 +263,8 @@ structure ToSML = struct
strstr: int * substring -> unit
}

fun mkStrcode push: strcode = let
fun encoder st f (_, s) = let
local
fun encoder f push (_, s) = let
val (s, start, len) = Substring.base s
val stop = start + len
fun loop start p =
Expand All @@ -278,19 +278,24 @@ structure ToSML = struct
push r;
loop (p+1) (p+1))
in loop start start end
in {
regular = fn s => push (Substring.string (#2 s)),
aux = push,
strstr = encoder "str" (fn ch =>
if ch < #"\128" then NONE else SOME (AttributeSyntax.bslash_escape ch)),
strcode = encoder "code" (fn
#"\\" => SOME "\\\\"
| #"\"" => SOME "\\\""
| #"\n" => SOME "\\n\\\n\\"
| ch => if Char.isPrint ch then NONE else SOME (AttributeSyntax.bslash_escape ch))
} end
in
val strstr = encoder (fn ch =>
if ch < #"\128" then NONE else SOME (AttributeSyntax.bslash_escape ch))
val strcode = encoder (fn
#"\\" => SOME "\\\\"
| #"\"" => SOME "\\\""
| #"\n" => SOME "\\n\\\n\\"
| ch => if Char.isPrint ch then NONE else SOME (AttributeSyntax.bslash_escape ch))
end

fun mkStrcode push: strcode = {
regular = fn s => push (Substring.string (#2 s)),
aux = push,
strstr = strstr push,
strcode = strcode push
}

fun mkPushTranslator {read, filename, parseError}
fun mkPushTranslatorCore {read, filename, parseError}
({regular, aux, strstr, strcode = strcode0}:strcode) = let
open Simple
val ss = Substring.string
Expand Down Expand Up @@ -333,12 +338,12 @@ structure ToSML = struct
fun magicBind name =
aux (" " ^ Systeml.bindstr (concat ["val ", name, " = DB.fetch \"-\" \"", name,
"\" handle Feedback.HOL_ERR _ => boolTheory.TRUTH;"]) ^ ";")
fun doThmAttrs false p attrs name_attrs = strcode' (p, name_attrs)
fun doThmAttrs false p attrs name_attrs = aux (ss name_attrs)
| doThmAttrs true p attrs name_attrs =
if Substring.isEmpty attrs then
(strcode' (p, name_attrs); aux "[local]")
(aux (ss name_attrs); aux "[local]")
else (
strcode' (p, Substring.slice (name_attrs, 0, SOME (Substring.size name_attrs - 1)));
aux (ss (Substring.slice (name_attrs, 0, SOME (Substring.size name_attrs - 1))));
aux ",local]")
fun doQuoteCore start ds stop f = case ds of
[] => quote (start, stop)
Expand Down Expand Up @@ -536,25 +541,35 @@ structure ToSML = struct
aux " "; p + size text)
and doDecls start [] stop = regular (start, stop)
| doDecls start (d :: ds) stop = doDecls (doDecl false start d) ds stop
in {
feed = feed',
regular = regular,
finishThmVal = finishThmVal,
doDecl = doDecl
} end

fun mkPushTranslator args strcode = let
open Simple
val {feed, regular, finishThmVal, doDecl, ...} = mkPushTranslatorCore args strcode
val pos = ref 0
in fn () =>
case feed' () of
case feed () of
TopDecl d => (pos := doDecl true (!pos) d; false)
| Simple.EOF p => (regular (!pos, p); finishThmVal (); pos := p; true)
end

fun mkPullTranslator args = let
val queue = ref []
val atEnd = ref false
val push = mkPushTranslator args (mkStrcode (fn s => queue := s :: !queue))
fun loop () =
case !queue of
s :: rest => (queue := rest; s)
| [] => if !atEnd then "" else (
atEnd := push ();
queue := rev (!queue);
loop ())
in loop end
fun mkPullTranslator args = let
val queue = ref []
val atEnd = ref false
val push = mkPushTranslator args (mkStrcode (fn s => queue := s :: !queue))
fun loop () =
case !queue of
s :: rest => (queue := rest; s)
| [] => if !atEnd then "" else (
atEnd := push ();
queue := rev (!queue);
loop ())
in loop end

end

Expand Down

0 comments on commit 1d8ef02

Please sign in to comment.