New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

nova_ecs

Package Overview
Dependencies
Maintainers
1
Versions
8
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

nova_ecs - npm Package Compare versions

Comparing version 0.1.9 to 0.1.10

8

arg_types.d.ts

@@ -7,2 +7,3 @@ /// <amd-module name="nova_ecs/arg_types" />

import { EntityMap } from "./entity_map";
import { EcsEvent, EventData } from "./events";
import { Modifier, ModifierResult } from "./modifier";

@@ -22,5 +23,8 @@ import { Query } from "./query";

export declare type GetArgSelector<T> = T extends typeof GetArg ? GetArgFunction : never;
export declare type ArgTypes = Component<any, any, any, any> | Query | Resource<any, any, any, any> | typeof Entities | typeof Components | typeof UUID | typeof GetEntity | typeof GetArg | Modifier<readonly ArgTypes[], any>;
export declare const Emit: unique symbol;
export declare type EmitFunction = <Data>(event: EcsEvent<Data, any>, data: Data, entities?: Set<string>) => void;
export declare type EmitSelector<T> = T extends typeof Emit ? EmitFunction : never;
export declare type ArgTypes = Component<any, any, any, any> | Query | Resource<any, any, any, any> | EcsEvent<any, any> | typeof Entities | typeof Components | typeof UUID | typeof GetEntity | typeof GetArg | typeof Emit | Modifier<readonly ArgTypes[], any>;
declare type AllowUndefined<T> = T extends undefined ? T : never;
export declare type ArgData<T> = Draft<ComponentData<T> | ResourceData<T>> | EntitiesObject<T> | ComponentsObject<T> | UUIDData<T> | GetEntityObject<T> | GetArgSelector<T> | ModifierResult<T> | AllowUndefined<T> | QueryResults<T>;
export declare type ArgData<T> = Draft<ComponentData<T> | ResourceData<T>> | QueryResults<T> | EventData<T> | EntitiesObject<T> | ComponentsObject<T> | UUIDData<T> | GetEntityObject<T> | GetArgSelector<T> | EmitSelector<T> | ModifierResult<T> | AllowUndefined<T>;
export declare type ArgsToData<Args> = {

@@ -27,0 +31,0 @@ [K in keyof Args]: ArgData<Args[K]>;

@@ -12,9 +12,10 @@ (function (factory) {

Object.defineProperty(exports, "__esModule", { value: true });
exports.GetArg = exports.GetEntity = exports.UUID = exports.Components = exports.Entities = void 0;
exports.Entities = Symbol();
exports.Components = Symbol();
exports.UUID = Symbol();
exports.GetEntity = Symbol();
exports.GetArg = Symbol();
exports.Emit = exports.GetArg = exports.GetEntity = exports.UUID = exports.Components = exports.Entities = void 0;
exports.Entities = Symbol('Entities');
exports.Components = Symbol('Components');
exports.UUID = Symbol('UUID');
exports.GetEntity = Symbol('Get Entity');
exports.GetArg = Symbol('Get Arg');
exports.Emit = Symbol('Emit');
});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJnX3R5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbm92YV9lY3MvYXJnX3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQVNhLFFBQUEsUUFBUSxHQUFHLE1BQU0sRUFBRSxDQUFDO0lBR3BCLFFBQUEsVUFBVSxHQUFHLE1BQU0sRUFBRSxDQUFDO0lBSXRCLFFBQUEsSUFBSSxHQUFHLE1BQU0sRUFBRSxDQUFDO0lBR2hCLFFBQUEsU0FBUyxHQUFHLE1BQU0sRUFBRSxDQUFDO0lBR3JCLFFBQUEsTUFBTSxHQUFHLE1BQU0sRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWl0aGVyIH0gZnJvbSBcImZwLXRzL2xpYi9FaXRoZXJcIjtcbmltcG9ydCB7IERyYWZ0IH0gZnJvbSBcImltbWVyXCI7XG5pbXBvcnQgeyBDb21wb25lbnQsIENvbXBvbmVudERhdGEsIFVua25vd25Db21wb25lbnQgfSBmcm9tIFwiLi9jb21wb25lbnRcIjtcbmltcG9ydCB7IEVudGl0eSB9IGZyb20gXCIuL2VudGl0eVwiO1xuaW1wb3J0IHsgRW50aXR5TWFwIH0gZnJvbSBcIi4vZW50aXR5X21hcFwiO1xuaW1wb3J0IHsgTW9kaWZpZXIsIE1vZGlmaWVyUmVzdWx0IH0gZnJvbSBcIi4vbW9kaWZpZXJcIjtcbmltcG9ydCB7IFF1ZXJ5IH0gZnJvbSBcIi4vcXVlcnlcIjtcbmltcG9ydCB7IFJlc291cmNlLCBSZXNvdXJjZURhdGEgfSBmcm9tIFwiLi9yZXNvdXJjZVwiO1xuXG5leHBvcnQgY29uc3QgRW50aXRpZXMgPSBTeW1ib2woKTtcbmV4cG9ydCB0eXBlIEVudGl0aWVzT2JqZWN0PFQ+ID0gVCBleHRlbmRzIHR5cGVvZiBFbnRpdGllcyA/IEVudGl0eU1hcCA6IG5ldmVyO1xuXG5leHBvcnQgY29uc3QgQ29tcG9uZW50cyA9IFN5bWJvbCgpO1xuZXhwb3J0IHR5cGUgQ29tcG9uZW50c09iamVjdDxUPiA9IFQgZXh0ZW5kcyB0eXBlb2YgQ29tcG9uZW50c1xuICAgID8gUmVhZG9ubHlNYXA8c3RyaW5nLCBVbmtub3duQ29tcG9uZW50PiA6IG5ldmVyO1xuXG5leHBvcnQgY29uc3QgVVVJRCA9IFN5bWJvbCgpO1xuZXhwb3J0IHR5cGUgVVVJRERhdGE8VD4gPSBUIGV4dGVuZHMgdHlwZW9mIFVVSUQgPyBzdHJpbmcgOiBuZXZlcjtcblxuZXhwb3J0IGNvbnN0IEdldEVudGl0eSA9IFN5bWJvbCgpO1xuZXhwb3J0IHR5cGUgR2V0RW50aXR5T2JqZWN0PFQ+ID0gVCBleHRlbmRzIHR5cGVvZiBHZXRFbnRpdHkgPyBFbnRpdHkgOiBuZXZlcjtcblxuZXhwb3J0IGNvbnN0IEdldEFyZyA9IFN5bWJvbCgpO1xuZXhwb3J0IHR5cGUgR2V0QXJnRnVuY3Rpb248VCBleHRlbmRzIEFyZ1R5cGVzID0gQXJnVHlwZXM+ID0gKGFyZzogVClcbiAgICA9PiBFaXRoZXI8dW5kZWZpbmVkLCBBcmdEYXRhPFQ+PjtcbmV4cG9ydCB0eXBlIEdldEFyZ1NlbGVjdG9yPFQ+ID0gVCBleHRlbmRzIHR5cGVvZiBHZXRBcmcgPyBHZXRBcmdGdW5jdGlvbiA6IG5ldmVyO1xuXG4vLyBUeXBlcyBmb3IgYXJncyB0aGF0IGFyZSB1c2VkIHRvIGRlZmluZSBhIHN5c3RlbSBvciBxdWVyeS4gUGFzc2VkIGluIGEgdHVwbGUuXG5leHBvcnQgdHlwZSBBcmdUeXBlcyA9IENvbXBvbmVudDxhbnksIGFueSwgYW55LCBhbnk+XG4gICAgfCBRdWVyeVxuICAgIHwgUmVzb3VyY2U8YW55LCBhbnksIGFueSwgYW55PlxuICAgIHwgdHlwZW9mIEVudGl0aWVzXG4gICAgfCB0eXBlb2YgQ29tcG9uZW50c1xuICAgIHwgdHlwZW9mIFVVSURcbiAgICB8IHR5cGVvZiBHZXRFbnRpdHlcbiAgICB8IHR5cGVvZiBHZXRBcmdcbiAgICB8IE1vZGlmaWVyPHJlYWRvbmx5IEFyZ1R5cGVzW10sIGFueT47XG5cbnR5cGUgQWxsb3dVbmRlZmluZWQ8VD4gPSBUIGV4dGVuZHMgdW5kZWZpbmVkID8gVCA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBBcmdEYXRhPFQ+ID1cbiAgICBEcmFmdDxDb21wb25lbnREYXRhPFQ+IHwgUmVzb3VyY2VEYXRhPFQ+PlxuICAgIHwgRW50aXRpZXNPYmplY3Q8VD5cbiAgICB8IENvbXBvbmVudHNPYmplY3Q8VD5cbiAgICB8IFVVSUREYXRhPFQ+XG4gICAgfCBHZXRFbnRpdHlPYmplY3Q8VD5cbiAgICB8IEdldEFyZ1NlbGVjdG9yPFQ+XG4gICAgfCBNb2RpZmllclJlc3VsdDxUPlxuICAgIHwgQWxsb3dVbmRlZmluZWQ8VD5cbiAgICB8IFF1ZXJ5UmVzdWx0czxUPjtcblxuZXhwb3J0IHR5cGUgQXJnc1RvRGF0YTxBcmdzPiA9IHtcbiAgICBbSyBpbiBrZXlvZiBBcmdzXTogQXJnRGF0YTxBcmdzW0tdPlxufVxuXG5leHBvcnQgdHlwZSBRdWVyeVJlc3VsdHM8UT4gPVxuICAgIFEgZXh0ZW5kcyBRdWVyeTxpbmZlciBRdWVyeUFyZ3M+ID8gQXJnc1RvRGF0YTxRdWVyeUFyZ3M+W10gOiBuZXZlcjtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJnX3R5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbm92YV9lY3MvYXJnX3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQVVhLFFBQUEsUUFBUSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUc5QixRQUFBLFVBQVUsR0FBRyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7SUFJbEMsUUFBQSxJQUFJLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBR3RCLFFBQUEsU0FBUyxHQUFHLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUdqQyxRQUFBLE1BQU0sR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7SUFLM0IsUUFBQSxJQUFJLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWl0aGVyIH0gZnJvbSBcImZwLXRzL2xpYi9FaXRoZXJcIjtcbmltcG9ydCB7IERyYWZ0IH0gZnJvbSBcImltbWVyXCI7XG5pbXBvcnQgeyBDb21wb25lbnQsIENvbXBvbmVudERhdGEsIFVua25vd25Db21wb25lbnQgfSBmcm9tIFwiLi9jb21wb25lbnRcIjtcbmltcG9ydCB7IEVudGl0eSB9IGZyb20gXCIuL2VudGl0eVwiO1xuaW1wb3J0IHsgRW50aXR5TWFwIH0gZnJvbSBcIi4vZW50aXR5X21hcFwiO1xuaW1wb3J0IHsgRWNzRXZlbnQsIEV2ZW50RGF0YSB9IGZyb20gXCIuL2V2ZW50c1wiO1xuaW1wb3J0IHsgTW9kaWZpZXIsIE1vZGlmaWVyUmVzdWx0IH0gZnJvbSBcIi4vbW9kaWZpZXJcIjtcbmltcG9ydCB7IFF1ZXJ5IH0gZnJvbSBcIi4vcXVlcnlcIjtcbmltcG9ydCB7IFJlc291cmNlLCBSZXNvdXJjZURhdGEgfSBmcm9tIFwiLi9yZXNvdXJjZVwiO1xuXG5leHBvcnQgY29uc3QgRW50aXRpZXMgPSBTeW1ib2woJ0VudGl0aWVzJyk7XG5leHBvcnQgdHlwZSBFbnRpdGllc09iamVjdDxUPiA9IFQgZXh0ZW5kcyB0eXBlb2YgRW50aXRpZXMgPyBFbnRpdHlNYXAgOiBuZXZlcjtcblxuZXhwb3J0IGNvbnN0IENvbXBvbmVudHMgPSBTeW1ib2woJ0NvbXBvbmVudHMnKTtcbmV4cG9ydCB0eXBlIENvbXBvbmVudHNPYmplY3Q8VD4gPSBUIGV4dGVuZHMgdHlwZW9mIENvbXBvbmVudHNcbiAgICA/IFJlYWRvbmx5TWFwPHN0cmluZywgVW5rbm93bkNvbXBvbmVudD4gOiBuZXZlcjtcblxuZXhwb3J0IGNvbnN0IFVVSUQgPSBTeW1ib2woJ1VVSUQnKTtcbmV4cG9ydCB0eXBlIFVVSUREYXRhPFQ+ID0gVCBleHRlbmRzIHR5cGVvZiBVVUlEID8gc3RyaW5nIDogbmV2ZXI7XG5cbmV4cG9ydCBjb25zdCBHZXRFbnRpdHkgPSBTeW1ib2woJ0dldCBFbnRpdHknKTtcbmV4cG9ydCB0eXBlIEdldEVudGl0eU9iamVjdDxUPiA9IFQgZXh0ZW5kcyB0eXBlb2YgR2V0RW50aXR5ID8gRW50aXR5IDogbmV2ZXI7XG5cbmV4cG9ydCBjb25zdCBHZXRBcmcgPSBTeW1ib2woJ0dldCBBcmcnKTtcbmV4cG9ydCB0eXBlIEdldEFyZ0Z1bmN0aW9uPFQgZXh0ZW5kcyBBcmdUeXBlcyA9IEFyZ1R5cGVzPiA9IChhcmc6IFQpXG4gICAgPT4gRWl0aGVyPHVuZGVmaW5lZCwgQXJnRGF0YTxUPj47XG5leHBvcnQgdHlwZSBHZXRBcmdTZWxlY3RvcjxUPiA9IFQgZXh0ZW5kcyB0eXBlb2YgR2V0QXJnID8gR2V0QXJnRnVuY3Rpb24gOiBuZXZlcjtcblxuZXhwb3J0IGNvbnN0IEVtaXQgPSBTeW1ib2woJ0VtaXQnKTtcbmV4cG9ydCB0eXBlIEVtaXRGdW5jdGlvbiA9IDxEYXRhPihldmVudDogRWNzRXZlbnQ8RGF0YSwgYW55PiwgZGF0YTogRGF0YSxcbiAgICBlbnRpdGllcz86IFNldDxzdHJpbmc+KSA9PiB2b2lkO1xuZXhwb3J0IHR5cGUgRW1pdFNlbGVjdG9yPFQ+ID0gVCBleHRlbmRzIHR5cGVvZiBFbWl0ID8gRW1pdEZ1bmN0aW9uIDogbmV2ZXI7XG5cbi8vIFR5cGVzIGZvciBhcmdzIHRoYXQgYXJlIHVzZWQgdG8gZGVmaW5lIGEgc3lzdGVtIG9yIHF1ZXJ5LiBQYXNzZWQgaW4gYSB0dXBsZS5cbmV4cG9ydCB0eXBlIEFyZ1R5cGVzID0gQ29tcG9uZW50PGFueSwgYW55LCBhbnksIGFueT5cbiAgICB8IFF1ZXJ5XG4gICAgfCBSZXNvdXJjZTxhbnksIGFueSwgYW55LCBhbnk+XG4gICAgfCBFY3NFdmVudDxhbnksIGFueT5cbiAgICB8IHR5cGVvZiBFbnRpdGllc1xuICAgIHwgdHlwZW9mIENvbXBvbmVudHNcbiAgICB8IHR5cGVvZiBVVUlEXG4gICAgfCB0eXBlb2YgR2V0RW50aXR5XG4gICAgfCB0eXBlb2YgR2V0QXJnXG4gICAgfCB0eXBlb2YgRW1pdFxuICAgIHwgTW9kaWZpZXI8cmVhZG9ubHkgQXJnVHlwZXNbXSwgYW55PjtcblxudHlwZSBBbGxvd1VuZGVmaW5lZDxUPiA9IFQgZXh0ZW5kcyB1bmRlZmluZWQgPyBUIDogbmV2ZXI7XG5cbmV4cG9ydCB0eXBlIEFyZ0RhdGE8VD4gPVxuICAgIERyYWZ0PENvbXBvbmVudERhdGE8VD4gfCBSZXNvdXJjZURhdGE8VD4+XG4gICAgfCBRdWVyeVJlc3VsdHM8VD5cbiAgICB8IEV2ZW50RGF0YTxUPlxuICAgIHwgRW50aXRpZXNPYmplY3Q8VD5cbiAgICB8IENvbXBvbmVudHNPYmplY3Q8VD5cbiAgICB8IFVVSUREYXRhPFQ+XG4gICAgfCBHZXRFbnRpdHlPYmplY3Q8VD5cbiAgICB8IEdldEFyZ1NlbGVjdG9yPFQ+XG4gICAgfCBFbWl0U2VsZWN0b3I8VD5cbiAgICB8IE1vZGlmaWVyUmVzdWx0PFQ+XG4gICAgfCBBbGxvd1VuZGVmaW5lZDxUPjtcblxuXG5leHBvcnQgdHlwZSBBcmdzVG9EYXRhPEFyZ3M+ID0ge1xuICAgIFtLIGluIGtleW9mIEFyZ3NdOiBBcmdEYXRhPEFyZ3NbS10+XG59XG5cbmV4cG9ydCB0eXBlIFF1ZXJ5UmVzdWx0czxRPiA9XG4gICAgUSBleHRlbmRzIFF1ZXJ5PGluZmVyIFF1ZXJ5QXJncz4gPyBBcmdzVG9EYXRhPFF1ZXJ5QXJncz5bXSA6IG5ldmVyO1xuIl19
/// <amd-module name="nova_ecs/events" />
export declare const StepEvent: unique symbol;
export declare const DeleteEvent: unique symbol;
import * as t from 'io-ts';
export declare class EcsEvent<Data, DataSerialized = Data> {
private readonly eventSymbol;
readonly name?: string;
readonly type?: t.Type<Data, DataSerialized>;
constructor(args?: {
name?: string;
type?: t.Type<Data, DataSerialized>;
});
}
export declare const StepEvent: EcsEvent<undefined, undefined>;
export declare const DeleteEvent: EcsEvent<undefined, undefined>;
export declare type EventData<E> = E extends EcsEvent<infer Data, any> ? Data : never;
export declare type UnknownEvent = EcsEvent<unknown, unknown>;

@@ -12,6 +12,17 @@ (function (factory) {

Object.defineProperty(exports, "__esModule", { value: true });
exports.DeleteEvent = exports.StepEvent = void 0;
exports.StepEvent = Symbol('step');
exports.DeleteEvent = Symbol('delete');
exports.DeleteEvent = exports.StepEvent = exports.EcsEvent = void 0;
const eventSymbol = Symbol('Event');
class EcsEvent {
constructor(args) {
// Necessary so Query does not extend EcsEvent, which ruins the arg
// type system.
this.eventSymbol = eventSymbol;
this.name = args?.name;
this.type = args?.type;
}
}
exports.EcsEvent = EcsEvent;
exports.StepEvent = new EcsEvent({ name: 'step' });
exports.DeleteEvent = new EcsEvent({ name: 'delete' });
});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbm92YV9lY3MvZXZlbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQUFhLFFBQUEsU0FBUyxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUMzQixRQUFBLFdBQVcsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgU3RlcEV2ZW50ID0gU3ltYm9sKCdzdGVwJyk7XG5leHBvcnQgY29uc3QgRGVsZXRlRXZlbnQgPSBTeW1ib2woJ2RlbGV0ZScpO1xuXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbm92YV9lY3MvZXZlbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQUdBLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNwQyxNQUFhLFFBQVE7UUFPakIsWUFBWSxJQUE2RDtZQU56RSxtRUFBbUU7WUFDbkUsZUFBZTtZQUNFLGdCQUFXLEdBQUcsV0FBVyxDQUFDO1lBS3ZDLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxFQUFFLElBQUksQ0FBQztZQUN2QixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksRUFBRSxJQUFJLENBQUM7UUFDM0IsQ0FBQztLQUNKO0lBWEQsNEJBV0M7SUFFWSxRQUFBLFNBQVMsR0FBRyxJQUFJLFFBQVEsQ0FBWSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDO0lBQ3RELFFBQUEsV0FBVyxHQUFHLElBQUksUUFBUSxDQUFZLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyB0IGZyb20gJ2lvLXRzJztcblxuXG5jb25zdCBldmVudFN5bWJvbCA9IFN5bWJvbCgnRXZlbnQnKTtcbmV4cG9ydCBjbGFzcyBFY3NFdmVudDxEYXRhLCBEYXRhU2VyaWFsaXplZCA9IERhdGE+IHtcbiAgICAvLyBOZWNlc3Nhcnkgc28gUXVlcnkgZG9lcyBub3QgZXh0ZW5kIEVjc0V2ZW50LCB3aGljaCBydWlucyB0aGUgYXJnXG4gICAgLy8gdHlwZSBzeXN0ZW0uXG4gICAgcHJpdmF0ZSByZWFkb25seSBldmVudFN5bWJvbCA9IGV2ZW50U3ltYm9sO1xuICAgIHJlYWRvbmx5IG5hbWU/OiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgdHlwZT86IHQuVHlwZTxEYXRhLCBEYXRhU2VyaWFsaXplZD47XG5cbiAgICBjb25zdHJ1Y3RvcihhcmdzPzogeyBuYW1lPzogc3RyaW5nLCB0eXBlPzogdC5UeXBlPERhdGEsIERhdGFTZXJpYWxpemVkPiB9KSB7XG4gICAgICAgIHRoaXMubmFtZSA9IGFyZ3M/Lm5hbWU7XG4gICAgICAgIHRoaXMudHlwZSA9IGFyZ3M/LnR5cGU7XG4gICAgfVxufVxuXG5leHBvcnQgY29uc3QgU3RlcEV2ZW50ID0gbmV3IEVjc0V2ZW50PHVuZGVmaW5lZD4oeyBuYW1lOiAnc3RlcCcgfSk7XG5leHBvcnQgY29uc3QgRGVsZXRlRXZlbnQgPSBuZXcgRWNzRXZlbnQ8dW5kZWZpbmVkPih7IG5hbWU6ICdkZWxldGUnIH0pO1xuXG5leHBvcnQgdHlwZSBFdmVudERhdGE8RT4gPSBFIGV4dGVuZHMgRWNzRXZlbnQ8aW5mZXIgRGF0YSwgYW55PiA/IERhdGEgOiBuZXZlcjtcblxuZXhwb3J0IHR5cGUgVW5rbm93bkV2ZW50ID0gRWNzRXZlbnQ8dW5rbm93biwgdW5rbm93bj47XG5cbiJdfQ==
{
"name": "nova_ecs",
"version": "0.1.9",
"version": "0.1.10",
"description": "The Entity Component System for NovaJS",

@@ -5,0 +5,0 @@ "repository": "https://github.com/mattsoulanille/NovaJS",

@@ -13,2 +13,3 @@ /// <amd-module name="nova_ecs/query" />

readonly name?: string | undefined;
private readonly querySymbol;
readonly components: ReadonlySet<UnknownComponent>;

@@ -15,0 +16,0 @@ readonly resources: ReadonlySet<UnknownResource>;

@@ -17,6 +17,3 @@ (function (factory) {

const utils_1 = require("nova_ecs/utils");
// type ComponentsOnly<T extends readonly [...unknown[]]> =
// Exclude<Extract<T[number], Component<any, any, any, any>>, Resource<any, any, any, any>>;
// type ResourcesOnly<T extends readonly [...unknown[]]> =
// Extract<T[number], Resource<any, any, any, any>>;
const querySymbol = Symbol('Query');
/**

@@ -30,2 +27,4 @@ * A query provides a way of iterating over all the Entities that have

this.name = name;
// Prevent query from being a subtype of EcsEvent
this.querySymbol = querySymbol;
const modifiers = args.filter(arg => arg instanceof modifier_1.Modifier);

@@ -51,2 +50,2 @@ const modifierComponents = modifiers

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9ub3ZhX2Vjcy9xdWVyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7SUFDQSxrREFBMEQ7SUFDMUQsZ0RBQXVEO0lBQ3ZELGdEQUF1RDtJQUN2RCwwQ0FBaUQ7SUFFakQsMkRBQTJEO0lBQzNELGdHQUFnRztJQUVoRywwREFBMEQ7SUFDMUQsd0RBQXdEO0lBR3hEOzs7T0FHRztJQUNILE1BQWEsS0FBSztRQUtkLFlBQXFCLElBQWUsRUFBVyxJQUFhO1lBQXZDLFNBQUksR0FBSixJQUFJLENBQVc7WUFBVyxTQUFJLEdBQUosSUFBSSxDQUFTO1lBQ3hELE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFlBQVksbUJBQVEsQ0FBc0IsQ0FBQztZQUNuRixNQUFNLGtCQUFrQixHQUFHLFNBQVM7aUJBQy9CLEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDO2lCQUMxQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLEdBQUcsRUFBRSxDQUFDLENBQUM7WUFFeEQsTUFBTSxpQkFBaUIsR0FBRyxTQUFTO2lCQUM5QixHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQztpQkFDekMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBR3hELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxHQUFHLENBQUMsQ0FBQyxHQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUMzQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxZQUFZLHFCQUFTLENBQUM7dUJBQ3RCLENBQUMsQ0FBQyxDQUFDLFlBQVksbUJBQVEsQ0FBQyxDQUF3QixFQUMzRCxHQUFHLGtCQUFrQixDQUFDLENBQUMsQ0FBQztZQUV4QixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksR0FBRyxDQUFDLENBQUMsR0FBSSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FDMUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsWUFBWSxtQkFBUSxDQUFDLENBQXVCLEVBQ3ZELEdBQUcsaUJBQWlCLENBQUMsQ0FBQyxDQUFDO1FBQzNCLENBQUM7UUFFRCxjQUFjLENBQUMsTUFBc0I7WUFDakMsT0FBTyxjQUFNLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxJQUFJLEdBQUcsQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztRQUN0RSxDQUFDO1FBRUQsUUFBUTtZQUNKLE9BQU8sU0FBUyxJQUFJLENBQUMsSUFBSSxJQUFJLFNBQVMsR0FBRyxDQUFDO1FBQzlDLENBQUM7S0FDSjtJQWpDRCxzQkFpQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcmdUeXBlcyB9IGZyb20gXCIuL2FyZ190eXBlc1wiO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBVbmtub3duQ29tcG9uZW50IH0gZnJvbSBcIi4vY29tcG9uZW50XCI7XG5pbXBvcnQgeyBNb2RpZmllciwgVW5rbm93bk1vZGlmaWVyIH0gZnJvbSBcIi4vbW9kaWZpZXJcIjtcbmltcG9ydCB7IFJlc291cmNlLCBVbmtub3duUmVzb3VyY2UgfSBmcm9tIFwiLi9yZXNvdXJjZVwiO1xuaW1wb3J0IHsgc3Vic2V0LCBXaXRoQ29tcG9uZW50cyB9IGZyb20gXCIuL3V0aWxzXCI7XG5cbi8vIHR5cGUgQ29tcG9uZW50c09ubHk8VCBleHRlbmRzIHJlYWRvbmx5IFsuLi51bmtub3duW11dPiA9XG4vLyAgICAgRXhjbHVkZTxFeHRyYWN0PFRbbnVtYmVyXSwgQ29tcG9uZW50PGFueSwgYW55LCBhbnksIGFueT4+LCBSZXNvdXJjZTxhbnksIGFueSwgYW55LCBhbnk+PjtcblxuLy8gdHlwZSBSZXNvdXJjZXNPbmx5PFQgZXh0ZW5kcyByZWFkb25seSBbLi4udW5rbm93bltdXT4gPVxuLy8gICAgIEV4dHJhY3Q8VFtudW1iZXJdLCBSZXNvdXJjZTxhbnksIGFueSwgYW55LCBhbnk+PjtcblxuXG4vKipcbiAqIEEgcXVlcnkgcHJvdmlkZXMgYSB3YXkgb2YgaXRlcmF0aW5nIG92ZXIgYWxsIHRoZSBFbnRpdGllcyB0aGF0IGhhdmVcbiAqIGEgc3BlY2lmaWVkIHNldCBvZiBjb21wb25lbnRzLlxuICovXG5leHBvcnQgY2xhc3MgUXVlcnk8UXVlcnlBcmdzIGV4dGVuZHMgcmVhZG9ubHkgQXJnVHlwZXNbXVxuICAgID0gcmVhZG9ubHkgQXJnVHlwZXNbXT4ge1xuICAgIHJlYWRvbmx5IGNvbXBvbmVudHM6IFJlYWRvbmx5U2V0PFVua25vd25Db21wb25lbnQ+O1xuICAgIHJlYWRvbmx5IHJlc291cmNlczogUmVhZG9ubHlTZXQ8VW5rbm93blJlc291cmNlPjtcblxuICAgIGNvbnN0cnVjdG9yKHJlYWRvbmx5IGFyZ3M6IFF1ZXJ5QXJncywgcmVhZG9ubHkgbmFtZT86IHN0cmluZykge1xuICAgICAgICBjb25zdCBtb2RpZmllcnMgPSBhcmdzLmZpbHRlcihhcmcgPT4gYXJnIGluc3RhbmNlb2YgTW9kaWZpZXIpIGFzIFVua25vd25Nb2RpZmllcltdO1xuICAgICAgICBjb25zdCBtb2RpZmllckNvbXBvbmVudHMgPSBtb2RpZmllcnNcbiAgICAgICAgICAgIC5tYXAobW9kaWZpZXIgPT4gbW9kaWZpZXIucXVlcnkuY29tcG9uZW50cylcbiAgICAgICAgICAgIC5yZWR1Y2UoKGEsIGIpID0+IG5ldyBTZXQoWy4uLmEsIC4uLmJdKSwgbmV3IFNldCgpKTtcblxuICAgICAgICBjb25zdCBtb2RpZmllclJlc291cmNlcyA9IG1vZGlmaWVyc1xuICAgICAgICAgICAgLm1hcChtb2RpZmllciA9PiBtb2RpZmllci5xdWVyeS5yZXNvdXJjZXMpXG4gICAgICAgICAgICAucmVkdWNlKChhLCBiKSA9PiBuZXcgU2V0KFsuLi5hLCAuLi5iXSksIG5ldyBTZXQoKSk7XG5cblxuICAgICAgICB0aGlzLmNvbXBvbmVudHMgPSBuZXcgU2V0KFsuLi4odGhpcy5hcmdzLmZpbHRlcihcbiAgICAgICAgICAgIGEgPT4gKGEgaW5zdGFuY2VvZiBDb21wb25lbnQpXG4gICAgICAgICAgICAgICAgJiYgIShhIGluc3RhbmNlb2YgUmVzb3VyY2UpKSBhcyBVbmtub3duQ29tcG9uZW50W10pLFxuICAgICAgICAuLi5tb2RpZmllckNvbXBvbmVudHNdKTtcblxuICAgICAgICB0aGlzLnJlc291cmNlcyA9IG5ldyBTZXQoWy4uLih0aGlzLmFyZ3MuZmlsdGVyKFxuICAgICAgICAgICAgYSA9PiAoYSBpbnN0YW5jZW9mIFJlc291cmNlKSkgYXMgVW5rbm93blJlc291cmNlW10pLFxuICAgICAgICAuLi5tb2RpZmllclJlc291cmNlc10pO1xuICAgIH1cblxuICAgIHN1cHBvcnRzRW50aXR5KGVudGl0eTogV2l0aENvbXBvbmVudHMpIHtcbiAgICAgICAgcmV0dXJuIHN1YnNldCh0aGlzLmNvbXBvbmVudHMsIG5ldyBTZXQoZW50aXR5LmNvbXBvbmVudHMua2V5cygpKSk7XG4gICAgfVxuXG4gICAgdG9TdHJpbmcoKSB7XG4gICAgICAgIHJldHVybiBgUXVlcnkoJHt0aGlzLm5hbWUgPz8gJ3VubmFtZWQnfSlgO1xuICAgIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9ub3ZhX2Vjcy9xdWVyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7SUFDQSxrREFBMEQ7SUFDMUQsZ0RBQXVEO0lBQ3ZELGdEQUF1RDtJQUN2RCwwQ0FBaUQ7SUFHakQsTUFBTSxXQUFXLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBRXBDOzs7T0FHRztJQUNILE1BQWEsS0FBSztRQVFkLFlBQXFCLElBQWUsRUFBVyxJQUFhO1lBQXZDLFNBQUksR0FBSixJQUFJLENBQVc7WUFBVyxTQUFJLEdBQUosSUFBSSxDQUFTO1lBTDVELGlEQUFpRDtZQUNoQyxnQkFBVyxHQUFHLFdBQVcsQ0FBQztZQUt2QyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxZQUFZLG1CQUFRLENBQXNCLENBQUM7WUFDbkYsTUFBTSxrQkFBa0IsR0FBRyxTQUFTO2lCQUMvQixHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQztpQkFDMUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBRXhELE1BQU0saUJBQWlCLEdBQUcsU0FBUztpQkFDOUIsR0FBRyxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUM7aUJBQ3pDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksR0FBRyxFQUFFLENBQUMsQ0FBQztZQUd4RCxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksR0FBRyxDQUFDLENBQUMsR0FBSSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FDM0MsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsWUFBWSxxQkFBUyxDQUFDO3VCQUN0QixDQUFDLENBQUMsQ0FBQyxZQUFZLG1CQUFRLENBQUMsQ0FBd0IsRUFDM0QsR0FBRyxrQkFBa0IsQ0FBQyxDQUFDLENBQUM7WUFFeEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLEdBQUcsQ0FBQyxDQUFDLEdBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQzFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFlBQVksbUJBQVEsQ0FBQyxDQUF1QixFQUN2RCxHQUFHLGlCQUFpQixDQUFDLENBQUMsQ0FBQztRQUMzQixDQUFDO1FBRUQsY0FBYyxDQUFDLE1BQXNCO1lBQ2pDLE9BQU8sY0FBTSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxHQUFHLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDdEUsQ0FBQztRQUVELFFBQVE7WUFDSixPQUFPLFNBQVMsSUFBSSxDQUFDLElBQUksSUFBSSxTQUFTLEdBQUcsQ0FBQztRQUM5QyxDQUFDO0tBQ0o7SUFwQ0Qsc0JBb0NDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXJnVHlwZXMgfSBmcm9tIFwiLi9hcmdfdHlwZXNcIjtcbmltcG9ydCB7IENvbXBvbmVudCwgVW5rbm93bkNvbXBvbmVudCB9IGZyb20gXCIuL2NvbXBvbmVudFwiO1xuaW1wb3J0IHsgTW9kaWZpZXIsIFVua25vd25Nb2RpZmllciB9IGZyb20gXCIuL21vZGlmaWVyXCI7XG5pbXBvcnQgeyBSZXNvdXJjZSwgVW5rbm93blJlc291cmNlIH0gZnJvbSBcIi4vcmVzb3VyY2VcIjtcbmltcG9ydCB7IHN1YnNldCwgV2l0aENvbXBvbmVudHMgfSBmcm9tIFwiLi91dGlsc1wiO1xuXG5cbmNvbnN0IHF1ZXJ5U3ltYm9sID0gU3ltYm9sKCdRdWVyeScpO1xuXG4vKipcbiAqIEEgcXVlcnkgcHJvdmlkZXMgYSB3YXkgb2YgaXRlcmF0aW5nIG92ZXIgYWxsIHRoZSBFbnRpdGllcyB0aGF0IGhhdmVcbiAqIGEgc3BlY2lmaWVkIHNldCBvZiBjb21wb25lbnRzLlxuICovXG5leHBvcnQgY2xhc3MgUXVlcnk8UXVlcnlBcmdzIGV4dGVuZHMgcmVhZG9ubHkgQXJnVHlwZXNbXVxuICAgID0gcmVhZG9ubHkgQXJnVHlwZXNbXT4ge1xuXG4gICAgLy8gUHJldmVudCBxdWVyeSBmcm9tIGJlaW5nIGEgc3VidHlwZSBvZiBFY3NFdmVudFxuICAgIHByaXZhdGUgcmVhZG9ubHkgcXVlcnlTeW1ib2wgPSBxdWVyeVN5bWJvbDtcbiAgICByZWFkb25seSBjb21wb25lbnRzOiBSZWFkb25seVNldDxVbmtub3duQ29tcG9uZW50PjtcbiAgICByZWFkb25seSByZXNvdXJjZXM6IFJlYWRvbmx5U2V0PFVua25vd25SZXNvdXJjZT47XG5cbiAgICBjb25zdHJ1Y3RvcihyZWFkb25seSBhcmdzOiBRdWVyeUFyZ3MsIHJlYWRvbmx5IG5hbWU/OiBzdHJpbmcpIHtcbiAgICAgICAgY29uc3QgbW9kaWZpZXJzID0gYXJncy5maWx0ZXIoYXJnID0+IGFyZyBpbnN0YW5jZW9mIE1vZGlmaWVyKSBhcyBVbmtub3duTW9kaWZpZXJbXTtcbiAgICAgICAgY29uc3QgbW9kaWZpZXJDb21wb25lbnRzID0gbW9kaWZpZXJzXG4gICAgICAgICAgICAubWFwKG1vZGlmaWVyID0+IG1vZGlmaWVyLnF1ZXJ5LmNvbXBvbmVudHMpXG4gICAgICAgICAgICAucmVkdWNlKChhLCBiKSA9PiBuZXcgU2V0KFsuLi5hLCAuLi5iXSksIG5ldyBTZXQoKSk7XG5cbiAgICAgICAgY29uc3QgbW9kaWZpZXJSZXNvdXJjZXMgPSBtb2RpZmllcnNcbiAgICAgICAgICAgIC5tYXAobW9kaWZpZXIgPT4gbW9kaWZpZXIucXVlcnkucmVzb3VyY2VzKVxuICAgICAgICAgICAgLnJlZHVjZSgoYSwgYikgPT4gbmV3IFNldChbLi4uYSwgLi4uYl0pLCBuZXcgU2V0KCkpO1xuXG5cbiAgICAgICAgdGhpcy5jb21wb25lbnRzID0gbmV3IFNldChbLi4uKHRoaXMuYXJncy5maWx0ZXIoXG4gICAgICAgICAgICBhID0+IChhIGluc3RhbmNlb2YgQ29tcG9uZW50KVxuICAgICAgICAgICAgICAgICYmICEoYSBpbnN0YW5jZW9mIFJlc291cmNlKSkgYXMgVW5rbm93bkNvbXBvbmVudFtdKSxcbiAgICAgICAgLi4ubW9kaWZpZXJDb21wb25lbnRzXSk7XG5cbiAgICAgICAgdGhpcy5yZXNvdXJjZXMgPSBuZXcgU2V0KFsuLi4odGhpcy5hcmdzLmZpbHRlcihcbiAgICAgICAgICAgIGEgPT4gKGEgaW5zdGFuY2VvZiBSZXNvdXJjZSkpIGFzIFVua25vd25SZXNvdXJjZVtdKSxcbiAgICAgICAgLi4ubW9kaWZpZXJSZXNvdXJjZXNdKTtcbiAgICB9XG5cbiAgICBzdXBwb3J0c0VudGl0eShlbnRpdHk6IFdpdGhDb21wb25lbnRzKSB7XG4gICAgICAgIHJldHVybiBzdWJzZXQodGhpcy5jb21wb25lbnRzLCBuZXcgU2V0KGVudGl0eS5jb21wb25lbnRzLmtleXMoKSkpO1xuICAgIH1cblxuICAgIHRvU3RyaW5nKCkge1xuICAgICAgICByZXR1cm4gYFF1ZXJ5KCR7dGhpcy5uYW1lID8/ICd1bm5hbWVkJ30pYDtcbiAgICB9XG59XG4iXX0=
/// <amd-module name="nova_ecs/system" />
import { ArgsToData, ArgTypes } from "./arg_types";
import { EcsEvent, UnknownEvent } from "./events";
import { Query } from "./query";

@@ -9,3 +10,3 @@ export interface BaseSystemArgs<StepArgTypes extends readonly ArgTypes[]> {

readonly after?: Iterable<System | string>;
readonly event?: Symbol;
readonly events?: Iterable<EcsEvent<any, any>>;
}

@@ -21,6 +22,6 @@ export interface SystemArgs<StepArgTypes extends readonly ArgTypes[]> extends BaseSystemArgs<StepArgTypes> {

readonly after: ReadonlySet<System | string>;
readonly event: Symbol;
readonly events: Set<UnknownEvent>;
readonly query: Query<StepArgTypes>;
constructor({ name, args, step, before, after, event }: SystemArgs<StepArgTypes>);
constructor({ name, args, step, before, after, events }: SystemArgs<StepArgTypes>);
toString(): string;
}

@@ -16,3 +16,3 @@ (function (factory) {

class System {
constructor({ name, args, step, before, after, event }) {
constructor({ name, args, step, before, after, events }) {
this.name = name;

@@ -23,3 +23,3 @@ this.args = args;

this.after = new Set([...after ?? []]);
this.event = event ?? events_1.StepEvent;
this.events = new Set([...events ?? [events_1.StepEvent]]);
this.query = new query_1.Query(args);

@@ -33,2 +33,2 @@ }

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3lzdGVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbm92YV9lY3Mvc3lzdGVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQUNBLDRDQUFxQztJQUNyQywwQ0FBZ0M7SUFjaEMsTUFBYSxNQUFNO1FBU2YsWUFBWSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUE0QjtZQUM1RSxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztZQUNqQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztZQUNqQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztZQUNqQixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksR0FBRyxDQUFDLENBQUMsR0FBRyxNQUFNLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztZQUN6QyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLENBQUMsR0FBRyxLQUFLLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztZQUN2QyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssSUFBSSxrQkFBUyxDQUFDO1lBQ2hDLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxhQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDakMsQ0FBQztRQUVELFFBQVE7WUFDSixPQUFPLFVBQVUsSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxHQUFHLENBQUM7UUFDdEUsQ0FBQztLQUNKO0lBdEJELHdCQXNCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFyZ3NUb0RhdGEsIEFyZ1R5cGVzIH0gZnJvbSBcIi4vYXJnX3R5cGVzXCI7XG5pbXBvcnQgeyBTdGVwRXZlbnQgfSBmcm9tIFwiLi9ldmVudHNcIjtcbmltcG9ydCB7IFF1ZXJ5IH0gZnJvbSBcIi4vcXVlcnlcIjtcblxuXG5leHBvcnQgaW50ZXJmYWNlIEJhc2VTeXN0ZW1BcmdzPFN0ZXBBcmdUeXBlcyBleHRlbmRzIHJlYWRvbmx5IEFyZ1R5cGVzW10+IHtcbiAgICByZWFkb25seSBuYW1lOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgYXJnczogU3RlcEFyZ1R5cGVzO1xuICAgIHJlYWRvbmx5IGJlZm9yZT86IEl0ZXJhYmxlPFN5c3RlbSB8IHN0cmluZz47IC8vIFN5c3RlbXMgdGhhdCB0aGlzIHN5c3RlbSBydW5zIGJlZm9yZVxuICAgIHJlYWRvbmx5IGFmdGVyPzogSXRlcmFibGU8U3lzdGVtIHwgc3RyaW5nPjsgLy8gU3lzdGVtcyB0aGF0IHRoaXMgc3lzdGVtIHJ1bnMgYWZ0ZXJcbiAgICByZWFkb25seSBldmVudD86IFN5bWJvbDtcbn1cbmV4cG9ydCBpbnRlcmZhY2UgU3lzdGVtQXJnczxTdGVwQXJnVHlwZXMgZXh0ZW5kcyByZWFkb25seSBBcmdUeXBlc1tdPiBleHRlbmRzIEJhc2VTeXN0ZW1BcmdzPFN0ZXBBcmdUeXBlcz4ge1xuICAgIHN0ZXA6ICguLi5hcmdzOiBBcmdzVG9EYXRhPFN0ZXBBcmdUeXBlcz4pID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBjbGFzcyBTeXN0ZW08U3RlcEFyZ1R5cGVzIGV4dGVuZHMgcmVhZG9ubHkgQXJnVHlwZXNbXSA9IHJlYWRvbmx5IEFyZ1R5cGVzW10+IHtcbiAgICByZWFkb25seSBuYW1lOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgYXJnczogU3RlcEFyZ1R5cGVzO1xuICAgIHJlYWRvbmx5IHN0ZXA6IFN5c3RlbUFyZ3M8U3RlcEFyZ1R5cGVzPlsnc3RlcCddO1xuICAgIHJlYWRvbmx5IGJlZm9yZTogUmVhZG9ubHlTZXQ8U3lzdGVtIHwgc3RyaW5nPjtcbiAgICByZWFkb25seSBhZnRlcjogUmVhZG9ubHlTZXQ8U3lzdGVtIHwgc3RyaW5nPjtcbiAgICByZWFkb25seSBldmVudDogU3ltYm9sO1xuICAgIHJlYWRvbmx5IHF1ZXJ5OiBRdWVyeTxTdGVwQXJnVHlwZXM+O1xuXG4gICAgY29uc3RydWN0b3IoeyBuYW1lLCBhcmdzLCBzdGVwLCBiZWZvcmUsIGFmdGVyLCBldmVudCB9OiBTeXN0ZW1BcmdzPFN0ZXBBcmdUeXBlcz4pIHtcbiAgICAgICAgdGhpcy5uYW1lID0gbmFtZTtcbiAgICAgICAgdGhpcy5hcmdzID0gYXJncztcbiAgICAgICAgdGhpcy5zdGVwID0gc3RlcDtcbiAgICAgICAgdGhpcy5iZWZvcmUgPSBuZXcgU2V0KFsuLi5iZWZvcmUgPz8gW11dKTtcbiAgICAgICAgdGhpcy5hZnRlciA9IG5ldyBTZXQoWy4uLmFmdGVyID8/IFtdXSk7XG4gICAgICAgIHRoaXMuZXZlbnQgPSBldmVudCA/PyBTdGVwRXZlbnQ7XG4gICAgICAgIHRoaXMucXVlcnkgPSBuZXcgUXVlcnkoYXJncyk7XG4gICAgfVxuXG4gICAgdG9TdHJpbmcoKSB7XG4gICAgICAgIHJldHVybiBgU3lzdGVtKCR7dGhpcy5uYW1lID8/IHRoaXMuYXJncy5tYXAoYSA9PiBhLnRvU3RyaW5nKCkpfSlgO1xuICAgIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3lzdGVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbm92YV9lY3Mvc3lzdGVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQUNBLDRDQUE2RDtJQUM3RCwwQ0FBZ0M7SUFjaEMsTUFBYSxNQUFNO1FBU2YsWUFBWSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUE0QjtZQUM3RSxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztZQUNqQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztZQUNqQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztZQUNqQixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksR0FBRyxDQUFDLENBQUMsR0FBRyxNQUFNLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztZQUN6QyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLENBQUMsR0FBRyxLQUFLLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztZQUN2QyxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksR0FBRyxDQUFDLENBQUMsR0FBRyxNQUFNLElBQUksQ0FBQyxrQkFBUyxDQUFDLENBQUMsQ0FBc0IsQ0FBQztZQUN2RSxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksYUFBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2pDLENBQUM7UUFFRCxRQUFRO1lBQ0osT0FBTyxVQUFVLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsR0FBRyxDQUFDO1FBQ3RFLENBQUM7S0FDSjtJQXRCRCx3QkFzQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcmdzVG9EYXRhLCBBcmdUeXBlcyB9IGZyb20gXCIuL2FyZ190eXBlc1wiO1xuaW1wb3J0IHsgRWNzRXZlbnQsIFN0ZXBFdmVudCwgVW5rbm93bkV2ZW50IH0gZnJvbSBcIi4vZXZlbnRzXCI7XG5pbXBvcnQgeyBRdWVyeSB9IGZyb20gXCIuL3F1ZXJ5XCI7XG5cblxuZXhwb3J0IGludGVyZmFjZSBCYXNlU3lzdGVtQXJnczxTdGVwQXJnVHlwZXMgZXh0ZW5kcyByZWFkb25seSBBcmdUeXBlc1tdPiB7XG4gICAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICAgIHJlYWRvbmx5IGFyZ3M6IFN0ZXBBcmdUeXBlcztcbiAgICByZWFkb25seSBiZWZvcmU/OiBJdGVyYWJsZTxTeXN0ZW0gfCBzdHJpbmc+OyAvLyBTeXN0ZW1zIHRoYXQgdGhpcyBzeXN0ZW0gcnVucyBiZWZvcmVcbiAgICByZWFkb25seSBhZnRlcj86IEl0ZXJhYmxlPFN5c3RlbSB8IHN0cmluZz47IC8vIFN5c3RlbXMgdGhhdCB0aGlzIHN5c3RlbSBydW5zIGFmdGVyXG4gICAgcmVhZG9ubHkgZXZlbnRzPzogSXRlcmFibGU8RWNzRXZlbnQ8YW55LCBhbnk+PjsgLy8gRXZlbnRzIHRoYXQgY2FuIHRyaWdnZXIgdGhpcyBzeXN0ZW1cbn1cbmV4cG9ydCBpbnRlcmZhY2UgU3lzdGVtQXJnczxTdGVwQXJnVHlwZXMgZXh0ZW5kcyByZWFkb25seSBBcmdUeXBlc1tdPiBleHRlbmRzIEJhc2VTeXN0ZW1BcmdzPFN0ZXBBcmdUeXBlcz4ge1xuICAgIHN0ZXA6ICguLi5hcmdzOiBBcmdzVG9EYXRhPFN0ZXBBcmdUeXBlcz4pID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBjbGFzcyBTeXN0ZW08U3RlcEFyZ1R5cGVzIGV4dGVuZHMgcmVhZG9ubHkgQXJnVHlwZXNbXSA9IHJlYWRvbmx5IEFyZ1R5cGVzW10+IHtcbiAgICByZWFkb25seSBuYW1lOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgYXJnczogU3RlcEFyZ1R5cGVzO1xuICAgIHJlYWRvbmx5IHN0ZXA6IFN5c3RlbUFyZ3M8U3RlcEFyZ1R5cGVzPlsnc3RlcCddO1xuICAgIHJlYWRvbmx5IGJlZm9yZTogUmVhZG9ubHlTZXQ8U3lzdGVtIHwgc3RyaW5nPjtcbiAgICByZWFkb25seSBhZnRlcjogUmVhZG9ubHlTZXQ8U3lzdGVtIHwgc3RyaW5nPjtcbiAgICByZWFkb25seSBldmVudHM6IFNldDxVbmtub3duRXZlbnQ+O1xuICAgIHJlYWRvbmx5IHF1ZXJ5OiBRdWVyeTxTdGVwQXJnVHlwZXM+O1xuXG4gICAgY29uc3RydWN0b3IoeyBuYW1lLCBhcmdzLCBzdGVwLCBiZWZvcmUsIGFmdGVyLCBldmVudHMgfTogU3lzdGVtQXJnczxTdGVwQXJnVHlwZXM+KSB7XG4gICAgICAgIHRoaXMubmFtZSA9IG5hbWU7XG4gICAgICAgIHRoaXMuYXJncyA9IGFyZ3M7XG4gICAgICAgIHRoaXMuc3RlcCA9IHN0ZXA7XG4gICAgICAgIHRoaXMuYmVmb3JlID0gbmV3IFNldChbLi4uYmVmb3JlID8/IFtdXSk7XG4gICAgICAgIHRoaXMuYWZ0ZXIgPSBuZXcgU2V0KFsuLi5hZnRlciA/PyBbXV0pO1xuICAgICAgICB0aGlzLmV2ZW50cyA9IG5ldyBTZXQoWy4uLmV2ZW50cyA/PyBbU3RlcEV2ZW50XV0pIGFzIFNldDxVbmtub3duRXZlbnQ+O1xuICAgICAgICB0aGlzLnF1ZXJ5ID0gbmV3IFF1ZXJ5KGFyZ3MpO1xuICAgIH1cblxuICAgIHRvU3RyaW5nKCkge1xuICAgICAgICByZXR1cm4gYFN5c3RlbSgke3RoaXMubmFtZSA/PyB0aGlzLmFyZ3MubWFwKGEgPT4gYS50b1N0cmluZygpKX0pYDtcbiAgICB9XG59XG4iXX0=

@@ -6,2 +6,3 @@ /// <amd-module name="nova_ecs/world" />

import { EntityMapHandle } from "./entity_map";
import { EcsEvent } from "./events";
import { EventMap } from "./event_map";

@@ -27,3 +28,6 @@ import { Plugin } from './plugin';

private eventQueue;
private boundEmit;
constructor(name?: string | undefined);
emit<Data>(event: EcsEvent<Data, any>, data: Data, entities?: Set<string>): void;
private emitWrapped;
addPlugin(plugin: Plugin): void;

@@ -30,0 +34,0 @@ private callWithNewDraft;

@@ -91,2 +91,3 @@ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {

this.eventQueue = [];
this.boundEmit = this.emit.bind(this);
this.addPlugin(async_system_1.AsyncSystemPlugin);

@@ -109,2 +110,3 @@ this.entities.set('singleton', {

event: events_1.DeleteEvent,
data: undefined,
entities: currentDeleted,

@@ -114,2 +116,12 @@ });

}
emit(event, data, entities) {
this.emitWrapped(event, data, entities);
}
emitWrapped(event, data, entities) {
this.eventQueue.push({
event: event,
data,
entities
});
}
addPlugin(plugin) {

@@ -207,10 +219,10 @@ // TODO: Namespace component and system names. Perhaps use ':' or '/' to

}
runEvent(draft, ecsEvent) {
runEvent(draft, eventWithEntities) {
// TODO: Cache this probably.
const systems = this.systems.filter(s => s.event === ecsEvent.event);
const systems = this.systems.filter(s => s.events.has(eventWithEntities.event));
// Default to all entities if none are specified. When defaulting to all,
// this includes entities added in the same step.
let entities;
if (ecsEvent.entities) {
entities = [...ecsEvent.entities].map(entry => {
if (eventWithEntities.entities) {
entities = [...eventWithEntities.entities].map(entry => {
if (typeof entry === 'string') {

@@ -224,4 +236,5 @@ return [entry, draft.entities.get(entry)];

}
const eventTuple = [eventWithEntities.event, eventWithEntities.data];
for (const system of systems) {
const argList = this.fulfillQuery(system.query, draft, entities);
const argList = this.fulfillQuery(system.query, draft, entities, eventTuple);
for (const args of argList) {

@@ -236,2 +249,3 @@ system.step(...args);

event: events_1.StepEvent,
data: undefined,
});

@@ -241,3 +255,3 @@ this.flush(draft);

}
getArg(arg, draft, entity, uuid) {
getArg(arg, draft, entity, uuid, event) {
if (arg instanceof resource_1.Resource) {

@@ -273,2 +287,5 @@ if (draft.resources.has(arg)) {

}
else if (arg === arg_types_1.Emit) {
return Either_1.right(this.boundEmit);
}
else if (arg === arg_types_1.GetArg) {

@@ -278,2 +295,12 @@ // TODO: Why don't these types work?

}
else if (arg instanceof events_1.EcsEvent) {
if (!event) {
return Either_1.left(undefined);
}
const [ecsEvent, data] = event;
if (ecsEvent === arg) {
return Either_1.right(data);
}
return Either_1.left(undefined);
}
else if (arg instanceof modifier_1.Modifier) {

@@ -291,10 +318,10 @@ const modifier = arg;

}
fulfillQuery(query, draft, entities = draft.entities) {
fulfillQuery(query, draft, entities = draft.entities, event) {
const supportedEntities = [...entities].filter(([, entity]) => query.supportsEntity(entity));
return supportedEntities.map(([uuid, entity]) => this.fulfillQueryForEntity(entity, uuid, query, draft))
return supportedEntities.map(([uuid, entity]) => this.fulfillQueryForEntity(entity, uuid, query, draft, event))
.filter((results) => Either_1.isRight(results))
.map(rightResults => rightResults.right);
}
fulfillQueryForEntity(entity, uuid, query, draft) {
const results = query.args.map(arg => this.getArg(arg, draft, entity, uuid));
fulfillQueryForEntity(entity, uuid, query, draft, event) {
const results = query.args.map(arg => this.getArg(arg, draft, entity, uuid, event));
const rightResults = [];

@@ -315,2 +342,2 @@ for (const result of results) {

});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"world.js","sourceRoot":"","sources":["../../../../nova_ecs/world.ts"],"names":[],"mappings":"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","sourcesContent":["import { Either, isLeft, isRight, left, Right, right } from \"fp-ts/lib/Either\";\nimport produce, { Draft, enableMapSet, enablePatches, Immutable } from \"immer\";\nimport { ArgData, ArgsToData, ArgTypes, Components, Entities, GetArg, GetEntity, QueryResults, UUID } from \"./arg_types\";\nimport { AsyncSystemPlugin } from \"./async_system\";\nimport { Component, UnknownComponent } from \"./component\";\nimport { Entity } from \"./entity\";\nimport { EntityMapHandle } from \"./entity_map\";\nimport { DeleteEvent, StepEvent } from \"./events\";\nimport { EventMap } from \"./event_map\";\nimport { Modifier, UnknownModifier } from \"./modifier\";\nimport { Plugin } from './plugin';\nimport { Query } from \"./query\";\nimport { Resource, UnknownResource } from \"./resource\";\nimport { ResourceMap, ResourceMapHandle } from \"./resource_map\";\nimport { System } from \"./system\";\nimport { currentIfDraft, topologicalSort } from './utils';\n\n\n// How do you serialize components and make sure the receiver\n// knows which is which?\n\n// How do you use immer and make patches when you step the state?\n\n// How do you keep entities mostly like data while also allowing to\n// add and remove components from them efficiently?\n\n// How do you create new entities that need to asynchronously load data for their\n// components from gameData?\n// - Serialize ship to id + outfits. Deserialize takes long time and requires reconstruction\n//   of properties from outfits. Just send the whole thing? How big is it?\n\n// How does ecs draw stuff?\n// - Can't store PIXI stuff as components since they're not immerable. Store references instead?\n\n// Have each system that wants to be multiplayer use the Multiplayer component. Then,\n// have a Multiplayer system that runs after other systems and queries for all systems\n// that have multiplayer components. Then, that system sends and\n// receives multiplayer messages. Solves Projectiles by not adding the Delta component\n// to them (Wait, this doesn't actually work. If they don't have the Delta component,\n// then the systems that add to Delta won't run). Add the ability to make\n// components optional for a system to fix this? Seems good to me.\n// It also solves the display systems since they simply don't add anything to the\n// Delta component.\n// To notify when an entity is added, it just sends that new Entity's delta.\n// To notify when an entity is removed, we need some kind of teardown system?\n// This loses the ease of use of immer patches, though.\n// What about resources? Use an entity to update their deltas and put them onto the\n// multiplayer component.\n\n// Idea: Run other nova systems in webworkers and pass the state to the main\n// thread when you jump between systems.\n\n// Idea: Load async stuff by adding components to the entity as the data becomes\n// available?\n\nenablePatches();\n\nexport interface State {\n    entities: EventMap<string, Entity>;\n    resources: ResourceMap;\n}\n\nexport type CallWithDraft<T> = <R>(callback: (draft: Draft<T>) => R) => R;\n\nenableMapSet();\n\ninterface EcsEvent {\n    event: Symbol;\n    entities?: Set<string | [string, Entity]>;\n}\n\nexport class World {\n    private state: Immutable<State> = {\n        entities: new EventMap(),\n        resources: new Map(),\n    };\n\n    readonly entities = new EntityMapHandle(\n        this.callWithNewDraft.bind(this),\n        this.addComponent.bind(this));\n\n    readonly resources = new ResourceMapHandle(\n        this.callWithNewDraft.bind(this),\n        this.addResource.bind(this));\n    // These maps exist in part to make sure there are no name collisions\n    private nameComponentMap = new Map<string, UnknownComponent>();\n    private nameSystemMap = new Map<string, System>();\n    private nameResourceMap = new Map<string, UnknownResource>();\n\n    private systems: Array<System> = []; // Not a map because order matters.\n    singletonEntity: Entity;\n\n    private eventQueue: EcsEvent[] = [];\n\n    constructor(private name?: string) {\n        this.addPlugin(AsyncSystemPlugin);\n        this.entities.set('singleton', {\n            components: new Map(),\n            multiplayer: false,\n            name: 'singleton'\n        });\n        // Get the handle for the singleton entity.\n        this.singletonEntity = this.entities.get('singleton')!;\n\n        // Subscribe the delete event\n        (this.state.entities as EventMap<string, Entity>)\n            .events.delete.subscribe(deleted => {\n                const currentDeleted = new Set([...deleted]\n                    .map(([uuid, entity]) => {\n                        return [uuid, currentIfDraft(entity)];\n                    })) as NonNullable<EcsEvent['entities']>;\n\n                this.eventQueue.push({\n                    event: DeleteEvent,\n                    entities: currentDeleted,\n                });\n            });\n    }\n\n    addPlugin(plugin: Plugin) {\n        // TODO: Namespace component and system names. Perhaps use ':' or '/' to\n        // denote namespace vs name. Use a proxy like NovaData uses.\n        plugin.build(this);\n    }\n\n    private callWithNewDraft<R>(callback: (draft: Draft<State>) => R) {\n        // Can't directly pass the draft because addEntity binds\n        // functions to edit the draft that can be called later.\n        let result: R;\n        let called = false;\n        this.state = produce(this.state, draft => {\n            result = callback(draft);\n            called = true;\n        });\n        if (!called) {\n            throw new Error('Expected to be called');\n        }\n        return result!;\n    }\n\n    private addResource(resource: Resource<any, any, any, any>) {\n        if (this.nameResourceMap.has(resource.name)\n            && this.nameResourceMap.get(resource.name) !== resource) {\n            throw new Error(`A resource with name ${resource.name} already exists`);\n        }\n        this.nameResourceMap.set(resource.name, resource as UnknownResource);\n    }\n\n    addSystem(system: System): this {\n        for (const resource of system.query.resources) {\n            if (!this.state.resources.has(resource)) {\n                throw new Error(\n                    `World is missing ${resource} needed for ${system}`);\n            }\n        }\n\n        if (this.nameSystemMap.has(system.name)\n            && this.nameSystemMap.get(system.name) !== system) {\n            throw new Error(`A system with name ${system.name} already exists`)\n        }\n\n        // ---- Topologically insert the new system ----\n        // Construct a graph with no edges. \n        const graph = new Map<System, Set<System>>(\n            this.systems.map(val => [val, new Set()]));\n        graph.set(system, new Set());\n\n        // Add all edges to the graph. Store directed edges from node A to B on node B.\n        // Include the system itself and its name as mapping to the system\n        const systemMap = new Map<System | string, System>(\n            [...[...graph.keys()].map(key => [key, key] as const),\n            ...[...graph.keys()].map(key => [key.name, key] as const)]);\n\n        for (const [system, incomingEdges] of graph) {\n            // Systems that this system runs before have incoming edges from this\n            // system in the graph.\n            for (const before of system.before) {\n                const beforeSystem = systemMap.get(before);\n                if (beforeSystem) {\n                    const incomingBeforeEdges = graph.get(beforeSystem);\n                    incomingBeforeEdges?.add(system)\n                }\n            }\n\n            // This system has incoming edges from the systems that it runs after.\n            for (const after of system.after) {\n                const afterSystem = systemMap.get(after);\n                if (afterSystem) {\n                    incomingEdges.add(afterSystem);\n                }\n            }\n        }\n\n        // Topologically sort the graph\n        this.systems = topologicalSort(graph);\n\n        this.nameSystemMap.set(system.name, system);\n        for (const component of system.query.components) {\n            this.addComponent(component);\n        }\n        return this;\n    }\n\n    addComponent(component: Component<any, any, any, any>) {\n        // Adds a component to the map of known components. Does not add to an entity.\n        // Necessary for multiplayer to create entities with components that haven't\n        // been used yet.\n        if (this.nameComponentMap.has(component.name)\n            && this.nameComponentMap.get(component.name) !== component) {\n            throw new Error(`A component with name ${component.name} already exists`);\n        }\n\n        this.nameComponentMap.set(component.name, component);\n    }\n\n    /**\n     * Flush the event queue.\n     */\n    private flush(draft: Draft<State>) {\n        // Not a for loop because more events may be added as prior\n        // ones are resolved.\n        while (this.eventQueue.length > 0) {\n            // TODO: Maybe use an actual queue for better time order.\n            const ecsEvent = this.eventQueue.shift()!;\n            this.runEvent(draft, ecsEvent);\n        }\n    }\n\n    private runEvent(draft: Draft<State>, ecsEvent: EcsEvent) {\n        // TODO: Cache this probably.\n        const systems = this.systems.filter(s => s.event === ecsEvent.event);\n\n        // Default to all entities if none are specified. When defaulting to all,\n        // this includes entities added in the same step.\n        let entities: [string, Draft<Entity>][] | undefined;\n        if (ecsEvent.entities) {\n            entities = [...ecsEvent.entities].map(entry => {\n                if (typeof entry === 'string') {\n                    return [entry, draft.entities.get(entry)];\n                } else {\n                    return entry;\n                }\n            }).filter((entry): entry is [string, Draft<Entity>] => Boolean(entry[1]));\n        }\n\n        for (const system of systems) {\n            const argList = this.fulfillQuery(system.query, draft, entities);\n            for (const args of argList) {\n                system.step(...args);\n            }\n        }\n    }\n\n    step() {\n        this.state = produce(this.state, draft => {\n            this.eventQueue.push({\n                event: StepEvent,\n            });\n\n            this.flush(draft);\n        });\n    }\n\n    private getArg<T extends ArgTypes = ArgTypes>(arg: T,\n        draft: Draft<State>, entity: Draft<Entity>, uuid: string):\n        Either<undefined, ArgData<T>> {\n        if (arg instanceof Resource) {\n            if (draft.resources.has(arg)) {\n                return right(draft.resources.get(arg) as ArgData<T>);\n            } else {\n                throw new Error(`Missing resource ${arg}`);\n            }\n        } else if (arg instanceof Component) {\n            if (entity.components.has(arg)) {\n                return right(entity.components.get(arg) as ArgData<T>);\n            }\n            return left(undefined);\n        } else if (arg instanceof Query) {\n            // Queries always fulfill because if no entities match, they return [].\n            return right(this.fulfillQuery(arg, draft) as ArgData<T>);\n        } else if (arg === Entities) {\n            return right(draft.entities as ArgData<T>);\n        } else if (arg === Components) {\n            return right(this.nameComponentMap as ArgData<T>);\n        } else if (arg === UUID) {\n            return right(uuid as ArgData<T>);\n        } else if (arg === GetEntity) {\n            return right(entity as ArgData<T>);\n        } else if (arg === GetArg) {\n            // TODO: Why don't these types work?\n            return right(<T extends ArgTypes = ArgTypes>(arg: T) =>\n                this.getArg<T>(arg, draft, entity, uuid)) as Right<ArgData<T>>;\n        } else if (arg instanceof Modifier) {\n            const modifier = arg as UnknownModifier;\n            const modifierQueryResults = this.fulfillQueryForEntity(entity, uuid,\n                modifier.query, draft);\n            if (isLeft(modifierQueryResults)) {\n                return left(undefined);\n            }\n            return modifier.transform(...modifierQueryResults.right) as\n                Either<undefined, ArgData<T>>;\n        } else {\n            throw new Error(`Internal error: unrecognized arg ${arg}`);\n        }\n    }\n\n    private fulfillQuery<C extends readonly ArgTypes[]>(query: Query<C>, draft: Draft<State>,\n        entities: Iterable<[string, Draft<Entity>]> = draft.entities): QueryResults<Query<C>> {\n\n        const supportedEntities = [...entities].filter(\n            ([, entity]) => query.supportsEntity(entity));\n\n        return supportedEntities.map(([uuid, entity]) =>\n            this.fulfillQueryForEntity(entity, uuid, query, draft))\n            .filter((results): results is Right<ArgsToData<C>> => isRight(results))\n            .map(rightResults => rightResults.right);\n    }\n\n    private fulfillQueryForEntity<C extends readonly ArgTypes[]>(\n        entity: Draft<Entity>, uuid: string, query: Query<C>, draft: Draft<State>):\n        Either<undefined, ArgsToData<C>> {\n\n        const results = query.args.map(arg => this.getArg(arg, draft, entity, uuid));\n        const rightResults: unknown[] = [];\n        for (const result of results) {\n            if (isLeft(result)) {\n                return left(undefined);\n            }\n            rightResults.push(result.right);\n        }\n        return right(rightResults as unknown as ArgsToData<C>);\n    }\n\n    toString() {\n        return `World(${this.name ?? 'unnamed'})`;\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"world.js","sourceRoot":"","sources":["../../../../nova_ecs/world.ts"],"names":[],"mappings":"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","sourcesContent":["import { Either, isLeft, isRight, left, Right, right } from \"fp-ts/lib/Either\";\nimport produce, { Draft, enableMapSet, enablePatches, Immutable } from \"immer\";\nimport { ArgData, ArgsToData, ArgTypes, Components, Emit, EmitFunction, Entities, GetArg, GetEntity, QueryResults, UUID } from \"./arg_types\";\nimport { AsyncSystemPlugin } from \"./async_system\";\nimport { Component, UnknownComponent } from \"./component\";\nimport { Entity } from \"./entity\";\nimport { EntityMapHandle } from \"./entity_map\";\nimport { DeleteEvent, EcsEvent, StepEvent, UnknownEvent } from \"./events\";\nimport { EventMap } from \"./event_map\";\nimport { Modifier, UnknownModifier } from \"./modifier\";\nimport { Plugin } from './plugin';\nimport { Query } from \"./query\";\nimport { Resource, UnknownResource } from \"./resource\";\nimport { ResourceMap, ResourceMapHandle } from \"./resource_map\";\nimport { System } from \"./system\";\nimport { currentIfDraft, topologicalSort } from './utils';\n\n\n// How do you serialize components and make sure the receiver\n// knows which is which?\n\n// How do you use immer and make patches when you step the state?\n\n// How do you keep entities mostly like data while also allowing to\n// add and remove components from them efficiently?\n\n// How do you create new entities that need to asynchronously load data for their\n// components from gameData?\n// - Serialize ship to id + outfits. Deserialize takes long time and requires reconstruction\n//   of properties from outfits. Just send the whole thing? How big is it?\n\n// How does ecs draw stuff?\n// - Can't store PIXI stuff as components since they're not immerable. Store references instead?\n\n// Have each system that wants to be multiplayer use the Multiplayer component. Then,\n// have a Multiplayer system that runs after other systems and queries for all systems\n// that have multiplayer components. Then, that system sends and\n// receives multiplayer messages. Solves Projectiles by not adding the Delta component\n// to them (Wait, this doesn't actually work. If they don't have the Delta component,\n// then the systems that add to Delta won't run). Add the ability to make\n// components optional for a system to fix this? Seems good to me.\n// It also solves the display systems since they simply don't add anything to the\n// Delta component.\n// To notify when an entity is added, it just sends that new Entity's delta.\n// To notify when an entity is removed, we need some kind of teardown system?\n// This loses the ease of use of immer patches, though.\n// What about resources? Use an entity to update their deltas and put them onto the\n// multiplayer component.\n\n// Idea: Run other nova systems in webworkers and pass the state to the main\n// thread when you jump between systems.\n\n// Idea: Load async stuff by adding components to the entity as the data becomes\n// available?\n\nenablePatches();\n\nexport interface State {\n    entities: EventMap<string, Entity>;\n    resources: ResourceMap;\n}\n\nexport type CallWithDraft<T> = <R>(callback: (draft: Draft<T>) => R) => R;\n\nenableMapSet();\n\ninterface EcsEventWithEntities<Data> {\n    event: EcsEvent<Data, any>;\n    data: Data;\n    entities?: Set<string | [string, Entity]>;\n}\n\nexport class World {\n    private state: Immutable<State> = {\n        entities: new EventMap(),\n        resources: new Map(),\n    };\n\n    readonly entities = new EntityMapHandle(\n        this.callWithNewDraft.bind(this),\n        this.addComponent.bind(this));\n\n    readonly resources = new ResourceMapHandle(\n        this.callWithNewDraft.bind(this),\n        this.addResource.bind(this));\n    // These maps exist in part to make sure there are no name collisions\n    private nameComponentMap = new Map<string, UnknownComponent>();\n    private nameSystemMap = new Map<string, System>();\n    private nameResourceMap = new Map<string, UnknownResource>();\n\n    private systems: Array<System> = []; // Not a map because order matters.\n    singletonEntity: Entity;\n\n    private eventQueue: EcsEventWithEntities<unknown>[] = [];\n    private boundEmit: EmitFunction = this.emit.bind(this);\n\n    constructor(private name?: string) {\n        this.addPlugin(AsyncSystemPlugin);\n        this.entities.set('singleton', {\n            components: new Map(),\n            multiplayer: false,\n            name: 'singleton'\n        });\n        // Get the handle for the singleton entity.\n        this.singletonEntity = this.entities.get('singleton')!;\n\n        // Subscribe the delete event\n        (this.state.entities as EventMap<string, Entity>)\n            .events.delete.subscribe(deleted => {\n                const currentDeleted = new Set([...deleted]\n                    .map(([uuid, entity]) => {\n                        return [uuid, currentIfDraft(entity)];\n                    })) as NonNullable<EcsEventWithEntities<unknown>['entities']>;\n\n                this.eventQueue.push({\n                    event: DeleteEvent as UnknownEvent,\n                    data: undefined,\n                    entities: currentDeleted,\n                });\n            });\n    }\n\n    emit<Data>(event: EcsEvent<Data, any>, data: Data, entities?: Set<string>) {\n        this.emitWrapped(event, data, entities);\n    }\n\n    private emitWrapped<Data>(event: EcsEvent<Data, any>, data: Data,\n        entities?: Set<string> | Set<[string, Entity]>) {\n        this.eventQueue.push({\n            event: event as UnknownEvent,\n            data,\n            entities\n        });\n    }\n\n    addPlugin(plugin: Plugin) {\n        // TODO: Namespace component and system names. Perhaps use ':' or '/' to\n        // denote namespace vs name. Use a proxy like NovaData uses.\n        plugin.build(this);\n    }\n\n    private callWithNewDraft<R>(callback: (draft: Draft<State>) => R) {\n        // Can't directly pass the draft because addEntity binds\n        // functions to edit the draft that can be called later.\n        let result: R;\n        let called = false;\n        this.state = produce(this.state, draft => {\n            result = callback(draft);\n            called = true;\n        });\n        if (!called) {\n            throw new Error('Expected to be called');\n        }\n        return result!;\n    }\n\n    private addResource(resource: Resource<any, any, any, any>) {\n        if (this.nameResourceMap.has(resource.name)\n            && this.nameResourceMap.get(resource.name) !== resource) {\n            throw new Error(`A resource with name ${resource.name} already exists`);\n        }\n        this.nameResourceMap.set(resource.name, resource as UnknownResource);\n    }\n\n    addSystem(system: System): this {\n        for (const resource of system.query.resources) {\n            if (!this.state.resources.has(resource)) {\n                throw new Error(\n                    `World is missing ${resource} needed for ${system}`);\n            }\n        }\n\n        if (this.nameSystemMap.has(system.name)\n            && this.nameSystemMap.get(system.name) !== system) {\n            throw new Error(`A system with name ${system.name} already exists`)\n        }\n\n        // ---- Topologically insert the new system ----\n        // Construct a graph with no edges. \n        const graph = new Map<System, Set<System>>(\n            this.systems.map(val => [val, new Set()]));\n        graph.set(system, new Set());\n\n        // Add all edges to the graph. Store directed edges from node A to B on node B.\n        // Include the system itself and its name as mapping to the system\n        const systemMap = new Map<System | string, System>(\n            [...[...graph.keys()].map(key => [key, key] as const),\n            ...[...graph.keys()].map(key => [key.name, key] as const)]);\n\n        for (const [system, incomingEdges] of graph) {\n            // Systems that this system runs before have incoming edges from this\n            // system in the graph.\n            for (const before of system.before) {\n                const beforeSystem = systemMap.get(before);\n                if (beforeSystem) {\n                    const incomingBeforeEdges = graph.get(beforeSystem);\n                    incomingBeforeEdges?.add(system)\n                }\n            }\n\n            // This system has incoming edges from the systems that it runs after.\n            for (const after of system.after) {\n                const afterSystem = systemMap.get(after);\n                if (afterSystem) {\n                    incomingEdges.add(afterSystem);\n                }\n            }\n        }\n\n        // Topologically sort the graph\n        this.systems = topologicalSort(graph);\n\n        this.nameSystemMap.set(system.name, system);\n        for (const component of system.query.components) {\n            this.addComponent(component);\n        }\n        return this;\n    }\n\n    addComponent(component: Component<any, any, any, any>) {\n        // Adds a component to the map of known components. Does not add to an entity.\n        // Necessary for multiplayer to create entities with components that haven't\n        // been used yet.\n        if (this.nameComponentMap.has(component.name)\n            && this.nameComponentMap.get(component.name) !== component) {\n            throw new Error(`A component with name ${component.name} already exists`);\n        }\n\n        this.nameComponentMap.set(component.name, component);\n    }\n\n    /**\n     * Flush the event queue.\n     */\n    private flush(draft: Draft<State>) {\n        // Not a for loop because more events may be added as prior\n        // ones are resolved.\n        while (this.eventQueue.length > 0) {\n            // TODO: Maybe use an actual queue for better time order.\n            const ecsEvent = this.eventQueue.shift()!;\n            this.runEvent(draft, ecsEvent);\n        }\n    }\n\n    private runEvent(draft: Draft<State>, eventWithEntities: EcsEventWithEntities<unknown>) {\n        // TODO: Cache this probably.\n        const systems = this.systems.filter(s => s.events.has(eventWithEntities.event));\n\n        // Default to all entities if none are specified. When defaulting to all,\n        // this includes entities added in the same step.\n        let entities: [string, Draft<Entity>][] | undefined;\n        if (eventWithEntities.entities) {\n            entities = [...eventWithEntities.entities].map(entry => {\n                if (typeof entry === 'string') {\n                    return [entry, draft.entities.get(entry)];\n                } else {\n                    return entry;\n                }\n            }).filter((entry): entry is [string, Draft<Entity>] => Boolean(entry[1]));\n        }\n\n        const eventTuple = [eventWithEntities.event, eventWithEntities.data] as const;\n        for (const system of systems) {\n            const argList = this.fulfillQuery(system.query, draft, entities, eventTuple);\n            for (const args of argList) {\n                system.step(...args);\n            }\n        }\n    }\n\n    step() {\n        this.state = produce(this.state, draft => {\n            this.eventQueue.push({\n                event: StepEvent as UnknownEvent,\n                data: undefined,\n            });\n\n            this.flush(draft);\n        });\n    }\n\n    private getArg<T extends ArgTypes = ArgTypes>(arg: T,\n        draft: Draft<State>, entity: Draft<Entity>, uuid: string,\n        event?: readonly [EcsEvent<unknown>, unknown]):\n        Either<undefined, ArgData<T>> {\n        if (arg instanceof Resource) {\n            if (draft.resources.has(arg)) {\n                return right(draft.resources.get(arg) as ArgData<T>);\n            } else {\n                throw new Error(`Missing resource ${arg}`);\n            }\n        } else if (arg instanceof Component) {\n            if (entity.components.has(arg)) {\n                return right(entity.components.get(arg) as ArgData<T>);\n            }\n            return left(undefined);\n        } else if (arg instanceof Query) {\n            // Queries always fulfill because if no entities match, they return [].\n            return right(this.fulfillQuery(arg, draft) as ArgData<T>);\n        } else if (arg === Entities) {\n            return right(draft.entities as ArgData<T>);\n        } else if (arg === Components) {\n            return right(this.nameComponentMap as ArgData<T>);\n        } else if (arg === UUID) {\n            return right(uuid as ArgData<T>);\n        } else if (arg === GetEntity) {\n            return right(entity as ArgData<T>);\n        } else if (arg === Emit) {\n            return right(this.boundEmit as ArgData<T>);\n        } else if (arg === GetArg) {\n            // TODO: Why don't these types work?\n            return right(<T extends ArgTypes = ArgTypes>(arg: T) =>\n                this.getArg<T>(arg, draft, entity, uuid)) as Right<ArgData<T>>;\n        } else if (arg instanceof EcsEvent) {\n            if (!event) {\n                return left(undefined);\n            }\n            const [ecsEvent, data] = event;\n            if (ecsEvent === arg) {\n                return right(data as ArgData<T>);\n            }\n            return left(undefined);\n        } else if (arg instanceof Modifier) {\n            const modifier = arg as UnknownModifier;\n            const modifierQueryResults = this.fulfillQueryForEntity(entity, uuid,\n                modifier.query, draft);\n            if (isLeft(modifierQueryResults)) {\n                return left(undefined);\n            }\n            return modifier.transform(...modifierQueryResults.right) as\n                Either<undefined, ArgData<T>>;\n        } else {\n            throw new Error(`Internal error: unrecognized arg ${arg}`);\n        }\n    }\n\n    private fulfillQuery<C extends readonly ArgTypes[]>(query: Query<C>, draft: Draft<State>,\n        entities: Iterable<[string, Draft<Entity>]> = draft.entities,\n        event?: readonly [EcsEvent<unknown>, unknown]): QueryResults<Query<C>> {\n\n        const supportedEntities = [...entities].filter(\n            ([, entity]) => query.supportsEntity(entity));\n\n        return supportedEntities.map(([uuid, entity]) =>\n            this.fulfillQueryForEntity(entity, uuid, query, draft, event))\n            .filter((results): results is Right<ArgsToData<C>> => isRight(results))\n            .map(rightResults => rightResults.right);\n    }\n\n    private fulfillQueryForEntity<C extends readonly ArgTypes[]>(\n        entity: Draft<Entity>, uuid: string, query: Query<C>, draft: Draft<State>,\n        event?: readonly [EcsEvent<unknown>, unknown]):\n        Either<undefined, ArgsToData<C>> {\n\n        const results = query.args.map(arg => this.getArg(arg, draft, entity, uuid, event));\n        const rightResults: unknown[] = [];\n        for (const result of results) {\n            if (isLeft(result)) {\n                return left(undefined);\n            }\n            rightResults.push(result.right);\n        }\n        return right(rightResults as unknown as ArgsToData<C>);\n    }\n\n    toString() {\n        return `World(${this.name ?? 'unnamed'})`;\n    }\n}\n"]}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc