class: middle # Eat your **Greens** -
A philosophy for language design. --- class: middle ## **Hi** ### *name -* Peter Saxton ### *@internets -* CrowdHailer ### *works -* Experimenting in building better languages and tools at [eyg.run](https://eyg.run)
--- class: middle data:image/s3,"s3://crabby-images/36c53/36c53a19121cf2c12ba9f1114a574ccdb496b368" alt="" ??? Look at the derogatory version. JavaScript Wat --- class: middle data:image/s3,"s3://crabby-images/fbab9/fbab9bb0ed879c5f14d038a7cf40f2ff6f35c47c" alt="" ??? Look at the first simile. --- class: middle **Predictable**: - No undefined behaviour. - Never crash. - Same answer every time. **Useful**: - Build the required applications. - Be useful in several ways, *but which ones?* --- class: middle ## Scale matters data:image/s3,"s3://crabby-images/adcc2/adcc26843b4c5bc0b3b5828257af1a810319ea59" alt="" ??? Why I got started - End user programming - Own your own software --- class: middle ## Rating language **features** Existing languages have already had to make choices that affect predictability and usability. --- class: middle data:image/s3,"s3://crabby-images/fae7c/fae7cc2e071c21665861f7de51b009ef7de1af78" alt="" ??? Everything is deterministic and Turing complete. Rust has Zero Cost abstractions. structural typing applies to slightly more things i.e databases --- class: middle ## Find a **philosophy** data:image/s3,"s3://crabby-images/3f0b9/3f0b94b30325bde34975254b6e2b6adee9994783" alt="" --- class: middle ## Eat Your **Greens** > Beyond diet, "eat your greens" can symbolize doing things that are good for you, even if they're not immediately enjoyable or easy. --- class: middle ## Who likes **types**? - Static? - Strong? - Gradual? -- Did you apprecate them the first day you were coding? --- class: middle ## Type systems are a **vegetable** ```py print("Hello, World!") ``` What do types add to this Python program? --- class: middle ## Types make things **harder** - Structured IO - JSON deserialization - SQL interop - Object creation - Foreign function interfaces -- Types are great for compounding value over time. --- class: middle data:image/s3,"s3://crabby-images/30dcd/30dcd1a09de3df8ae044cf54901742cfd9990d01" alt="" --- class: middle ## Gall's Law > A complex system that works is invariably found to have evolved from a simple system that worked. A complex system designed from scratch never works and cannot be patched up to make it work. You have to start over with a working simple system *The Systems Bible: The Beginner's Guide to Systems Large and Small* --- class: middle data:image/s3,"s3://crabby-images/61771/6177149b38bfd8973752ce1abe13ab9dc907ce41" alt="" --- class: middle data:image/s3,"s3://crabby-images/c8376/c837648142c52b6ee0257c53f8d6af229feaee1f" alt="" ??? WASM --- class: middle ## EYG the **Basics** - Statically typed - Structurally typed - Sound type inference - Algebraic effects - Closure serialization - Strongly typed REPL - Inline references (for another time) - Minimal AST (for another time) *I'll be talking about the other two later in the year.* --- class: middle ### EYG is **statically** typed ??? embed code and see the type --- class: middle ### EYG is **structurally** typed --- class: middle ### EYG is **soundly** typed This extends to effects. --- class: middle EYG is a **browser native** runtime. --- class: middle ## **Algebraic** effects An abstraction to represent all impure behaviour including: - Input and output operations - Non determinism i.e. random - Time - Exceptions - Concurrency - Mutability --- class: middle ### What is a **function**? > A function is the relation between a set of inputs and a set of outputs, so that every set of inputs has exactly one output. data:image/s3,"s3://crabby-images/4df5a/4df5a3c2d471d7dd7e0641aeccdc12c4591cecce" alt="" --- class: middle Functions compose. data:image/s3,"s3://crabby-images/1244b/1244b9fa2c157e88935109565de61c77cfcb7abc" alt="" Functions can be values. data:image/s3,"s3://crabby-images/9f044/9f04434a7bc2495579ecf5d472747e632a26ba2c" alt="" --- class: middle ### Side **effects** and side **causes** data:image/s3,"s3://crabby-images/053a1/053a1220950b346f209fda26df8563cadfd643d9" alt="" -- data:image/s3,"s3://crabby-images/19467/19467a349a37cc745ff54738c238d1a30a41297f" alt="" --- class: middle Side effects depend on the whole world. data:image/s3,"s3://crabby-images/4e1d6/4e1d6c94f1cb455aa6b70e5e308801b9c1a4d006" alt="" --- class: middle A quick aside for **continuations** data:image/s3,"s3://crabby-images/895c0/895c0809576c72d357d2e7dfe7a0b04afc5c92f4" alt="" *The best resource explaining continuations is. [Delimited Continuations, Demystified by Alexis King](https://www.youtube.com/watch?v=TE48LsgVlIU)* --- class: middle Programs **perform** effects with the remaining program captured as a continuation. data:image/s3,"s3://crabby-images/dfad9/dfad966144e243ce4d03a282112ae0e92deeb31f" alt="" --- class: middle Runtimes **resume** programs by calling the stored continuation data:image/s3,"s3://crabby-images/265f1/265f1e13f0b028e46792b753463e8e525d5d382a" alt="" --- class: middle Effects can be inferred
--- class: middle --- class: middle ## **Closure serialization** > The process of converting a closure into a format that can be stored or transmitted. A closure is a function along with its captured environment. --- class: middle Serialized code can be handled, i.e. copy pasted.
--- class: middle Serialized code can be transpiled --- class: middle Is closure serialization possible in other languages? - short answer: yes - long answer: ermmmmmmmmmmmmmmmmmmmm... --- class: middle data:image/s3,"s3://crabby-images/38f61/38f610d48e3d4539f705c3b6b793344d12972d25" alt="" --- class: middle ### Why do closure serialization data:image/s3,"s3://crabby-images/95608/956083dd5e2445d4687bca18292a4ef4db4b28a9" alt="" ??? We already do but the packages are really inefficient Kill build scripts Sending types through time and space --- class: middle --- class: middle --- class: middle ### The **first** environment > A read-eval-print loop (REPL), also termed an interactive toplevel or language shell, is a simple interactive computer programming environment that takes single user inputs, executes them, and returns the result to the user --- class: middle ### Typing a **REPL** - Types are refined - The result of `eval` can be typed - Type checking is optional ??? {"0":"a","f":{"0":"b","l":"eval"},"a":{"0":"a","f":{"0":"a","f":{"0":"c"},"a":{"0":"a","f":{"0":"t","l":"Let"},"a":{"0":"s","v":"x"}}},"a":{"0":"a","f":{"0":"a","f":{"0":"c"},"a":{"0":"a","f":{"0":"t","l":"Integer"},"a":{"0":"i","v":100}}},"a":{"0":"a","f":{"0":"a","f":{"0":"c"},"a":{"0":"a","f":{"0":"t","l":"Variable"},"a":{"0":"s","v":"x"}}},"a":{"0":"ta"}}}}} --- class: middle
--- class: middle ## **Structural** or **Nominal** typing? Java ```java class Person { public name: string; } ``` TypeScript ```ts interface Person { name: string; } ``` --- class: middle ## **Structural** or **Nominal** typing? - Structural types are universal - Nominal types have a bounded validity, *usually a single compilation.* - Nominal typing requires type declarations --- class: middle ## Eat your **Greens** A simple type system leveraged everywhere is more interesting than a complex one limited to the application. - Development environments - Build servers - CI/CD - codegen - Backend/frontend - Service workers - Background queues - Infra provisioning - Database queries A single typed program should extend over the whole stack --- class: middle # One more thing Code **reloading** .. if we have time. --- class: middle # Questions? - [eyg.run](https://eyg.run) - Join the mailing list --- class: middle There is more coming ... data:image/s3,"s3://crabby-images/9cb25/9cb25eb8c08f4e51dfef475716bdcb20ab4a1440" alt=""