--- a/src/HOL/SPARK/Examples/Gcd/Greatest_Common_Divisor.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/Gcd/Greatest_Common_Divisor.thy Wed Apr 30 22:35:42 2014 +0200
@@ -10,7 +10,7 @@
spark_proof_functions
gcd = "gcd :: int \<Rightarrow> int \<Rightarrow> int"
-spark_open "greatest_common_divisor/g_c_d.siv"
+spark_open "greatest_common_divisor/g_c_d"
spark_vc procedure_g_c_d_4
proof -
--- a/src/HOL/SPARK/Examples/Liseq/Longest_Increasing_Subsequence.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/Liseq/Longest_Increasing_Subsequence.thy Wed Apr 30 22:35:42 2014 +0200
@@ -27,7 +27,7 @@
*}
definition liseq' :: "(nat \<Rightarrow> 'a::linorder) \<Rightarrow> nat \<Rightarrow> nat" where
- "liseq' xs i = Max (card ` (iseq xs (Suc i) \<inter> {is. Max is = i}))"
+ "liseq' xs i = Max (card ` (iseq xs (Suc i) \<inter> {is. Max is = i}))"
lemma iseq_finite: "finite (iseq xs i)"
apply (simp add: iseq_def)
@@ -541,7 +541,7 @@
text {* The verification conditions *}
-spark_open "liseq/liseq_length.siv"
+spark_open "liseq/liseq_length"
spark_vc procedure_liseq_length_5
by (simp_all add: liseq_singleton liseq'_singleton)
--- a/src/HOL/SPARK/Examples/RIPEMD-160/F.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/RIPEMD-160/F.thy Wed Apr 30 22:35:42 2014 +0200
@@ -8,7 +8,7 @@
imports RMD_Specification
begin
-spark_open "rmd/f.siv"
+spark_open "rmd/f"
spark_vc function_f_2
using assms by simp_all
--- a/src/HOL/SPARK/Examples/RIPEMD-160/Hash.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/RIPEMD-160/Hash.thy Wed Apr 30 22:35:42 2014 +0200
@@ -8,7 +8,7 @@
imports RMD_Specification
begin
-spark_open "rmd/hash.siv"
+spark_open "rmd/hash"
abbreviation from_chain :: "chain \<Rightarrow> RMD.chain" where
"from_chain c \<equiv> (
--- a/src/HOL/SPARK/Examples/RIPEMD-160/K_L.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/RIPEMD-160/K_L.thy Wed Apr 30 22:35:42 2014 +0200
@@ -8,7 +8,7 @@
imports RMD_Specification
begin
-spark_open "rmd/k_l.siv"
+spark_open "rmd/k_l"
spark_vc function_k_l_6
using assms by (simp add: K_def)
--- a/src/HOL/SPARK/Examples/RIPEMD-160/K_R.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/RIPEMD-160/K_R.thy Wed Apr 30 22:35:42 2014 +0200
@@ -8,7 +8,7 @@
imports RMD_Specification
begin
-spark_open "rmd/k_r.siv"
+spark_open "rmd/k_r"
spark_vc function_k_r_6
using assms by (simp add: K'_def)
--- a/src/HOL/SPARK/Examples/RIPEMD-160/R_L.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/RIPEMD-160/R_L.thy Wed Apr 30 22:35:42 2014 +0200
@@ -8,7 +8,7 @@
imports RMD_Specification RMD_Lemmas
begin
-spark_open "rmd/r_l.siv"
+spark_open "rmd/r_l"
spark_vc function_r_l_2
proof -
--- a/src/HOL/SPARK/Examples/RIPEMD-160/R_R.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/RIPEMD-160/R_R.thy Wed Apr 30 22:35:42 2014 +0200
@@ -8,7 +8,7 @@
imports RMD_Specification RMD_Lemmas
begin
-spark_open "rmd/r_r.siv"
+spark_open "rmd/r_r"
spark_vc function_r_r_2
proof -
--- a/src/HOL/SPARK/Examples/RIPEMD-160/Round.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/RIPEMD-160/Round.thy Wed Apr 30 22:35:42 2014 +0200
@@ -8,7 +8,7 @@
imports RMD_Specification
begin
-spark_open "rmd/round.siv"
+spark_open "rmd/round"
abbreviation from_chain :: "chain \<Rightarrow> RMD.chain" where
"from_chain c \<equiv> (
@@ -88,7 +88,7 @@
show ?thesis
unfolding `nat (i + 1) = Suc (nat i)` steps_step steps_to_steps'
..
-qed
+qed
lemma step_from_hyp:
assumes
@@ -244,7 +244,7 @@
nat_transfer
unfolding `?MM = 2 ^ len_of TYPE(32)`
unfolding word_uint.Abs_norm
- by (simp add:
+ by (simp add:
`a' mod ?MM = a'`
`e' mod ?MM = e'`
`?X mod ?MM = ?X`)
@@ -274,7 +274,7 @@
\<lparr>h0 = ca, h1 = cb, h2 = cc,
h3 = cd, h4 = ce\<rparr>\<rparr>)
0 x"
- unfolding steps_def
+ unfolding steps_def
by (simp add:
uint_word_of_int_id[OF `0 <= ca` `ca <= ?M`]
uint_word_of_int_id[OF `0 <= cb` `cb <= ?M`]
@@ -398,7 +398,7 @@
`crc <= ?M`
`crd <= ?M`
`cre <= ?M`
-
+
`0 <= cla`
`0 <= clb`
`0 <= clc`
--- a/src/HOL/SPARK/Examples/RIPEMD-160/S_L.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/RIPEMD-160/S_L.thy Wed Apr 30 22:35:42 2014 +0200
@@ -8,7 +8,7 @@
imports RMD_Specification RMD_Lemmas
begin
-spark_open "rmd/s_l.siv"
+spark_open "rmd/s_l"
spark_vc function_s_l_2
proof -
--- a/src/HOL/SPARK/Examples/RIPEMD-160/S_R.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/RIPEMD-160/S_R.thy Wed Apr 30 22:35:42 2014 +0200
@@ -8,7 +8,7 @@
imports RMD_Specification RMD_Lemmas
begin
-spark_open "rmd/s_r.siv"
+spark_open "rmd/s_r"
spark_vc function_s_r_2
proof -
--- a/src/HOL/SPARK/Examples/Sqrt/Sqrt.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Examples/Sqrt/Sqrt.thy Wed Apr 30 22:35:42 2014 +0200
@@ -7,7 +7,7 @@
imports SPARK
begin
-spark_open "sqrt/isqrt.siv"
+spark_open "sqrt/isqrt"
spark_vc function_isqrt_4
proof -
--- a/src/HOL/SPARK/Manual/Complex_Types.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Manual/Complex_Types.thy Wed Apr 30 22:35:42 2014 +0200
@@ -31,7 +31,7 @@
complex_types__initialized3 = initialized3
(*<*)
-spark_open "complex_types_app/initialize.siv"
+spark_open "complex_types_app/initialize"
spark_vc procedure_initialize_1
by (simp add: initialized_def)
--- a/src/HOL/SPARK/Manual/Example_Verification.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Manual/Example_Verification.thy Wed Apr 30 22:35:42 2014 +0200
@@ -127,7 +127,7 @@
We now instruct Isabelle to open
a new verification environment and load a set of VCs. This is done using the
command \isa{\isacommand{spark\_open}}, which must be given the name of a
-\texttt{*.siv} or \texttt{*.vcg} file as an argument. Behind the scenes, Isabelle
+\texttt{*.siv} file as an argument. Behind the scenes, Isabelle
parses this file and the corresponding \texttt{*.fdl} and \texttt{*.rls} files,
and converts the VCs to Isabelle terms. Using the command \isa{\isacommand{spark\_status}},
the user can display the current VCs together with their status (proved, unproved).
--- a/src/HOL/SPARK/Manual/Proc1.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Manual/Proc1.thy Wed Apr 30 22:35:42 2014 +0200
@@ -2,7 +2,7 @@
imports SPARK
begin
-spark_open "loop_invariant/proc1.siv"
+spark_open "loop_invariant/proc1"
spark_vc procedure_proc1_5
by (simp add: ring_distribs pull_mods)
--- a/src/HOL/SPARK/Manual/Proc2.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Manual/Proc2.thy Wed Apr 30 22:35:42 2014 +0200
@@ -2,7 +2,7 @@
imports SPARK
begin
-spark_open "loop_invariant/proc2.siv"
+spark_open "loop_invariant/proc2"
spark_vc procedure_proc2_7
by (simp add: ring_distribs pull_mods)
--- a/src/HOL/SPARK/Manual/Reference.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Manual/Reference.thy Wed Apr 30 22:35:42 2014 +0200
@@ -24,8 +24,9 @@
This section describes the syntax and effect of each of the commands provided
by HOL-\SPARK{}.
@{rail "@'spark_open' name ('(' name ')')?"}
-Opens a new \SPARK{} verification environment and loads a file with VCs. The file can be either
-a \texttt{*.vcg} or a \texttt{*.siv} file. The corresponding \texttt{*.fdl} and \texttt{*.rls}
+Opens a new \SPARK{} verification environment and loads a \texttt{*.siv} file with VCs.
+Alternatively, \texttt{*.vcg} files can be loaded using \isa{\isacommand{spark\_open\_vcg}}.
+The corresponding \texttt{*.fdl} and \texttt{*.rls}
files must reside in the same directory as the file given as an argument to the command.
This command also generates records and datatypes for the types specified in the
\texttt{*.fdl} file, unless they have already been associated with user-defined
--- a/src/HOL/SPARK/Manual/Simple_Greatest_Common_Divisor.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Manual/Simple_Greatest_Common_Divisor.thy Wed Apr 30 22:35:42 2014 +0200
@@ -10,7 +10,7 @@
spark_proof_functions
gcd = "gcd :: int \<Rightarrow> int \<Rightarrow> int"
-spark_open "simple_greatest_common_divisor/g_c_d.siv"
+spark_open "simple_greatest_common_divisor/g_c_d"
spark_vc procedure_g_c_d_4
using `0 < d` `gcd c d = gcd m n`
--- a/src/HOL/SPARK/SPARK_Setup.thy Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/SPARK_Setup.thy Wed Apr 30 22:35:42 2014 +0200
@@ -9,8 +9,8 @@
imports "~~/src/HOL/Word/Word" "~~/src/HOL/Word/Bit_Comparison"
keywords
"spark_open_vcg" :: thy_load ("vcg", "fdl", "rls") and
- "spark_open_siv" :: thy_load ("siv", "fdl", "rls") and
- "spark_open" "spark_proof_functions" "spark_types" "spark_end" :: thy_decl and
+ "spark_open" :: thy_load ("siv", "fdl", "rls") and
+ "spark_proof_functions" "spark_types" "spark_end" :: thy_decl and
"spark_vc" :: thy_goal and "spark_status" :: diag
begin
--- a/src/HOL/SPARK/Tools/spark_commands.ML Wed Apr 30 22:34:11 2014 +0200
+++ b/src/HOL/SPARK/Tools/spark_commands.ML Wed Apr 30 22:35:42 2014 +0200
@@ -4,10 +4,11 @@
Isar commands for handling SPARK/Ada verification conditions.
*)
+
structure SPARK_Commands: sig end =
struct
-fun spark_open header (prfx, files) thy =
+fun spark_open header (files, prfx) thy =
let
val ([{src_path, lines = vc_lines, pos = vc_pos, ...}: Token.file,
{lines = fdl_lines, pos = fdl_pos, ...},
@@ -21,25 +22,6 @@
base prfx thy'
end;
-(* FIXME *)
-fun spark_open_old (vc_name, prfx) thy =
- let
- val ((vc_path, vc_id), vc_text) = Resources.load_file thy (Path.explode vc_name);
- val (base, header) =
- (case Path.split_ext vc_path of
- (base, "vcg") => (base, Fdl_Lexer.vcg_header >> K ())
- | (base, "siv") => (base, Fdl_Lexer.siv_header >> K ())
- | _ => error "File name must end with .vcg or .siv");
- val fdl_path = Path.ext "fdl" base;
- val rls_path = Path.ext "rls" base;
- in
- SPARK_VCs.set_vcs
- (snd (Fdl_Parser.parse_declarations (Path.position fdl_path) (File.read fdl_path)))
- (Fdl_Parser.parse_rules (Path.position rls_path) (File.read rls_path))
- (snd (Fdl_Parser.parse_vcs header (Path.position vc_path) vc_text))
- base prfx thy
- end;
-
fun add_proof_fun_cmd pf thy =
let val ctxt = Proof_Context.init_global thy
in SPARK_VCs.add_proof_fun
@@ -110,20 +92,15 @@
end;
val _ =
- Outer_Syntax.command @{command_spec "spark_open"}
- "open a new SPARK environment and load a SPARK-generated .vcg or .siv file"
- (Parse.name -- Parse.parname >> (Toplevel.theory o spark_open_old));
-
-val _ =
Outer_Syntax.command @{command_spec "spark_open_vcg"}
"open a new SPARK environment and load a SPARK-generated .vcg file"
- (Parse.parname -- Resources.provide_parse_files "spark_open_vcg"
+ (Resources.provide_parse_files "spark_open_vcg" -- Parse.parname
>> (Toplevel.theory o spark_open Fdl_Lexer.vcg_header));
val _ =
- Outer_Syntax.command @{command_spec "spark_open_siv"}
+ Outer_Syntax.command @{command_spec "spark_open"}
"open a new SPARK environment and load a SPARK-generated .siv file"
- (Parse.parname -- Resources.provide_parse_files "spark_open_siv"
+ (Resources.provide_parse_files "spark_open" -- Parse.parname
>> (Toplevel.theory o spark_open Fdl_Lexer.siv_header));
val pfun_type = Scan.option
@@ -169,7 +146,7 @@
val _ = Theory.setup (Theory.at_end (fn thy =>
let
val _ = SPARK_VCs.is_closed thy
- orelse error ("Found the end of the theory, " ^
+ orelse error ("Found the end of the theory, " ^
"but the last SPARK environment is still open.")
in NONE end));