diff --git a/benchmark/.gitignore b/benchmark/.gitignore index 43824c2fe34a64a9be9527c9b969959770000acc..b0922ce45a97271cc5b0af2b0b698241f4420bc0 100644 --- a/benchmark/.gitignore +++ b/benchmark/.gitignore @@ -1,3 +1,3 @@ __pycache__ -build-times.log* +build-times* gitlab-extract diff --git a/benchmark/export.py b/benchmark/export.py index 9707edff28968fad8a42c3554645cfb09325f39b..c3269c2426edce4352229ae94603fc83b3c46b21 100755 --- a/benchmark/export.py +++ b/benchmark/export.py @@ -3,8 +3,6 @@ import argparse, sys, pprint, itertools, subprocess import requests import parse_log -markers = itertools.cycle([(3, 0), (3, 0, 180), (4, 0), (4, 0, 45), (8, 0)]) - # read command-line arguments parser = argparse.ArgumentParser(description='Export iris-coq build times to grafana') parser.add_argument("-f", "--file", @@ -19,6 +17,9 @@ parser.add_argument("-p", "--project", parser.add_argument("-b", "--branch", dest="branch", required=True, help="Branch name sent to the server.") +parser.add_argument("--config", + dest="config", required=True, + help="The config string.") parser.add_argument("-s", "--server", dest="server", required=True, help="The server (URL) to send the data to.") @@ -39,10 +40,11 @@ if args.commits: results = list(results) for datapoint in results: - times = ''.join(datapoint.times) + times = '\n'.join(datapoint.times) commit = datapoint.commit + print("Sending {}...".format(commit), end='') date = subprocess.check_output(['git', 'show', commit, '-s', '--pretty=%cI']).strip().decode('UTF-8') - headers = {'X-Project': args.project, 'X-Branch': args.branch, 'X-Commit': commit, 'X-Date': date} - r = requests.post(args.server, data=times, headers=headers, auth=(args.user, args.password)) + headers = {'X-Project': args.project, 'X-Branch': args.branch, 'X-Commit': commit, 'X-Config': args.config, 'X-Date': date} + r = requests.post(args.server+"/build_times_8.6", data=times, headers=headers, auth=(args.user, args.password)) + print(" {}".format(r.text.strip())) r.raise_for_status() - diff --git a/benchmark/parse_log.py b/benchmark/parse_log.py index 568f83d9c3134142df9e26a59f7b8bc93043dd52..29ce97312ee85e33862c5ff35045ac5ecb9c73fa 100644 --- a/benchmark/parse_log.py +++ b/benchmark/parse_log.py @@ -17,6 +17,7 @@ def parse(file, parse_times = PARSE_FULL): commit = None times = None for line in file: + line = line.strip() # next commit? m = commit_re.match(line) if m is not None: @@ -40,6 +41,7 @@ def parse(file, parse_times = PARSE_FULL): times[name] = time continue # nothing else we know about, ignore + print("Ignoring line",line) # end of file. previous commit, if any, is done now. if commit is not None: yield Result(commit, times) diff --git a/theories/heap_lang/proofmode.v b/theories/heap_lang/proofmode.v index 991a9e695319160388a6395ee83527743cfec2f9..f9d4f458df41c44987a5daa429383af2de1114a9 100644 --- a/theories/heap_lang/proofmode.v +++ b/theories/heap_lang/proofmode.v @@ -69,7 +69,7 @@ Tactic Notation "wp_pure" open_constr(efoc) := |apply _ (* IntoLaters *) |wp_expr_simpl_subst; try wp_value_head (* new goal *) ]) - || fail "wp_pure: cannot find" efoc "in" e "or" efoc "is not a reduct" + || fail "wp_pure: cannot find" efoc "in" e "or" efoc "is not a redex" | |- envs_entails _ (twp ?s ?E ?e ?Q) => let e := eval simpl in e in reshape_expr e ltac:(fun K e' => @@ -79,7 +79,7 @@ Tactic Notation "wp_pure" open_constr(efoc) := |try fast_done (* The pure condition for PureExec *) |wp_expr_simpl_subst; try wp_value_head (* new goal *) ]) - || fail "wp_pure: cannot find" efoc "in" e "or" efoc "is not a reduct" + || fail "wp_pure: cannot find" efoc "in" e "or" efoc "is not a redex" | _ => fail "wp_pure: not a 'wp'" end. diff --git a/theories/proofmode/coq_tactics.v b/theories/proofmode/coq_tactics.v index 26afcd885acdd8318defbc54d59bd615a28518ee..af7262f9cbfca1a7a11abfed57145c2c8344b81a 100644 --- a/theories/proofmode/coq_tactics.v +++ b/theories/proofmode/coq_tactics.v @@ -99,7 +99,7 @@ Definition envs_simple_replace {PROP : bi} (i : ident) (p : bool) Definition envs_replace {PROP : bi} (i : ident) (p q : bool) (Γ : env PROP) (Δ : envs PROP) : option (envs PROP) := - if eqb p q then envs_simple_replace i p Γ Δ + if Bool.eqb p q then envs_simple_replace i p Γ Δ else envs_app q Γ (envs_delete true i p Δ). Definition env_spatial_is_nil {PROP} (Δ : envs PROP) : bool := @@ -332,7 +332,7 @@ Lemma envs_replace_sound' Δ Δ' i p q Γ : envs_replace i p q Γ Δ = Some Δ' → of_envs (envs_delete true i p Δ) ⊢ (if q then □ [∧] Γ else [∗] Γ) -∗ of_envs Δ'. Proof. - rewrite /envs_replace; destruct (eqb _ _) eqn:Hpq. + rewrite /envs_replace; destruct (Bool.eqb _ _) eqn:Hpq. - apply eqb_prop in Hpq as ->. apply envs_simple_replace_sound'. - apply envs_app_sound. Qed.