aboutsummaryrefslogtreecommitdiff
path: root/v2/src/content
diff options
context:
space:
mode:
authorEuAndreh <eu@euandre.org>2024-11-17 19:49:05 -0300
committerEuAndreh <eu@euandre.org>2024-11-17 19:49:05 -0300
commit08c9bcb3fed37d9483258bd97aaebc47b54b3fa3 (patch)
tree7b114f79c44d347a5ecd1082943d2ba8c95dac5c /v2/src/content
parentmv src/content/styles.css src/content/style.css (diff)
downloadeuandre.org-08c9bcb3fed37d9483258bd97aaebc47b54b3fa3.tar.gz
euandre.org-08c9bcb3fed37d9483258bd97aaebc47b54b3fa3.tar.xz
rm -rf v2/
Diffstat (limited to '')
-rw-r--r--v2/src/content/.well-known/security.txt4
-rw-r--r--v2/src/content/en/about.page7
-rw-r--r--v2/src/content/en/pastebin/guix-shebang.md15
-rw-r--r--v2/src/content/en/pastebin/raku-tuple-type-annotation.md33
-rw-r--r--v2/src/content/en/pastebin/sicp-exercise-3-19.md109
-rw-r--r--v2/src/content/en/remembering-ann.md186
-rw-r--r--v2/src/content/en/slide/local-first.ps522
-rw-r--r--v2/src/content/en/slide/local-first.slides204
-rw-r--r--v2/src/content/en/slide/rollouts.ps500
-rw-r--r--v2/src/content/en/slide/rollouts.slides208
-rw-r--r--v2/src/content/en/til/lisp-three-way-conditional.md59
-rw-r--r--v2/src/content/favicon.icobin1150 -> 0 bytes
-rw-r--r--v2/src/content/img/alt/atom.en.txt1
-rw-r--r--v2/src/content/img/alt/atom.pt.txt1
-rw-r--r--v2/src/content/img/alt/envelope.en.txt1
-rw-r--r--v2/src/content/img/alt/envelope.pt.txt1
-rw-r--r--v2/src/content/img/alt/favicon.en.txt1
-rw-r--r--v2/src/content/img/alt/favicon.pt.txt1
-rw-r--r--v2/src/content/img/alt/link.en.txt1
-rw-r--r--v2/src/content/img/alt/link.pt.txt1
-rw-r--r--v2/src/content/img/alt/linkto.en.txt1
-rw-r--r--v2/src/content/img/alt/linkto.pt.txt2
-rw-r--r--v2/src/content/img/alt/lock.en.txt1
-rw-r--r--v2/src/content/img/alt/lock.pt.txt1
-rw-r--r--v2/src/content/img/atom.svg5
-rw-r--r--v2/src/content/img/dark-mode.xml12
-rw-r--r--v2/src/content/img/envelope.svg.uncolored4
-rw-r--r--v2/src/content/img/favicon.svg.uncolored62
-rw-r--r--v2/src/content/img/link.svg.uncolored5
-rw-r--r--v2/src/content/img/linkto.svg.uncolored7
-rw-r--r--v2/src/content/img/lock.svg.uncolored4
-rw-r--r--v2/src/content/pt/hea/condicional-ternario-lisp.md65
-rw-r--r--v2/src/content/pt/pastebin/exercicios-sicp-e-19.md105
-rw-r--r--v2/src/content/pt/sobre.page7
-rw-r--r--v2/src/content/public.asc.txt86
-rw-r--r--v2/src/content/style.css205
36 files changed, 0 insertions, 2427 deletions
diff --git a/v2/src/content/.well-known/security.txt b/v2/src/content/.well-known/security.txt
deleted file mode 100644
index dd35c49..0000000
--- a/v2/src/content/.well-known/security.txt
+++ /dev/null
@@ -1,4 +0,0 @@
-Contact: mailto:eu@euandre.org
-Encryption: https://euandre.org/public.asc.txt
-Expires: 2024-07-15T00:00:00z
-Preferred-Languages: en, pt
diff --git a/v2/src/content/en/about.page b/v2/src/content/en/about.page
deleted file mode 100644
index aac3e67..0000000
--- a/v2/src/content/en/about.page
+++ /dev/null
@@ -1,7 +0,0 @@
----
-
-title: About
-
----
-
-It's all about me, baby!
diff --git a/v2/src/content/en/pastebin/guix-shebang.md b/v2/src/content/en/pastebin/guix-shebang.md
deleted file mode 100644
index 5be9ada..0000000
--- a/v2/src/content/en/pastebin/guix-shebang.md
+++ /dev/null
@@ -1,15 +0,0 @@
----
-
-title: Guix shebang
-
-date: 2020-02-14
-
----
-
-```shell
-#!/usr/bin/env -S guix environment --ad-hoc bash -- bash
-set -Eeuo pipefail
-cd "$(dirname "${BASH_SOURCE[0]}")"
-
-pwd
-```
diff --git a/v2/src/content/en/pastebin/raku-tuple-type-annotation.md b/v2/src/content/en/pastebin/raku-tuple-type-annotation.md
deleted file mode 100644
index 6c13b39..0000000
--- a/v2/src/content/en/pastebin/raku-tuple-type-annotation.md
+++ /dev/null
@@ -1,33 +0,0 @@
----
-
-title: Raku tuple type annotation
-
-date: 2019-12-29
-
-categories: raku programming-languages
-
----
-
-```perl
-# Single Str return value: this works
-sub f1(Str $in --> Str) {
- $in;
-}
-
-# Tuple of Str as return value: this works
-sub f2(Str $in) {
- ($in, $in);
-}
-
-# Tuple of Str as return value with type annotation: this doesn't works
-sub f2(Str $in --> (Str, Str)) {
- ($in, $in);
-}
-```
-
-Error log is:
-
-```perl
-===SORRY!=== Error while compiling /path/to/my/file
-Malformed return value
-```
diff --git a/v2/src/content/en/pastebin/sicp-exercise-3-19.md b/v2/src/content/en/pastebin/sicp-exercise-3-19.md
deleted file mode 100644
index 32f7aa9..0000000
--- a/v2/src/content/en/pastebin/sicp-exercise-3-19.md
+++ /dev/null
@@ -1,109 +0,0 @@
----
-
-title: SICP exercise 3.19
-
-date: 2021-09-02
-
-categories: lisp programming-languages
-
----
-
-Some content here, before:
-
-```scheme
-(define (cycle? l)
- (define (rec l x)
- (cond
- ((null? x) false)
- ((eq? l x) true)
- (true (rec l (cdr x)))))
- (rec l (cdr l)))
-```
-
-Sample interactive session:
-
-```scheme
-scheme@(guile-user)> (define true #t)
-scheme@(guile-user)> (define false #f)
-scheme@(guile-user)>
-(define (cycle? l)
- (define (rec l x)
- (cond
- ((null? x) false)
- ((eq? l x) true)
- (true (rec l (cdr x)))))
- (rec l (cdr l)))
-scheme@(guile-user)> (cycle? '(1 2 3))
-$9 = #f
-scheme@(guile-user)> (cycle? (make-cycle '(1 2 3)))
-$10 = #t
-```
-
-# An h1
-
-a list:
-
-1. one
-2. two
-3. three
-
-some content.
-
-- item
-- another
-- yet another
-
-## An h2
-
-Xablau:
-
-```
-xupliu 1
-
-3
-4
-
-
-
-
-
-dez
-```
-
-Foi `wikiwiu`.
-
-a very long code block:
-
-```
-wef
-wef wef wef wef
-wef wef wef wef we fwef wef wef wef wef
-```
-
-Someone said:
-
-> Xablau, xupliu.
-
-### A repeated header
-### A repeated header
-
-a big list:
-
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
diff --git a/v2/src/content/en/remembering-ann.md b/v2/src/content/en/remembering-ann.md
deleted file mode 100644
index 9013ad4..0000000
--- a/v2/src/content/en/remembering-ann.md
+++ /dev/null
@@ -1,186 +0,0 @@
----
-
-title: ANN: remembering - Add memory to dmenu, fzf and similar tools
-
-date: 2021-01-26
-
-categories: ann
-
----
-
-Today I pushed v0.1.0 of [remembering][remembering], a tool to enhance the interactive usability of menu-like tools, such as [dmenu][dmenu] and [fzf][fzf].
-
-## Previous solution
-
-I previously used [yeganesh][yeganesh] fill this gap, but as I started to rely less on Emacs, I added fzf as my go-to tool for doing fuzzy searching on the terminal.
-But I didn't like that fzf always showed the same order of things, when I would only need 3 or 4 commonly used files.
-
-For those who don't know: yeganesh is a wrapper around dmenu that will remember your most used programs and put them on the beginning of the list of executables.
-This is very convenient for interactive prolonged use, as with time the things you usually want are right at the very beginning.
-
-But now I had this thing, yeganesh, that solved this problem for dmenu, but didn't for fzf.
-
-I initially considered patching yeganesh to support it, but I found it more coupled to dmenu than I would desire.
-I'd rather have something that knows nothing about dmenu, fzf or anything, but enhances tools like those in a useful way.
-
-[remembering]: https://euandreh.xyz/remembering/
-[dmenu]: https://tools.suckless.org/dmenu/
-[fzf]: https://github.com/junegunn/fzf
-[yeganesh]: http://dmwit.com/yeganesh/
-
-## Implementation
-
-Other than being decoupled from dmenu, another improvement I though that could be made on top of yeganesh is the programming language choice.
-Instead of Haskell, I went with POSIX sh.
-Sticking to POSIX sh makes it require less build-time dependencies. There aren't any, actually. Packaging is made much easier due to that.
-
-The good thing is that the program itself is small enough ([119 lines][119-lines] on v0.1.0) that POSIX sh does the job just fine, combined with other POSIX utilities such as [getopts][getopts], [sort][sort] and [awk][awk].
-
-[119-lines]: https://euandre.org/git/remembering/tree/remembering?id=v0.1.0
-[getopts]: http://www.opengroup.org/onlinepubs/9699919799/utilities/getopts.html
-[sort]: http://www.opengroup.org/onlinepubs/9699919799/utilities/sort.html
-[awk]: http://www.opengroup.org/onlinepubs/9699919799/utilities/awk.html
-
-The behaviour is: given a program that will read from STDIN and write a single entry to STDOUT, `remembering` wraps that program, and rearranges STDIN so that previous choices appear at the beginning.
-
-Where you would do:
-
-```shell
-$ seq 5 | fzf
-
- 5
- 4
- 3
- 2
-> 1
- 5/5
->
-```
-
-And every time get the same order of numbers, now you can write:
-
-```shell
-$ seq 5 | remembering -p seq-fzf -c fzf
-
- 5
- 4
- 3
- 2
-> 1
- 5/5
->
-```
-
-On the first run, everything is the same. If you picked 4 on the previous example, the following run would be different:
-
-```shell
-$ seq 5 | remembering -p seq-fzf -c fzf
-
- 5
- 3
- 2
- 1
-> 4
- 5/5
->
-```
-
-As time passes, the list would adjust based on the frequency of your choices.
-
-I aimed for reusability, so that I could wrap diverse commands with `remembering` and it would be able to work. To accomplish that, a "profile" (the `-p something` part) stores data about different runs separately.
-
-I took the idea of building something small with few dependencies to other places too:
-- the manpages are written in troff directly;
-- the tests are just more POSIX sh files;
-- and a POSIX Makefile to `check` and `install`.
-
-I was aware of the value of sticking to coding to standards, but I had past experience mostly with programming language standards, such as ECMAScript, Common Lisp, Scheme, or with IndexedDB or DOM APIs.
-It felt good to rediscover these nice POSIX tools, which makes me remember of a quote by [Henry Spencer][poor-unix]:
-
-> Those who do not understand Unix are condemned to reinvent it, poorly.
-
-[poor-unix]: https://en.wikipedia.org/wiki/Henry_Spencer#cite_note-3
-
-## Usage examples
-
-Here are some functions I wrote myself that you may find useful:
-
-### Run a command with fzf on `$PWD`
-
-```shellcheck
-f() {
- profile="$f-shell-function(pwd | sed -e 's_/_-_g')"
- file="$(git ls-files | \
- remembering -p "$profile" \
- -c "fzf --select-1 --exit -0 --query \"$2\" --preview 'cat {}'")"
- if [ -n "$file" ]; then
- # shellcheck disable=2068
- history -s f $@
- history -s "$1" "$file"
- "$1" "$file"
-fi
-}
-```
-
-This way I can run `f vi` or `f vi config` at the root of a repository, and the list of files will always appear on the most used order.
-Adding `pwd` to the profile allows it to not mix data for different repositories.
-
-### Copy password to clipboard
-
-```shell
-choice="$(find "$HOME/.password-store" -type f | \
- grep -Ev '(.git|.gpg-id)' | \
- sed -e "s|$HOME/.password-store/||" -e 's/\.gpg$//' | \
- remembering -p password-store \
- -c 'dmenu -l 20 -i')"
-
-
-if [ -n "$choice" ]; then
- pass show "$choice" -c
-fi
-```
-
-Adding the above to a file and binding it to a keyboard shortcut, I can access the contents of my [password store][password-store], with the entries ordered by usage.
-
-[password-store]: https://www.passwordstore.org/
-
-### Replacing yeganesh
-
-Where I previously had:
-
-```shell
-exe=$(yeganesh -x) && exec $exe
-```
-
-Now I have:
-
-```shell
-exe=$(dmenu_path | remembering -p dmenu-exec -c dmenu) && exec $exe
-```
-
-This way, the executables appear on order of usage.
-
-If you don't have `dmenu_path`, you can get just the underlying `stest` tool that looks at the executables available in your `$PATH`. Here's a juicy one-liner to do it:
-
-```shell
-$ wget -O- https://dl.suckless.org/tools/dmenu-5.0.tar.gz | \
- tar Ozxf - dmenu-5.0/arg.h dmenu-5.0/stest.c | \
- sed 's|^#include "arg.h"$|// #include "arg.h"|' | \
- cc -xc - -o stest
-```
-
-With the `stest` utility you'll be able to list executables in your `$PATH` and pipe them to dmenu or something else yourself:
-```shell
-$ (IFS=:; ./stest -flx $PATH;) | sort -u | remembering -p another-dmenu-exec -c dmenu | sh
-```
-
-In fact, the code for `dmenu_path` is almost just like that.
-
-## Conclusion
-
-For my personal use, I've [packaged] `remembering` for GNU Guix and Nix. Packaging it to any other distribution should be trivial, or just downloading the tarball and running `[sudo] make install`.
-
-Patches welcome!
-
-[packaged]: https://euandre.org/git/package-repository/
-[nix-file]: https://euandre.org/git/dotfiles/tree/nixos/not-on-nixpkgs/remembering.nix?id=0831444f745cf908e940407c3e00a61f6152961f
diff --git a/v2/src/content/en/slide/local-first.ps b/v2/src/content/en/slide/local-first.ps
deleted file mode 100644
index 44c5858..0000000
--- a/v2/src/content/en/slide/local-first.ps
+++ /dev/null
@@ -1,522 +0,0 @@
-%!PS-Adobe-3.0
-%%DocumentMedia: SLIDE 842 595 0 () ()
-%%EndComments
-%%BeginDefaults
-%%PageMedia: SLIDE
-%%EndDefaults
-<< /PageSize [842 595] /ImagingBBox null >> setpagedevice
-
-/reencode {
- exch
- findfont
- dup length dict
- begin
- {
- 1 index /FID ne
- { def }
- { pop pop }
- ifelse
- } forall
- /Encoding ISOLatin1Encoding def
- currentdict
- end
- definefont pop
-} def
-/Courier /Courier reencode
-/Helvetica /Helvetica reencode
-/Times /Times reencode
-/Times-Italic /Times-Italic reencode
-
-
-/headerheight 77 def
-
-/frontfontsz 60 def
-/authorfontsz 40 def
-/titlefontsz 40 def
-/mainfontsz 30 def
-/codefontsz 18 def
-/tinyfontsz 18 def
-
-/titlefont /Helvetica findfont titlefontsz scalefont def
-/mainfont /Courier findfont mainfontsz scalefont def
-/codefont /Courier findfont codefontsz scalefont def
-/tinyfont /Times findfont tinyfontsz scalefont def
-/frontfont /Helvetica findfont frontfontsz scalefont def
-/authorfont /Times-Italic findfont authorfontsz scalefont def
-/authorfonttwo /Times findfont authorfontsz scalefont def
-
-
-/pagewidth 842 def
-/pageheight 595 def
-/leftmargin 30 def
-/topmargin 595 def
-
-/pad 10 def
-
-/titlefonth titlefontsz pad add def
-/mainfonth mainfontsz pad add def
-/codefonth codefontsz pad add def
-/tinyfonth tinyfontsz pad add def
-/frontfonth frontfontsz pad add def
-/authorfonth authorfontsz pad add def
-
-/headermargin
- pageheight headerheight titlefonth sub 2 div titlefontsz add sub
-def
-/rightmargin pagewidth leftmargin sub def
-/tbtop topmargin def
-/ypos topmargin def
-
-/xcur { currentpoint pop } def
-/ycur { currentpoint exch pop } def
-
-/wordbreak ( ) def
-/linewrap {
- /proc exch def
- /linelength exch def
- /textstring exch def
- /breakwidth wordbreak stringwidth pop def
- /curwidth 0 def
- /lastwordbreak 0 def
- /startchar 0 def
- /restoftext textstring def
- {
- restoftext wordbreak search
- {
- /nextword exch def pop
- /restoftext exch def
- /wordwidth nextword stringwidth pop def
- curwidth wordwidth add linelength gt
- {
- textstring startchar
- lastwordbreak startchar sub
- getinterval proc
- /startchar lastwordbreak def
- /curwidth wordwidth breakwidth add def
- }
- {
- /curwidth curwidth wordwidth add
- breakwidth add def
- } ifelse
- /lastwordbreak lastwordbreak
- nextword length add 1 add def
- }
- {
- pop exit
- } ifelse
- } loop
- /lastchar textstring length def
- textstring startchar lastchar startchar sub
- getinterval proc
-} def
-
-/line {
- 0 0 0 setrgbcolor
- 0.5 setlinewidth
- leftmargin ypos moveto
- rightmargin ypos lineto
- stroke
-} def
-
-/center {
- dup
- /str exch def
- /sw str stringwidth pop def
- /xpos pagewidth sw sub 2 div xcur sub def
- xpos 0 rmoveto
-} def
-
-/objcenter {
- pagewidth exch sub 2 div 0 translate
-} def
-
-/s {
- /tbtop topmargin def
- /ypos topmargin def
- 1 1 1 setrgbcolor
- 0 setlinewidth
- newpath
- 0 pageheight moveto
- pagewidth pageheight lineto
- pagewidth 0 lineto
- 0 0 lineto
- closepath
- fill
- stroke
-} def
-
-/l {
- /h exch def
- /ypos ypos h sub def
- leftmargin ypos moveto
-} def
-
-/title {
- frontfonth l
- frontfont setfont
- 0.5 0.5 0.9 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { frontfonth l center show }
- linewrap
- frontfonth 2 div l
- frontfonth l
-} def
-
-/author {
- authorfont setfont
- 0 0 0 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { authorfonth l center show }
- linewrap
-} def
-
-/authortwo {
- authorfonttwo setfont
- 0 0 0 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { authorfonth l center show }
- linewrap
-} def
-
-/header {
- /ypos pageheight headerheight sub def
- 0 0 0 setrgbcolor
- 0 setlinewidth
- newpath
- 0 pageheight moveto
- pagewidth pageheight lineto
- pagewidth ypos lineto
- 0 ypos lineto
- closepath
- fill
- stroke
- leftmargin headermargin moveto
- titlefont setfont
- 0.5 0.5 0.9 setrgbcolor
- center show
- leftmargin ypos moveto
-} def
-
-/n {
- mainfont setfont
- 0 0 0 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { mainfonth l show }
- linewrap
-} def
-
-/cn {
- codefont setfont
- 0 0 0 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { codefonth l show }
- linewrap
-} def
-
-/tn {
- tinyfont setfont
- 0 0 0 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { tinyfonth l show }
- linewrap
-} def
-
-/is {
- /level1 save def
- /showpage {} def
-} def
-
-/ie {
- level1 restore
-} def
-
-/bs {
- /tbtop ypos def
-} def
-
-/be {
- /tm tbtop pad sub def
- /bm ypos pad sub def
- newpath
- leftmargin 10 sub tm moveto
- rightmargin tm lineto
- rightmargin bm lineto
- leftmargin 10 sub bm lineto
- closepath
- 0 0 0 setrgbcolor
- 0.5 setlinewidth
- stroke
-} def
-( On "local-first") title
-(Beyond the CRDT silver bullet) authortwo
-showpage
-%%Page: 1 1
-s
-( Part 1) header
-( Exposition) title
-showpage
-%%Page: 2 2
-s
-( Target) header
-() n
-() n
-() n
-(- documents) n
-(- files) n
-(- personal data repositories) n
-() n
-() n
-(Not: banking services, e-commerce, social networking, ride-sharing, etc.) n
-showpage
-%%Page: 3 3
-s
-() n
-() n
-() n
-( 7 ideals for local-first software) title
-showpage
-%%Page: 4 4
-s
-() n
-() n
-() n
-( 1 - no spinners: your work at your fingertips) title
-showpage
-%%Page: 5 5
-s
-() n
-() n
-() n
-( 2 - your work is not trapped on one device) title
-showpage
-%%Page: 6 6
-s
-() n
-() n
-() n
-( 3 - the network is optional) title
-showpage
-%%Page: 7 7
-s
-() n
-() n
-() n
-( 4 - seamless collaboration with your colleagues) title
-showpage
-%%Page: 8 8
-s
-() n
-() n
-() n
-( 5 - the long now) title
-showpage
-%%Page: 9 9
-s
-() n
-() n
-() n
-( 6 - security and privacy by default ) title
-showpage
-%%Page: 10 10
-s
-() n
-() n
-() n
-( 7 - you retain ultimate ownership and control) title
-showpage
-%%Page: 11 11
-s
-( Towards a better future) header
-() n
-() n
-() n
-() n
-( CRDTs \(Conflict-free Replicated Data Types\) as a Foundational Technology) authortwo
-showpage
-%%Page: 12 12
-s
-( Use case) header
-() n
-bs
-(# in node A and node B) cn
-(s = "Hello, World") cn
-() cn
-(# in node A) cn
-(s = "Hello, Alice") cn
-() cn
-(# in node B) cn
-(s = "Hello, Bob") cn
-be
-(How to reconcile those?) n
-(- Hello, ABloibce) n
-(- Hello, AliceBob) n
-(- Hello, BobAlice) n
-(- Hello, Alice) n
-(...) n
-showpage
-%%Page: 13 13
-s
-( Existing CRDTs differ) title
-(- performance) n
-(- storage) n
-(- compression) n
-(- metadata overhead) n
-showpage
-%%Page: 14 14
-s
-() n
-() n
-() n
-( Hint towards the "automerge" CRDT) title
-showpage
-%%Page: 15 15
-s
-() n
-() n
-() n
-() n
-() n
-() n
-(show comparison table, page 9) author
-showpage
-%%Page: 16 16
-s
-( Part 2) header
-( Critique) title
-showpage
-%%Page: 17 17
-s
-( Software license) header
-() n
-() n
-() n
-("In our opinion, maintaining control and ownership of data does not mean that the software must necessarily be open source.") author
-showpage
-%%Page: 18 18
-s
-( Example 1 - intentional restriction) header
-() n
-bs
-(#!/bin/sh) cn
-(TODAY="$\(date +%s\)") cn
-(LICENSE_EXPIRATION="$\(date -d 2020-10-27 +%s\)") cn
-(if [ "$TODAY" -ge "$LICENSE_EXPIRATION" ]; then) cn
-( echo 'License expired!') cn
-( exit 1) cn
-(fi) cn
-(echo $\(\(2 + 2\)\)) cn
-be
-() n
-bs
-(# today) cn
-($ ./useful-adder.sh) cn
-(4) cn
-(# tomorrow) cn
-($ ./useful-adder.sh) cn
-(License expired!) cn
-be
-showpage
-%%Page: 19 19
-s
-( Example 2 - unintentional restriction) header
-() n
-bs
-(# today) cn
-($ useful-program) cn
-(# ... useful output ...) cn
-() cn
-(# tomorrow, with more data) cn
-($ useful-program) cn
-(ERROR: Panic! Stack overflow!) cn
-be
-showpage
-%%Page: 20 20
-s
-() n
-() n
-( local-first *requires* free software ) title
-(Otherwise "The Long Now" \(ideal nº5\) is lost) n
-showpage
-%%Page: 21 21
-s
-( Denial of existing solutions) header
-() n
-() n
-("In principle it is possible to collaborate without a repository service, e.g. by sending patch files by email, but the majority of Git users rely on GitHub." ) author
-() n
-(Solution: either GitHub+CRDTs or git send-email ) n
-showpage
-%%Page: 22 22
-s
-( Plain-text formats) header
-() n
-("Git is highly optimized for code and similar line-based text file") author
-() n
-(It even pulls software to the plain text directtion, e.g.:) n
-(- delivery-templates) n
-(- common-core.protocols.config) n
-() n
-(Why not exploit that more?) n
-showpage
-%%Page: 23 23
-s
-( Ditching of web applications) header
-() n
-() n
-("The architecture of web apps remains fundamentally server-centric) author
-() n
-(Disagree. Contrast PouchDB with Android Instant Apps) n
-showpage
-%%Page: 24 24
-s
-( Costs are underrated) header
-() n
-(- storage) n
-(- backups) n
-(- maintenance) n
-() n
-(Example: blog vs vlog) n
-showpage
-%%Page: 25 25
-s
-( Real-time collaboration a bit overrated) header
-() n
-(It is only possible on the presence of reliable, medium-quality network connection) n
-() n
-() n
-("X also works when inside an elevator, subway or plane!") author
-showpage
-%%Page: 26 26
-s
-( On CRDTs and developer experience) header
-() n
-("For an app developer, how does the use of a CRDT-based data layer compare to existing storage layers like a SQL database, a filesystem, or CoreData? Is a distributed system harder to write software for?) author
-() n
-(YES.) authortwo
-() n
-(See "A Note on Distributed Computing") n
-showpage
-%%Page: 27 27
-s
-( Conclusion) header
-() n
-(Why this is a "paper I love": it took offline-first and ran with it.) n
-() n
-(But a pinch of CRDT won't make the world local-first. ) n
-() n
-(The tricky part is the end of the sentence: "in spite of the Cloud".) n
-showpage
-%%Page: 28 28
-s
-( References) header
-() n
-(1. "Local-First Software: You Own Your Data, in spite of the Cloud", by M. Kleppmann, A. Wiggins, P. Van Hardenberg and M. F. McGranaghan) n
-(2. The Morning Paper article) n
-(3. "A Note on Distributed Compiting", by J. Waldo, G. Wyant, A. Wollrath and S. Kendall) n
-(4. these slides: euandre.org/slide/) n
-(5. prose version of this presentation) n
-(6. view source) n
-
-showpage
-
-%%EOF
diff --git a/v2/src/content/en/slide/local-first.slides b/v2/src/content/en/slide/local-first.slides
deleted file mode 100644
index fd83115..0000000
--- a/v2/src/content/en/slide/local-first.slides
+++ /dev/null
@@ -1,204 +0,0 @@
-# On "local-first"
-
-@Beyond the CRDT silver bullet
-
----
-## Part 1
-# Exposition
-
----
-## Target
-...
-- documents
-- files
-- personal data repositories
-..
-Not: banking services, e-commerce, social networking, ride-sharing, etc.
-
----
-...
-# 7 ideals for local-first software
-
----
-...
-# 1 - no spinners: your work at your fingertips
-
----
-...
-# 2 - your work is not trapped on one device
-
----
-...
-# 3 - the network is optional
-
----
-...
-# 4 - seamless collaboration with your colleagues
-
----
-...
-# 5 - the long now
-
----
-...
-# 6 - security and privacy by default
-
----
-...
-# 7 - you retain ultimate ownership and control
-
----
-## Towards a better future
-....
-@ CRDTs (Conflict-free Replicated Data Types) as a Foundational Technology
-
----
-## Use case
-.
- # in node A and node B
- s = "Hello, World"
-
- # in node A
- s = "Hello, Alice"
-
- # in node B
- s = "Hello, Bob"
-
-How to reconcile those?
-- Hello, ABloibce
-- Hello, AliceBob
-- Hello, BobAlice
-- Hello, Alice
-\...
-
----
-# Existing CRDTs differ
-- performance
-- storage
-- compression
-- metadata overhead
-
----
-...
-# Hint towards the "automerge" CRDT
-
----
-......
-@@show comparison table, page 9
-
----
-## Part 2
-# Critique
-
----
-## Software license
-...
-@@"In our opinion, maintaining control and ownership of data does not mean that the software must necessarily be open source."
-
----
-## Example 1 - intentional restriction
-.
- #!/bin/sh
- TODAY="$(date +%s)"
- LICENSE_EXPIRATION="$(date -d 2020-10-27 +%s)"
- if [ "$TODAY" -ge "$LICENSE_EXPIRATION" ]; then
- echo 'License expired!'
- exit 1
- fi
- echo $((2 + 2))
-.
- # today
- $ ./useful-adder.sh
- 4
-
- # tomorrow
- $ ./useful-adder.sh
- License expired!
----
-## Example 2 - unintentional restriction
-.
- # today
- $ useful-program
- # ... useful output ...
-
- # tomorrow, with more data
- $ useful-program
- ERROR: Panic! Stack overflow!
-
----
-..
-# local-first *requires* free software
-
-Otherwise "The Long Now" (ideal nº5) is lost
-
----
-## Denial of existing solutions
-..
-@@"In principle it is possible to collaborate without a repository service, e.g. by sending patch files by email, but the majority of Git users rely on GitHub."
-.
-Solution: either GitHub+CRDTs or git send-email
-
----
-## Plain-text formats
-.
-@@"Git is highly optimized for code and similar line-based text file"
-.
-It even pulls software to the plain text directtion, e.g.:
-- delivery-templates
-- common-core.protocols.config
-.
-Why not exploit that more?
-
----
-## Ditching of web applications
-..
-@@"The architecture of web apps remains fundamentally server-centric
-.
-% FIXME: links
-Disagree. Contrast PouchDB with Android Instant Apps
-
----
-## Costs are underrated
-.
-- storage
-- backups
-- maintenance
-.
-Example: blog vs vlog
-
----
-## Real-time collaboration a bit overrated
-.
-It is only possible on the presence of reliable, medium-quality network connection
-..
-@@"X also works when inside an elevator, subway or plane!"
-
----
-## On CRDTs and developer experience
-.
-@@"For an app developer, how does the use of a CRDT-based data layer compare to existing storage layers like a SQL database, a filesystem, or CoreData? Is a distributed system harder to write software for?
-.
-@YES.
-.
-% FIXME: link
-See "A Note on Distributed Computing"
-
----
-## Conclusion
-.
-Why this is a "paper I love": it took offline-first and ran with it.
-.
-But a pinch of CRDT won't make the world local-first.
-.
-The tricky part is the end of the sentence: "in spite of the Cloud".
-
----
-## References
-.
-% FIXME: links
-1. "Local-First Software: You Own Your Data, in spite of the Cloud", by M. Kleppmann, A. Wiggins, P. Van Hardenberg and M. F. McGranaghan
-2. The Morning Paper article
-3. "A Note on Distributed Compiting", by J. Waldo, G. Wyant, A. Wollrath and S. Kendall
-4. these slides: euandre.org/slide/
-5. prose version of this presentation
-6. view source
diff --git a/v2/src/content/en/slide/rollouts.ps b/v2/src/content/en/slide/rollouts.ps
deleted file mode 100644
index 0a8b39f..0000000
--- a/v2/src/content/en/slide/rollouts.ps
+++ /dev/null
@@ -1,500 +0,0 @@
-%!PS-Adobe-3.0
-%%DocumentMedia: SLIDE 842 595 0 () ()
-%%EndComments
-%%BeginDefaults
-%%PageMedia: SLIDE
-%%EndDefaults
-<< /PageSize [842 595] /ImagingBBox null >> setpagedevice
-
-/reencode {
- exch
- findfont
- dup length dict
- begin
- {
- 1 index /FID ne
- { def }
- { pop pop }
- ifelse
- } forall
- /Encoding ISOLatin1Encoding def
- currentdict
- end
- definefont pop
-} def
-/Times /Times reencode
-/Courier /Courier reencode
-/Times-Italic /Times-Italic reencode
-/Helvetica /Helvetica reencode
-
-
-/headerheight 75 def
-
-/frontfontsz 60 def
-/authorfontsz 40 def
-/titlefontsz 40 def
-/mainfontsz 30 def
-/codefontsz 18 def
-/tinyfontsz 18 def
-
-/titlefont /Helvetica findfont titlefontsz scalefont def
-/mainfont /Courier findfont mainfontsz scalefont def
-/codefont /Courier findfont codefontsz scalefont def
-/tinyfont /Times findfont tinyfontsz scalefont def
-/frontfont /Helvetica findfont frontfontsz scalefont def
-/authorfont /Times-Italic findfont authorfontsz scalefont def
-/authorfonttwo /Times findfont authorfontsz scalefont def
-
-
-/pagewidth 842 def
-/pageheight 595 def
-/leftmargin 30 def
-/topmargin 595 def
-
-/pad 10 def
-
-/titlefonth titlefontsz pad add def
-/mainfonth mainfontsz pad add def
-/codefonth codefontsz pad add def
-/tinyfonth tinyfontsz pad add def
-/frontfonth frontfontsz pad add def
-/authorfonth authorfontsz pad add def
-
-/headermargin
- pageheight headerheight titlefonth sub 2 div titlefontsz add sub
-def
-/rightmargin pagewidth leftmargin sub def
-/tbtop topmargin def
-/ypos topmargin def
-
-/xcur { currentpoint pop } def
-/ycur { currentpoint exch pop } def
-
-/wordbreak ( ) def
-/linewrap {
- /proc exch def
- /linelength exch def
- /textstring exch def
- /breakwidth wordbreak stringwidth pop def
- /curwidth 0 def
- /lastwordbreak 0 def
- /startchar 0 def
- /restoftext textstring def
- {
- restoftext wordbreak search
- {
- /nextword exch def pop
- /restoftext exch def
- /wordwidth nextword stringwidth pop def
- curwidth wordwidth add linelength gt
- {
- textstring startchar
- lastwordbreak startchar sub
- getinterval proc
- /startchar lastwordbreak def
- /curwidth wordwidth breakwidth add def
- }
- {
- /curwidth curwidth wordwidth add
- breakwidth add def
- } ifelse
- /lastwordbreak lastwordbreak
- nextword length add 1 add def
- }
- {
- pop exit
- } ifelse
- } loop
- /lastchar textstring length def
- textstring startchar lastchar startchar sub
- getinterval proc
-} def
-
-/line {
- 0 0 0 setrgbcolor
- 0.5 setlinewidth
- leftmargin ypos moveto
- rightmargin ypos lineto
- stroke
-} def
-
-/center {
- dup
- /str exch def
- /sw str stringwidth pop def
- /xpos pagewidth sw sub 2 div xcur sub def
- xpos 0 rmoveto
-} def
-
-/objcenter {
- pagewidth exch sub 2 div 0 translate
-} def
-
-/s {
- /tbtop topmargin def
- /ypos topmargin def
- 1 1 1 setrgbcolor
- 0 setlinewidth
- newpath
- 0 pageheight moveto
- pagewidth pageheight lineto
- pagewidth 0 lineto
- 0 0 lineto
- closepath
- fill
- stroke
-} def
-
-/l {
- /h exch def
- /ypos ypos h sub def
- leftmargin ypos moveto
-} def
-
-/title {
- frontfonth l
- frontfont setfont
- 0.5 0.5 0.9 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { frontfonth l center show }
- linewrap
- frontfonth 2 div l
- frontfonth l
-} def
-
-/author {
- authorfont setfont
- 0 0 0 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { authorfonth l center show }
- linewrap
-} def
-
-/authortwo {
- authorfonttwo setfont
- 0 0 0 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { authorfonth l center show }
- linewrap
-} def
-
-/header {
- /ypos pageheight headerheight sub def
- 0 0 0 setrgbcolor
- 0 setlinewidth
- newpath
- 0 pageheight moveto
- pagewidth pageheight lineto
- pagewidth ypos lineto
- 0 ypos lineto
- closepath
- fill
- stroke
- leftmargin headermargin moveto
- titlefont setfont
- 0.5 0.5 0.9 setrgbcolor
- center show
- leftmargin ypos moveto
-} def
-
-/n {
- mainfont setfont
- 0 0 0 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { mainfonth l show }
- linewrap
-} def
-
-/cn {
- codefont setfont
- 0 0 0 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { codefonth l show }
- linewrap
-} def
-
-/tn {
- tinyfont setfont
- 0 0 0 setrgbcolor
- { pagewidth leftmargin 2 mul sub }
- { tinyfonth l show }
- linewrap
-} def
-
-/is {
- /level1 save def
- /showpage {} def
-} def
-
-/ie {
- level1 restore
-} def
-
-/bs {
- /tbtop ypos def
-} def
-
-/be {
- /tm tbtop pad sub def
- /bm ypos pad sub def
- newpath
- leftmargin 10 sub tm moveto
- rightmargin tm lineto
- rightmargin bm lineto
- leftmargin 10 sub bm lineto
- closepath
- 0 0 0 setrgbcolor
- 0.5 setlinewidth
- stroke
-} def
-showpage
-%%Page: 1 1
-s
-( Rollout, feature flag, experiment, operational toggle) title
-(Different use cases for backend, frontend and mobile ) authortwo
-showpage
-%%Page: 2 2
-s
-() n
-() n
-() n
-( "Feature flags" tend to come up when talking about continuous deployment) title
-showpage
-%%Page: 3 3
-s
-() n
-() n
-() n
-() n
-(CI: continuous integration) authortwo
-() n
-(CD: continuous delivery) authortwo
-() n
-(CD: continuous deployment) authortwo
-showpage
-%%Page: 4 4
-s
-( Types) header
-() n
-() n
-() n
-(1. rollout) n
-(2. feature flag) n
-(3. experiment) n
-(4. operational toggle) n
-showpage
-%%Page: 5 5
-s
-( Rollout) header
-( For *rolling out* a new version of software) title
-(Short-lived using percentages) n
-(- a new deployment of kubernetes) n
-(- new APK released to the Play Store) n
-showpage
-%%Page: 6 6
-s
-( Feature flag) header
-( For turning a feature *on* or *off* ) title
-(Medium-lived using allow list, A/B test, percentage, app version, etc.) n
-(- :new-chargeback-flow) n
-(- :new-debit-card-activation-screen) n
-showpage
-%%Page: 7 7
-s
-( Experiment) header
-( For analysing behaviour) title
-(Medium-lived using allow list and A/B test) n
-(- :debit-withdrawal-test) n
-showpage
-%%Page: 8 8
-s
-( Operational toggle) header
-( For disabling features in #crash-like situations) title
-(Long-lived using percentage) n
-(- :bank-barcode-payment) n
-(- :savings-bank-barcode-query-provider) n
-showpage
-%%Page: 9 9
-s
-() n
-() n
-(We know know about the types) authortwo
-( But they have different relevance for backend, frontend and mobile) title
-showpage
-%%Page: 10 10
-s
-( backend) header
-() n
-() n
-(1. rollout: k8s blue/green, canary and ~common-rollout~ common-xp) n
-(2. feature flag: ~common-rollout~ common-xp and datasets) n
-(3. experiment: common-xp) n
-(4. operational toggle: ~common-rollout~ common-xp ) n
-showpage
-%%Page: 11 11
-s
-( frontend) header
-() n
-() n
-(1. rollout: CDN and page refreshes) n
-(2. feature flag: percentages and maybe IPs \(no :customer/id on the website\)) n
-(3. experiment: via dynamic backend control) n
-(4. operational toggle: via dynamic backend control ) n
-showpage
-%%Page: 12 12
-s
-( backend) header
-() n
-() n
-(1. rollout: app stores) n
-(2. feature flag: via dynamic backend control) n
-(3. experiment: via dynamic backend control) n
-(4. operational toggle: via dynamic backend control ) n
-showpage
-%%Page: 13 13
-s
-() n
-() n
-(Key differentiator is) authortwo
-( how much *control* we have over the environment) title
-showpage
-%%Page: 14 14
-s
-( backend) header
-( full control) title
-showpage
-%%Page: 15 15
-s
-( frontend) header
-( partial control) title
-(We choose when to make a new version available ) n
-showpage
-%%Page: 16 16
-s
-( mobile) header
-( very limited control) title
-(- app stores can restrict updates \(worse for iOS\)) n
-(- customers still have to download new versions ) n
-showpage
-%%Page: 17 17
-s
-( Costs) title
-(- more complex code) n
-(- compatibility with old app versions) n
-(- nesting is exponential) n
-showpage
-%%Page: 18 18
-s
-( Benefits) title
-(- dynamicity) n
-showpage
-%%Page: 19 19
-s
-( weighting costs × benefits) header
-( The less control we have, the more we value dynamicity ) title
-showpage
-%%Page: 20 20
-s
-( weighting costs × benefits) header
-() n
-() n
-() n
-(- backend: sometimes worth the cost) n
-(- frontend: almost always worth the cost) n
-(- mobile: *always* worth the cost) n
-showpage
-%%Page: 21 21
-s
-() n
-() n
-() n
-( Best practices) title
-showpage
-%%Page: 22 22
-s
-( dynamic content > feature flag) title
-(Always true for mobile, almost always for frontend ) n
-showpage
-%%Page: 23 23
-s
-( Use :include-list for named groups ) title
-(Always true for backend, frontend and mobile ) n
-bs
-({:rules) cn
-( #{{:types :include-list) cn
-( :content {:filename "debit-team-members.txt"}}}}) cn
-be
-showpage
-%%Page: 24 24
-s
-( Always use :app-version) title
-(Only for mobile) n
-bs
-({:rules) cn
-( #{{:types :app-version) cn
-( :content {:min-version #{{:platform :android) cn
-( :code 1000000}) cn
-( {:platform :ios) cn
-( :code 2000000}}}}}}) cn
-be
-showpage
-%%Page: 25 25
-s
-( Extend ~common-rollout~ common-xp if required) title
-(That's how :include-list, :app-version, etc. were born) n
-showpage
-%%Page: 26 26
-s
-( Beware of many nested feature flags) title
-(True for backend, frontend and mobile) n
-showpage
-%%Page: 27 27
-s
-( Don't delete app-facing feature flags) title
-(True for mobile) n
-showpage
-%%Page: 28 28
-s
-() n
-() n
-() n
-( Include a feature flag on the whiteboarding phase) title
-showpage
-%%Page: 29 29
-s
-() n
-() n
-() n
-( Include deleting/retiring the feature flag at the end) title
-showpage
-%%Page: 30 30
-s
-( Avoid renaming a feature flag) title
-(Use :app-version with :min-version instead) n
-showpage
-%%Page: 31 31
-s
-() n
-() n
-() n
-( And most importantly...) title
-showpage
-%%Page: 32 32
-s
-( *Always* rely on a feature flag on the app) title
-(Never do a hotfix, avoid expedited releases at all costs) n
-showpage
-%%Page: 33 33
-s
-( References) header
-() n
-(1. "Feature Toggles \(aka Feature Flags\)", by Pete Hodgson) n
-(2. "Continuous integration vs. delivery vs. deployment", by Sten Pittet) n
-(3. Accelerate, by N. Forsgren, J. Humble and G. Kim) n
-(4. these slides: euandre.org/slide/) n
-(5. prose version of this presentation) n
-(6. view source) n
-
-showpage
-
-%%EOF
diff --git a/v2/src/content/en/slide/rollouts.slides b/v2/src/content/en/slide/rollouts.slides
deleted file mode 100644
index aed745e..0000000
--- a/v2/src/content/en/slide/rollouts.slides
+++ /dev/null
@@ -1,208 +0,0 @@
----
-# Rollout, feature flag, experiment, operational toggle
-
-@Different use cases for backend, frontend and mobile
-
----
-...
-# "Feature flags" tend to come up when talking about continuous deployment
-
----
-....
-@CI: continuous integration
-.
-@CD: continuous delivery
-.
-@CD: continuous deployment
-
----
-## Types
-...
-1. rollout
-2. feature flag
-3. experiment
-4. operational toggle
-
-% {favicon.svg}
----
-## Rollout
-
-# For *rolling out* a new version of software
-
-Short-lived using percentages
-
-% FIXME: links
-- a new deployment of kubernetes
-- new APK released to the Play Store
-
----
-## Feature flag
-
-# For turning a feature *on* or *off*
-
-Medium-lived using allow list, A/B test, percentage, app version, etc.
-
-- :new-chargeback-flow
-- :new-debit-card-activation-screen
-
----
-## Experiment
-
-# For analysing behaviour
-
-Medium-lived using allow list and A/B test
-
-- :debit-withdrawal-test
-
----
-## Operational toggle
-
-# For disabling features in #crash-like situations
-
-Long-lived using percentage
-
-- :bank-barcode-payment
-- :savings-bank-barcode-query-provider
-
----
-..
-@We know know about the types
-# But they have different relevance for backend, frontend and mobile
-
----
-## backend
-..
-1. rollout: k8s blue/green, canary and ~common-rollout~ common-xp
-2. feature flag: ~common-rollout~ common-xp and datasets
-3. experiment: common-xp
-4. operational toggle: ~common-rollout~ common-xp
-
----
-## frontend
-..
-1. rollout: CDN and page refreshes
-2. feature flag: percentages and maybe IPs (no :customer/id on the website)
-3. experiment: via dynamic backend control
-4. operational toggle: via dynamic backend control
-
----
-## backend
-..
-1. rollout: app stores
-2. feature flag: via dynamic backend control
-3. experiment: via dynamic backend control
-4. operational toggle: via dynamic backend control
-
----
-..
-@Key differentiator is
-# how much *control* we have over the environment
-
----
-## backend
-# full control
-% FIXME: emoji
-% 🎉
-
----
-## frontend
-# partial control
-We choose when to make a new version available
-
----
-## mobile
-# very limited control
-- app stores can restrict updates (worse for iOS)
-- customers still have to download new versions
-
----
-# Costs
-- more complex code
-- compatibility with old app versions
-- nesting is exponential
-
----
-# Benefits
-- dynamicity
-
----
-## weighting costs × benefits
-# The less control we have, the more we value dynamicity
-
----
-## weighting costs × benefits
-...
-- backend: sometimes worth the cost
-- frontend: almost always worth the cost
-- mobile: *always* worth the cost
-
----
-...
-# Best practices
-
----
-# dynamic content > feature flag
-Always true for mobile, almost always for frontend
-
----
-# Use :include-list for named groups
-Always true for backend, frontend and mobile
-
- {:rules
- #{{:types :include-list
- :content {:filename "debit-team-members.txt"}}}}
-
----
-# Always use :app-version
-Only for mobile
-
- {:rules
- #{{:types :app-version
- :content {:min-version #{{:platform :android
- :code 1000000}
- {:platform :ios
- :code 2000000}}}}}}
-
----
-# Extend ~common-rollout~ common-xp if required
-
-That's how :include-list, :app-version, etc. were born
-
----
-# Beware of many nested feature flags
-True for backend, frontend and mobile
-
----
-# Don't delete app-facing feature flags
-True for mobile
-
----
-...
-# Include a feature flag on the whiteboarding phase
-
----
-...
-# Include deleting/retiring the feature flag at the end
-
----
-# Avoid renaming a feature flag
-Use :app-version with :min-version instead
-
----
-...
-# And most importantly...
-
----
-# *Always* rely on a feature flag on the app
-Never do a hotfix, avoid expedited releases at all costs
-
----
-## References
-.
-% FIXME: links
-1. "Feature Toggles (aka Feature Flags)", by Pete Hodgson
-2. "Continuous integration vs. delivery vs. deployment", by Sten Pittet
-3. Accelerate, by N. Forsgren, J. Humble and G. Kim
-4. these slides: euandre.org/slide/
-5. prose version of this presentation
-6. view source
diff --git a/v2/src/content/en/til/lisp-three-way-conditional.md b/v2/src/content/en/til/lisp-three-way-conditional.md
deleted file mode 100644
index 20fbd09..0000000
--- a/v2/src/content/en/til/lisp-three-way-conditional.md
+++ /dev/null
@@ -1,59 +0,0 @@
----
-
-title: Three-way conditional for number signs on Lisp
-
-date: 2021-04-24 3
-
-update: 2021-08-14
-
-categories: lisp scheme common-lisp
-
----
-
-A useful macro from Paul Graham's [On Lisp][on-lisp] book:
-
-```lisp
-(defmacro nif (expr pos zero neg)
- (let ((g (gensym)))
- `(let ((,g ,expr))
- (cond ((plusp ,g) ,pos)
- ((zerop ,g) ,zero)
- (t ,neg)))))
-```
-
-After I looked at this macro, I started seeing opportunities to using it in many places, and yet I didn't see anyone else using it.
-
-The latest example I can think of is section 1.3.3 of [Structure and Interpretation of Computer Programs][sicp], which I was reading recently:
-
-```scheme
-(define (search f neg-point pos-point)
- (let ((midpoint (average neg-point pos-point)))
- (if (close-enough? neg-point post-point)
- midpoint
- (let ((test-value (f midpoint)))
- (cond ((positive? test-value)
- (search f neg-point midpoint))
- ((negative? test-value)
- (search f midpoint pos-point))
- (else midpoint))))))
-```
-
-Not that the book should introduce such macro this early, but I couldn't avoid feeling bothered by not using the `nif` macro, which could even remove the need for the intermediate `test-value` variable:
-
-```scheme
-(define (search f neg-point pos-point)
- (let ((midpoint (average neg-point pos-point)))
- (if (close-enough? neg-point post-point)
- midpoint
- (nif (f midpoint)
- (search f neg-point midpoint)
- (midpoint)
- (search f midpoint pos-point)))))
-```
-
-It also avoids `cond`'s extra clunky parentheses for grouping, which is unnecessary but built-in.
-
-As a macro, I personally feel it tilts the balance towards expressivenes despite its extra cognitive load toll.
-
-[on-lisp]: http://www.paulgraham.com/onlisptext.html
-[sicp]: https://mitpress.mit.edu/sites/default/files/sicp/index.html
diff --git a/v2/src/content/favicon.ico b/v2/src/content/favicon.ico
deleted file mode 100644
index 8f2130a..0000000
--- a/v2/src/content/favicon.ico
+++ /dev/null
Binary files differ
diff --git a/v2/src/content/img/alt/atom.en.txt b/v2/src/content/img/alt/atom.en.txt
deleted file mode 100644
index 33bc955..0000000
--- a/v2/src/content/img/alt/atom.en.txt
+++ /dev/null
@@ -1 +0,0 @@
-three yellow lines representing an Atom feed
diff --git a/v2/src/content/img/alt/atom.pt.txt b/v2/src/content/img/alt/atom.pt.txt
deleted file mode 100644
index 33bc955..0000000
--- a/v2/src/content/img/alt/atom.pt.txt
+++ /dev/null
@@ -1 +0,0 @@
-three yellow lines representing an Atom feed
diff --git a/v2/src/content/img/alt/envelope.en.txt b/v2/src/content/img/alt/envelope.en.txt
deleted file mode 100644
index 8b72080..0000000
--- a/v2/src/content/img/alt/envelope.en.txt
+++ /dev/null
@@ -1 +0,0 @@
-an envelope icon representing an email address
diff --git a/v2/src/content/img/alt/envelope.pt.txt b/v2/src/content/img/alt/envelope.pt.txt
deleted file mode 100644
index 8b72080..0000000
--- a/v2/src/content/img/alt/envelope.pt.txt
+++ /dev/null
@@ -1 +0,0 @@
-an envelope icon representing an email address
diff --git a/v2/src/content/img/alt/favicon.en.txt b/v2/src/content/img/alt/favicon.en.txt
deleted file mode 100644
index add8557..0000000
--- a/v2/src/content/img/alt/favicon.en.txt
+++ /dev/null
@@ -1 +0,0 @@
-a crude hand doing a thumbs up
diff --git a/v2/src/content/img/alt/favicon.pt.txt b/v2/src/content/img/alt/favicon.pt.txt
deleted file mode 100644
index add8557..0000000
--- a/v2/src/content/img/alt/favicon.pt.txt
+++ /dev/null
@@ -1 +0,0 @@
-a crude hand doing a thumbs up
diff --git a/v2/src/content/img/alt/link.en.txt b/v2/src/content/img/alt/link.en.txt
deleted file mode 100644
index bbf036f..0000000
--- a/v2/src/content/img/alt/link.en.txt
+++ /dev/null
@@ -1 +0,0 @@
-two chain rings, representing an anchor to this header
diff --git a/v2/src/content/img/alt/link.pt.txt b/v2/src/content/img/alt/link.pt.txt
deleted file mode 100644
index bbf036f..0000000
--- a/v2/src/content/img/alt/link.pt.txt
+++ /dev/null
@@ -1 +0,0 @@
-two chain rings, representing an anchor to this header
diff --git a/v2/src/content/img/alt/linkto.en.txt b/v2/src/content/img/alt/linkto.en.txt
deleted file mode 100644
index a192899..0000000
--- a/v2/src/content/img/alt/linkto.en.txt
+++ /dev/null
@@ -1 +0,0 @@
-a drawing of a box with an arrow going outwards, representing an internal link
diff --git a/v2/src/content/img/alt/linkto.pt.txt b/v2/src/content/img/alt/linkto.pt.txt
deleted file mode 100644
index df3bbf7..0000000
--- a/v2/src/content/img/alt/linkto.pt.txt
+++ /dev/null
@@ -1,2 +0,0 @@
-a drawing of a box with an arrow going outwards, representing an internal
-link
diff --git a/v2/src/content/img/alt/lock.en.txt b/v2/src/content/img/alt/lock.en.txt
deleted file mode 100644
index b809247..0000000
--- a/v2/src/content/img/alt/lock.en.txt
+++ /dev/null
@@ -1 +0,0 @@
-a lock icon representing a GPG public key
diff --git a/v2/src/content/img/alt/lock.pt.txt b/v2/src/content/img/alt/lock.pt.txt
deleted file mode 100644
index b809247..0000000
--- a/v2/src/content/img/alt/lock.pt.txt
+++ /dev/null
@@ -1 +0,0 @@
-a lock icon representing a GPG public key
diff --git a/v2/src/content/img/atom.svg b/v2/src/content/img/atom.svg
deleted file mode 100644
index 37bace2..0000000
--- a/v2/src/content/img/atom.svg
+++ /dev/null
@@ -1,5 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<svg width="22" height="22" viewBox="0 0 1792 1792" xmlns="http://www.w3.org/2000/svg">
- <path d="M576 1344q0 80-56 136t-136 56-136-56-56-136 56-136 136-56 136 56 56 136zm512 123q2 28-17 48-18 21-47 21h-135q-25 0-43-16.5t-20-41.5q-22-229-184.5-391.5t-391.5-184.5q-25-2-41.5-20t-16.5-43v-135q0-29 21-47 17-17 43-17h5q160 13 306 80.5t259 181.5q114 113 181.5 259t80.5 306zm512 2q2 27-18 47-18 20-46 20h-143q-26 0-44.5-17.5t-19.5-42.5q-12-215-101-408.5t-231.5-336-336-231.5-408.5-102q-25-1-42.5-19.5t-17.5-43.5v-143q0-28 20-46 18-18 44-18h3q262 13 501.5 120t425.5 294q187 186 294 425.5t120 501.5z"
- fill="#EA990E" />
-</svg>
diff --git a/v2/src/content/img/dark-mode.xml b/v2/src/content/img/dark-mode.xml
deleted file mode 100644
index 7c2b572..0000000
--- a/v2/src/content/img/dark-mode.xml
+++ /dev/null
@@ -1,12 +0,0 @@
- <defs>
- <style>
- path {
- fill: black;
- }
- @media(prefers-color-scheme: dark) {
- path {
- fill: white;
- }
- }
- </style>
- </defs>
diff --git a/v2/src/content/img/envelope.svg.uncolored b/v2/src/content/img/envelope.svg.uncolored
deleted file mode 100644
index c2251f4..0000000
--- a/v2/src/content/img/envelope.svg.uncolored
+++ /dev/null
@@ -1,4 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<svg width="22" height="22" viewBox="0 0 1792 1792" xmlns="http://www.w3.org/2000/svg">
- <path d="M1664 1504v-768q-32 36-69 66-268 206-426 338-51 43-83 67t-86.5 48.5-102.5 24.5h-2q-48 0-102.5-24.5t-86.5-48.5-83-67q-158-132-426-338-37-30-69-66v768q0 13 9.5 22.5t22.5 9.5h1472q13 0 22.5-9.5t9.5-22.5zm0-1051v-24.5l-.5-13-3-12.5-5.5-9-9-7.5-14-2.5h-1472q-13 0-22.5 9.5t-9.5 22.5q0 168 147 284 193 152 401 317 6 5 35 29.5t46 37.5 44.5 31.5 50.5 27.5 43 9h2q20 0 43-9t50.5-27.5 44.5-31.5 46-37.5 35-29.5q208-165 401-317 54-43 100.5-115.5t46.5-131.5zm128-37v1088q0 66-47 113t-113 47h-1472q-66 0-113-47t-47-113v-1088q0-66 47-113t113-47h1472q66 0 113 47t47 113z" />
-</svg>
diff --git a/v2/src/content/img/favicon.svg.uncolored b/v2/src/content/img/favicon.svg.uncolored
deleted file mode 100644
index ce566b2..0000000
--- a/v2/src/content/img/favicon.svg.uncolored
+++ /dev/null
@@ -1,62 +0,0 @@
-<?xml version="1.0" encoding="UTF-8" standalone="no"?>
-<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" width="16" height="16">
- <path d="M 0 8 L 1 8 L 1 9 L 0 9 L 0 8 Z" />
- <path d="M 0 13 L 1 13 L 1 14 L 0 14 L 0 13 Z" />
- <path d="M 1 8 L 2 8 L 2 9 L 1 9 L 1 8 Z" />
- <path d="M 1 13 L 2 13 L 2 14 L 1 14 L 1 13 Z" />
- <path d="M 2 8 L 3 8 L 3 9 L 2 9 L 2 8 Z" />
- <path d="M 2 13 L 3 13 L 3 14 L 2 14 L 2 13 Z" />
- <path d="M 3 8 L 4 8 L 4 9 L 3 9 L 3 8 Z" />
- <path d="M 3 13 L 4 13 L 4 14 L 3 14 L 3 13 Z" />
- <path d="M 4 7 L 5 7 L 5 8 L 4 8 L 4 7 Z" />
- <path d="M 4 8 L 5 8 L 5 9 L 4 9 L 4 8 Z" />
- <path d="M 4 13 L 5 13 L 5 14 L 4 14 L 4 13 Z" />
- <path d="M 5 6 L 6 6 L 6 7 L 5 7 L 5 6 Z" />
- <path d="M 5 7 L 6 7 L 6 8 L 5 8 L 5 7 Z" />
- <path d="M 5 13 L 6 13 L 6 14 L 5 14 L 5 13 Z" />
- <path d="M 6 5 L 7 5 L 7 6 L 6 6 L 6 5 Z" />
- <path d="M 6 6 L 7 6 L 7 7 L 6 7 L 6 6 Z" />
- <path d="M 6 14 L 7 14 L 7 15 L 6 15 L 6 14 Z" />
- <path d="M 7 1 L 8 1 L 8 2 L 7 2 L 7 1 Z" />
- <path d="M 7 14 L 8 14 L 8 15 L 7 15 L 7 14 Z" />
- <path d="M 7 15 L 8 15 L 8 16 L 7 16 L 7 15 Z" />
- <path d="M 7 2 L 8 2 L 8 3 L 7 3 L 7 2 Z" />
- <path d="M 7 3 L 8 3 L 8 4 L 7 4 L 7 3 Z" />
- <path d="M 7 4 L 8 4 L 8 5 L 7 5 L 7 4 Z" />
- <path d="M 7 5 L 8 5 L 8 6 L 7 6 L 7 5 Z" />
- <path d="M 8 1 L 9 1 L 9 2 L 8 2 L 8 1 Z" />
- <path d="M 8 15 L 9 15 L 9 16 L 8 16 L 8 15 Z" />
- <path d="M 9 1 L 10 1 L 10 2 L 9 2 L 9 1 Z" />
- <path d="M 9 2 L 10 2 L 10 3 L 9 3 L 9 2 Z" />
- <path d="M 9 6 L 10 6 L 10 7 L 9 7 L 9 6 Z" />
- <path d="M 9 15 L 10 15 L 10 16 L 9 16 L 9 15 Z" />
- <path d="M 10 2 L 11 2 L 11 3 L 10 3 L 10 2 Z" />
- <path d="M 10 3 L 11 3 L 11 4 L 10 4 L 10 3 Z" />
- <path d="M 10 4 L 11 4 L 11 5 L 10 5 L 10 4 Z" />
- <path d="M 10 5 L 11 5 L 11 6 L 10 6 L 10 5 Z" />
- <path d="M 10 6 L 11 6 L 11 7 L 10 7 L 10 6 Z" />
- <path d="M 11 6 L 12 6 L 12 7 L 11 7 L 11 6 Z" />
- <path d="M 11 8 L 12 8 L 12 9 L 11 9 L 11 8 Z" />
- <path d="M 10 15 L 11 15 L 11 16 L 10 16 L 10 15 Z" />
- <path d="M 11 10 L 12 10 L 12 11 L 11 11 L 11 10 Z" />
- <path d="M 11 12 L 12 12 L 12 13 L 11 13 L 11 12 Z" />
- <path d="M 11 14 L 12 14 L 12 15 L 11 15 L 11 14 Z" />
- <path d="M 11 15 L 12 15 L 12 16 L 11 16 L 11 15 Z" />
- <path d="M 12 6 L 13 6 L 13 7 L 12 7 L 12 6 Z" />
- <path d="M 12 8 L 13 8 L 13 9 L 12 9 L 12 8 Z" />
- <path d="M 12 10 L 13 10 L 13 11 L 12 11 L 12 10 Z" />
- <path d="M 12 12 L 13 12 L 13 13 L 12 13 L 12 12 Z" />
- <path d="M 12 14 L 13 14 L 13 15 L 12 15 L 12 14 Z" />
- <path d="M 13 6 L 14 6 L 14 7 L 13 7 L 13 6 Z" />
- <path d="M 13 8 L 14 8 L 14 9 L 13 9 L 13 8 Z" />
- <path d="M 13 10 L 14 10 L 14 11 L 13 11 L 13 10 Z" />
- <path d="M 13 12 L 14 12 L 14 13 L 13 13 L 13 12 Z" />
- <path d="M 13 13 L 14 13 L 14 14 L 13 14 L 13 13 Z" />
- <path d="M 13 14 L 14 14 L 14 15 L 13 15 L 13 14 Z" />
- <path d="M 14 7 L 15 7 L 15 8 L 14 8 L 14 7 Z" />
- <path d="M 14 8 L 15 8 L 15 9 L 14 9 L 14 8 Z" />
- <path d="M 14 9 L 15 9 L 15 10 L 14 10 L 14 9 Z" />
- <path d="M 14 10 L 15 10 L 15 11 L 14 11 L 14 10 Z" />
- <path d="M 14 11 L 15 11 L 15 12 L 14 12 L 14 11 Z" />
- <path d="M 14 12 L 15 12 L 15 13 L 14 13 L 14 12 Z" />
-</svg>
diff --git a/v2/src/content/img/link.svg.uncolored b/v2/src/content/img/link.svg.uncolored
deleted file mode 100644
index e5c7050..0000000
--- a/v2/src/content/img/link.svg.uncolored
+++ /dev/null
@@ -1,5 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<svg width="22" height="22" viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg">
- <path fill-rule="evenodd"
- d="M7.775 3.275a.75.75 0 001.06 1.06l1.25-1.25a2 2 0 112.83 2.83l-2.5 2.5a2 2 0 01-2.83 0 .75.75 0 00-1.06 1.06 3.5 3.5 0 004.95 0l2.5-2.5a3.5 3.5 0 00-4.95-4.95l-1.25 1.25zm-4.69 9.64a2 2 0 010-2.83l2.5-2.5a2 2 0 012.83 0 .75.75 0 001.06-1.06 3.5 3.5 0 00-4.95 0l-2.5 2.5a3.5 3.5 0 004.95 4.95l1.25-1.25a.75.75 0 00-1.06-1.06l-1.25 1.25a2 2 0 01-2.83 0z" />
-</svg>
diff --git a/v2/src/content/img/linkto.svg.uncolored b/v2/src/content/img/linkto.svg.uncolored
deleted file mode 100644
index d4d9fe1..0000000
--- a/v2/src/content/img/linkto.svg.uncolored
+++ /dev/null
@@ -1,7 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<svg width="22" height="22" viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg">
- <path fill-rule="evenodd"
- d="M8.636 3.5a.5.5 0 0 0-.5-.5H1.5A1.5 1.5 0 0 0 0 4.5v10A1.5 1.5 0 0 0 1.5 16h10a1.5 1.5 0 0 0 1.5-1.5V7.864a.5.5 0 0 0-1 0V14.5a.5.5 0 0 1-.5.5h-10a.5.5 0 0 1-.5-.5v-10a.5.5 0 0 1 .5-.5h6.636a.5.5 0 0 0 .5-.5z"/>
- <path fill-rule="evenodd"
- d="M16 .5a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h3.793L6.146 9.146a.5.5 0 1 0 .708.708L15 1.707V5.5a.5.5 0 0 0 1 0v-5z"/>
-</svg>
diff --git a/v2/src/content/img/lock.svg.uncolored b/v2/src/content/img/lock.svg.uncolored
deleted file mode 100644
index 1a4a18e..0000000
--- a/v2/src/content/img/lock.svg.uncolored
+++ /dev/null
@@ -1,4 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<svg width="22" height="22" viewBox="0 0 1792 1792" xmlns="http://www.w3.org/2000/svg">
- <path d="M640 768h512v-192q0-106-75-181t-181-75-181 75-75 181v192zm832 96v576q0 40-28 68t-68 28h-960q-40 0-68-28t-28-68v-576q0-40 28-68t68-28h32v-192q0-184 132-316t316-132 316 132 132 316v192h32q40 0 68 28t28 68z" />
-</svg>
diff --git a/v2/src/content/pt/hea/condicional-ternario-lisp.md b/v2/src/content/pt/hea/condicional-ternario-lisp.md
deleted file mode 100644
index 6971827..0000000
--- a/v2/src/content/pt/hea/condicional-ternario-lisp.md
+++ /dev/null
@@ -1,65 +0,0 @@
----
-
-title: Three-way conditional for number signs on Lisp
-
-date: 2021-04-24 3
-
-update: 2021-08-14
-
-categories: lisp scheme common-lisp
-
----
-
-A useful macro from Paul Graham's [On Lisp][on-lisp] book:
-
-```lisp
-(defmacro nif (expr pos zero neg)
- (let ((g (gensym)))
- `(let ((,g ,expr))
- (cond ((plusp ,g) ,pos)
- ((zerop ,g) ,zero)
- (t ,neg)))))
-```
-
-After I looked at this macro, I started seeing opportunities to using it in
-many places, and yet I didn't see anyone else using it.
-
-The latest example I can think of is section 1.3.3 of [Structure and
-Interpretation of Computer Programs][sicp], which I was reading recently:
-
-```scheme
-(define (search f neg-point pos-point)
- (let ((midpoint (average neg-point pos-point)))
- (if (close-enough? neg-point post-point)
- midpoint
- (let ((test-value (f midpoint)))
- (cond ((positive? test-value)
- (search f neg-point midpoint))
- ((negative? test-value)
- (search f midpoint pos-point))
- (else midpoint))))))
-```
-
-Not that the book should introduce such macro this early, but I couldn't
-avoid feeling bothered by not using the `nif` macro, which could even remove
-the need for the intermediate `test-value` variable:
-
-```scheme
-(define (search f neg-point pos-point)
- (let ((midpoint (average neg-point pos-point)))
- (if (close-enough? neg-point post-point)
- midpoint
- (nif (f midpoint)
- (search f neg-point midpoint)
- (midpoint)
- (search f midpoint pos-point)))))
-```
-
-It also avoids `cond`'s extra clunky parentheses for grouping, which is
-unnecessary but built-in.
-
-As a macro, I personally feel it tilts the balance towards expressivenes
-despite its extra cognitive load toll.
-
-[on-lisp]: http://www.paulgraham.com/onlisptext.html [sicp]:
-https://mitpress.mit.edu/sites/default/files/sicp/index.html
diff --git a/v2/src/content/pt/pastebin/exercicios-sicp-e-19.md b/v2/src/content/pt/pastebin/exercicios-sicp-e-19.md
deleted file mode 100644
index 89dacfd..0000000
--- a/v2/src/content/pt/pastebin/exercicios-sicp-e-19.md
+++ /dev/null
@@ -1,105 +0,0 @@
----
-
-title: SICP exercise 3.19
-
-date: 2021-09-02
-
-categories: lisp programming-languages
-
----
-
-Some content here, before:
-
-```scheme
-(define (cycle? l)
- (define (rec l x)
- (cond
- ((null? x) false)
- ((eq? l x) true)
- (true (rec l (cdr x)))))
- (rec l (cdr l)))
-```
-
-Sample interactive session:
-
-```scheme
-scheme@(guile-user)> (define true #t)
-scheme@(guile-user)> (define false #f)
-scheme@(guile-user)>
-(define (cycle? l)
- (define (rec l x)
- (cond
- ((null? x) false)
- ((eq? l x) true)
- (true (rec l (cdr x)))))
- (rec l (cdr l)))
-scheme@(guile-user)> (cycle? '(1 2 3))
-$9 = #f
-scheme@(guile-user)> (cycle? (make-cycle '(1 2 3)))
-$10 = #t
-```
-
-# An h1
-
-a list:
-
-1. one
-2. two
-3. three
-
-some content.
-
-- item
-- another
-- yet another
-
-## An h2
-
-Xablau:
-
-``` xupliu 1
-
-3 4
-
-
-
-
-
-dez ```
-
-Foi `wikiwiu`.
-
-a very long code block:
-
-```
-wef
-wef wef wef wef
-wef wef wef wef we fwef wef wef wef wef
-```
-
-Someone said:
-
-> Xablau, xupliu.
-
-### A repeated header ### A repeated header
-
-a big list:
-
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
-1. a
diff --git a/v2/src/content/pt/sobre.page b/v2/src/content/pt/sobre.page
deleted file mode 100644
index aac3e67..0000000
--- a/v2/src/content/pt/sobre.page
+++ /dev/null
@@ -1,7 +0,0 @@
----
-
-title: About
-
----
-
-It's all about me, baby!
diff --git a/v2/src/content/public.asc.txt b/v2/src/content/public.asc.txt
deleted file mode 100644
index 533b54c..0000000
--- a/v2/src/content/public.asc.txt
+++ /dev/null
@@ -1,86 +0,0 @@
------BEGIN PGP PUBLIC KEY BLOCK-----
-
-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
-LsPdAc9FGcUNEy+/AlLpM1Y=
-=2ZCp
------END PGP PUBLIC KEY BLOCK-----
diff --git a/v2/src/content/style.css b/v2/src/content/style.css
deleted file mode 100644
index a4a635f..0000000
--- a/v2/src/content/style.css
+++ /dev/null
@@ -1,205 +0,0 @@
-/* Colors */
-
-:root {
- --color: black;
- --background-color: white;
- --nav-color: hsl(0, 100%, 25%);
- --fade-color: #555;
- --quote-color: hsl(0, 0%, 41%);
- --code-border-color: hsla(0, 0%, 0%, 0.3);
- --link-color: #0000ee;
- --link-color-visited: #551a8b;
-}
-
-@media(prefers-color-scheme: dark) {
- :root {
- --color: white;
- --background-color: black;
- --fade-color: #aaa;
- --nav-color: hsl(0, 100%, 75%);
- --quote-color: hsl(0, 0%, 59%);
- --code-border-color: hsla(0, 0%, 100%, 0.3);
- --link-color: hsl(211, 100%, 60%);
- --link-color-visited: hsl(242, 100%, 80%);
- }
-}
-
-
-/* General declarations */
-
-body {
- color: var(--color);
- background-color: var(--background-color);
- margin: 0px auto;
- padding: 1%;
- max-width: 750px;
-}
-
-a {
- color: var(--link-color);
-}
-
-a:visited {
- color: var(--link-color-visited);
-}
-
-.svg-icon {
- vertical-align: middle;
-}
-
-
-/* Navigation header */
-
-nav {
- margin-top: 8px;
-}
-
-nav a, nav a:visited {
- color: var(--nav-color);
-}
-
-nav a {
- font-size: 18px;
- margin: 12px;
- text-decoration: none;
-}
-
-nav ul, nav li {
- display: inline;
-}
-
-nav ul.translation-list a, nav ul.translation-list a:visited {
- color: var(--color);
- font-size: 14px;
-}
-
-nav ul.translation-list {
- display: flex;
- justify-content: flex-end;
- font-size: 16px;
- margin: 0;
- padding: 0;
-}
-
-nav ul li a {
- font-size: 18px;
- margin: 6px;
-}
-
-
-/* Article bodies */
-
-.timestamp {
- color: var(--fade-color);
- font-size: 14px;
- font-style: italic;
-}
-
-blockquote {
- font-style: italic;
- color: var(--quote-color);
- padding-left: 10px;
- border-left: 3px solid #ccc;
-}
-
-ul.no-style {
- list-style-type: none;
-}
-
-ul.no-style li {
- margin: 20px 0px;
-}
-
-
-/* Footer */
-
-footer {
- font-size: 14px;
- margin-top: 30px;
- padding: 12px 0px 12px 0px;
-}
-
-footer li {
- list-style-type: none;
- margin-top: 10px;
-}
-
-footer li a {
- margin-left: 5px;
- user-select: none;
-}
-
-/* Code blocks */
-
-/* The "lineno" class is the default generated by Rouge for table-row in code blocks, see:
- https://github.com/rouge-ruby/rouge */
-.line-number, pre.lineno {
- margin-right: 3px;
- padding-right: 3px;
- border-right: 1px solid;
- border-color: var(--code-border-color);
- text-align: right;
- user-select: none;
-}
-
-.code-line {
- padding-left: 8px;
-}
-
-.code-block {
- padding: 6px 4px;
- display: block;
-}
-
-.code-block, pre.highlight {
- border: 1px solid #ccc;
- border-radius: 10px;
-}
-
-pre {
- overflow: auto;
-}
-
-
-/* Code block anchors */
-
-.line-number a, a.code-line-anchor {
- color: var(--color);
- text-decoration: none;
-}
-
-a.code-line-anchor:hover {
- text-decoration: underline;
-}
-
-
-/* Header anchor */
-
-.header-anchor {
- color: var(--color);
- text-decoration: none;
- display: block;
- margin-bottom: 15px;
-}
-
-.header-anchor {
-}
-
-
-.header-anchor img {
- margin-left: 5px;
- visibility: hidden;
-}
-
-.header-anchor:hover img {
- visibility: visible;
-}
-
-
-/* Plaintext code block links */
-
-.plaintext-link {
- margin: auto auto 0 auto;
- text-align: right;
- font-family: monospace;
-}