Navigation Menu

Skip to content

Instantly share code, notes, and snippets.

@mlhaufe
mlhaufe / arith-bool.js
Created January 8, 2019 06:20
Booleans with arithmetic
// x, y :: {0,1}
var and = (x,y) => x * y,
not = (x) => 1 - x,
or = (x,y) => 1 - (1 - x) * (1 - y)
and(0,0) // 0
and(0,1) // 0
and(1,0) // 0
and(1,1) // 1
@mlhaufe
mlhaufe / README.txt
Created December 10, 2018 05:39
A half assed, buggy implementation of a Tiny File System. Not useful for anything as is.
- The application is currently single threaded
- The following commands have been implemented:
- exit
- create <PATH>
- open <PATH>
- display
- ls
- cd <TFS> (partial)
- mkdir <TFS> (partial). currently buggy due to nibble manipulation
- import <PATH> <TFS> (partial) stub + error checking only
function main() {
console.log("question1(0) == 0");
console.assert(question1(0) == 0, `${question1(0)}`);
console.log("question1(1) == 1");
console.assert(question1(1) == 1, `${question1(1)}`);
console.log("question1(7) == 13");
console.assert(question1(7) == 13, `${question1(7)}`);
console.log("question1(12) == 144");
console.assert(question1(12) == 144, `${question1(12)}`);
@mlhaufe
mlhaufe / uMVC.ts
Last active October 5, 2019 18:18
TypeScript uMVC based on <https://github.com/petermichaux/uMVC>
abstract class Observer {
abstract update(data?: any): void
}
abstract class Observable {
protected _observers: Observer[] = []
observe(observer: Observer) {
if (this._observers.indexOf(observer) > -1)
throw new Error('Observer already added')
abstract class Command {
abstract execute(): void
}
abstract class UndoableCommand extends Command {
abstract undo(): void
}
class Direction {
static readonly UP = 0
@mlhaufe
mlhaufe / simulating-generics.ts
Last active July 8, 2019 01:37
Simulating Generics w/ Inheritance in TypeScript.
abstract class Comparable {
abstract le(other: this): boolean
min(other: this): Comparable {
return this.le(other) ? this : other
}
}
abstract class Ring {
constructor(
readonly zero: Ring,
interface Publisher<T> {
subscribe(s: Subscriber<T>): void
}
interface Subscriber<T> {
onNext(value: T): void
onError(e: Error): void
onDone(): void
onSubscribe(s: Subscription): void
}
@mlhaufe
mlhaufe / Either.ts
Last active January 16, 2017 19:10
Coproducts
// data Either a b = Left a | Right b
abstract class Either<A, B> {
constructor(public value: A | B) { }
}
// Inject Left
// inl a
class Left<A> extends Either<A, never>{
constructor(value: A) { super(value) }
}
// Inject Right
@mlhaufe
mlhaufe / index.html
Last active March 6, 2020 14:59
strict mode efficiency comparison w/ Newtons Method (http://jsbench.github.io/#7e323ab9310ec4fc933db0883c96ce0c) #jsbench #jsperf
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title>strict mode efficiency comparison w/ Newtons Method</title>
<script src="https://cdnjs.cloudflare.com/ajax/libs/benchmark/1.0.0/benchmark.min.js"></script>
<script src="./suite.js"></script>
</head>
<body>
<h1>Open the console to view the results</h1>