Theory XML_Data

(*  Title:      HOL/Proofs/ex/XML_Data.thy
    Author:     Makarius
    Author:     Stefan Berghofer

XML data representation of proof terms.
*)

theory XML_Data
  imports "HOL-Examples.Drinker"
begin

subsection ‹Export and re-import of global proof terms›

ML fun export_proof thy thm = thm
    |> Proof_Syntax.standard_proof_of {full = true, expand_name = Thm.expand_name thm}
    |> Proofterm.encode (Sign.consts_of thy);

  fun import_proof thy xml =
    let
      val prf = Proofterm.decode (Sign.consts_of thy) xml;
      val (prf', _) = Proofterm.freeze_thaw_prf prf;
    in Drule.export_without_context (Proof_Checker.thm_of_proof thy prf') end;


subsection ‹Examples›

ML val thy1 = theory

lemma ex: "A  A" ..

ML_val val xml = export_proof thy1 @{thm ex};
  val thm = import_proof thy1 xml;

ML_val val xml = export_proof thy1 @{thm de_Morgan};
  val thm = import_proof thy1 xml;

ML_val val xml = export_proof thy1 @{thm Drinker's_Principle};
  val thm = import_proof thy1 xml;

text ‹Some fairly large proof:›

ML_val val xml = export_proof thy1 @{thm abs_less_iff};
  val thm = import_proof thy1 xml;

  val xml_size = size (YXML.string_of_body xml);
  assert (xml_size > 100000);

end