←
Prev
↑
Up
Next
→
The Lean Language Reference
1.
Introduction
2.
Elaboration and Compilation
3.
The Lean Language
4.
Terms
5.
Functors, Monads and
do
-Notation
6.
IO
7.
Tactic Proofs
8.
The Simplifier
9.
Basic Types
10.
Standard Library
11.
Notations and Macros
12.
Output from Lean
13.
Elan
14.
Lake and Reservoir
Index
3.
The Lean Language
3.1.
Files
3.2.
The Type System
3.3.
Module Contents
3.4.
Axioms
3.5.
Recursive Definitions
3.6.
Attributes
3.7.
Type Classes
3.8.
Dynamic Typing
3.9.
Coercions
Source Code
Report Issues
3. The Lean Language
3.1.
Files
3.1.1.
Modules
3.1.1.1.
Encoding and Representation
3.1.1.2.
Concrete Syntax
3.1.1.2.1.
Whitespace
3.1.1.2.2.
Comments
3.1.1.2.3.
Keywords and Identifiers
3.1.1.3.
Structure
3.1.1.3.1.
Module Headers
3.1.1.3.2.
Commands
3.1.1.4.
Contents
3.1.2.
Packages, Libraries, and Targets
3.2.
The Type System
3.2.1.
Functions
3.2.1.1.
Function Abstractions
3.2.1.2.
Currying
3.2.1.3.
Extensionality
3.2.1.4.
Totality and Termination
3.2.2.
Propositions
3.2.3.
Universes
3.2.3.1.
Predicativity
3.2.3.2.
Polymorphism
3.2.3.2.1.
Level Expressions
3.2.3.2.2.
Universe Variable Bindings
3.2.3.2.3.
Universe Unification
3.2.3.2.4.
Universe Lifting
3.2.4.
Inductive Types
3.2.4.1.
Inductive Type Declarations
3.2.4.1.1.
Parameters and Indices
3.2.4.1.2.
Example Inductive Types
3.2.4.1.3.
Anonymous Constructor Syntax
3.2.4.1.4.
Deriving Instances
3.2.4.2.
Structure Declarations
3.2.4.2.1.
Structure Parameters
3.2.4.2.2.
Fields
3.2.4.2.3.
Structure Constructors
3.2.4.2.4.
Structure Inheritance
3.2.4.3.
Logical Model
3.2.4.3.1.
Recursors
3.2.4.3.1.1.
Recursor Types
3.2.4.3.1.1.1.
Subsingleton Elimination
3.2.4.3.1.2.
Reduction
3.2.4.3.2.
Well-Formedness Requirements
3.2.4.3.2.1.
Universe Levels
3.2.4.3.2.2.
Strict Positivity
3.2.4.3.2.3.
Prop vs Type
3.2.4.3.3.
Constructions for Termination Checking
3.2.4.4.
Run-Time Representation
3.2.4.4.1.
Exceptions
3.2.4.4.2.
Relevance
3.2.4.4.3.
Trivial Wrappers
3.2.4.4.4.
Other Inductive Types
3.2.4.4.4.1.
FFI
3.2.4.5.
Mutual Inductive Types
3.2.4.5.1.
Requirements
3.2.4.5.1.1.
Mutual Dependencies
3.2.4.5.1.2.
Parameters Must Match
3.2.4.5.1.3.
Universe Levels
3.2.4.5.1.4.
Positivity
3.2.4.5.2.
Recursors
3.2.4.5.3.
Run-Time Representation
3.2.5.
Quotients
3.3.
Module Contents
3.3.1.
Commands and Declarations
3.3.1.1.
Definition-Like Commands
3.3.1.2.
Modifiers
3.3.1.3.
Signatures
3.3.1.4.
Headers
3.3.2.
Namespaces
3.3.3.
Section Scopes
3.3.3.1.
Controlling Section Scopes
3.3.3.2.
Section Variables
3.3.3.3.
Scoped Attributes
3.4.
Axioms
3.5.
Recursive Definitions
3.5.1.
Structural Recursion
3.5.1.1.
Matching Pairs vs Simultaneous Matching
3.5.1.2.
Mutual Structural Recursion
3.5.2.
Well-Founded Recursion
3.5.3.
Controlling Reduction
3.5.4.
Partial and Unsafe Recursive Definitions
3.6.
Attributes
3.7.
Type Classes
3.7.1.
Class Declarations
3.7.1.1.
Sum Types as Classes
3.7.1.2.
Class Abbreviations
3.7.2.
Instance Declarations
3.7.2.1.
Recursive Instances
3.7.2.2.
Instances of
class inductive
s
3.7.2.3.
Instance Priorities
3.7.2.4.
Default Instances
3.7.2.5.
The Instance Attribute
3.7.3.
Instance Synthesis
3.7.3.1.
Instance Search Summary
3.7.3.2.
Instance Search Problems
3.7.3.3.
Candidate Instances
3.7.3.4.
Instance Parameters and Synthesis
3.7.3.5.
Output Parameters
3.7.3.6.
Default Instances
3.7.3.7.
“Morally Canonical” Instances
3.7.3.8.
Options
3.7.4.
Deriving Instances
3.7.4.1.
Deriving Handlers
3.7.5.
Basic Classes
3.7.5.1.
Boolean Equality Tests
3.7.5.2.
Ordering
3.7.5.3.
Decidability
3.7.5.4.
Inhabited Types
3.7.5.5.
Visible Representations
3.7.5.6.
Arithmetic and Bitwise Operators
3.7.5.7.
Append
3.7.5.8.
Data Lookups
3.8.
Dynamic Typing
3.9.
Coercions