Skip to content

Latest commit

 

History

History
72 lines (59 loc) · 2.3 KB

README.md

File metadata and controls

72 lines (59 loc) · 2.3 KB

Tiny Programs: Rosetta code for implementations

Learning a new language can be hard. Developers go to "Hello World" but this is so trivial a program so as to be almost useless.

This project is a collection of tiny programs that may help you learn a language. It is similar to Rosetta Code except that all programs here will be implementations and not library calls.

Implementations are opinionated and simple, but not necessarily idiomatic. Tests are in place for all implementations but they are not necessarily 100% bug-free or (in the case of SHA-256) secure. Basically, don't use any code here for anything other than to as a learning resource.

Programs

  • Brainfuck: A complete Brainfuck implementation
  • UUIDv4: A UUIDv4 generator
  • AATree: A generic, balanced binary tree
  • SHA256: An implementation of SHA-256
  • Potential:
    • HTTP: An HTTP client from UNIX sockets
    • Ring: Ring buffer/double linked list
    • Log: Bitcask-style on-disk key-value store via an append-only log
    • Snake: The arcade game

Contributing an implementation

A few rules:

  1. Keep it simple and readable.
  2. This isn't code golfing.
  3. Do not copy any external code. Write the program from scratch. See rule 1.
  4. Use existing implementations in this project as guidelines. Use the same or similar algorithms and data structures. See rule 1.
  5. Avoid programming patterns and object-oriented design and functional programming for the sake of patterns and OOP and FP. See rule 1.
  6. Avoid unnecessarily complex syntax, even if the complex syntax is more idiomatic in the language. See rule 1.
  7. Copy program.yaml and implement the source, authors, prepare and run settings so that your implementation is automatically tested in Github Actions and set up correctly for the website.
  8. Definitely no 3rd-party libraries. And definitely not builtin libraries if they implement the entirety of the program.

Ultimately, Phil is the BDFL and reserves the right to be picky. :)

Call for languages

  • Ada
  • FreePascal
  • FreeBASIC
  • R
  • Octave
  • Common Lisp
  • Swift
  • Kotlin
  • Scala
  • Clojure
  • Lua
  • C++
  • D
  • Standard ML
  • OCaml

Discussion

Questions? Ideas? Suggestions? Bring it up in the #hacking channel on discord.multiprocess.io.