This file provides a guide for how to name things. Note that many files in the library do not currently follow these guidelines.
For naming conventions specific to the Algebra subfolder, see Cubical/Algebra/NAMING.md.
-
Use either descriptive names for universe levels or
ℓ ℓ' ℓ'' ℓ''' ...
-
Names of types should begin with an uppercase letter; names of non-type terms should begin with a lowercase letter. The exception is types that represent properties, which should begin with
is
(for exampleisProp
). -
Use abbreviations to avoid very long names, e.g.
Comm
= commutativeAssoc
= associativeDistR
/DistL
= distribute right/left
-
Use camelCase as much as possible, also for properties/lemmas related to operations. For example:
+Assoc
,·DistR+
. -
Avoid referring to variable names in the names of definitions. For example, prefer
+Comm
to something likem+n≡n+m
. -
Use Equiv or
≃
to refer to equivalences of types or structures. -
Use Iso or
≅
to refer to isomorphisms of types or structures. Here an isomorphism is a function with a quasi-inverse, i.e. a quasi-equivalence in the sense of the HoTT Book. -
Use
Path
or≡
to refer to paths in names, notEq
,Id
, or other "equality" or "identity"-related names. -
Results about
PathP
(path overs) should end withP
(likecompPathP
). -
The order of terms in names should reflect the type and things should appear in the order they appear in the type (like
isContrUnit
). For functions things can either be separated by→
(likeisProp→isSet
) orTo
(likeisoToEquiv
). -
When defining eliminators, recursors and similar functions for datatypes, use the names
elim
andrec
, potentially with a suitable suffix (likeelimProp
). Do not useind
. You can look here and here to see how diffrent versions ofelim
andrec
are named and typed. -
The
elim
andrec
should be used as much as possible without renaming, but by importing and renaming the module. For instance useopen import Cubical.Data.Empty as ⊥
then use⊥.rec
or⊥.elim
rather than doingrenaming (rec to rec-⊥)
and usingrec-⊥
.Some convetional naming :
- Empty -> ⊥
- PropositionalTruncation -> PT
- SetTruncation -> ST
- SetQuotient -> SQ