@awesome-ecs/abstract 0.1.3 → 0.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/component.js +2 -1
- package/dist/components/identity-component.js +5 -2
- package/dist/components/identity-component.js.map +1 -1
- package/dist/entities/entity-proxy.js +2 -1
- package/dist/entities/entity-queue.d.ts +2 -1
- package/dist/entities/entity-queue.js +5 -2
- package/dist/entities/entity-queue.js.map +1 -1
- package/dist/entities/entity-repository.js +2 -1
- package/dist/entities/entity-scheduler.js +2 -1
- package/dist/entities/entity-trigger.d.ts +2 -2
- package/dist/entities/entity-trigger.js +2 -1
- package/dist/entities/entity.d.ts +2 -1
- package/dist/entities/entity.js +2 -1
- package/dist/index.js +28 -16
- package/dist/index.js.map +1 -1
- package/dist/pipelines/middleware.d.ts +3 -0
- package/dist/pipelines/middleware.js +2 -1
- package/dist/pipelines/pipeline.js +2 -1
- package/dist/systems/system-middleware.js +2 -1
- package/dist/systems/system-pipeline-context.d.ts +12 -3
- package/dist/systems/system-pipeline-context.js +2 -1
- package/dist/systems/system-pipeline-type.js +5 -2
- package/dist/systems/system-pipeline-type.js.map +1 -1
- package/dist/systems/system-pipeline.js +2 -1
- package/dist/systems/system-runtime.js +2 -1
- package/dist/utils/performance-timer.js +2 -1
- package/package.json +2 -2
|
@@ -1,5 +1,8 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BasicComponentType = void 0;
|
|
4
|
+
var BasicComponentType;
|
|
2
5
|
(function (BasicComponentType) {
|
|
3
6
|
BasicComponentType["identity"] = "identity";
|
|
4
|
-
})(BasicComponentType || (BasicComponentType = {}));
|
|
7
|
+
})(BasicComponentType = exports.BasicComponentType || (exports.BasicComponentType = {}));
|
|
5
8
|
//# sourceMappingURL=identity-component.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"identity-component.js","sourceRoot":"","sources":["../../src/components/identity-component.ts"],"names":[],"mappings":"AAIA,
|
|
1
|
+
{"version":3,"file":"identity-component.js","sourceRoot":"","sources":["../../src/components/identity-component.ts"],"names":[],"mappings":";;;AAIA,IAAY,kBAEX;AAFD,WAAY,kBAAkB;IAC5B,2CAAqB,CAAA;AACvB,CAAC,EAFW,kBAAkB,GAAlB,0BAAkB,KAAlB,0BAAkB,QAE7B"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { EntityTriggerUid } from "..";
|
|
1
2
|
import { IEntityModel } from "./entity";
|
|
2
3
|
import { IEntityProxy } from "./entity-proxy";
|
|
3
4
|
import { IEntityTrigger, ITriggerData } from "./entity-trigger";
|
|
@@ -15,7 +16,7 @@ export interface IEntityUpdate {
|
|
|
15
16
|
type: EntityUpdateType;
|
|
16
17
|
entity: IEntityProxy;
|
|
17
18
|
model?: IEntityModel;
|
|
18
|
-
|
|
19
|
+
triggers?: Map<EntityTriggerUid, IEntityTrigger<ITriggerData>>;
|
|
19
20
|
forceUpdate?: boolean;
|
|
20
21
|
}
|
|
21
22
|
/**
|
|
@@ -1,9 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EntityUpdateType = void 0;
|
|
1
4
|
/**
|
|
2
5
|
* The Entity update state for this change.
|
|
3
6
|
*/
|
|
4
|
-
|
|
7
|
+
var EntityUpdateType;
|
|
5
8
|
(function (EntityUpdateType) {
|
|
6
9
|
EntityUpdateType["update"] = "update";
|
|
7
10
|
EntityUpdateType["remove"] = "remove";
|
|
8
|
-
})(EntityUpdateType || (EntityUpdateType = {}));
|
|
11
|
+
})(EntityUpdateType = exports.EntityUpdateType || (exports.EntityUpdateType = {}));
|
|
9
12
|
//# sourceMappingURL=entity-queue.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"entity-queue.js","sourceRoot":"","sources":["../../src/entities/entity-queue.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"entity-queue.js","sourceRoot":"","sources":["../../src/entities/entity-queue.ts"],"names":[],"mappings":";;;AAKA;;GAEG;AACH,IAAY,gBAGX;AAHD,WAAY,gBAAgB;IAC1B,qCAAiB,CAAA;IACjB,qCAAiB,CAAA;AACnB,CAAC,EAHW,gBAAgB,GAAhB,wBAAgB,KAAhB,wBAAgB,QAG3B"}
|
|
@@ -2,7 +2,8 @@ import { IEntityProxy } from "./entity-proxy";
|
|
|
2
2
|
import { EntityUpdateType } from "./entity-queue";
|
|
3
3
|
export declare type EntityTriggerUid = string | number;
|
|
4
4
|
export interface ITriggerData {
|
|
5
|
-
|
|
5
|
+
uid: EntityTriggerUid;
|
|
6
|
+
action?: EntityUpdateType;
|
|
6
7
|
}
|
|
7
8
|
/**
|
|
8
9
|
* Entity Triggers represent a basic inter-Entity messaging mechanism.
|
|
@@ -11,7 +12,6 @@ export interface ITriggerData {
|
|
|
11
12
|
* The Triggers will be enqueued as part of an Entity Update envelope.
|
|
12
13
|
*/
|
|
13
14
|
export interface IEntityTrigger<TTriggerData extends ITriggerData> {
|
|
14
|
-
uid: EntityTriggerUid;
|
|
15
15
|
origin: IEntityProxy;
|
|
16
16
|
data: TTriggerData;
|
|
17
17
|
}
|
|
@@ -13,6 +13,7 @@ export interface IEntityModel {
|
|
|
13
13
|
export interface IEntity {
|
|
14
14
|
readonly components: Map<ComponentUid, IComponent>;
|
|
15
15
|
readonly proxies: Map<EntityTypeUid, Map<EntityUid, IEntityProxy>>;
|
|
16
|
-
readonly triggers: Map<EntityTriggerUid, IEntityTrigger<ITriggerData
|
|
16
|
+
readonly triggers: Map<EntityTriggerUid, IEntityTrigger<ITriggerData>[]>;
|
|
17
17
|
readonly identity: IdentityComponent<IEntityModel>;
|
|
18
|
+
readonly myProxy: IEntityProxy;
|
|
18
19
|
}
|
package/dist/entities/entity.js
CHANGED
package/dist/index.js
CHANGED
|
@@ -1,17 +1,29 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
|
+
};
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
__exportStar(require("./components/component"), exports);
|
|
14
|
+
__exportStar(require("./components/identity-component"), exports);
|
|
15
|
+
__exportStar(require("./entities/entity"), exports);
|
|
16
|
+
__exportStar(require("./entities/entity-proxy"), exports);
|
|
17
|
+
__exportStar(require("./entities/entity-queue"), exports);
|
|
18
|
+
__exportStar(require("./entities/entity-repository"), exports);
|
|
19
|
+
__exportStar(require("./entities/entity-scheduler"), exports);
|
|
20
|
+
__exportStar(require("./entities/entity-trigger"), exports);
|
|
21
|
+
__exportStar(require("./pipelines/middleware"), exports);
|
|
22
|
+
__exportStar(require("./pipelines/pipeline"), exports);
|
|
23
|
+
__exportStar(require("./systems/system-middleware"), exports);
|
|
24
|
+
__exportStar(require("./systems/system-pipeline"), exports);
|
|
25
|
+
__exportStar(require("./systems/system-pipeline-context"), exports);
|
|
26
|
+
__exportStar(require("./systems/system-pipeline-type"), exports);
|
|
27
|
+
__exportStar(require("./systems/system-runtime"), exports);
|
|
28
|
+
__exportStar(require("./utils/performance-timer"), exports);
|
|
17
29
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,yDAAsC;AACtC,kEAA+C;AAE/C,oDAAiC;AACjC,0DAAuC;AACvC,0DAAuC;AACvC,+DAA4C;AAC5C,8DAA2C;AAC3C,4DAAyC;AAEzC,yDAAsC;AACtC,uDAAoC;AAEpC,8DAA2C;AAC3C,4DAAyC;AACzC,oEAAiD;AACjD,iEAA8C;AAC9C,2DAAwC;AAExC,4DAAyC"}
|
|
@@ -2,6 +2,9 @@
|
|
|
2
2
|
* 'Stop' function, passed to a middleware. Call it to break the pipeline execution.
|
|
3
3
|
*/
|
|
4
4
|
export declare type Stop = () => void;
|
|
5
|
+
/**
|
|
6
|
+
* A middleware, the building block of a Pipeline. The middlewares will get called in the same order they get registered in the Pipeline.
|
|
7
|
+
*/
|
|
5
8
|
export interface IMiddleware<TContext> {
|
|
6
9
|
/**
|
|
7
10
|
* This (optional) function gets called before executing the middleware. It acts as a boolean gateway whether enough conditions are
|
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
import { EntityTypeUid, IEntity, IEntityModel } from "../entities/entity";
|
|
2
2
|
import { EntityProxy, IEntityProxy } from "../entities/entity-proxy";
|
|
3
|
-
import { ITriggerData } from "../entities/entity-trigger";
|
|
3
|
+
import { EntityTriggerUid, IEntityTrigger, ITriggerData } from "../entities/entity-trigger";
|
|
4
4
|
export interface IEntitySchedule {
|
|
5
5
|
target: IEntityProxy;
|
|
6
6
|
intervalMs?: number;
|
|
7
7
|
}
|
|
8
8
|
export interface ISystemPipelineContext<TEntity extends IEntity> {
|
|
9
9
|
readonly entity: TEntity;
|
|
10
|
-
addEntity(entityType: EntityTypeUid, model: IEntityModel): void;
|
|
11
|
-
addTrigger<TTriggerData extends ITriggerData>(target: IEntityProxy, data: TTriggerData): void;
|
|
10
|
+
addEntity(entityType: EntityTypeUid, model: IEntityModel, triggers?: ITriggerData[]): void;
|
|
12
11
|
updateEntity(target?: IEntityProxy, model?: IEntityModel): void;
|
|
13
12
|
removeEntity(target?: IEntityProxy): void;
|
|
14
13
|
scheduleUpdateOnInterval(target?: IEntityProxy, intervalMs?: number): void;
|
|
@@ -17,4 +16,14 @@ export interface ISystemPipelineContext<TEntity extends IEntity> {
|
|
|
17
16
|
registerProxy(proxy: IEntityProxy, cleanup?: boolean): void;
|
|
18
17
|
registerProxies(proxies: IEntityProxy[], cleanup?: boolean): void;
|
|
19
18
|
removeProxies(proxyEntityType?: EntityTypeUid): void;
|
|
19
|
+
addTrigger<TTriggerData extends ITriggerData>(target: IEntityProxy, data: TTriggerData): void;
|
|
20
|
+
addTriggers<TTriggerData extends ITriggerData>(target: IEntityProxy, data: TTriggerData[]): void;
|
|
21
|
+
/**
|
|
22
|
+
* Retrieve the first Trigger of the specified type.
|
|
23
|
+
* @param uid The Trigger type.
|
|
24
|
+
*/
|
|
25
|
+
getTrigger<TTriggerData extends ITriggerData>(uid: EntityTriggerUid): IEntityTrigger<TTriggerData>;
|
|
26
|
+
getTriggers<TTriggerData extends ITriggerData>(uid: EntityTriggerUid): IEntityTrigger<TTriggerData>[];
|
|
27
|
+
hasTriggers(uid?: EntityTriggerUid): boolean;
|
|
28
|
+
removeTriggers(uid?: EntityTriggerUid): void;
|
|
20
29
|
}
|
|
@@ -1,9 +1,12 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SystemPipelineType = void 0;
|
|
4
|
+
var SystemPipelineType;
|
|
2
5
|
(function (SystemPipelineType) {
|
|
3
6
|
SystemPipelineType["initialize"] = "initialize";
|
|
4
7
|
SystemPipelineType["update"] = "update";
|
|
5
8
|
SystemPipelineType["render"] = "render";
|
|
6
9
|
SystemPipelineType["sync"] = "sync";
|
|
7
10
|
SystemPipelineType["dispatch"] = "dispatch";
|
|
8
|
-
})(SystemPipelineType || (SystemPipelineType = {}));
|
|
11
|
+
})(SystemPipelineType = exports.SystemPipelineType || (exports.SystemPipelineType = {}));
|
|
9
12
|
//# sourceMappingURL=system-pipeline-type.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"system-pipeline-type.js","sourceRoot":"","sources":["../../src/systems/system-pipeline-type.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"system-pipeline-type.js","sourceRoot":"","sources":["../../src/systems/system-pipeline-type.ts"],"names":[],"mappings":";;;AAAA,IAAY,kBAMX;AAND,WAAY,kBAAkB;IAC5B,+CAAyB,CAAA;IACzB,uCAAiB,CAAA;IACjB,uCAAiB,CAAA;IACjB,mCAAa,CAAA;IACb,2CAAqB,CAAA;AACvB,CAAC,EANW,kBAAkB,GAAlB,0BAAkB,KAAlB,0BAAkB,QAM7B"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@awesome-ecs/abstract",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.2.2",
|
|
4
4
|
"description": "A comprehensive Entity-Component-System (ECS) Architecture implementation. Abstract components.",
|
|
5
5
|
"main": "./dist/index.js",
|
|
6
6
|
"types": "./dist/index.d.ts",
|
|
@@ -32,5 +32,5 @@
|
|
|
32
32
|
"url": "https://github.com/andreicojocaru/awesome-ecs/issues"
|
|
33
33
|
},
|
|
34
34
|
"homepage": "https://github.com/andreicojocaru/awesome-ecs#readme",
|
|
35
|
-
"gitHead": "
|
|
35
|
+
"gitHead": "ee7686721914451579e349f1d106501ae616399d"
|
|
36
36
|
}
|