forked from Isabelle_DOF/Isabelle_DOF
54 lines
2.1 KiB
Plaintext
54 lines
2.1 KiB
Plaintext
theory Conceptual
|
|
imports "../Isa_DOF" "../Isa_COL"
|
|
begin
|
|
|
|
doc_class A =
|
|
x :: int
|
|
|
|
doc_class B =
|
|
x :: "string" (* attributes live in their own name-space *)
|
|
y :: "string list" <= "[]" (* and can have arbitrary type constructors *)
|
|
(* LaTeX may have problems with this, though *)
|
|
|
|
doc_class C = B +
|
|
z :: "A option" <= None (* A LINK, i.e. an attribute that has a type
|
|
referring to a document class. Mathematical
|
|
relations over document items can be modeled. *)
|
|
g :: "thm"
|
|
|
|
datatype enum = X1 | X2 | X3
|
|
|
|
doc_class D = B +
|
|
x :: "string" <= "''def''" (* overriding default *)
|
|
a1 :: enum <= "X2" (* class - definitions may be mixed
|
|
with arbitrary HOL-commands, thus
|
|
also local definitions of enumerations *)
|
|
a2 :: int <= 0
|
|
|
|
doc_class E = D +
|
|
x :: "string" <= "''qed''" (* overriding default *)
|
|
|
|
doc_class F =
|
|
r :: "thm list"
|
|
u :: "file"
|
|
s :: "typ list"
|
|
b :: "(A \<times> C) set" <= "{}" (* This is a relation link, roughly corresponding
|
|
to an association class. It can be used to track
|
|
claims to result - relations, for example.*)
|
|
doc_class G = C +
|
|
g :: "thm" <= "@{thm ''HOL.refl''}"
|
|
|
|
doc_class M =
|
|
trace :: "(A + C + D + F) list"
|
|
accepts "A ~~ \<lbrace>C || D\<rbrace>\<^sup>* ~~ \<lbrakk>F\<rbrakk>"
|
|
|
|
|
|
section*[test::A]\<open> Test and Validation\<close>
|
|
text\<open>Defining some document elements to be referenced in later on in another theory: \<close>
|
|
text*[sdf] {* f @{thm refl}*}
|
|
text*[sdfg] {* fg @{thm refl}*}
|
|
|
|
text*[xxxy] {* dd @{docitem \<open>sdfg\<close>} @{thm refl}*}
|
|
|
|
|
|
end |