I swapped in the new macro in source files numbers/predicate.ts,
Complex/arithmetic.ts, and Complex/predicate.ts. Note that you have
to specify whether you are reflecting the generic or concrete
implementations, which in some cases will mean two separate macro calls
(as in Complex/predicate.ts).
Also tried out the $$typeMetadata macro in Complex/all.ts; you can see the
result by building and looking at build/Complex/all.js. It splits things
up somewhat but we would still need to do a bunch of parsing, so probably
not worth switching.
Also starts work on typing that closure. Gets the property names right,
but currently has the "unfilled" method types, rather than the returned
"filled-in" function types. Not sure how to fix this.
Now each behavior specification "knows" its type information.
Also bumps version number and sets up so that the scripts will run on Windows as well as Unix (thanks to Jos).
Resolves#5.
Resolves#16.
Co-authored-by: Jos de Jong <wjosdejong@gmail.com>
Reviewed-on: #17
Co-authored-by: Glen Whitney <glen@studioinfinity.org>
Co-committed-by: Glen Whitney <glen@studioinfinity.org>
Rather than via some format on the name of the identifier, this commit
changes the construction of Dispatcher to assume that functions are
implementations and other objects are type specifiers.
Also installs all types first, before any implementations.
Resolves#3.
Resolves#12.
Reviewed-on: #15
Co-authored-by: Glen Whitney <glen@studioinfinity.org>
Co-committed-by: Glen Whitney <glen@studioinfinity.org>
This commit adds pnpm scripts for compiling and running the
typocomath package, and a convenience script `pnpm go` that does
both in succession. It also configure pnpm to use a shell
emulator so that it should work on Windows as well. Finally,
it changes the directory for object files from obj to build.
Resolves#9.
Reviewed-on: #13
Co-authored-by: Glen Whitney <glen@studioinfinity.org>
Co-committed-by: Glen Whitney <glen@studioinfinity.org>
Adds a new subdirectory `interfaces` where standard interfaces
are defined. Additional interfaces for a given operation can
be added with an `AliasOf` type operator. Provides type
operators that give the return type, full function type, and
the type of a dependency on, a given operator.
Resolves#6.
Co-authored-by: Glen Whitney <glen@studioinfinity.org>
Co-authored-by: Jos de Jong <wjosdejong@gmail.com>
Reviewed-on: #8
This PR is an effort to address #1. It removes all boilerplate
from individual implementation files, and moves it into
a small, fixed section in the single `all.ts` module for each
type that collects up all of the implementations relating
to that type.
Co-authored-by: Glen Whitney <glen@studioinfinity.org>
Reviewed-on: #2
A first pass at specifying some implementations in TypeScript
that actually compiles. It doesn't do anything, as installing
types and operation specifications are currently dummy operations,
but they are all invoked.