author | wenzelm |
Wed, 06 Oct 2021 13:28:11 +0200 | |
changeset 74464 | c30906fbbe91 |
parent 74313 | 6b998ce1b8cb |
child 74465 | 981e3b6b08a5 |
permissions | -rw-r--r-- |
72886 | 1 |
/* Title: Pure/Admin/build_vampire.scala |
2 |
Author: Makarius |
|
3 |
||
4 |
Build Isabelle Vampire component from repository. |
|
5 |
*/ |
|
6 |
||
7 |
package isabelle |
|
8 |
||
9 |
||
10 |
object Build_Vampire |
|
11 |
{ |
|
12 |
val default_repository = "https://github.com/vprover/vampire.git" |
|
74464 | 13 |
val default_version = "4.5.1" |
72890 | 14 |
val default_jobs = 1 |
72887 | 15 |
|
74464 | 16 |
def make_component_name(version: String): String = |
17 |
"vampire-" + Library.try_unprefix("v", version).getOrElse(version) |
|
72886 | 18 |
|
19 |
||
20 |
/* build Vampire */ |
|
21 |
||
22 |
def build_vampire( |
|
23 |
repository: String = default_repository, |
|
74464 | 24 |
version: String = default_version, |
72890 | 25 |
jobs: Int = default_jobs, |
72887 | 26 |
component_name: String = "", |
72886 | 27 |
verbose: Boolean = false, |
28 |
progress: Progress = new Progress, |
|
73340 | 29 |
target_dir: Path = Path.current): Unit = |
72886 | 30 |
{ |
73650 | 31 |
Isabelle_System.require_command("git") |
32 |
Isabelle_System.require_command("cmake") |
|
72938 | 33 |
|
72886 | 34 |
Isabelle_System.with_tmp_dir("build")(tmp_dir => |
35 |
{ |
|
36 |
/* component and platform */ |
|
37 |
||
74464 | 38 |
val component = proper_string(component_name) getOrElse make_component_name(version) |
72887 | 39 |
val component_dir = Isabelle_System.new_directory(target_dir + Path.basic(component)) |
72886 | 40 |
progress.echo("Component " + component_dir) |
41 |
||
42 |
val platform_name = |
|
43 |
proper_string(Isabelle_System.getenv("ISABELLE_PLATFORM64")) getOrElse |
|
44 |
error("No 64bit platform") |
|
45 |
val platform_dir = Isabelle_System.make_directory(component_dir + Path.basic(platform_name)) |
|
46 |
||
47 |
||
48 |
/* clone repository */ |
|
49 |
||
50 |
progress.echo("Cloning repository " + repository) |
|
51 |
progress.bash("git clone " + Bash.string(repository) + " vampire", |
|
52 |
cwd = tmp_dir.file, echo = verbose).check |
|
53 |
||
72888
74d785882737
prefer cmake build for standard version: more portable;
wenzelm
parents:
72887
diff
changeset
|
54 |
val source_dir = tmp_dir + Path.explode("vampire") |
74d785882737
prefer cmake build for standard version: more portable;
wenzelm
parents:
72887
diff
changeset
|
55 |
|
73317 | 56 |
Isabelle_System.copy_file(source_dir + Path.explode("LICENCE"), component_dir) |
72888
74d785882737
prefer cmake build for standard version: more portable;
wenzelm
parents:
72887
diff
changeset
|
57 |
|
74d785882737
prefer cmake build for standard version: more portable;
wenzelm
parents:
72887
diff
changeset
|
58 |
|
74464 | 59 |
/* build */ |
72886 | 60 |
|
74464 | 61 |
progress.echo("Building vampire") |
62 |
progress.bash("git checkout --quiet --detach " + Bash.string(version), |
|
63 |
cwd = source_dir.file, echo = verbose).check |
|
72888
74d785882737
prefer cmake build for standard version: more portable;
wenzelm
parents:
72887
diff
changeset
|
64 |
|
74464 | 65 |
val build_dir = source_dir + Path.explode("build") |
66 |
Isabelle_System.rm_tree(build_dir) |
|
67 |
Isabelle_System.make_directory(build_dir) |
|
72888
74d785882737
prefer cmake build for standard version: more portable;
wenzelm
parents:
72887
diff
changeset
|
68 |
|
74464 | 69 |
val cmake_opts = if (Platform.is_linux) "-DBUILD_SHARED_LIBS=0 " else "" |
70 |
val cmake_out = |
|
71 |
progress.bash("cmake " + cmake_opts + """-G "Unix Makefiles" ..""", |
|
72 |
cwd = build_dir.file, echo = verbose).check.out |
|
72886 | 73 |
|
74464 | 74 |
val Pattern = """-- Setting binary name to '?([^\s']*)'?""".r |
75 |
val binary = |
|
76 |
split_lines(cmake_out).collectFirst({ case Pattern(name) => name }) |
|
77 |
.getOrElse(error("Failed to determine binary name from cmake output:\n" + cmake_out)) |
|
72888
74d785882737
prefer cmake build for standard version: more portable;
wenzelm
parents:
72887
diff
changeset
|
78 |
|
74464 | 79 |
progress.bash("make -j" + jobs, cwd = build_dir.file, echo = verbose).check |
72888
74d785882737
prefer cmake build for standard version: more portable;
wenzelm
parents:
72887
diff
changeset
|
80 |
|
74464 | 81 |
Isabelle_System.copy_file(build_dir + Path.basic("bin") + Path.basic(binary).platform_exe, |
82 |
platform_dir + Path.basic("vampire").platform_exe) |
|
72888
74d785882737
prefer cmake build for standard version: more portable;
wenzelm
parents:
72887
diff
changeset
|
83 |
|
74d785882737
prefer cmake build for standard version: more portable;
wenzelm
parents:
72887
diff
changeset
|
84 |
|
72886 | 85 |
/* settings */ |
86 |
||
87 |
val etc_dir = Isabelle_System.make_directory(component_dir + Path.basic("etc")) |
|
88 |
File.write(etc_dir + Path.basic("settings"), |
|
89 |
"""# -*- shell-script -*- :mode=shellscript: |
|
90 |
||
91 |
VAMPIRE_HOME="$COMPONENT/$ISABELLE_PLATFORM64" |
|
92 |
||
93 |
ISABELLE_VAMPIRE="$VAMPIRE_HOME/vampire" |
|
94 |
""") |
|
95 |
||
96 |
||
97 |
/* README */ |
|
98 |
||
99 |
File.write(component_dir + Path.basic("README"), |
|
74464 | 100 |
"This Isabelle component provides Vampire " + version + """ |
101 |
using original sources from https://github.com/vprover/vampire |
|
72886 | 102 |
|
74464 | 103 |
The executable has been built like this: |
72886 | 104 |
|
74464 | 105 |
git checkout REV |
72889
5db643841f5d
back to uniform build, using latest repository version for vampire_polymorphic;
wenzelm
parents:
72888
diff
changeset
|
106 |
cmake . |
5db643841f5d
back to uniform build, using latest repository version for vampire_polymorphic;
wenzelm
parents:
72888
diff
changeset
|
107 |
make |
72886 | 108 |
|
109 |
The precise commit id is revealed by executing "vampire --version". |
|
110 |
||
111 |
||
112 |
Makarius |
|
113 |
""" + Date.Format.date(Date.now()) + "\n") |
|
114 |
}) |
|
115 |
} |
|
116 |
||
117 |
||
118 |
/* Isabelle tool wrapper */ |
|
119 |
||
120 |
val isabelle_tool = |
|
121 |
Isabelle_Tool("build_vampire", "build prover component from repository", Scala_Project.here, |
|
122 |
args => |
|
123 |
{ |
|
124 |
var target_dir = Path.current |
|
125 |
var repository = default_repository |
|
74464 | 126 |
var version = default_version |
72890 | 127 |
var jobs = default_jobs |
72887 | 128 |
var component_name = "" |
72886 | 129 |
var verbose = false |
130 |
||
131 |
val getopts = Getopts(""" |
|
132 |
Usage: isabelle build_vampire [OPTIONS] |
|
133 |
||
134 |
Options are: |
|
135 |
-D DIR target directory (default ".") |
|
136 |
-U URL repository (default: """" + default_repository + """") |
|
74464 | 137 |
-V REV version tag (default: """" + default_version + """") |
72890 | 138 |
-j NUMBER parallel jobs for make (default: """ + default_jobs + """) |
74464 | 139 |
-n NAME component name (default: """" + make_component_name("REV") + """") |
72886 | 140 |
-v verbose |
141 |
||
142 |
Build prover component from official download. |
|
143 |
""", |
|
144 |
"D:" -> (arg => target_dir = Path.explode(arg)), |
|
145 |
"U:" -> (arg => repository = arg), |
|
74464 | 146 |
"V:" -> (arg => version = arg), |
72890 | 147 |
"j:" -> (arg => jobs = Value.Nat.parse(arg)), |
72886 | 148 |
"n:" -> (arg => component_name = arg), |
149 |
"v" -> (_ => verbose = true)) |
|
150 |
||
151 |
val more_args = getopts(args) |
|
152 |
if (more_args.nonEmpty) getopts.usage() |
|
153 |
||
154 |
val progress = new Console_Progress() |
|
155 |
||
74464 | 156 |
build_vampire(repository = repository, version = version, component_name = component_name, |
157 |
jobs = jobs, verbose = verbose, progress = progress, target_dir = target_dir) |
|
72886 | 158 |
}) |
159 |
} |