From 7873cf2098544500391066db6540887d3f2fdee4 Mon Sep 17 00:00:00 2001 From: Eric Wieser Date: Thu, 18 Jan 2024 03:32:25 +0000 Subject: [PATCH 1/3] fix: make exfalso actually do what it claims to (#540) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * fix: make exfalso actually do what it claims to Before this change, ```lean example {A} : False → A := by exfalso ``` would work, but the docstring says it should not. * Add a test --- Std/Tactic/Basic.lean | 2 +- test/exfalso.lean | 13 +++++++++++++ 2 files changed, 14 insertions(+), 1 deletion(-) create mode 100644 test/exfalso.lean diff --git a/Std/Tactic/Basic.lean b/Std/Tactic/Basic.lean index 56c22b1b89..f03b59f39f 100644 --- a/Std/Tactic/Basic.lean +++ b/Std/Tactic/Basic.lean @@ -19,7 +19,7 @@ namespace Std.Tactic open Lean Parser.Tactic Elab Command Elab.Tactic Meta /-- `exfalso` converts a goal `⊢ tgt` into `⊢ False` by applying `False.elim`. -/ -macro "exfalso" : tactic => `(tactic| apply False.elim) +macro "exfalso" : tactic => `(tactic| refine False.elim ?_) /-- `_` in tactic position acts like the `done` tactic: it fails and gives the list diff --git a/test/exfalso.lean b/test/exfalso.lean new file mode 100644 index 0000000000..a8771348f4 --- /dev/null +++ b/test/exfalso.lean @@ -0,0 +1,13 @@ +import Std.Tactic.Basic + +private axiom test_sorry : ∀ {α}, α + +example {A} (h : False) : A := by + exfalso + exact h + +example {A} : False → A := by + exfalso + show False -- exfalso is not supposed to close the goal yet + exact test_sorry + From 3ee9480677b2f47fa7f29f0d3222f3123322b5be Mon Sep 17 00:00:00 2001 From: Scott Morrison Date: Sun, 21 Jan 2024 10:46:30 +1100 Subject: [PATCH 2/3] chore: make nightly-testing-YYYY-MM-DD a tag, not a branch (#545) * chore: make nightly-testing-YYYY-MM-DD a tag, not a branch * Update .github/workflows/nightly_detect_failure.yml Co-authored-by: Joachim Breitner * branch -> tag --------- Co-authored-by: Joachim Breitner --- .github/workflows/nightly_detect_failure.yml | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/.github/workflows/nightly_detect_failure.yml b/.github/workflows/nightly_detect_failure.yml index 87bb6f8708..57a3225dee 100644 --- a/.github/workflows/nightly_detect_failure.yml +++ b/.github/workflows/nightly_detect_failure.yml @@ -39,12 +39,19 @@ jobs: ref: nightly-testing # checkout nightly-testing branch fetch-depth: 0 # checkout all branches so that we can push from `nightly-testing` to `nightly-testing-YYYY-MM-DD` token: ${{ secrets.NIGHTLY_TESTING }} - - name: Update the nightly-testing-YYYY-MM-DD branch + - name: Update the nightly-testing-YYYY-MM-DD tag run: | toolchain=$(/dev/null; then + echo "Tag nightly-testing-$version already exists on the remote." + else + # If the tag does not exist, create and push the tag to remote + echo "Creating tag nightly-testing-$version from the current state of the nightly-testing branch." + git tag nightly-testing-$version + git push origin nightly-testing-$version + fi else echo "Error: The file lean-toolchain does not contain the expected pattern." exit 1 From d7228c76cf7bffd8cc1d803f6ca82b0bcb4a6488 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Philipp=20Br=C3=BCschweiler?= Date: Mon, 22 Jan 2024 17:43:38 +0100 Subject: [PATCH 3/3] Add minWith, maxWith; fix bugs in other min_ and max_ functions. (#433) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Philipp Brüschweiler --- Std/Data/Array/Basic.lean | 33 +++++++++++++++++++++++++++++---- 1 file changed, 29 insertions(+), 4 deletions(-) diff --git a/Std/Data/Array/Basic.lean b/Std/Data/Array/Basic.lean index 6b82ab02a3..04975b66a2 100644 --- a/Std/Data/Array/Basic.lean +++ b/Std/Data/Array/Basic.lean @@ -36,6 +36,18 @@ Sort an array using `compare` to compare elements. def qsortOrd [ord : Ord α] (xs : Array α) : Array α := xs.qsort fun x y => compare x y |>.isLT +set_option linter.unusedVariables.funArgs false in +/-- +Returns the first minimal element among `d` and elements of the array. +If `start` and `stop` are given, only the subarray `xs[start:stop]` is +considered (in addition to `d`). +-/ +@[inline] +protected def minWith [ord : Ord α] + (xs : Array α) (d : α) (start := 0) (stop := xs.size) : α := + xs.foldl (init := d) (start := start) (stop := stop) fun min x => + if compare x min |>.isLT then x else min + set_option linter.unusedVariables.funArgs false in /-- Find the first minimal element of an array. If the array is empty, `d` is @@ -45,8 +57,10 @@ considered. @[inline] protected def minD [ord : Ord α] (xs : Array α) (d : α) (start := 0) (stop := xs.size) : α := - xs.foldl (init := d) (start := start) (stop := stop) fun min x => - if compare x min |>.isLT then x else min + if h: start < xs.size ∧ start < stop then + xs.minWith (xs.get ⟨start, h.left⟩) (start + 1) stop + else + d set_option linter.unusedVariables.funArgs false in /-- @@ -57,8 +71,8 @@ considered. @[inline] protected def min? [ord : Ord α] (xs : Array α) (start := 0) (stop := xs.size) : Option α := - if h : start < xs.size then - some $ xs.minD (xs.get ⟨start, h⟩) start stop + if h : start < xs.size ∧ start < stop then + some $ xs.minD (xs.get ⟨start, h.left⟩) start stop else none @@ -73,6 +87,17 @@ protected def minI [ord : Ord α] [Inhabited α] (xs : Array α) (start := 0) (stop := xs.size) : α := xs.minD default start stop +set_option linter.unusedVariables.funArgs false in +/-- +Returns the first maximal element among `d` and elements of the array. +If `start` and `stop` are given, only the subarray `xs[start:stop]` is +considered (in addition to `d`). +-/ +@[inline] +protected def maxWith [ord : Ord α] + (xs : Array α) (d : α) (start := 0) (stop := xs.size) : α := + xs.minWith (ord := ord.opposite) d start stop + set_option linter.unusedVariables.funArgs false in /-- Find the first maximal element of an array. If the array is empty, `d` is