Releases: leanprover/lean4-nightly
nightly-2024-12-15
Changes since nightly-2024-12-14:
Full commit log
- a8a160b fix:
revertAll
must clear auxiliary declarations (#6386) - e08d35c fix: type incorrect term produced by
contradiction
(#6387) - 94641e8 fix:
simp_all?
local declarations (#6385) - b721c0f test: add test for issue #4585 (#6384)
- f790b19 fix: new code generator must generate code for opaque declarations that are not
@[extern]
(#6383) - 6571bc0 fix:
withTrackingZetaDelta
must reset cache (#6381) - 37122c3 chore: move implementation details of
mergeSort
into namespace (#6380)
nightly-2024-12-14
Changes since nightly-2024-12-13:
Full commit log
- 280fcc9 feat:
lean --error=kind
(#6362) - 19eac5f fix: propagate
Simp.Config
when reducing terms and checking definitional equality insimp
(#6123) - aa00725 chore: stop running compiler twice during tests (#6321)
- 7530fd6 chore: remove Lean.Compiler.LCNF.ForEachExpr (#6313)
- 58ffd15 doc: fix typo reference in doc of lazy discrimination tree (#6377)
nightly-2024-12-13
nightly-2024-12-12
nightly-2024-12-11
Changes since nightly-2024-12-10:
Full commit log
- 8709ca3 chore: DecidableRel allows a heterogeneous relation (#6341)
- 19fb1fb feat: do not propagate pretty printer errors through messages (#3696)
- cb31ddc feat: lemmas about indexing and membership for Vector (#6367)
- 633c825 feat: add
Float32
support (#6366) - c83ce02 feat: alignment of Array.set lemmas with List lemmas (#6365)
- cd909b0 fix: when pretty printing constant names, do not use aliases from "non-API
export
s" (#5689) - d27c5af refactor: ArgsPacker.unpack to return
Option
(#6359) - 9386511 refactor: elabWFRel to take names, not
PreDefinition
(#6358) - a9b6a9a refactor: WF.EqnInfo.hasInduct (#6357)
- d5b565e refactor: make
mkInhabitantFor
error message configurable (#6356) - 27c2323 chore: alignment of Array.any/all lemmas with List (#6353)
- 1786539 feat: BitVec.[toInt|toFin|getMsbD]_ofBool (#6317)
- a805946 chore: adjust CODEOWNERS (#6327)
nightly-2024-12-10
Changes since nightly-2024-12-09:
Full commit log
- 8a3a806 chore: update stage0
- 5c333ef fix:
Float32
runtime support (#6350) - e69bcb0 chore: improve BitVec ext lemmas (#6349)
- c5b82e0 feat: BitVec.[toFin|getMsbD]_setWidth and [getMsbD|msb]_signExtend (#6338)
- b6177ba chore: update stage0
- 2e11b8a feat: add support for
Float32
to the Lean runtime (#6348) - ff3d12c doc: clarify difference between Expr.hasLooseBVars and Expr.hasLooseBVar (#6344)
- 520d4b6 chore: cleanup of Array lemmas (#6343)
- c7b8c5c chore: alignment of Array and List lemmas (#6342)
nightly-2024-12-09
Changes since nightly-2024-12-08:
Full Changelog: leanprover/lean4@v4.13.0...v4.14.0
Language features, tactics, and metaprograms
-
structure
andinductive
commands- #5517 improves universe level inference for the resulting type of an
inductive
orstructure.
Recall that aProp
-valued inductive type is a syntactic subsingleton if it has at most one constructor and all the arguments to the constructor are inProp
. Such types have large elimination, so they could be defined inType
orProp
without any trouble. The way inference has changed is that if a type is a syntactic subsingleton with exactly one constructor, and the constructor has at least one parameter/field, then theinductive
/structure
command will prefer creating aProp
instead of aType
. The upshot is that the: Prop
instructure S : Prop
is often no longer needed. (With @arthur-adjedj). - #5842 and #5783 implement a feature where the
structure
command can now define recursive inductive types:structure Tree where n : Nat children : Fin n → Tree def Tree.size : Tree → Nat | {n, children} => Id.run do let mut s := 0 for h : i in [0 : n] do s := s + (children ⟨i, h.2⟩).size pure s
- #5814 fixes a bug where Mathlib's
Type*
elaborator could lead to incorrect universe parameters with theinductive
command. - #3152 and #5844 fix bugs in default value processing for structure instance notation (with @arthur-adjedj).
- #5399 promotes instance synthesis order calculation failure from a soft error to a hard error.
- #5542 deprecates
:=
variants ofinductive
andstructure
(see breaking changes).
- #5517 improves universe level inference for the resulting type of an
-
Application elaboration improvements
- #5671 makes
@[elab_as_elim]
require at least one discriminant, since otherwise there is no advantage to this alternative elaborator. - #5528 enables field notation in explicit mode. The syntax
@x.f
elaborates as@S.f
withx
supplied to the appropriate parameter. - #5692 modifies the dot notation resolution algorithm so that it can apply
CoeFun
instances. For example, Mathlib hasMultiset.card : Multiset α →+ Nat
, and now withm : Multiset α
, the notationm.card
resolves to⇑Multiset.card m
. - #5658 fixes a bug where 'don't know how to synthesize implicit argument' errors might have the incorrect local context when the eta arguments feature is activated.
- #5933 fixes a bug where
..
ellipses in patterns made use of optparams and autoparams. - #5770 makes dot notation for structures resolve using all ancestors. Adds a resolution order for generalized field notation. This is the order of namespaces visited during resolution when trying to resolve names. The algorithm to compute a resolution order is the commonly used C3 linearization (used for example by Python), which when successful ensures that immediate parents' namespaces are considered before more distant ancestors' namespaces. By default we use a relaxed version of the algorithm that tolerates inconsistencies, but using
set_option structure.strictResolutionOrder true
makes inconsistent parent orderings into warnings.
- #5671 makes
-
Recursion and induction principles
- #5619 fixes functional induction principle generation to avoid over-eta-expanding in the preprocessing step.
- #5766 fixes structural nested recursion so that it is not confused when a nested type appears first.
- #5803 fixes a bug in functional induction principle generation when there are
let
bindings. - #5904 improves functional induction principle generation to unfold aux definitions more carefully.
- #5850 refactors code for
Predefinition.Structural
.
-
Error messages
- #5276 fixes a bug in "type mismatch" errors that would structurally assign metavariables during the algorithm to expose differences.
- #5919 makes "type mismatch" errors add type ascriptions to expose differences for numeric literals.
- #5922 makes "type mismatch" errors expose differences in the bodies of functions and pi types.
- #5888 improves the error message for invalid induction alternative names in
match
expressions (@josojo). - #5719 improves
calc
error messages.
-
#5627 and #5663 improve the
#eval
command and introduce some new features.- Now results can be pretty printed if there is a
ToExpr
instance, which means hoverable output. IfToExpr
fails, it then tries looking for aRepr
orToString
instance like before. Settingset_option eval.pp false
disables making use ofToExpr
instances. - There is now auto-derivation of
Repr
instances, enabled with thepp.derive.repr
option (default to true). For example:It simply doesinductive Baz | a | b #eval Baz.a -- Baz.a
deriving instance Repr for Baz
when there's no way to representBaz
. - The option
eval.type
controls whether or not to include the type in the output. For now the default is false. - Now expressions such as
#eval do return 2
, where monad is unknown, work. It tries unifying the monad withCommandElabM
,TermElabM
, orIO
. - The classes
Lean.Eval
andLean.MetaEval
have been removed. These each used to be responsible for adapting monads and printing results. Now theMonadEval
class is responsible for adapting monads for evaluation (it is similar toMonadLift
, but instances are allowed to use default data when initializing state), and representing results is handled through a separate process. - Error messages about failed instance synthesis are now more precise. Once it detects that a
MonadEval
class applies, then the error message will be specific about missingToExpr
/Repr
/ToString
instances. - Fixes bugs where evaluating
MetaM
andCoreM
wouldn't collect log messages. - Fixes a bug where
let rec
could not be used in#eval
.
- Now results can be pretty printed if there is a
-
partial
definitions -
New tactic configuration syntax. The configuration syntax for all core tactics has been given an upgrade. Rather than
simp (config := { contextual := true, maxSteps := 22})
, one can now writesimp +contextual (maxSteps := 22)
. Tactic authors can migrate by switching from(config)?
tooptConfig
in tactic syntaxes and potentially deletingmkOptionalNode
in elaborators. #5883, #5898, #5928, and #5932. (Tactic authors, see breaking changes.) -
simp
tactic- #5632 fixes the simpproc for
Fin
literals to reduce more consistently. - #5648 fixes a bug in
simpa ... using t
where metavariables int
were not properly accounted for, and also improves the type mismatch error. - #5838 fixes the docstring of
simp!
to actually talk aboutsimp!
. - #5870 adds support for
attribute [simp ←]
(note the reverse direction). This adds the reverse of a theorem as a global simp theorem.
- #5632 fixes the simpproc for
-
decide
tactic- #5665 adds
decide!
tactic for using kernel reduction (warning: this is renamed todecide +kernel
in a future release).
- #5665 adds
-
bv_decide
tactic- #5714 adds inequality regression tests (@alexkeizer).
- #5608 adds
bv_toNat
tag fortoNat_ofInt
(@bollu). - #5618 adds support for
at
inac_nf
and uses it inbv_normalize
(@tobiasgrosser). - #5628 adds udiv support.
- #5635 adds auxiliary bitblasters for negation and subtraction.
- #5637 adds more
getLsbD
bitblaster theory. - #5652 adds umod support.
- #5653 adds performance benchmark for modulo.
- #5655 reduces error on
bv_check
to warning. - [#5670...
nightly-2024-12-08
nightly-2024-12-07
nightly-2024-12-06
Changes since nightly-2024-12-05:
Full commit log
- 6e60d13 feat: getElem lemmas for Vector operations (#6324)