Stream: Mirror: Isabelle Users Mailing List

Topic: [isabelle] cut for context_parser + improved error messag...


view this post on Zulip Email Gateway (Sep 13 2023 at 13:55):

From: Kevin Kappelmann <kevin.kappelmann@tum.de>
Hello,

Unlike Parse.enum1, the definition of Parse.enum1' does not include a
cut. This causes unhelpful error messages down the road, as exemplified
in below theory (tested with Isabelle version 3032bc7d613d (i.e. latest
development version)).

Would it be possible to include "!!!+" and "enum1'" from below theory in
the standard distribution (in parse.ML)?

Best wishes,

Kevin

theory Scratch
   imports
     Main
begin

ML
fun get_tokens_pos [] = " (end-of-input)"
   | get_tokens_pos (tok :: _) = Position.here (Token.pos_of tok);

(*generalisation of Parse.cut*)
fun cut get_pos kind scan =
   let
     fun err (x, NONE) = (fn () => kind ^ get_pos x)
       | err (x, SOME msg) =
           (fn () =>
             let val s = msg () in
               if String.isPrefix kind s then s
               else kind ^ get_pos x ^ ": " ^ s
             end);
   in Scan.!! err scan end;

local
val error_msg = "Outer syntax error";
in
fun !!! scan = cut get_tokens_pos error_msg scan;
(*!!! for context parsers (currently missing in the standard distribution)*)
fun !!!+ scan = cut (get_tokens_pos o snd) error_msg scan;
end

(*same definition as Parse.enum1*)
fun enum1 sep scan = scan ::: Scan.repeat (Parse.$$$ sep |-- !!! scan);
(*now including cuts (unlike Parse.enum1')*)
fun enum1' sep scan = scan ::: Scan.repeat (Scan.lift (Parse.$$$ sep)
|-- !!!+ scan);
(*current definition of Parse.enum1'*)
(* fun enum1' sep scan = scan ::: Scan.repeat (Scan.lift ($$$ sep) |--
scan); *)

(*example attributes to show parsing differences*)
val _ =
   Theory.setup (
     Attrib.setup \<^binding>‹withcut›
       (enum1' "and" (Scan.lift Parse.nat) |-- Scan.succeed (K (NONE,
NONE)))
       "withcut"
     #> Attrib.setup \<^binding>‹withoutcut›
       (Parse.enum1' "and" (Scan.lift Parse.nat) |-- Scan.succeed (K
(NONE, NONE)))
       "withoutcut"
   )


(*
error/squiggly line at "this is not a nat"; error message:
Outer syntax error⌂: natural number expected,
but quoted string "this is not a nat"⌂ was found
*)
declare [[withcut 0 and "this is not a nat"]]
(*
error/squiggly line at "withoutcut"; error message:
Bad arguments for attribute "withoutcut"⌂:
   and "this is not a nat"
*)
declare [[withoutcut 0 and "this is not a nat"]]

end

view this post on Zulip Email Gateway (Oct 23 2023 at 12:27):

From: Makarius <makarius@sketis.net>
Thanks for the hint. That omission goes back to 1998 (Isabelle/769abc29bb8e),
when the "Args" parsing was quite different from Isar output syntax ("Parse").

I have now improved the situation for the next release in Isabelle/b8775a63cb35.

Side-remark: "the latest development version" is already long past
3032bc7d613d. In other words: that expression is ill-defined, it falsely
assumes a real-time communication channel with synchronisation against the
repository history.

Makarius


Last updated: Jan 04 2025 at 20:18 UTC