From 25fbc53ecbb19a7489b9e0f0bf75b403cf287cea Mon Sep 17 00:00:00 2001 From: Zachary Brown Date: Wed, 29 Jan 2020 15:56:50 -0800 Subject: [PATCH 1/7] Add note about agda pragma placement --- src/plfa/part1/Naturals.lagda.md | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/src/plfa/part1/Naturals.lagda.md b/src/plfa/part1/Naturals.lagda.md index 694e3f0c..f06192ac 100644 --- a/src/plfa/part1/Naturals.lagda.md +++ b/src/plfa/part1/Naturals.lagda.md @@ -252,6 +252,20 @@ with `zero` and `suc` requires space proportional to _n_, whereas representing it as an arbitrary-precision integer in Haskell only requires space proportional to the logarithm of _n_. +Note that the data declaration must come _before_ the `BUILTIN` pragma, +as Agda will attempt to bind the given built-in to whatever name is given +in the pragma statement. As such, that name must be in scope relative to +the pragma. If you encounter a "Not in scope" error after adding the +pragma, this is likely the cause. + +Complete definition with pragma: +``` +data ℕ : Set where + zero : ℕ + suc : ℕ → ℕ +{-# BUILTIN NATURAL ℕ #-} +``` + ## Imports From 310ab576926bfe0be8c613356b883c0d3f13ef2b Mon Sep 17 00:00:00 2001 From: Zachary Brown Date: Thu, 6 Feb 2020 17:04:02 -0800 Subject: [PATCH 2/7] =?UTF-8?q?Address=20PR=20feedback=20=E2=80=94=20remov?= =?UTF-8?q?e=20additional=20agda=20specifics?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/plfa/part1/Naturals.lagda.md | 23 ++++------------------- 1 file changed, 4 insertions(+), 19 deletions(-) diff --git a/src/plfa/part1/Naturals.lagda.md b/src/plfa/part1/Naturals.lagda.md index f06192ac..3c7d9e75 100644 --- a/src/plfa/part1/Naturals.lagda.md +++ b/src/plfa/part1/Naturals.lagda.md @@ -239,11 +239,10 @@ Including the line ``` tells Agda that `ℕ` corresponds to the natural numbers, and hence one is permitted to type `0` as shorthand for `zero`, `1` as shorthand for -`suc zero`, `2` as shorthand for `suc (suc zero)`, and so on. The -declaration is not permitted unless the type given has exactly two -constructors, one with no arguments (corresponding to zero) and -one with a single argument of the same type given in the pragma -(corresponding to successor). +`suc zero`, `2` as shorthand for `suc (suc zero)`, and so on. The pragma +must be given a previously declared type (in this case `ℕ`) with +precisely two constructors, one with no arguments (in this case `zero`), +and one with a single argument of the given type (in this case `succ`). As well as enabling the above shorthand, the pragma also enables a more efficient internal representation of naturals using the Haskell @@ -252,20 +251,6 @@ with `zero` and `suc` requires space proportional to _n_, whereas representing it as an arbitrary-precision integer in Haskell only requires space proportional to the logarithm of _n_. -Note that the data declaration must come _before_ the `BUILTIN` pragma, -as Agda will attempt to bind the given built-in to whatever name is given -in the pragma statement. As such, that name must be in scope relative to -the pragma. If you encounter a "Not in scope" error after adding the -pragma, this is likely the cause. - -Complete definition with pragma: -``` -data ℕ : Set where - zero : ℕ - suc : ℕ → ℕ -{-# BUILTIN NATURAL ℕ #-} -``` - ## Imports From f4776a9df4ae776c724822a2f28bb6e41cab1850 Mon Sep 17 00:00:00 2001 From: Fangyi Zhou Date: Fri, 7 Feb 2020 23:31:20 +0000 Subject: [PATCH 3/7] Use anchorjs for generating anchors --- _includes/script.html | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/_includes/script.html b/_includes/script.html index 725385a6..f9fa4b12 100644 --- a/_includes/script.html +++ b/_includes/script.html @@ -1,6 +1,11 @@ + + +