From 62b8446da77702f3dd53fb1d86243c32f823ce21 Mon Sep 17 00:00:00 2001 From: Bulhwi Cha Date: Mon, 18 Mar 2024 16:27:14 +0900 Subject: [PATCH] feat: add lemmas about lists MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit I need these lemmas to prove `String.splitOn_of_valid`. Co-authored-by: François G. Dorais --- Batteries/Data/List/Lemmas.lean | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/Batteries/Data/List/Lemmas.lean b/Batteries/Data/List/Lemmas.lean index 6a956f9b1d..60156cf88a 100644 --- a/Batteries/Data/List/Lemmas.lean +++ b/Batteries/Data/List/Lemmas.lean @@ -19,6 +19,11 @@ namespace List @[deprecated (since := "2024-08-15")] alias isEmpty_iff_eq_nil := isEmpty_iff +/-! ### head and tail -/ + +theorem head_cons_tail : ∀ (l : List α) (hne : l ≠ []), l.head hne :: l.tail = l + | _::_, _ => rfl + /-! ### next? -/ @[simp] theorem next?_nil : @next? α [] = none := rfl @@ -482,6 +487,12 @@ theorem Sublist.erase_diff_erase_sublist {a : α} : end Diff +/-! ### prefix, suffix, infix -/ + +theorem ne_nil_of_not_prefix (h : ¬l₁ <+: l₂) : l₁ ≠ [] := by + intro heq + simp [heq, nil_prefix] at h + /-! ### drop -/ theorem disjoint_take_drop : ∀ {l : List α}, l.Nodup → m ≤ n → Disjoint (l.take m) (l.drop n)