aboutsummaryrefslogtreecommitdiffhomepage
path: root/docs/script.js
blob: 463baddc919de16c4fd54faeaf719dd8efd0de77 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
[...document.getElementsByClassName("term")].forEach(el => {
	el.innerHTML = el.innerHTML
		.replaceAll(/(?<!\>)(\()/g, "<span class='left-app'>(</span>")
		.replaceAll(/(\))(?!\<)/g, "<span class='right-app'>)</span>")
		.replaceAll("[", "<span class='left-abs'>[</span>")
		.replaceAll("]", "<span class='right-abs'>]</span>")
		.replaceAll(/(?<!\+)([0-9])/g, "<span class='index'>$1</span>")
})

const clearPopups = () => {
	[...document.getElementsByClassName("popup")].forEach(el => {
		el.remove()
	})
}

const notify = (s, e) => {
	console.log(e);
	clearPopups()
	const popup = document.createElement("div")
	popup.className = "popup"
	const content = document.createTextNode(s)
	popup.style.left = e.pageX + "px";
	popup.style.top = e.pageY + "px";
	popup.appendChild(content)
	document.body.appendChild(popup)
}

const describe = (c, d) => {
	[...document.getElementsByClassName(c)].forEach(el => el.addEventListener("click", e => notify(d, e)));
}

describe("binary", "Syntactic sugar for a binary number representation using abstractions as data. Needs a sign and brackets to differentiate it from De Bruijn indices");
describe("char", "Syntactic sugar for a binary representation of characters using abstractions as data.");
describe("com", "This indicates a command to the interpreter. The most common commands are :test (verifying α-equivalency) and :import (importing definitions from other files).");
describe("def", "This defines a new term substitution. Using this identifier will substitute the term on its right side.");
describe("header", "[0] is the identity operation. It returns the first argument it gets. Nothing more.");
describe("index", "This number references the nth abstraction, starting counting from the inside. These 'De Bruijn indices' replace the concept of variables in lambda calculus.");
describe("left-abs", "The opening bracket of a function abstraction. It's basically the equivalent of the λ in lambda calculus.");
describe("left-app", "The opening bracket of a function application.");
describe("meta", "This is the quote operator. It converts any given expression to bruijn's meta encoding. The meta encoding can be used for self modification and can be turned back to normal bruijn code.");
describe("mixfix", "This is a mixfix operator. They can be defined like …*… where the … can then be any other term. You can use them without the … as a notation of function application.");
describe("prefix", "This is a prefix operator. They can be defined like *‣ where the ‣ can then be any other term.");
describe("repl", "This indicates a REPL input.");
describe("right-abs", "The closing bracket of a function abstraction.");
describe("right-app", "The closing bracket of a function application.");
describe("stack", "Stack is a dependency manager for Haskell. Install it using the corresponding instructions for your operating system.")
describe("string", "Syntactic sugar for a list of binary encoded chars.")
describe("symbol", "This substitutes a previously defined term (for example from the standard library).");
describe("ternary", "Syntactic sugar for a balanced ternary number representation using abstractions as data. Needs a sign and brackets to differentiate it from De Bruijn indices.");
describe("time", "Incredibly fast for lambda calculus standards.");
describe("unary", "Syntactic sugar for a unary number representation using abstractions as data. This is commonly known as a Church numeral. Needs a sign and brackets to differentiate it from De Bruijn indices.");

document.body.addEventListener("click", clearPopups, true)