0.0.13 • Published 5 years ago
@browndragon/switch-type v0.0.13
@browndragon/switch-type
Install & use with $ npm i @browndragon/switch-type and then
import switchType from '@browndragon/switch-type';
switchType(
undefined,
{default(x, ...params) {console.log(`Default ${x} & params ${params}!`);}},
'someParam1', 'someParam2'
);
// Prints 'Default undefined & params someParam1,someParam2!'Why switchType?
I got very fed up with the mess that is javascript type introspection, so I wrote my own.
switchType(unknownObject, handler) will do type analysis on the unknown object and then invoke the correctly named method on handler with the object.
The methods it will call are (roughly in order, omit irrelevants):
undefined(will also trynull)null(will also tryundefined)boolean(avalue)bigint(avalue)number(avalue)string(avalueand aniterable)function(avalue)
Then we start considering (non-null) objects;
array(aniterable): Anything that isArray.isArray.map(anassociativeand aniterable) -- usesinstanceof Map(as do the other specialized types).set(aniterable)iterable: Anything with aSymbol.iteratoron it (including collections & arrays & strings).regExp: Aninstanceof RegExp.literal: an object whose prototype is literallyObject(as created byObject.createand the{}syntax). Alsoassociative.associative: An object which@browndragon/objcan get/set fields on. A Map or an object literal.
Finally, objects will try to call:
object: Any non-nulljstypeof(x)=='object'.
Finally-finally, anything will try to call:
default: Anything that wasn't otherwise matched.
switchType returns the result of the called method or else undefined.
What about other "root types"?
To make this work, I've invented several new root types which "feel like" javascript basic types. To me.
- The
valuesare mostly unobjectionable. - Everyone agrees the
undefined/null/class Objectsituation is messy; this is just a semi-opinionated, semi-flexible way to cut through that. I don't considerundefinedornullto bevaluesin this library. Objectis the root of the object hierarchy, but is also used directly as a container.- As a container type, it's called a
literal. - As the root of the object hierarchy, it's customized into a few builtin es6 types (Map, Set, Array, RegExp). You can add more with
withHandler(which returns a new instance with the additional handlers) oraddHandler(which modifies the handler in-place, possibly including the globally imported one!).
- As a container type, it's called a