Skip to content

Latest commit

 

History

History
115 lines (71 loc) · 4.03 KB

README.md

File metadata and controls

115 lines (71 loc) · 4.03 KB

Thrafe

Pronounced like the name Rafe, as in:

My uncle, Thrafe lives in the Cayman Islands.

This is a library that aims to make it simple and straightforward to make typesafe, multithreaded web applications (using Typescript and web workers) -- hence the annoying name, Thrafe: threading + typesafe.

Why?

When working on my CommunicativeCode webapp, I found it tricky to use both Typescript and web workers for reasons I outline further below.

Additionally, existing awesome worker libraries like Comlink and workway didn't make it easy to accomplish the twoway message passing I needed (i.e. in addition to the main thread talking to the web worker, I also wanted the worker code to be able to talk to the main thread at will*):

MainThread ⇄ Worker

_*= This is probably also possible through passing callbacks using a 'proxy' mechanism in one of these libraries, but that seemed like more indirection than I wanted

A little terminology

Usage

Using thrafe requires you to do 4 things (3 development steps, and 1 build step):

  1. Define your Threading Architecture using types
  2. Instantiate a Context in your threaded code
  3. Instantiate a Thread in your client / main thread code
  4. Add the thrafe generation step in your application's build steps

Check out the specifics of each step below.

Architecture Definition

This can go in its own .ts file, or at the top of the worker file, or wherever you want really! It's just a type definition, so will be transpiled away.

An architecture consists of 6 things:

1. Thread Name:

A string literal type definition that defines what this thread should be referred to as, and utlimately the name of the file that is created by the thrafe generator.

For example:

type MyVerySpecialThreadName = "myWorkerThread";

2. To Worker Thread Events Enum:

const enum defining the events where the MAIN THREAD calls into a worker thread

For example:

const enum ToMyVerySpecialThreadEvents {
  DoSomeWork,
  FactorTheseNumbers
}

3. To Worker Thread Message Structure Definition:

blah blah blah

4. To Main Thread Events Enum:

const enum defining the events where the WORKER THREAD calls into the main thread

5. To Main Thread Message Structure Definition:

blah blah blah

5. Thread Architecture Defintion

Worker File

Main Thread

Worker code

Component code

Svelte

React

...TBD...

Vue

...TBD...

How it works

...TBD...

State of things

Why? (cont.)

Where / how should types fit it in?

Bungling Bundling

On one side, it's completely unobvious how best to compile & bundle a web worker written in typescript down to a single javascript file so that it can then be executed as a worker in the browser, e.g.:

const worker = new Worker('https://www.my-example-website.com/static/worker.js');

Bundlers are supporting this in different ways, which I think is already confusing.

Vite's solution seems pretty neat, webpack seems to be working on it (not immediately clear to me how this works with typescript), but regardless I don't like how any of the solutions I've seen.

Two-way communication

Anatomy of a Thrafe Implementation