definition-generator-framework 2.0.0-rc0 → 2.0.0
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/index.d.mts +7 -1
- package/dist/index.d.ts +7 -1
- package/dist/index.js +15 -15
- package/dist/index.mjs +15 -15
- package/package.json +2 -2
package/dist/index.d.mts
CHANGED
|
@@ -2,6 +2,9 @@ import Joi from 'joi';
|
|
|
2
2
|
import { Vec2, Vector } from 'helpers-lib';
|
|
3
3
|
import { ScriptDefinition, ScriptTestActionDefinition, ScriptEngineSimulatorFunctions } from 'script-engine-lib';
|
|
4
4
|
|
|
5
|
+
interface FileSystem {
|
|
6
|
+
existsSync: (path: string) => boolean;
|
|
7
|
+
}
|
|
5
8
|
interface AddFileOptions {
|
|
6
9
|
path: string;
|
|
7
10
|
variableName: string;
|
|
@@ -112,6 +115,9 @@ declare module 'joi' {
|
|
|
112
115
|
positionOnSprite(options: PositionOnSpriteValidationOptions): Joi.ObjectSchema;
|
|
113
116
|
}
|
|
114
117
|
}
|
|
118
|
+
declare class JoiCustomValidators {
|
|
119
|
+
static decorate(joi: object, fs: FileSystem): void;
|
|
120
|
+
}
|
|
115
121
|
|
|
116
122
|
interface ValidatedSpriteUrl {
|
|
117
123
|
readonly url: string;
|
|
@@ -195,4 +201,4 @@ declare class ScriptTesting<ScriptInputType, EventInputType> {
|
|
|
195
201
|
addCustomEventTestCase(customMessage: string, eventId: string, testCase: ScriptTestCasesDefinition): void;
|
|
196
202
|
}
|
|
197
203
|
|
|
198
|
-
export { DefinitionComponent, type DefinitionComponentClassType, DefinitionComponentDecorator, DefinitionGenerator, DefinitionGeneratorDecorator, DefinitionStore, type ErrorLog, EventComponent, type EventID, EventTestComponent, FixedArraySchema, FontComponent, type FontID, HexColorSchema, type LocationInFile, type Output, PixelPerfectSpriteSchema, PoligonSchema, RotationSchema, ScriptComponent, type ScriptID, ScriptTestComponent, ScriptTesting, SingleDefinitionComponent, SpriteComponent, SpriteGroupComponent, type SpriteGroupID, type SpriteID, SpriteSchema, type ValidatedSpriteUrl, Validator, Vec2Schema };
|
|
204
|
+
export { DefinitionComponent, type DefinitionComponentClassType, DefinitionComponentDecorator, DefinitionGenerator, DefinitionGeneratorDecorator, DefinitionStore, type ErrorLog, EventComponent, type EventID, EventTestComponent, FixedArraySchema, FontComponent, type FontID, HexColorSchema, JoiCustomValidators, type LocationInFile, type Output, PixelPerfectSpriteSchema, PoligonSchema, RotationSchema, ScriptComponent, type ScriptID, ScriptTestComponent, ScriptTesting, SingleDefinitionComponent, SpriteComponent, SpriteGroupComponent, type SpriteGroupID, type SpriteID, SpriteSchema, type ValidatedSpriteUrl, Validator, Vec2Schema };
|
package/dist/index.d.ts
CHANGED
|
@@ -2,6 +2,9 @@ import Joi from 'joi';
|
|
|
2
2
|
import { Vec2, Vector } from 'helpers-lib';
|
|
3
3
|
import { ScriptDefinition, ScriptTestActionDefinition, ScriptEngineSimulatorFunctions } from 'script-engine-lib';
|
|
4
4
|
|
|
5
|
+
interface FileSystem {
|
|
6
|
+
existsSync: (path: string) => boolean;
|
|
7
|
+
}
|
|
5
8
|
interface AddFileOptions {
|
|
6
9
|
path: string;
|
|
7
10
|
variableName: string;
|
|
@@ -112,6 +115,9 @@ declare module 'joi' {
|
|
|
112
115
|
positionOnSprite(options: PositionOnSpriteValidationOptions): Joi.ObjectSchema;
|
|
113
116
|
}
|
|
114
117
|
}
|
|
118
|
+
declare class JoiCustomValidators {
|
|
119
|
+
static decorate(joi: object, fs: FileSystem): void;
|
|
120
|
+
}
|
|
115
121
|
|
|
116
122
|
interface ValidatedSpriteUrl {
|
|
117
123
|
readonly url: string;
|
|
@@ -195,4 +201,4 @@ declare class ScriptTesting<ScriptInputType, EventInputType> {
|
|
|
195
201
|
addCustomEventTestCase(customMessage: string, eventId: string, testCase: ScriptTestCasesDefinition): void;
|
|
196
202
|
}
|
|
197
203
|
|
|
198
|
-
export { DefinitionComponent, type DefinitionComponentClassType, DefinitionComponentDecorator, DefinitionGenerator, DefinitionGeneratorDecorator, DefinitionStore, type ErrorLog, EventComponent, type EventID, EventTestComponent, FixedArraySchema, FontComponent, type FontID, HexColorSchema, type LocationInFile, type Output, PixelPerfectSpriteSchema, PoligonSchema, RotationSchema, ScriptComponent, type ScriptID, ScriptTestComponent, ScriptTesting, SingleDefinitionComponent, SpriteComponent, SpriteGroupComponent, type SpriteGroupID, type SpriteID, SpriteSchema, type ValidatedSpriteUrl, Validator, Vec2Schema };
|
|
204
|
+
export { DefinitionComponent, type DefinitionComponentClassType, DefinitionComponentDecorator, DefinitionGenerator, DefinitionGeneratorDecorator, DefinitionStore, type ErrorLog, EventComponent, type EventID, EventTestComponent, FixedArraySchema, FontComponent, type FontID, HexColorSchema, JoiCustomValidators, type LocationInFile, type Output, PixelPerfectSpriteSchema, PoligonSchema, RotationSchema, ScriptComponent, type ScriptID, ScriptTestComponent, ScriptTesting, SingleDefinitionComponent, SpriteComponent, SpriteGroupComponent, type SpriteGroupID, type SpriteID, SpriteSchema, type ValidatedSpriteUrl, Validator, Vec2Schema };
|
package/dist/index.js
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
'use strict';var helpersLib=require('helpers-lib'),
|
|
1
|
+
'use strict';var S=require('fs'),h=require('joi'),helpersLib=require('helpers-lib'),dt=require('path'),ee=require('prettier/plugins/estree'),ie=require('prettier/plugins/typescript'),standalone=require('prettier/standalone'),jsonpathPlus=require('jsonpath-plus'),pe=require('image-size'),Pt=require('glob'),scriptEngineLib=require('script-engine-lib');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var S__namespace=/*#__PURE__*/_interopNamespace(S);var h__default=/*#__PURE__*/_interopDefault(h);var dt__namespace=/*#__PURE__*/_interopNamespace(dt);var ee__namespace=/*#__PURE__*/_interopNamespace(ee);var ie__namespace=/*#__PURE__*/_interopNamespace(ie);var pe__default=/*#__PURE__*/_interopDefault(pe);var Pt__namespace=/*#__PURE__*/_interopNamespace(Pt);var w=(n,t,e,i)=>{for(var r=t,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=(s(r))||r);return r};var N=class{static generate(t){let e="";t.preText&&(e+=`${t.preText}
|
|
2
2
|
|
|
3
3
|
`);let i;if(t.assetUrl){if(!t.filePath)throw new Error("filePath is required when using assetUrl");if(!helpersLib.Comparator.isArray(t.variable))throw new Error("variable should be an array when using assetUrl");let{assetImports:r,replaceMap:o}=this.ɗi(t.variable,t.assetUrl,t.filePath);e+=r+`
|
|
4
4
|
|
|
5
|
-
`,i=o;}return t.variableType?e+=`export const ${t.variableName}: ${t.variableType} = ${this.ɗcb(t.variable)}`:e+=`export const ${t.variableName} = ${this.ɗcb(t.variable)}`,i&&(e=this.ɗbo(e,i)),t.replaceMap&&(e=this.ɗbo(e,t.replaceMap)),this.format(e)}static async format(t){return standalone.format(t,{parser:"typescript",trailingComma:"none",tabWidth:2,printWidth:130,singleQuote:true,arrowParens:"avoid",plugins:[
|
|
6
|
-
`),a=r.reduce((p,c)=>[...p,{target:`"${c}"`,replace:o.get(c)}],[]);return {assetImports:s,replaceMap:a}}static ɗcb(t){return JSON.stringify(t,(e,i)=>i===void 0?null:i).replace(/null/gm,"undefined")}};
|
|
7
|
-
`):t.preText,variableName:t.variableName,variableType:t.variableType,variable:t.variable,replaceMap:t.replaceMap,filePath:t.path,assetUrl:t.assetUrl})});}static get successful(){return this.errorLogs.length===0}static addErrorLog(t,e="default"){helpersLib.Comparator.isArray(t)?e==="lowPriority"?this.ɗu=[...t,...this.ɗu]:this.ɗu.push(...t):e==="lowPriority"?this.ɗu=[t,...this.ɗu]:this.ɗu.push(t);}static flushErrorLogs(){this.errorLogs=[...this.ɗu,...this.errorLogs],this.ɗu=[];}static{this.errorLogs=[];}static{this.ɗu=[];}};});var Z,_t=w(()=>{P();Z=class{constructor(t){this.ɗar=t;this.ɗav=new Set;this.ɗau=new Map;this.ɗb=new Set;this.ɗt=[];}newEntry(t,e){if(this.ɗav.has(t)){if(!this.ɗb.has(t)){this.ɗb.add(t);let i=this.ɗau.get(t);i&&this.ɗt.push({identifier:t,location:i});}return this.ɗt.push({identifier:t,location:e}),false}else return this.ɗav.add(t),this.ɗau.set(t,e),true}logDuplicateErrors(){this.ɗt.forEach(t=>{let e={description:`Value should be singular! Group: "${this.ɗar}", Value: "${t.identifier}"`,location:t.location};l.addErrorLog(e);});}};});var T,q=w(()=>{_t();T=class{static{this.ɗs=new Map;}static logDuplicates(){this.ɗs.forEach(t=>t.logDuplicateErrors());}static getDefinitionComponentName(t){return t.$meta.componentName}static getDefinitionComponentNamesFromArray(t){return helpersLib.Comparator.isArray(t)?t.map(e=>this.getDefinitionComponentName(e)):[this.getDefinitionComponentName(t)]}static getValidationState(t){return t.state.path&&(t.state.path.length===0||t.state.path[0]!==void 0&&t.prefs.context.rawDefinition)?"valid":"notValid"}static getPathAndRawDefinition(t){let e=t.state.path,i=t.prefs.context.rawDefinition;return {path:e,rawDefinition:i}}static getDuplicateHelper(t){let e=this.ɗs.get(t);return e||(e=new Z(t),this.ɗs.set(t,e)),e}};});var R,X=w(()=>{R=class{static findLine(t,e){if(e.length===0)return t.parsedStructure.line;{let i,r=[...e];for(;i===void 0&&r.length>0;)i=this.ɗz(t.parsedStructure.rawData,[...r]),r.pop();return i||t.parsedStructure.line}}static flatten(t){return this.ɗaa(t.parsedStructure.rawData)}static ɗz(t,e){let i=e.shift(),r;if(t&&i!==void 0&&(helpersLib.Comparator.isNumber(i)?helpersLib.Comparator.isArray(t)&&(r=t[i]):helpersLib.Comparator.isObject(t)&&(r=t[i])),r)return e.length===0?r.line:this.ɗz(r.rawData,e)}static ɗaa(t){if(helpersLib.Comparator.isArray(t))return t.map(e=>this.ɗaa(e.rawData));if(helpersLib.Comparator.isObject(t)){let e=t;return Object.keys(e).reduce((i,r)=>{let o=e[r];return i[r]=this.ɗaa(o.rawData),i},{})}else return t}};});exports.DefinitionStore=void 0;var j=w(()=>{X();exports.DefinitionStore=class{static{this.ɗas=new Map;}static{this.ɗp=new Map;}static{this.ɗq=new Map;}static{this.ɗh=new Map;}static getDefinitions(t){let e=this.ɗq.get(this.ɗal(t));return e?Array.from(e.values()):[]}static getDefinition(t,e){if(!t.$meta.keyName)throw new Error(`"${t.name}" doesn't have a keyName, getDefinition cannot be called on it.`);return this.ɗq.get(this.ɗal(t))?.get(e)}static getDefinitionOrFail(t,e){let i=this.getDefinition(t,e);if(!i)throw new Error(`No result found for "${e}" in "${t.name}".`);return i}static getSingletonDefinition(t){return this.ɗq.get(this.ɗal(t))?.get(this.ɗal(t))}static getSingletonDefinitionOrFail(t){let e=this.getSingletonDefinition(t);if(!e)throw new Error(`No result found for "${t.name}".`);return e}static getLocationInFile(t,e,i){let r=this.ɗp.get(t.name)?.get(e);if(!r)throw new Error(`No raw definition found for "${e}" in "${t.name}".`);return {line:R.findLine(r,i),path:r.location.path}}static getLocationInFileById(t,e,i){let r=this.ɗap(t,e);if(!r)throw new Error(`No raw definition found for "${e}" in "${t.name}".`);return {line:R.findLine(r,i),path:r.location.path}}static ɗay(t){return this.ɗq.has(t)}static ɗak(t){let e=this.ɗh.get(t);if(!e)throw new Error(`No component found for "${t}".`);return e}static ɗbw(t){t.forEach((e,i)=>{this.ɗq.set(i,new Map);}),this.ɗh=t;}static ɗbx(t,e,i){let r=this.ɗq.get(this.ɗal(t));r&&r.set(e,helpersLib.JsonHelper.deepCopy(i));}static ɗca(t,e){let i=this.ɗal(t),r=this.ɗq.get(i);r&&r.set(i,helpersLib.JsonHelper.deepCopy(e));}static ɗax(t,e){return !!this.ɗas.get(t.name)?.has(e)}static ɗap(t,e){return this.ɗas.get(t.name)?.get(e)}static ɗbz(t,e,i){this.ɗas.has(t.name)||this.ɗas.set(t.name,new Map);let r=this.ɗas.get(t.name);r&&r.set(e,helpersLib.JsonHelper.deepCopy(i));}static ɗby(t,e,i){this.ɗp.has(t.name)||this.ɗp.set(t.name,new Map);let r=this.ɗp.get(t.name);r&&r.set(e,helpersLib.JsonHelper.deepCopy(i));}static ɗal(t){return t.$meta.componentName}};});var ht,At=w(()=>{P();q();ht=class{constructor(t){this.ɗac=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(T.getValidationState(e)==="valid"){let{rawDefinition:r}=T.getPathAndRawDefinition(e);if(t=r.location.path.substring(0,r.location.path.lastIndexOf("/")+1)+t,this.ɗac.existsSync(t))try{let s=Ue__default.default(t);return {url:t.replace(l.config.projectRoot,"."),size:{x:s.width,y:s.height}}}catch{throw new Error(`The file in the path "${t}" is not an image`)}else throw new Error(`No file is found in the path: "${t}"`)}else throw new Error(`Internal Error; joi validation context for image validator: Path: "${e.state.path}", RawDefinition: "${JSON.stringify(e.prefs.context.rawDefinition)}"`)};}};});var St,te=w(()=>{P();q();St=class{constructor(t){this.ɗac=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(T.getValidationState(e)==="valid"){let{rawDefinition:r}=T.getPathAndRawDefinition(e);if(t=r.location.path.substring(0,r.location.path.lastIndexOf("/")+1)+t,this.ɗac.existsSync(t))return t.replace(l.config.projectRoot,".");throw new Error(`No file is found in the path: "${t}"`)}else throw new Error(`Internal Error; joi validation context for path validator: Path: "${e.state.path}", RawDefinition: "${JSON.stringify(e.prefs.context.rawDefinition)}"`)};}};});var Dt,ee=w(()=>{Dt=class{constructor(t,e,i,r){t={x:t.x*i,y:t.y*i},this.ɗbq=i,this.ɗe=r||false,this.ɗc=this.ɗai(t,e),this.ɗd=this.ɗaj(t,this.ɗc);}convertPositionToSpriteAnchor(t){t={x:t.x*this.ɗbq,y:t.y*this.ɗbq};let e={x:t.x+this.ɗd.topLeft.x,y:t.y+this.ɗd.topLeft.y};if(this.ɗe&&!this.ɗce(e))throw new Error(`location is outside of the sprite boundaries. Entered position: {x: ${t.x}, y: ${t.y}}, position on sprite: {x: ${e.x}, y: ${e.y}}, bounding box: ${JSON.stringify(this.ɗd)}.`);return e}getRotationFromAnchor(t){return helpersLib.Vector.fromVec2(t).radian.value}ɗce(t){return !(t.x<this.ɗd.topLeft.x||t.x>this.ɗd.bottomRight.x||t.y<this.ɗd.topLeft.y||t.y>this.ɗd.bottomRight.y)}ɗai(t,e){return {x:t.x*e.x,y:t.y*e.y}}ɗaj(t,e){return {topLeft:{x:-e.x,y:-e.y},bottomRight:{x:t.x-e.x,y:t.y-e.y}}}};});var Ct,ie=w(()=>{ee();Ct=class{constructor(t){this.ɗbd=t;this.validate=(t,e)=>{let i=this.ɗbd.selectSpriteDefinition(t);if(!i)throw new Error("positionOnSprite - callback function did not return sprite definition.");let r=new Dt(i.url.size,i.anchor,i.scale,this.ɗbd.checkIfPositionIsOnSprite);return (Array.isArray(this.ɗbd.positionsJsonPath)?this.ɗbd.positionsJsonPath:[this.ɗbd.positionsJsonPath]).forEach(s=>jsonpathPlus.JSONPath({json:t,path:s}).forEach(a=>{if(helpersLib.Comparator.isObject(a)){if(!helpersLib.Comparator.isNumber(a.x)||!helpersLib.Comparator.isNumber(a.y))throw new Error(`positionOnSprite, positions json path returned a non-vec2 result. Value: "${a}".`)}else throw new Error(`positionOnSprite, positions json path returned a non-object result. Value: "${a}".`);let p=r.convertPositionToSpriteAnchor(a);p={x:Math.round(p.x),y:Math.round(p.y)},this.ɗbd.includeRotationFromAnchor?(a.rotationFromAnchor=r.getRotationFromAnchor(p),a.positionFromAnchor=p,delete a.x,delete a.y):(a.x=p.x,a.y=p.y);})),t};}};});var Tt,wt,xt,re=w(()=>{P();j();X();q();Tt=class{constructor(t){this.options=t;this.regex=/^[a-z]+([a-zA-Z0-9]+)*$/;}validatePropertyExistence(t,e,i){if(i?.additionalValidation){let r=exports.DefinitionStore.ɗap(t,e),o=r?R.flatten(r):void 0,s=i.additionalValidation.validate(o);if(s.error)throw new Error(s.error.message)}}},wt=class extends Tt{constructor(e,i){super(i);this.validate=(e,i)=>{if(T.getValidationState(i)==="valid"){let o=this.ɗbl.find(s=>exports.DefinitionStore.getDefinition(s,e));if(o)return this.validatePropertyExistence(o,e,this.options),this.ɗaw?{value:e,type:T.getDefinitionComponentName(o)}:e;if(this.ɗbl.find(a=>exports.DefinitionStore.ɗax(a,e)))i.prefs.context.failSilently=true;else throw new Error(`There is no "${this.ɗbl.map(a=>T.getDefinitionComponentName(a)).join(" or ")}" definition found for "${e}"`)}else throw new Error(`Internal Error; joi validation context for reference validator: Path: "${i.state.path}", RawDefinition: "${JSON.stringify(i.prefs.context)}"`)};this.ɗbl=[];helpersLib.Comparator.isArray(e)?(this.ɗaw=true,this.ɗbl=e):(this.ɗaw=false,this.ɗbl=[e]);}},xt=class extends Tt{constructor(e,i){super(i);this.ɗg=e;this.validate=(e,i)=>{if(!l.componentInProgressData)helpersLib.ConsoleHelper.log("Unexpected error: Lazy reference validation has been called outside of the validation cycle.","red");else if(!l.componentInProgressData.meta.keyName)helpersLib.ConsoleHelper.log("Lazy reference can only be used for definitions with key name defined.","red");else if(l.componentInProgressData.meta.componentName!==this.ɗg)helpersLib.ConsoleHelper.log(`Lazy reference can only be used for self referencing. It is used under: "${this.ɗg}"`,"red");else if(l.componentInProgressData.meta.singleton)helpersLib.ConsoleHelper.log(`Lazy reference cannot be used for singleton components. It is used under: "${this.ɗg}"`,"red");else {let a=i.state.ancestors.at(-1)[l.componentInProgressData.meta.keyName];a?(l.componentInProgressData.idToReferencesMap.has(a)||l.componentInProgressData.idToReferencesMap.set(a,new Set),l.componentInProgressData.idToReferencesMap.get(a).add(e)):helpersLib.ConsoleHelper.log("Unexpected error: definitionId cannot be retrieved by keyname.","red");}let r=exports.DefinitionStore.ɗak(this.ɗg);if(T.getValidationState(i)==="valid"){if(exports.DefinitionStore.ɗax(r,e))return this.validatePropertyExistence(r,e,this.options),e;throw new Error(`There is no "${this.ɗg}" definition found for "${e}"`)}else throw new Error(`Internal Error; joi validation context for reference validator: Path: "${i.state.path}", RawDefinition: "${JSON.stringify(i.prefs.context)}"`)};}};});var vt,ne=w(()=>{vt=class{constructor(t){this.ɗbb=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(this.ɗbb.has(t))throw new Error(`Value "${t}" is not unique in the name space: "${Array.from(this.ɗbb).join(", ")}"`);return this.ɗbb.add(t),t};}};});var bt,ae=w(()=>{te();ie();re();At();ne();bt=class n{static decorate(t,e){t.string().__proto__.unique=function(i){let r=new vt(i);return n.ɗn(this,r)},t.string().__proto__.path=function(){let i=new St(e);return n.ɗn(this,i)},t.string().__proto__.sprite=function(){let i=new ht(e);return n.ɗn(this,i)},t.string().__proto__.reference=function(i,r){let o=new wt(i,r);return n.ɗn(this,o)},t.string().__proto__.lazyReference=function(i,r){let o=new xt(i,r);return n.ɗn(this,o)},t.object().__proto__.positionOnSprite=function(i){let r=new Ct(i);return this.custom(r.validate)},t!==h__default.default&&this.decorate(h__default.default,e);}static ɗn(t,e){return t.regex(e.regex).custom(e.validate)}};});var se=w(()=>{ae();bt.decorate(h__default.default,S__namespace.default);});function ge(n){return n.replace(/[-_]/g," ").replace(/([a-z])([A-Z])/g,"$1 $2").replace(/\s+/g," ").trim().toLowerCase().split(" ").map(t=>t.charAt(0).toUpperCase()+t.slice(1)).join("")}function C(n){return function(t){if(n.singleton){if(n.keyName!==void 0)throw new Error(`Singleton components should not have keyName! Component: ${n.componentName}`);if(!(t.prototype instanceof Q))throw new Error(`Singleton components should extend SingleDefinitionComponent! Component: ${n.componentName}`)}else if(!(t.prototype instanceof g))throw new Error(`Non singleton components should extend DefinitionComponent! Component: ${n.componentName}`);t.$meta={componentName:n.componentName,pascalCaseComponentName:ge(n.componentName),keyName:n.keyName,singleton:n.singleton,validationSchema:n.validationSchema};}}var g=class{static getSchema(){return this.$meta.validationSchema}},Q=class{static getSchema(){return this.$meta.validationSchema}};q();P();X();var O=class{static{this.definitionToRawDefintion=new Map;}static getRawDefinitions(t){return l.rawDefinitions.filter(e=>e.componentName===t)}static validateAndConvert(t,e){return this.getRawDefinitions(t).map(i=>{let r=this.ɗcd(i,e);if(this.definitionToRawDefintion.set(r,i),r)return {definition:r,rawDefinition:i}}).filter(i=>i)}static validateAndConvertSingular(t,e){let i=this.validateAndConvert(t,e);if(i.length===0){if(l.successful){let r={description:`Singleton definition has no declared entry "${t}"`,location:{line:0,path:"*"}};l.addErrorLog(r,"lowPriority");}}else if(i.length>1)l.rawDefinitions.filter(r=>r.componentName===t).forEach(r=>{let o={description:`Only one definition can be defined for "${t}"`,location:r.location};l.addErrorLog(o,"lowPriority");});else return i[0]}static ɗcd(t,e){let i={rawDefinition:t,failSilently:false},{value:r,error:o}=e.validate(R.flatten(t),{abortEarly:false,context:i});if(o?.details){let s=o.details.reverse().map(a=>({description:a.message,location:{line:R.findLine(t,a.path),path:t.location.path}}));l.addErrorLog(s.reverse());}else if(!i.failSilently)return r}};P();var Y="CONFIG",Ut=h__default.default.object().keys({projectRoot:h__default.default.string().regex(/^[\S]+$/).required(),compilerModulesPath:h__default.default.string().regex(/^[\S]+$/).optional()}),B=class{static{this.$meta={componentName:Y,validationSchema:Ut};}static process(){let t=O.validateAndConvertSingular(Y,Ut);if(t){let e=t.definition;l.config.projectRoot=e.projectRoot,e.compilerModulesPath&&(l.config.compilerModulesPath=`${e.projectRoot}${e.compilerModulesPath.replace("./","")}`);}}};P();j();var Pt=class{decorateDefinitionName(t,e){return `${this.kebabCaseToCamelCase(e)}${this.upperCaseFirstLetter(t)}`}kebabCaseToCamelCase(t){return t.toLowerCase().replace(/-./g,e=>e[1].toUpperCase())}lowerCaseFirstLetter(t){return t.charAt(0).toLowerCase()+t.slice(1)}upperCaseFirstLetter(t){return t.charAt(0).toUpperCase()+t.slice(1)}removeWhiteSpace(t){return t.replace(/\r?\n|\r/g,"").replace(/\/\/.*$/gm,"").trim().replace(/ {2,}/g," ")}removeComments(t){return t.replace(/\/\/.*$/gm,"").trimEnd()}},_=new Pt;var et=class{constructor(){this.ɗr=false;this.ɗo=[];this.ɗv=[];this.ɗl="";}process(t){return this.ɗr=false,this.ɗm=void 0,this.ɗo=[],this.ɗv=[],this.ɗl=t.path,t.content.split(`
|
|
8
|
-
`).forEach((e,i)=>{let r=
|
|
9
|
-
`)}}else throw {description:`Multiline string should end with backtick in new line "${i}"!`,location:{line:e.line+t.length,path:e.path}}}};var
|
|
5
|
+
`,i=o;}return t.variableType?e+=`export const ${t.variableName}: ${t.variableType} = ${this.ɗcb(t.variable)}`:e+=`export const ${t.variableName} = ${this.ɗcb(t.variable)}`,i&&(e=this.ɗbo(e,i)),t.replaceMap&&(e=this.ɗbo(e,t.replaceMap)),this.format(e)}static async format(t){return standalone.format(t,{parser:"typescript",trailingComma:"none",tabWidth:2,printWidth:130,singleQuote:true,arrowParens:"avoid",plugins:[ie__namespace,ee__namespace]})}static ɗj(t,e){let i=l.outputPath+t.substring(0,t.lastIndexOf("/")),r=l.config.projectRoot+e.substring(1);return dt__namespace.default.relative(i,r).replace(/\\/g,"/")}static ɗbo(t,e){return e.forEach(i=>{t=t.replace(new RegExp(i.target,"g"),i.replace);}),t}static ɗi(t,e,i){let r=t.map(p=>{let c=helpersLib.JsonHelper.deepFind(p,e);if(!c)throw new Error(`OutputHelperClass: Asset url is not found in the given variable! item: "${JSON.stringify(p)}", assetUrl: "${e}"`);return c}),o=new Map;r.forEach(p=>{if(!o.has(p)){let c=`asset${o.size}`;o.set(p,c);}});let s=Array.from(o,([p,c])=>({name:c,url:p})).map(p=>`import ${p.name} from '${this.ɗj(i,p.url)}';`).join(`
|
|
6
|
+
`),a=r.reduce((p,c)=>[...p,{target:`"${c}"`,replace:o.get(c)}],[]);return {assetImports:s,replaceMap:a}}static ɗcb(t){return JSON.stringify(t,(e,i)=>i===void 0?null:i).replace(/null/gm,"undefined")}};var l=class{static{this.compilerExecutionPath="";}static{this.outputPath="";}static{this.config={projectRoot:"",compilerModulesPath:""};}static{this.rawDefinitions=[];}static{this.files=[];}static{this.output=[];}static{this.exports=[];}static{this.componentInProgressData=void 0;}static async addFile(t){this.exports.push({variableName:t.variableName,path:t.path}),this.output.push({path:t.path,content:await N.generate({preText:helpersLib.Comparator.isArray(t.preText)?t.preText.join(`
|
|
7
|
+
`):t.preText,variableName:t.variableName,variableType:t.variableType,variable:t.variable,replaceMap:t.replaceMap,filePath:t.path,assetUrl:t.assetUrl})});}static get successful(){return this.errorLogs.length===0}static addErrorLog(t,e="default"){helpersLib.Comparator.isArray(t)?e==="lowPriority"?this.ɗu=[...t,...this.ɗu]:this.ɗu.push(...t):e==="lowPriority"?this.ɗu=[t,...this.ɗu]:this.ɗu.push(t);}static flushErrorLogs(){this.errorLogs=[...this.ɗu,...this.errorLogs],this.ɗu=[];}static{this.errorLogs=[];}static{this.ɗu=[];}static reset(){this.compilerExecutionPath="D:/test",this.outputPath="D:/test/.asset-build",this.config.projectRoot="D:/",this.files=[],this.rawDefinitions=[],this.errorLogs=[],this.ɗu=[],this.output=[];}};var G=class{constructor(t){this.ɗar=t;this.ɗav=new Set;this.ɗau=new Map;this.ɗb=new Set;this.ɗt=[];}newEntry(t,e){if(this.ɗav.has(t)){if(!this.ɗb.has(t)){this.ɗb.add(t);let i=this.ɗau.get(t);i&&this.ɗt.push({identifier:t,location:i});}return this.ɗt.push({identifier:t,location:e}),false}else return this.ɗav.add(t),this.ɗau.set(t,e),true}logDuplicateErrors(){this.ɗt.forEach(t=>{let e={description:`Value should be singular! Group: "${this.ɗar}", Value: "${t.identifier}"`,location:t.location};l.addErrorLog(e);});}};var C=class{static{this.ɗs=new Map;}static logDuplicates(){this.ɗs.forEach(t=>t.logDuplicateErrors());}static getDefinitionComponentName(t){return t.$meta.componentName}static getDefinitionComponentNamesFromArray(t){return helpersLib.Comparator.isArray(t)?t.map(e=>this.getDefinitionComponentName(e)):[this.getDefinitionComponentName(t)]}static getValidationState(t){return t.state.path&&(t.state.path.length===0||t.state.path[0]!==void 0&&t.prefs.context.rawDefinition)?"valid":"notValid"}static getPathAndRawDefinition(t){let e=t.state.path,i=t.prefs.context.rawDefinition;return {path:e,rawDefinition:i}}static getDuplicateHelper(t){let e=this.ɗs.get(t);return e||(e=new G(t),this.ɗs.set(t,e)),e}};var W=class{constructor(t){this.ɗac=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(C.getValidationState(e)==="valid"){let{rawDefinition:r}=C.getPathAndRawDefinition(e);if(t=r.location.path.substring(0,r.location.path.lastIndexOf("/")+1)+t,this.ɗac.existsSync(t))return t.replace(l.config.projectRoot,".");throw new Error(`No file is found in the path: "${t}"`)}else throw new Error(`Internal Error; joi validation context for path validator: Path: "${e.state.path}", RawDefinition: "${JSON.stringify(e.prefs.context.rawDefinition)}"`)};}};var K=class{constructor(t,e,i,r){t={x:t.x*i,y:t.y*i},this.ɗbq=i,this.ɗe=r||false,this.ɗc=this.ɗai(t,e),this.ɗd=this.ɗaj(t,this.ɗc);}convertPositionToSpriteAnchor(t){t={x:t.x*this.ɗbq,y:t.y*this.ɗbq};let e={x:t.x+this.ɗd.topLeft.x,y:t.y+this.ɗd.topLeft.y};if(this.ɗe&&!this.ɗce(e))throw new Error(`location is outside of the sprite boundaries. Entered position: {x: ${t.x}, y: ${t.y}}, position on sprite: {x: ${e.x}, y: ${e.y}}, bounding box: ${JSON.stringify(this.ɗd)}.`);return e}getRotationFromAnchor(t){return helpersLib.Vector.fromVec2(t).radian.value}ɗce(t){return !(t.x<this.ɗd.topLeft.x||t.x>this.ɗd.bottomRight.x||t.y<this.ɗd.topLeft.y||t.y>this.ɗd.bottomRight.y)}ɗai(t,e){return {x:t.x*e.x,y:t.y*e.y}}ɗaj(t,e){return {topLeft:{x:-e.x,y:-e.y},bottomRight:{x:t.x-e.x,y:t.y-e.y}}}};var Q=class{constructor(t){this.ɗbd=t;this.validate=(t,e)=>{let i=this.ɗbd.selectSpriteDefinition(t);if(!i)throw new Error("positionOnSprite - callback function did not return sprite definition.");let r=new K(i.url.size,i.anchor,i.scale,this.ɗbd.checkIfPositionIsOnSprite);return (Array.isArray(this.ɗbd.positionsJsonPath)?this.ɗbd.positionsJsonPath:[this.ɗbd.positionsJsonPath]).forEach(s=>jsonpathPlus.JSONPath({json:t,path:s}).forEach(a=>{if(helpersLib.Comparator.isObject(a)){if(!helpersLib.Comparator.isNumber(a.x)||!helpersLib.Comparator.isNumber(a.y))throw new Error(`positionOnSprite, positions json path returned a non-vec2 result. Value: "${a}".`)}else throw new Error(`positionOnSprite, positions json path returned a non-object result. Value: "${a}".`);let p=r.convertPositionToSpriteAnchor(a);p={x:Math.round(p.x),y:Math.round(p.y)},this.ɗbd.includeRotationFromAnchor?(a.rotationFromAnchor=r.getRotationFromAnchor(p),a.positionFromAnchor=p,delete a.x,delete a.y):(a.x=p.x,a.y=p.y);})),t};}};var $=class{static findLine(t,e){if(e.length===0)return t.parsedStructure.line;{let i,r=[...e];for(;i===void 0&&r.length>0;)i=this.ɗz(t.parsedStructure.rawData,[...r]),r.pop();return i||t.parsedStructure.line}}static flatten(t){return this.ɗaa(t.parsedStructure.rawData)}static ɗz(t,e){let i=e.shift(),r;if(t&&i!==void 0&&(helpersLib.Comparator.isNumber(i)?helpersLib.Comparator.isArray(t)&&(r=t[i]):helpersLib.Comparator.isObject(t)&&(r=t[i])),r)return e.length===0?r.line:this.ɗz(r.rawData,e)}static ɗaa(t){if(helpersLib.Comparator.isArray(t))return t.map(e=>this.ɗaa(e.rawData));if(helpersLib.Comparator.isObject(t)){let e=t;return Object.keys(e).reduce((i,r)=>{let o=e[r];return i[r]=this.ɗaa(o.rawData),i},{})}else return t}};var m=class{static{this.ɗas=new Map;}static{this.ɗp=new Map;}static{this.ɗq=new Map;}static{this.ɗh=new Map;}static getDefinitions(t){let e=this.ɗq.get(this.ɗal(t));return e?Array.from(e.values()):[]}static getDefinition(t,e){if(!t.$meta.keyName)throw new Error(`"${t.name}" doesn't have a keyName, getDefinition cannot be called on it.`);return this.ɗq.get(this.ɗal(t))?.get(e)}static getDefinitionOrFail(t,e){let i=this.getDefinition(t,e);if(!i)throw new Error(`No result found for "${e}" in "${t.name}".`);return i}static getSingletonDefinition(t){return this.ɗq.get(this.ɗal(t))?.get(this.ɗal(t))}static getSingletonDefinitionOrFail(t){let e=this.getSingletonDefinition(t);if(!e)throw new Error(`No result found for "${t.name}".`);return e}static getLocationInFile(t,e,i){let r=this.ɗp.get(t.name)?.get(e);if(!r)throw new Error(`No raw definition found for "${e}" in "${t.name}".`);return {line:$.findLine(r,i),path:r.location.path}}static getLocationInFileById(t,e,i){let r=this.ɗap(t,e);if(!r)throw new Error(`No raw definition found for "${e}" in "${t.name}".`);return {line:$.findLine(r,i),path:r.location.path}}static ɗay(t){return this.ɗq.has(t)}static ɗak(t){let e=this.ɗh.get(t);if(!e)throw new Error(`No component found for "${t}".`);return e}static ɗbw(t){t.forEach((e,i)=>{this.ɗq.set(i,new Map);}),this.ɗh=t;}static ɗbx(t,e,i){let r=this.ɗq.get(this.ɗal(t));r&&r.set(e,helpersLib.JsonHelper.deepCopy(i));}static ɗca(t,e){let i=this.ɗal(t),r=this.ɗq.get(i);r&&r.set(i,helpersLib.JsonHelper.deepCopy(e));}static ɗax(t,e){return !!this.ɗas.get(t.name)?.has(e)}static ɗap(t,e){return this.ɗas.get(t.name)?.get(e)}static ɗbz(t,e,i){this.ɗas.has(t.name)||this.ɗas.set(t.name,new Map);let r=this.ɗas.get(t.name);r&&r.set(e,helpersLib.JsonHelper.deepCopy(i));}static ɗby(t,e,i){this.ɗp.has(t.name)||this.ɗp.set(t.name,new Map);let r=this.ɗp.get(t.name);r&&r.set(e,helpersLib.JsonHelper.deepCopy(i));}static ɗal(t){return t.$meta.componentName}};var X=class{constructor(t){this.options=t;this.regex=/^[a-z]+([a-zA-Z0-9]+)*$/;}validatePropertyExistence(t,e,i){if(i?.additionalValidation){let r=m.ɗap(t,e),o=r?$.flatten(r):void 0,s=i.additionalValidation.validate(o);if(s.error)throw new Error(s.error.message)}}},Y=class extends X{constructor(e,i){super(i);this.validate=(e,i)=>{if(C.getValidationState(i)==="valid"){let o=this.ɗbl.find(s=>m.getDefinition(s,e));if(o)return this.validatePropertyExistence(o,e,this.options),this.ɗaw?{value:e,type:C.getDefinitionComponentName(o)}:e;if(this.ɗbl.find(a=>m.ɗax(a,e)))i.prefs.context.failSilently=true;else throw new Error(`There is no "${this.ɗbl.map(a=>C.getDefinitionComponentName(a)).join(" or ")}" definition found for "${e}"`)}else throw new Error(`Internal Error; joi validation context for reference validator: Path: "${i.state.path}", RawDefinition: "${JSON.stringify(i.prefs.context)}"`)};this.ɗbl=[];helpersLib.Comparator.isArray(e)?(this.ɗaw=true,this.ɗbl=e):(this.ɗaw=false,this.ɗbl=[e]);}},tt=class extends X{constructor(e,i){super(i);this.ɗg=e;this.validate=(e,i)=>{if(!l.componentInProgressData)helpersLib.ConsoleHelper.log("Unexpected error: Lazy reference validation has been called outside of the validation cycle.","red");else if(!l.componentInProgressData.meta.keyName)helpersLib.ConsoleHelper.log("Lazy reference can only be used for definitions with key name defined.","red");else if(l.componentInProgressData.meta.componentName!==this.ɗg)helpersLib.ConsoleHelper.log(`Lazy reference can only be used for self referencing. It is used under: "${this.ɗg}"`,"red");else if(l.componentInProgressData.meta.singleton)helpersLib.ConsoleHelper.log(`Lazy reference cannot be used for singleton components. It is used under: "${this.ɗg}"`,"red");else {let a=i.state.ancestors.at(-1)[l.componentInProgressData.meta.keyName];a?(l.componentInProgressData.idToReferencesMap.has(a)||l.componentInProgressData.idToReferencesMap.set(a,new Set),l.componentInProgressData.idToReferencesMap.get(a).add(e)):helpersLib.ConsoleHelper.log("Unexpected error: definitionId cannot be retrieved by keyname.","red");}let r=m.ɗak(this.ɗg);if(C.getValidationState(i)==="valid"){if(m.ɗax(r,e))return this.validatePropertyExistence(r,e,this.options),e;throw new Error(`There is no "${this.ɗg}" definition found for "${e}"`)}else throw new Error(`Internal Error; joi validation context for reference validator: Path: "${i.state.path}", RawDefinition: "${JSON.stringify(i.prefs.context)}"`)};}};var et=class{constructor(t){this.ɗac=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(C.getValidationState(e)==="valid"){let{rawDefinition:r}=C.getPathAndRawDefinition(e);if(t=r.location.path.substring(0,r.location.path.lastIndexOf("/")+1)+t,this.ɗac.existsSync(t))try{let s=pe__default.default(t);return {url:t.replace(l.config.projectRoot,"."),size:{x:s.width,y:s.height}}}catch{throw new Error(`The file in the path "${t}" is not an image`)}else throw new Error(`No file is found in the path: "${t}"`)}else throw new Error(`Internal Error; joi validation context for image validator: Path: "${e.state.path}", RawDefinition: "${JSON.stringify(e.prefs.context.rawDefinition)}"`)};}};var it=class{constructor(t){this.ɗbb=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(this.ɗbb.has(t))throw new Error(`Value "${t}" is not unique in the name space: "${Array.from(this.ɗbb).join(", ")}"`);return this.ɗbb.add(t),t};}};var H=class n{static decorate(t,e){t.string().__proto__.unique=function(i){let r=new it(i);return n.ɗn(this,r)},t.string().__proto__.path=function(){let i=new W(e);return n.ɗn(this,i)},t.string().__proto__.sprite=function(){let i=new et(e);return n.ɗn(this,i)},t.string().__proto__.reference=function(i,r){let o=new Y(i,r);return n.ɗn(this,o)},t.string().__proto__.lazyReference=function(i,r){let o=new tt(i,r);return n.ɗn(this,o)},t.object().__proto__.positionOnSprite=function(i){let r=new Q(i);return this.custom(r.validate)},t!==h__default.default&&this.decorate(h__default.default,e);}static ɗn(t,e){return t.regex(e.regex).custom(e.validate)}};H.decorate(h__default.default,S__namespace.default);function me(n){return n.replace(/[-_]/g," ").replace(/([a-z])([A-Z])/g,"$1 $2").replace(/\s+/g," ").trim().toLowerCase().split(" ").map(t=>t.charAt(0).toUpperCase()+t.slice(1)).join("")}function T(n){return function(t){if(n.singleton){if(n.keyName!==void 0)throw new Error(`Singleton components should not have keyName! Component: ${n.componentName}`);if(!(t.prototype instanceof rt))throw new Error(`Singleton components should extend SingleDefinitionComponent! Component: ${n.componentName}`)}else if(!(t.prototype instanceof g))throw new Error(`Non singleton components should extend DefinitionComponent! Component: ${n.componentName}`);t.$meta={componentName:n.componentName,pascalCaseComponentName:me(n.componentName),keyName:n.keyName,singleton:n.singleton,validationSchema:n.validationSchema};}}var g=class{static getSchema(){return this.$meta.validationSchema}},rt=class{static getSchema(){return this.$meta.validationSchema}};var R=class{static{this.definitionToRawDefintion=new Map;}static getRawDefinitions(t){return l.rawDefinitions.filter(e=>e.componentName===t)}static validateAndConvert(t,e){return this.getRawDefinitions(t).map(i=>{let r=this.ɗcd(i,e);if(this.definitionToRawDefintion.set(r,i),r)return {definition:r,rawDefinition:i}}).filter(i=>i)}static validateAndConvertSingular(t,e){let i=this.validateAndConvert(t,e);if(i.length===0){if(l.successful){let r={description:`Singleton definition has no declared entry "${t}"`,location:{line:0,path:"*"}};l.addErrorLog(r,"lowPriority");}}else if(i.length>1)l.rawDefinitions.filter(r=>r.componentName===t).forEach(r=>{let o={description:`Only one definition can be defined for "${t}"`,location:r.location};l.addErrorLog(o,"lowPriority");});else return i[0]}static ɗcd(t,e){let i={rawDefinition:t,failSilently:false},{value:r,error:o}=e.validate($.flatten(t),{abortEarly:false,context:i});if(o?.details){let s=o.details.reverse().map(a=>({description:a.message,location:{line:$.findLine(t,a.path),path:t.location.path}}));l.addErrorLog(s.reverse());}else if(!i.failSilently)return r}};var nt="CONFIG",Jt=h__default.default.object().keys({projectRoot:h__default.default.string().regex(/^[\S]+$/).required(),compilerModulesPath:h__default.default.string().regex(/^[\S]+$/).optional()}),J=class{static{this.$meta={componentName:nt,validationSchema:Jt};}static process(){let t=R.validateAndConvertSingular(nt,Jt);if(t){let e=t.definition;l.config.projectRoot=e.projectRoot,e.compilerModulesPath&&(l.config.compilerModulesPath=`${e.projectRoot}${e.compilerModulesPath.replace("./","")}`);}}};var xt=class{decorateDefinitionName(t,e){return `${this.kebabCaseToCamelCase(e)}${this.upperCaseFirstLetter(t)}`}kebabCaseToCamelCase(t){return t.toLowerCase().replace(/-./g,e=>e[1].toUpperCase())}lowerCaseFirstLetter(t){return t.charAt(0).toLowerCase()+t.slice(1)}upperCaseFirstLetter(t){return t.charAt(0).toUpperCase()+t.slice(1)}removeWhiteSpace(t){return t.replace(/\r?\n|\r/g,"").replace(/\/\/.*$/gm,"").trim().replace(/ {2,}/g," ")}removeComments(t){return t.replace(/\/\/.*$/gm,"").trimEnd()}},q=new xt;var ot=class{constructor(){this.ɗr=false;this.ɗo=[];this.ɗv=[];this.ɗl="";}process(t){return this.ɗr=false,this.ɗm=void 0,this.ɗo=[],this.ɗv=[],this.ɗl=t.path,t.content.split(`
|
|
8
|
+
`).forEach((e,i)=>{let r=q.removeWhiteSpace(e);this.ɗr?r.startsWith("###")?(this.ɗab(),this.ɗbc(e,i,r.substring(4))):this.ɗm&&r.length>0&&this.ɗm.content.push(q.removeComments(e)):r==="# DEFINITIONS"&&(this.ɗr=true);}),this.ɗab(),{definitionPlaneTexts:this.ɗo,errorLogs:this.ɗv}}ɗab(){if(this.ɗm)if(this.ɗm.content.length>0)this.ɗo.push(this.ɗm);else {let t={description:"Definitions cannot be empty!",location:this.ɗm.location};this.ɗv.push(t);}this.ɗm=void 0;}ɗbc(t,e,i){if(m.ɗay(i))this.ɗm={type:i,location:{line:e+1,path:this.ɗl},content:[]};else {let r={description:`Invalid definition header: "${t.trim()}"`,location:{line:e+1,path:this.ɗl}};this.ɗv.push(r),this.ɗm=void 0;}}};var at=class{static parse(t,e){let i=[],r=e.line,o=[];if(t.forEach((s,a)=>{if(s.startsWith(" ")){if(a===0)throw {description:"Invalid coding indent!",location:{line:e.line+a,path:e.path}};i.push(s.substring(2));}else {if(s.match(/^- {2}/g)||s.match(/^-[\S]/g))throw {description:`There should be one space after dash operator! "${s}"`,location:{line:e.line+a,path:e.path}};if(s.startsWith("-")){if(i.length){let p=b.getParsedStructure(i,{line:r,path:e.path});o.push(p);}i=[s.substring(2)],r=e.line+a;}else throw s.startsWith(" ")?{description:"Invalid coding indent!",location:{line:e.line+a,path:e.path}}:{description:`Unexpected array element! "${s}"`,location:{line:e.line+a,path:e.path}}}}),i.length){let s=b.getParsedStructure(i,{line:r,path:e.path});o.push(s);}return {line:e.line,rawData:o}}};var st=class{static parse(t,e){let i=[],r="",o=0,s,a={};if(t.forEach((p,c)=>{if(!p.startsWith(" ")&&!p.startsWith("- ")&&s!=="multiLineString"){if(p.startsWith(":"))throw {description:`Invalid row, row cannot start with columns! "${p}"`,location:{line:e.line+c,path:e.path}};if(p.match(/[\w]*:[\w]*:/g))throw {description:`Invalid row, multiple columns! "${p}"`,location:{line:e.line+c,path:e.path}};if(p.match(/: {2}/g)||p.match(/^[\w]+:[\S]/g))throw {description:`There should be one space after column operator! "${p}"`,location:{line:e.line+c,path:e.path}};if(p.startsWith(" "))throw {description:`Invalid coding indent! "${p}"`,location:{line:e.line+c,path:e.path}};if(p.indexOf(":")===-1)throw {description:`Unexpected object element! "${p}"`,location:{line:e.line+c,path:e.path}};{if(i.length){let I=b.getParsedStructure(i,{line:o,path:e.path});I.line-=1,a[r]=I,i=[],r="",o=0;}let d=q.lowerCaseFirstLetter(p.substring(0,p.indexOf(":")));if(p.trimEnd().endsWith(":"))if(r=d,o=e.line+c+1,t[c+1])s=t[c+1].startsWith("-")?"array":"object";else throw {description:`No value found after column! "${p}"`,location:{line:e.line+c,path:e.path}};else if(p.trimEnd().endsWith("`")&&p.indexOf("`")===p.lastIndexOf("`"))i.push("`"),r=d,o=e.line+c+1,s="multiLineString";else {let I=p.substring(p.indexOf(":")+2),U=b.getParsedStructure([I],{line:e.line+c,path:e.path});a[d]=U;}}}else {if(c===0)throw p.startsWith("-")?{description:`Unexpected object element! "${p}"`,location:{line:e.line+c,path:e.path}}:{description:`Invalid coding indent! "${p}"`,location:{line:e.line+c,path:e.path}};if(p.startsWith("`")){i.push(p);let d=b.getParsedStructure(i,{line:o,path:e.path});d.line-=1,a[r]=d,i=[],r="",o=0;}else i.push(p.substring(s==="object"?2:0));}}),i.length){let p=b.getParsedStructure(i,{line:o,path:e.path});p.line-=1,a[r]=p;}return {line:e.line,rawData:a}}};var pt=class{static parse(t,e){let i=t[0];if(i.startsWith("`"))return t.length===1?this.ɗbg(i,e,"`"):this.ɗbe(t,e);if(t.length>1)throw {description:`Invalid row! "${t[1]}"`,location:{line:e.line+2,path:e.path}};return i.startsWith('"')?this.ɗbg(i,e,'"'):this.ɗbf(i,e)}static ɗbf(t,e){if(t.indexOf(" ")!==-1)throw {description:`Unexpected space! "${t}"`,location:e};return {line:e.line,rawData:t==="undefined"?void 0:t}}static ɗbg(t,e,i){let r=new RegExp(i,"g");if((t.match(r)||[]).length>2)throw {description:"There should be only one opening and one closeing quote!",location:e};if(t.endsWith(i))return {line:e.line,rawData:t.replace(r,"")};throw {description:"Quote is not get closed!",location:e}}static ɗbe(t,e){let i=t[t.length-1];if(t[0]!=="`")throw {description:`There should be new line after backtick "${t[0]}"!`,location:{line:e.line,path:e.path}};if(i.startsWith("`")&&i!=="`")throw {description:`There should be new line after backtick "${i}"!`,location:{line:e.line+t.length,path:e.path}};if(i.trim().startsWith("`")){if(i!=="`")throw {description:"Invalid coding indent!",location:{line:e.line+t.length,path:e.path}};return {line:e.line,rawData:t.slice(0,t.length-1).slice(1).join(`
|
|
9
|
+
`)}}else throw {description:`Multiline string should end with backtick in new line "${i}"!`,location:{line:e.line+t.length,path:e.path}}}};var b=class n{static getParsedStructure(t,e){switch(this.ɗaq(t[0])){case "object":return st.parse(t,e);case "array":return at.parse(t,e);case "primitive":return pt.parse(t,e)}}static ɗaq(t){return t.startsWith("-")&&!t.match(/^-?\d+(\.\d+)?$/)?"array":t.match(/^[\w]+:/)?"object":"primitive"}process(t){let e=[];return {rawDefinitions:t.map(r=>{try{if(r.content.length)return {componentName:r.type,location:r.location,parsedStructure:n.getParsedStructure(r.content,{line:r.location.line+1,path:r.location.path})}}catch(o){o?.description&&o?.location?e.push(o):e.push({description:`Unexpected Error! Error: "${o}"`,location:r.location});}}).filter(r=>r),errorLogs:e}}};var lt=class{static{this.ɗbv=new ot;}static{this.ɗcc=new b;}static process(){let t=l.files.reduce((i,r)=>{let o=this.ɗbv.process(r);return l.addErrorLog(o.errorLogs),i.push(...o.definitionPlaneTexts),i},[]),e=this.ɗcc.process(t);l.rawDefinitions.push(...e.rawDefinitions),l.addErrorLog(e.errorLogs),J.process();}};var Et="// ---- INDEX OUTPUT ----",fe="// ---- END ----",j=class{static{this.ɗbi=[];}static{this.ɗat=[];}static addPremadeInterface(t){this.ɗbi.push(t);}static addIdType(t,e){let i=`export type ${t}ID = ${e.map(r=>`'${r}'`).join(" | ")};`;this.ɗat.push(i);}static async generateFile(t,e){if(l.config.compilerModulesPath){let i=await this.ɗaf(t);i&&await this.ɗk(i);}else await this.ɗk(e);}static async ɗk(t){let e=t,i=this.generateTypes();i&&(e+=`
|
|
10
10
|
|
|
11
|
-
`+i),l.output.push({path:"/index.ts",content:await
|
|
11
|
+
`+i),l.output.push({path:"/index.ts",content:await N.format(e)});}static async ɗaf(t){let e=Pt__namespace.sync(`${l.config.compilerModulesPath}/**/*.ts`).map(o=>o.replace(/\\/g,"/"));e.length===0&&helpersLib.ConsoleHelper.log("No typescript file found to generate index.ts file.","red");let i=this.ɗae(),r=await this.ɗag(e);if(r!==void 0){let o=`${t}
|
|
12
12
|
${i}
|
|
13
13
|
|
|
14
|
-
${r}`;return o=await
|
|
14
|
+
${r}`;return o=await N.format(o),S__namespace.writeFileSync(`${l.compilerExecutionPath}/output-index-file.ts`,`// AUTO GENERATED - CHANGES WILL BE REPLACED
|
|
15
15
|
export const OutputIndexFile = \`${o}\`;
|
|
16
16
|
`),helpersLib.ConsoleHelper.log("Index content 'output-index-file.ts' is generated.","green"),o}}static ɗae(){return l.exports.map(t=>`export { ${t.variableName} } from '.${t.path.substring(0,t.path.lastIndexOf("."))}';`).join(`
|
|
17
17
|
`)}static async ɗag(t){let e=0,i=[];t.forEach(o=>{let s=o.substring(o.lastIndexOf("/")+1,o.lastIndexOf(".")),a=S__namespace.readFileSync(o,"utf-8");try{let p=this.ɗam(s,a);p&&i.push(p);}catch(p){e++,helpersLib.ConsoleHelper.log(`Error parsing file: ${o}, error: '${p.message}'`,"red");}});let r=`//-------------------------- DEFINITIONS --------------------------
|
|
@@ -19,25 +19,25 @@ export const OutputIndexFile = \`${o}\`;
|
|
|
19
19
|
`),r+=`
|
|
20
20
|
|
|
21
21
|
`),r+=i.join(`
|
|
22
|
-
`),e===0?r:void 0}static ɗam(t,e){let i=e.indexOf(
|
|
23
|
-
`,i+
|
|
22
|
+
`),e===0?r:void 0}static ɗam(t,e){let i=e.indexOf(Et),r=i!==-1,o=[];for(;i!==-1;){let s=e.indexOf(fe,i);if(s===-1)throw new Error("No end command found.");o.push(e.substring(e.indexOf(`
|
|
23
|
+
`,i+Et.length)+1,s)),i=e.indexOf(Et,s);}if(r)return `// ---- ${t} ----
|
|
24
24
|
${o.join(`
|
|
25
25
|
`)}`}static generateTypes(){let t="";return this.ɗat.length>0&&(t+=`//-------------------------- ID TYPES --------------------------
|
|
26
26
|
`,t+=this.ɗat.join(`
|
|
27
27
|
`),t+=`
|
|
28
|
-
`),t}};var
|
|
28
|
+
`),t}};var de=/^[a-z]+([a-zA-Z0-9]+)*$/,mt="======================================================",ue="------------------------------------------------------",Mt=n=>n.path.replace(l.compilerExecutionPath+"/","")+":"+n.line,ft=class{static async process(t,e,i){let r=new Map;r.set(nt,J),t.forEach(s=>{let a=s.$meta.componentName;if(r.has(a))throw new Error(`Component name "${a}" is used more than once.`);r.set(a,s);}),m.ɗbw(r),helpersLib.ConsoleHelper.log("Compilation is in progress.","white"),this.ɗbk();let o=await this.ɗah(t,e,i);this.ɗcf(o,l.outputPath);}static ɗbk(){l.compilerExecutionPath=dt__namespace.resolve("./").replace(/\\/g,"/"),l.outputPath=`${l.compilerExecutionPath}/.asset-build`,l.files=Pt__namespace.sync(`${l.compilerExecutionPath}/**/*.md`).map(t=>t.replace(/\\/g,"/")).map(t=>{let e=S__namespace.readFileSync(t).toString();return {path:t,content:e}});}static ɗcf(t,e){let i=new Set;Pt__namespace.sync(`${l.outputPath}/**/*`,{nodir:true}).map(a=>a.replace(/\\/g,"/")).forEach(a=>{i.add(a);}),t.forEach(a=>{a.path=e+a.path,i.delete(a.path);}),l.successful&&(helpersLib.ConsoleHelper.log(mt,"gray"),helpersLib.ConsoleHelper.log("Changes:","gray"),helpersLib.ConsoleHelper.newLine());let r=0;l.successful&&i.forEach(a=>{r++,console.info(`${helpersLib.ConsoleHelper.red}Erasing file:${helpersLib.ConsoleHelper.gray} "${this.ɗf(a)}"${helpersLib.ConsoleHelper.default}`),S__namespace.unlinkSync(a);});let o=0,s=0;t.forEach(a=>{let p=a.path.substring(0,a.path.lastIndexOf("/"));S__namespace.mkdirSync(p,{recursive:true});let c=S__namespace.existsSync(a.path);(c?S__namespace.readFileSync(a.path).toString():"")!==a.content&&(c?(o++,console.info(`${helpersLib.ConsoleHelper.blue}Modifying file:${helpersLib.ConsoleHelper.gray} "${this.ɗf(a.path)}"${helpersLib.ConsoleHelper.default}`)):(s++,console.info(`${helpersLib.ConsoleHelper.cyan}Creating file:${helpersLib.ConsoleHelper.gray} "${this.ɗf(a.path)}"${helpersLib.ConsoleHelper.default}`)),S__namespace.writeFileSync(a.path,a.content));}),this.ɗbn(e),s+o+r>0&&helpersLib.ConsoleHelper.newLine(),helpersLib.ConsoleHelper.log(`Created file count: ${s}`,"gray"),helpersLib.ConsoleHelper.log(`Modified file count: ${o}`,"gray"),helpersLib.ConsoleHelper.log(`Erased file count: ${r}`,"gray"),helpersLib.ConsoleHelper.log(mt,"gray"),l.successful?helpersLib.ConsoleHelper.log("Compilation is completed successfuly!","green"):helpersLib.ConsoleHelper.log("Compilation encountered errors!","red");}static ɗf(t){let e=l.compilerExecutionPath.length;return t.substring(e)}static ɗbn(t){let e=S__namespace.readdirSync(t),i=true;for(let r of e){let o=dt__namespace.join(t,r);S__namespace.statSync(o).isDirectory()&&this.ɗbn(o)?(S__namespace.rmdirSync(o),console.info(`${helpersLib.ConsoleHelper.red}Erasing folder:${helpersLib.ConsoleHelper.gray} "${o.substring(t.length).replace(/\\/g,"/")}"${helpersLib.ConsoleHelper.default}`)):i=false;}return i}static async ɗah(t,e,i){lt.process(),l.flushErrorLogs();let r=t.map(o=>{let s=o.$meta;l.componentInProgressData={meta:s,idToReferencesMap:new Map};let a={addFile:c=>l.addFile(c),addError:c=>l.addErrorLog(c),convertLocationInFileToLink:c=>Mt(c)};this.ɗaz(s.keyName,s.componentName,o);let p;if(s.singleton){let c=R.validateAndConvertSingular(s.componentName,s.validationSchema);c&&(p=c.definition,m.ɗby(o,c.definition,c.rawDefinition),m.ɗca(o,p));}else {let c=R.validateAndConvert(s.componentName,s.validationSchema);if(l.componentInProgressData.idToReferencesMap.size>0){let d=s.keyName;if(!d)throw new Error("Unexpected Error: KeyName should be defined for lazy references.");let I=l.componentInProgressData.idToReferencesMap,U=true;for(;U;){let Ut=c.length,Gt=new Set(c.map(Tt=>Tt.definition[d]));c=c.filter(Tt=>{let Vt=Tt.definition[d];if(I.has(Vt)){let Wt=I.get(Vt),Nt=true;return Wt.forEach(Kt=>Gt.has(Kt)||(Nt=false)),Nt}return true}),U=Ut!==c.length;}}c.forEach(d=>{m.ɗby(o,d.definition,d.rawDefinition);}),p=c.map(d=>d.definition),this.ɗbm(p,s.keyName,o);}return l.flushErrorLogs(),l.componentInProgressData=void 0,{definitionToProcess:p,output:a,moduleClass:o}});for(let o of r)if(o.definitionToProcess){let s=new o.moduleClass,a=o.moduleClass.$meta.keyName;a&&j.addIdType(o.moduleClass.$meta.pascalCaseComponentName,o.definitionToProcess.map(p=>p[a])),await s.process(o.definitionToProcess,o.output);}return l.flushErrorLogs(),C.logDuplicates(),l.successful&&await j.generateFile(e,i),this.ɗao()}static ɗaz(t,e,i){let r=R.getRawDefinitions(e);t&&r.forEach(o=>{let s=o.parsedStructure.rawData;if(!helpersLib.Comparator.isObject(s)||helpersLib.Comparator.isArray(s))l.addErrorLog({description:`KeyName shold not be used with a content which is not an object, keyName: "${t}" in "${e}"`,location:{line:o.parsedStructure.line,path:o.location.path}});else {let a=s[t]?.rawData;helpersLib.Comparator.isString(a)&&(de.test(a)===false?l.addErrorLog({description:`KeyValue should be a valid key, keyValue: "${a}"`,location:{line:s[t].line,path:o.location.path}}):m.ɗax(i,a)?l.addErrorLog({description:`Definition with key "${a}" already exists`,location:{line:s[t].line,path:o.location.path}}):m.ɗbz(i,a,o));}});}static ɗbm(t,e,i){e&&t.forEach(r=>{let o=r[e];m.ɗbx(i,o,r);});}static ɗao(){return l.successful?l.output:(helpersLib.ConsoleHelper.newLine(),helpersLib.ConsoleHelper.log("ERROR LOGS:","red"),helpersLib.ConsoleHelper.log(mt,"gray"),l.errorLogs.forEach((t,e)=>{e>0&&helpersLib.ConsoleHelper.log(ue,"gray"),helpersLib.ConsoleHelper.log("Error:","red"),console.info(`${helpersLib.ConsoleHelper.white}Details:${helpersLib.ConsoleHelper.green} ${t.description}`),console.info(`${helpersLib.ConsoleHelper.white}Location:${helpersLib.ConsoleHelper.green} ${Mt(t.location)}`);}),helpersLib.ConsoleHelper.log(mt,"gray"),[{path:"/error-logs.md",content:l.errorLogs.map(t=>`${t.description}\r
|
|
29
29
|
Path: '${t.location.path}', Line: '${t.location.line}'\r
|
|
30
30
|
`).join(`\r
|
|
31
|
-
`)}])}};var
|
|
31
|
+
`)}])}};var $t=class{constructor(t,e,i){u.setup(t,e,i);}setScriptInput(t,e){u.setScriptInput(t,e);}setEventInput(t,e){u.setEventInput(t,e);}addCustomScriptTestCase(t,e,i){u.addCustomScriptTestCase(e,i,t);}addCustomEventTestCase(t,e,i){u.addCustomEventTestCase(e,i,t);}},u=class{static{this.ɗbr=new Map;}static{this.ɗw=new Map;}static{this.ɗbt=new Map;}static{this.ɗy=new Map;}static get scriptSimulatorFunctionsConstructor(){if(!this.ɗbs)throw new Error("ScriptSimulatorFunctionsConstructor is not set");return this.ɗbs}static get eventSimulatorFunctionsConstructor(){if(!this.ɗx)throw new Error("ScriptSimulatorFunctionsConstructor is not set");return this.ɗx}static get richTextTags(){return this.ɗbp}static get isInitialized(){return this.ɗbs&&this.ɗx&&this.ɗbp!==void 0}static setup(t,e,i){this.ɗbs=t,this.ɗx=e,this.ɗbp=i;}static getScriptInput(t){return this.ɗbr.get(t)}static getEventInput(t){return this.ɗw.get(t)}static getCustomScriptTestCases(){return Array.from(this.ɗbt.values())}static getCustomEventTestCases(){return Array.from(this.ɗy.values())}static isCustomScriptTestCase(t){return this.ɗbt.has(t.script)}static isCustomEventTestCase(t){return this.ɗy.has(t.script)}static setScriptInput(t,e){if(this.ɗbr.has(t))throw new Error(`Script input for ${t} already set`);this.ɗbr.set(t,e);}static setEventInput(t,e){if(this.ɗw.has(t))throw new Error(`Event input for ${t} already set`);this.ɗw.set(t,e);}static addCustomScriptTestCase(t,e,i){let r={testDefinition:{script:t,cases:[e]},customMessage:`Prebuild Test Case:
|
|
32
32
|
${i}`};this.ɗbt.set(t,r);}static addCustomEventTestCase(t,e,i){let r={testDefinition:{script:t,cases:[e]},customMessage:`Prebuild Test Case:
|
|
33
|
-
${i}`};this.ɗy.set(t,r);}};var
|
|
33
|
+
${i}`};this.ɗy.set(t,r);}};var ut=class{static convert(t){let e=false,i=t.indexOf('"');for(;i>=0;){let r=e?'"</b>':'<b>"';t=t.substring(0,i)+r+t.substring(i+1),e=!e,i=t.indexOf('"',i+r.length);}if(e)throw new Error("Quote is not closed.");return scriptEngineLib.RichTextValidator.validate(t,u.richTextTags),t}};var ht=()=>h__default.default.string().custom(n=>({type:"command",value:n})),gt=n=>h__default.default.object().keys({branchByCondition:h__default.default.array().items(h__default.default.object().keys({condition:h__default.default.string().optional(),actions:h__default.default.link("#"+n).default([]).optional()})).custom((t,e)=>{let i=t.length;if(i>1){for(let r=0;r<i-1;r++)if(t[r].condition===void 0)throw new Error(`Element at index ${r} must have "condition"`)}else if(i===1&&t[0].condition===void 0)throw new Error('Single element must have "condition"');return t})}).custom(t=>({type:"branchByCondition",value:t.branchByCondition})),Bt=n=>h__default.default.object().keys({branchByPlayerChoice:h__default.default.array().items(h__default.default.object().keys({text:h__default.default.string().min(2).required(),condition:h__default.default.string().optional(),actions:h__default.default.link("#"+n).default([]).optional()}))}).custom(t=>({type:"branchByPlayerChoice",value:t.branchByPlayerChoice})),yt=n=>h__default.default.object().keys({branchByChance:h__default.default.array().items(h__default.default.object().keys({label:h__default.default.string().optional(),weight:h__default.default.number().integer().min(1).max(100).required(),condition:h__default.default.string().optional(),actions:h__default.default.link("#"+n).default([]).optional()}))}).custom(t=>({type:"branchByChance",value:t.branchByChance})),Ht=()=>h__default.default.object().min(1).max(1).custom(n=>{let t=Object.keys(n);if(t.length!==1)throw new Error("object must have exactly one key/value pair");let e=t[0],i=n[e];if(typeof i!="string")throw new Error("value must be a string");return i=ut.convert(i),{type:"dialog",value:{text:i,speaker:e}}});var Rt=new Set,ye=()=>h__default.default.object().keys({jumpTo:h__default.default.string().lazyReference("SCRIPT").required()}).custom(n=>({type:"jumpTo",value:n.jumpTo})),It="ScriptActionsSchema",Se=()=>h__default.default.array().items(h__default.default.alternatives().conditional(h__default.default.string(),{then:ht()}).conditional(h__default.default.object({jumpTo:h__default.default.exist()}).unknown(),{then:ye()}).conditional(h__default.default.object({branchByChance:h__default.default.exist()}).unknown(),{then:yt(It)}).conditional(h__default.default.object({branchByCondition:h__default.default.exist()}).unknown(),{then:gt(It)}).conditional(h__default.default.object({branchByPlayerChoice:h__default.default.exist()}).unknown(),{then:h__default.default.forbidden().messages({"any.unknown":"branchByPlayerChoice is not allowed in scripts"})}).conditional(h__default.default.object().min(1).max(1).unknown(),{then:h__default.default.forbidden().messages({"any.unknown":"dialogs are not allowed in scripts"})}).error(n=>n.map(t=>{if(t.code==="alternatives.any"){let e="command, jumpToScript, branchByCondition, branchByChance";t.message=`${t.local.label} does not match any of the allowed types: ${e}`;}return t}))).custom(n=>{let t=false,e=false;if(n.forEach(i=>{e?t=true:(i.type==="branchByCondition"||i.type==="branchByChance")&&(e=true);}),t)throw new Error("There should not be any command after branching.");return n}).id(It);exports.ScriptComponent=class v extends g{async process(t,e){await e.addFile({path:"/_premade/script-engine-definitions/scripts.ts",preText:'import { ScriptDefinition } from "script-engine-lib";',variableName:"ScriptDefinitions",variableType:"Readonly<Record<string, ScriptDefinition>>",variable:helpersLib.JsonHelper.arrayToObject(t,"id")});}};exports.ScriptComponent=w([T({componentName:"SCRIPT",keyName:"id",validationSchema:h__default.default.object().keys({id:h__default.default.string().unique(Rt).required(),actions:Se().min(1).required()}).required()})],exports.ScriptComponent);var A=class{constructor(t,e,i){this.ɗad=e;this.ɗba=i;this.ɗbu=new scriptEngineLib.ScriptTestSimulator(t);}runTests(t,e){let i=[];return t.forEach(r=>{let o=false;r.cases.forEach((s,a)=>{if(!o){let p=new scriptEngineLib.JSEngine(new this.ɗad(r.scriptInput),{});try{this.ɗbu.simulateScript(r.script,p,s.actionsBeforeTesting);}catch(c){let d=this.ɗbj(c,r,a,e);i.push(d),o=true;}}});}),i}printErrors(t,e){t.length===0&&this.ɗbu.getUnvisitedBranchLocations().forEach(i=>e.addError({description:"Event branch is not reaced by any of the combinations during the tests.",location:this.ɗba.getLocationOfDefinition(i.scriptId,i.path)})),t.forEach(i=>e.addError(i));}ɗbj(t,e,i,r){if(t instanceof scriptEngineLib.SimulationError)return {description:e.customMessage?e.customMessage+`
|
|
34
34
|
`+t.message:t.message,location:this.ɗba.getLocationOfDefinition(t.location.scriptId,t.location.path)};if(t instanceof scriptEngineLib.ActionsBeforeTestingError){let o=e.customMessage?e.customMessage+`
|
|
35
35
|
`+t.message:t.message,s=this.ɗba.getLocationOfTestDefinition(e.testDefinitionRef,["cases",`${i}`,"actionsBeforeTesting",`${t.actionIndex}`]);return {description:o,location:s}}else if(t instanceof scriptEngineLib.BranchingBeforeTestingError){let o=this.ɗba.getLocationOfTestDefinition(e.testDefinitionRef,[]),s=`Running the test: ${r.convertLocationInFileToLink(o)}
|
|
36
36
|
|
|
37
37
|
`,a=t.message.indexOf(`
|
|
38
38
|
`,t.message.indexOf("Execution history"))+1,p=t.message.slice(0,a)+s+t.message.slice(a);return {description:e.customMessage?e.customMessage+`
|
|
39
|
-
`+p:p,location:this.ɗba.getLocationOfDefinition(t.location.scriptId,t.location.path)}}else throw t}};var
|
|
39
|
+
`+p:p,location:this.ɗba.getLocationOfDefinition(t.location.scriptId,t.location.path)}}else throw t}};var xe=h__default.default.string().custom(n=>({type:"command",value:n})),be=h__default.default.object().keys({runScript:h__default.default.string().reference(exports.ScriptComponent).required()}).custom(n=>({type:"runScript",value:n.runScript})),Ee=()=>h__default.default.array().items(h__default.default.alternatives().conditional(h__default.default.string(),{then:xe}).conditional(h__default.default.object({runScript:h__default.default.exist()}).unknown(),{then:be}).error(n=>n.map(t=>{if(t.code==="alternatives.any"){let e="command, runScript";t.message=`${t.local.label} does not match any of the allowed types: ${e}`;}return t}))).min(1);exports.ScriptTestComponent=class F extends g{async process(t,e){let i=m.getDefinitions(exports.ScriptComponent),r=new A(i,u.scriptSimulatorFunctionsConstructor,this.ɗan()),o=t.map(c=>({cases:c.cases,script:m.getDefinitionOrFail(exports.ScriptComponent,c.script),scriptInput:u.getScriptInput(c.script),testDefinitionRef:c})),s=u.getCustomScriptTestCases().map(c=>({cases:c.testDefinition.cases,script:m.getDefinitionOrFail(exports.ScriptComponent,c.testDefinition.script),scriptInput:u.getScriptInput(c.testDefinition.script),testDefinitionRef:c.testDefinition,customMessage:c.customMessage})),a=o.concat(s),p=r.runTests(a,e);r.printErrors(p,e);}ɗan(){return {getLocationOfDefinition:(t,e)=>m.getLocationInFileById(exports.ScriptComponent,t,e),getLocationOfTestDefinition:(t,e)=>{if(u.isCustomScriptTestCase(t)){let i=`Internal error: custom script test case is failing. Definition: ${JSON.stringify(t)}, Path: ${JSON.stringify(e)}`;throw new Error(i)}else return m.getLocationInFile(exports.ScriptTestComponent,t,e)}}}};exports.ScriptTestComponent=w([T({componentName:"SCRIPT-TEST",validationSchema:h__default.default.object().keys({script:h__default.default.string().reference(exports.ScriptComponent).required(),cases:h__default.default.array().items(h__default.default.object().keys({actionsBeforeTesting:Ee().default([]).optional()}).required()).required()}).required()})],exports.ScriptTestComponent);var Pe=h__default.default.object().keys({jumpTo:h__default.default.string().lazyReference("EVENT").required()}).custom(n=>({type:"jumpTo",value:n.jumpTo})),St="EventActionsSchema",$e=()=>h__default.default.array().items(h__default.default.alternatives().conditional(h__default.default.string(),{then:ht()}).conditional(h__default.default.object({jumpTo:h__default.default.exist()}).unknown(),{then:Pe}).conditional(h__default.default.object({branchByChance:h__default.default.exist()}).unknown(),{then:yt(St)}).conditional(h__default.default.object({branchByCondition:h__default.default.exist()}).unknown(),{then:gt(St)}).conditional(h__default.default.object({branchByPlayerChoice:h__default.default.exist()}).unknown(),{then:Bt(St)}).conditional(h__default.default.object().min(1).max(1).unknown(),{then:Ht()}).error(n=>n.map(t=>{if(t.code==="alternatives.any"){let e="command, jumpTo, branchByCondition, branchByPlayerChoice, branchByChance";t.message=`${t.local.label} does not match any of the allowed types: ${e}`;}return t}))).custom(n=>{let t=false,e=false;if(n.forEach(i=>{e?t=true:(i.type==="branchByCondition"||i.type==="branchByPlayerChoice"||i.type==="branchByChance")&&(e=true);}),t)throw new Error("There should not be any command after branching.");return n}).id(St);exports.EventComponent=class x extends g{async process(t,e){await e.addFile({path:"/_premade/script-engine-definitions/events.ts",preText:'import { ScriptDefinition } from "script-engine-lib";',variableName:"EventDefinitions",variableType:"Readonly<Record<string, ScriptDefinition>>",variable:helpersLib.JsonHelper.arrayToObject(t,"id")});}};exports.EventComponent=w([T({componentName:"EVENT",keyName:"id",validationSchema:h__default.default.object().keys({id:h__default.default.string().unique(Rt).required(),actions:$e().min(1).required()}).required()})],exports.EventComponent);var Ie=h__default.default.string().custom(n=>({type:"command",value:n})),Re=h__default.default.object().keys({runEvent:h__default.default.string().reference(exports.EventComponent).required()}).custom(n=>({type:"runScript",value:n.runEvent})),Fe=()=>h__default.default.array().items(h__default.default.alternatives().conditional(h__default.default.string(),{then:Ie}).conditional(h__default.default.object({runEvent:h__default.default.exist()}).unknown(),{then:Re}).error(n=>n.map(t=>{if(t.code==="alternatives.any"){let e="command, runEvent";t.message=`${t.local.label} does not match any of the allowed types: ${e}`;}return t}))).min(1);exports.EventTestComponent=class O extends g{async process(t,e){let i=m.getDefinitions(exports.EventComponent),r=new A(i,u.eventSimulatorFunctionsConstructor,this.ɗan()),o=r.runTests(t.map(s=>({cases:s.cases,script:m.getDefinitionOrFail(exports.EventComponent,s.script),scriptInput:u.getEventInput(s.script),testDefinitionRef:s})),e);r.printErrors(o,e);}ɗan(){return {getLocationOfDefinition:(t,e)=>m.getLocationInFileById(exports.EventComponent,t,e),getLocationOfTestDefinition:(t,e)=>m.getLocationInFile(exports.EventTestComponent,t,e)}}};exports.EventTestComponent=w([T({componentName:"EVENT-TEST",validationSchema:h__default.default.object().keys({event:h__default.default.string().reference(exports.EventComponent).required(),cases:h__default.default.array().items(h__default.default.object().keys({actionsBeforeTesting:Fe().default([]).optional()}).required()).required()}).required().custom(n=>({script:n.event,cases:n.cases}))})],exports.EventTestComponent);var qt=false;function Oe(n){return function(t){if(qt)console.error("There can be only one definition generator!");else {qt=true;let e=[...n.modules];u.isInitialized&&(e=[exports.ScriptComponent,exports.EventComponent,...e,exports.ScriptTestComponent,exports.EventTestComponent]),ft.process(e,n.indexFilePretext,n.outputIndexFile);}}}var Ft=class{};var Ot=()=>h__default.default.array().items(h__default.default.array().items(zt().required()).min(3).required()).min(1),zt=()=>h__default.default.object().keys({x:h__default.default.number().required(),y:h__default.default.number().required()}),je=()=>h__default.default.string().pattern(/^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/).custom(n=>helpersLib.ColorHelper.stringColorToRGBColor(n)),ke=()=>h__default.default.number().min(-Math.PI).max(Math.PI),Je=(n,t)=>h__default.default.array().items(n).max(t).custom(e=>{if(e.length>t)throw new Error(`Array exceeds maximum size of ${t}`);for(;e.length<t;)e.push(void 0);return e}).default(helpersLib.ArrayHelper.createEmptyArray(t)).optional();exports.SpriteComponent=class P extends g{async process(t,e){await e.addFile({path:"/_premade/assets/sprites.ts",preText:"import { AssetDefinition } from 'bard-legends-framework';",variableName:"SpriteAssets",variableType:"readonly AssetDefinition[]",assetUrl:"url",variable:t.map(i=>({id:i.id,url:i.url.url}))}),await e.addFile({path:"/_premade/asset-definitions/sprites.ts",preText:'import { SpriteDefinition } from "bard-legends-framework";',variableName:"SpriteDefinitions",variableType:"Readonly<Record<string, SpriteDefinition>>",variable:helpersLib.JsonHelper.arrayToObject(t,"id",{transformFunction:i=>({id:i.id,size:i.url.size,scale:i.scale,anchor:i.anchor,boundingShapes:i.boundingShapes})})});}};exports.SpriteComponent=w([T({componentName:"SPRITE",keyName:"id",validationSchema:h__default.default.object().keys({id:h__default.default.string().required(),url:h__default.default.string().sprite().required(),scale:h__default.default.number().min(.1).max(1).default(1).optional(),anchor:h__default.default.object().keys({x:h__default.default.number().min(0).max(1).required(),y:h__default.default.number().min(0).max(1).required()}).default({x:.5,y:.5}).optional(),boundingShapes:Ot().optional()}).positionOnSprite({selectSpriteDefinition:n=>n,positionsJsonPath:["$..boundingShapes[*][*]"],includeRotationFromAnchor:false}).required()})],exports.SpriteComponent);var Me=()=>h__default.default.string().reference(exports.SpriteComponent).custom(n=>{let t=m.getDefinitionOrFail(exports.SpriteComponent,n);if(t.url.size.x%4!==0)throw new Error(`Sprite width must be multiplier of four in order to keep the pixel perfection. Got: '${t.url.size.x}'`);if(t.url.size.y%4!==0)throw new Error(`Sprite height must be multiplier of four in order to keep the pixel perfection. Got: '${t.url.size.y}'`);return n}),Be=n=>h__default.default.string().reference(exports.SpriteComponent).custom(t=>{let e=m.getDefinitionOrFail(exports.SpriteComponent,t);if(n?.size){if(e.url.size.x!==n.size.x)throw new Error(`Sprite width must be '${n.size.x}px'. Got: '${e.url.size.x}'`);if(e.url.size.y!==n.size.y)throw new Error(`Sprite height must be '${n.size.y}px'. Got: '${e.url.size.y}'`)}if(n?.scale&&e.scale!==n.scale)throw new Error(`Sprite '${t}' scale must be '${n.scale}'. Got: '${e.scale}'`);return t});exports.SpriteGroupComponent=class z extends g{async process(t,e){await e.addFile({path:"/_premade/asset-definitions/sprite-groups.ts",preText:"",variableName:"SpriteGroupDefinitions",variableType:"Readonly<Record<string, readonly string[]>>",variable:helpersLib.JsonHelper.arrayToObject(t,"id",{transformFunction:i=>i.group})});}};exports.SpriteGroupComponent=w([T({componentName:"SPRITE-GROUP",keyName:"id",validationSchema:h__default.default.object().keys({id:h__default.default.string().required(),group:h__default.default.array().items(h__default.default.string().reference(exports.SpriteComponent)).unique().required()}).required()})],exports.SpriteGroupComponent);var ze=`
|
|
40
40
|
export interface FontDefinition {
|
|
41
41
|
readonly id: string;
|
|
42
42
|
readonly fontFamily: string;
|
|
43
|
-
}`;exports.FontComponent=class
|
|
43
|
+
}`;exports.FontComponent=class _ extends g{constructor(){super(),j.addPremadeInterface(ze);}async process(t,e){await e.addFile({path:"/_premade/assets/fonts.ts",preText:"import { AssetDefinition } from 'bard-legends-framework';",variableName:"FontAssets",variableType:"readonly AssetDefinition[]",assetUrl:"url",variable:t.map(i=>({id:i.id,url:i.url}))}),await e.addFile({path:"/_premade/asset-definitions/fonts.ts",preText:'import { FontDefinition } from "../../";',variableName:"FontDefinitions",variableType:"Readonly<Record<string, FontDefinition>>",variable:helpersLib.JsonHelper.arrayToObject(t,"id",{transformFunction:i=>({id:i.id,fontFamily:i.fontFamily})})});}};exports.FontComponent=w([T({componentName:"FONT",keyName:"id",validationSchema:h__default.default.object().keys({id:h__default.default.string().required(),fontFamily:h__default.default.string().required(),url:h__default.default.string().path().required()}).required()})],exports.FontComponent);exports.DefinitionComponent=g;exports.DefinitionComponentDecorator=T;exports.DefinitionGenerator=Ft;exports.DefinitionGeneratorDecorator=Oe;exports.DefinitionStore=m;exports.FixedArraySchema=Je;exports.HexColorSchema=je;exports.JoiCustomValidators=H;exports.PixelPerfectSpriteSchema=Me;exports.PoligonSchema=Ot;exports.RotationSchema=ke;exports.ScriptTesting=$t;exports.SingleDefinitionComponent=rt;exports.SpriteSchema=Be;exports.Validator=R;exports.Vec2Schema=zt;
|
package/dist/index.mjs
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
import {Comparator,
|
|
1
|
+
import*as S from'fs';import S__default from'fs';import h from'joi';import {JsonHelper,Comparator,ConsoleHelper,Vector,ColorHelper,ArrayHelper}from'helpers-lib';import*as dt from'path';import dt__default from'path';import*as ee from'prettier/plugins/estree';import*as ie from'prettier/plugins/typescript';import {format}from'prettier/standalone';import {JSONPath}from'jsonpath-plus';import pe from'image-size';import*as Pt from'glob';import {RichTextValidator,ScriptTestSimulator,JSEngine,SimulationError,ActionsBeforeTestingError,BranchingBeforeTestingError}from'script-engine-lib';var w=(n,t,e,i)=>{for(var r=t,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=(s(r))||r);return r};var N=class{static generate(t){let e="";t.preText&&(e+=`${t.preText}
|
|
2
2
|
|
|
3
3
|
`);let i;if(t.assetUrl){if(!t.filePath)throw new Error("filePath is required when using assetUrl");if(!Comparator.isArray(t.variable))throw new Error("variable should be an array when using assetUrl");let{assetImports:r,replaceMap:o}=this.ɗi(t.variable,t.assetUrl,t.filePath);e+=r+`
|
|
4
4
|
|
|
5
|
-
`,i=o;}return t.variableType?e+=`export const ${t.variableName}: ${t.variableType} = ${this.ɗcb(t.variable)}`:e+=`export const ${t.variableName} = ${this.ɗcb(t.variable)}`,i&&(e=this.ɗbo(e,i)),t.replaceMap&&(e=this.ɗbo(e,t.replaceMap)),this.format(e)}static async format(t){return format(t,{parser:"typescript",trailingComma:"none",tabWidth:2,printWidth:130,singleQuote:true,arrowParens:"avoid",plugins:[
|
|
6
|
-
`),a=r.reduce((p,c)=>[...p,{target:`"${c}"`,replace:o.get(c)}],[]);return {assetImports:s,replaceMap:a}}static ɗcb(t){return JSON.stringify(t,(e,i)=>i===void 0?null:i).replace(/null/gm,"undefined")}};
|
|
7
|
-
`):t.preText,variableName:t.variableName,variableType:t.variableType,variable:t.variable,replaceMap:t.replaceMap,filePath:t.path,assetUrl:t.assetUrl})});}static get successful(){return this.errorLogs.length===0}static addErrorLog(t,e="default"){Comparator.isArray(t)?e==="lowPriority"?this.ɗu=[...t,...this.ɗu]:this.ɗu.push(...t):e==="lowPriority"?this.ɗu=[t,...this.ɗu]:this.ɗu.push(t);}static flushErrorLogs(){this.errorLogs=[...this.ɗu,...this.errorLogs],this.ɗu=[];}static{this.errorLogs=[];}static{this.ɗu=[];}};});var Z,_t=w(()=>{P();Z=class{constructor(t){this.ɗar=t;this.ɗav=new Set;this.ɗau=new Map;this.ɗb=new Set;this.ɗt=[];}newEntry(t,e){if(this.ɗav.has(t)){if(!this.ɗb.has(t)){this.ɗb.add(t);let i=this.ɗau.get(t);i&&this.ɗt.push({identifier:t,location:i});}return this.ɗt.push({identifier:t,location:e}),false}else return this.ɗav.add(t),this.ɗau.set(t,e),true}logDuplicateErrors(){this.ɗt.forEach(t=>{let e={description:`Value should be singular! Group: "${this.ɗar}", Value: "${t.identifier}"`,location:t.location};l.addErrorLog(e);});}};});var T,q=w(()=>{_t();T=class{static{this.ɗs=new Map;}static logDuplicates(){this.ɗs.forEach(t=>t.logDuplicateErrors());}static getDefinitionComponentName(t){return t.$meta.componentName}static getDefinitionComponentNamesFromArray(t){return Comparator.isArray(t)?t.map(e=>this.getDefinitionComponentName(e)):[this.getDefinitionComponentName(t)]}static getValidationState(t){return t.state.path&&(t.state.path.length===0||t.state.path[0]!==void 0&&t.prefs.context.rawDefinition)?"valid":"notValid"}static getPathAndRawDefinition(t){let e=t.state.path,i=t.prefs.context.rawDefinition;return {path:e,rawDefinition:i}}static getDuplicateHelper(t){let e=this.ɗs.get(t);return e||(e=new Z(t),this.ɗs.set(t,e)),e}};});var R,X=w(()=>{R=class{static findLine(t,e){if(e.length===0)return t.parsedStructure.line;{let i,r=[...e];for(;i===void 0&&r.length>0;)i=this.ɗz(t.parsedStructure.rawData,[...r]),r.pop();return i||t.parsedStructure.line}}static flatten(t){return this.ɗaa(t.parsedStructure.rawData)}static ɗz(t,e){let i=e.shift(),r;if(t&&i!==void 0&&(Comparator.isNumber(i)?Comparator.isArray(t)&&(r=t[i]):Comparator.isObject(t)&&(r=t[i])),r)return e.length===0?r.line:this.ɗz(r.rawData,e)}static ɗaa(t){if(Comparator.isArray(t))return t.map(e=>this.ɗaa(e.rawData));if(Comparator.isObject(t)){let e=t;return Object.keys(e).reduce((i,r)=>{let o=e[r];return i[r]=this.ɗaa(o.rawData),i},{})}else return t}};});var m,j=w(()=>{X();m=class{static{this.ɗas=new Map;}static{this.ɗp=new Map;}static{this.ɗq=new Map;}static{this.ɗh=new Map;}static getDefinitions(t){let e=this.ɗq.get(this.ɗal(t));return e?Array.from(e.values()):[]}static getDefinition(t,e){if(!t.$meta.keyName)throw new Error(`"${t.name}" doesn't have a keyName, getDefinition cannot be called on it.`);return this.ɗq.get(this.ɗal(t))?.get(e)}static getDefinitionOrFail(t,e){let i=this.getDefinition(t,e);if(!i)throw new Error(`No result found for "${e}" in "${t.name}".`);return i}static getSingletonDefinition(t){return this.ɗq.get(this.ɗal(t))?.get(this.ɗal(t))}static getSingletonDefinitionOrFail(t){let e=this.getSingletonDefinition(t);if(!e)throw new Error(`No result found for "${t.name}".`);return e}static getLocationInFile(t,e,i){let r=this.ɗp.get(t.name)?.get(e);if(!r)throw new Error(`No raw definition found for "${e}" in "${t.name}".`);return {line:R.findLine(r,i),path:r.location.path}}static getLocationInFileById(t,e,i){let r=this.ɗap(t,e);if(!r)throw new Error(`No raw definition found for "${e}" in "${t.name}".`);return {line:R.findLine(r,i),path:r.location.path}}static ɗay(t){return this.ɗq.has(t)}static ɗak(t){let e=this.ɗh.get(t);if(!e)throw new Error(`No component found for "${t}".`);return e}static ɗbw(t){t.forEach((e,i)=>{this.ɗq.set(i,new Map);}),this.ɗh=t;}static ɗbx(t,e,i){let r=this.ɗq.get(this.ɗal(t));r&&r.set(e,JsonHelper.deepCopy(i));}static ɗca(t,e){let i=this.ɗal(t),r=this.ɗq.get(i);r&&r.set(i,JsonHelper.deepCopy(e));}static ɗax(t,e){return !!this.ɗas.get(t.name)?.has(e)}static ɗap(t,e){return this.ɗas.get(t.name)?.get(e)}static ɗbz(t,e,i){this.ɗas.has(t.name)||this.ɗas.set(t.name,new Map);let r=this.ɗas.get(t.name);r&&r.set(e,JsonHelper.deepCopy(i));}static ɗby(t,e,i){this.ɗp.has(t.name)||this.ɗp.set(t.name,new Map);let r=this.ɗp.get(t.name);r&&r.set(e,JsonHelper.deepCopy(i));}static ɗal(t){return t.$meta.componentName}};});var ht,At=w(()=>{P();q();ht=class{constructor(t){this.ɗac=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(T.getValidationState(e)==="valid"){let{rawDefinition:r}=T.getPathAndRawDefinition(e);if(t=r.location.path.substring(0,r.location.path.lastIndexOf("/")+1)+t,this.ɗac.existsSync(t))try{let s=Ue(t);return {url:t.replace(l.config.projectRoot,"."),size:{x:s.width,y:s.height}}}catch{throw new Error(`The file in the path "${t}" is not an image`)}else throw new Error(`No file is found in the path: "${t}"`)}else throw new Error(`Internal Error; joi validation context for image validator: Path: "${e.state.path}", RawDefinition: "${JSON.stringify(e.prefs.context.rawDefinition)}"`)};}};});var St,te=w(()=>{P();q();St=class{constructor(t){this.ɗac=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(T.getValidationState(e)==="valid"){let{rawDefinition:r}=T.getPathAndRawDefinition(e);if(t=r.location.path.substring(0,r.location.path.lastIndexOf("/")+1)+t,this.ɗac.existsSync(t))return t.replace(l.config.projectRoot,".");throw new Error(`No file is found in the path: "${t}"`)}else throw new Error(`Internal Error; joi validation context for path validator: Path: "${e.state.path}", RawDefinition: "${JSON.stringify(e.prefs.context.rawDefinition)}"`)};}};});var Dt,ee=w(()=>{Dt=class{constructor(t,e,i,r){t={x:t.x*i,y:t.y*i},this.ɗbq=i,this.ɗe=r||false,this.ɗc=this.ɗai(t,e),this.ɗd=this.ɗaj(t,this.ɗc);}convertPositionToSpriteAnchor(t){t={x:t.x*this.ɗbq,y:t.y*this.ɗbq};let e={x:t.x+this.ɗd.topLeft.x,y:t.y+this.ɗd.topLeft.y};if(this.ɗe&&!this.ɗce(e))throw new Error(`location is outside of the sprite boundaries. Entered position: {x: ${t.x}, y: ${t.y}}, position on sprite: {x: ${e.x}, y: ${e.y}}, bounding box: ${JSON.stringify(this.ɗd)}.`);return e}getRotationFromAnchor(t){return Vector.fromVec2(t).radian.value}ɗce(t){return !(t.x<this.ɗd.topLeft.x||t.x>this.ɗd.bottomRight.x||t.y<this.ɗd.topLeft.y||t.y>this.ɗd.bottomRight.y)}ɗai(t,e){return {x:t.x*e.x,y:t.y*e.y}}ɗaj(t,e){return {topLeft:{x:-e.x,y:-e.y},bottomRight:{x:t.x-e.x,y:t.y-e.y}}}};});var Ct,ie=w(()=>{ee();Ct=class{constructor(t){this.ɗbd=t;this.validate=(t,e)=>{let i=this.ɗbd.selectSpriteDefinition(t);if(!i)throw new Error("positionOnSprite - callback function did not return sprite definition.");let r=new Dt(i.url.size,i.anchor,i.scale,this.ɗbd.checkIfPositionIsOnSprite);return (Array.isArray(this.ɗbd.positionsJsonPath)?this.ɗbd.positionsJsonPath:[this.ɗbd.positionsJsonPath]).forEach(s=>JSONPath({json:t,path:s}).forEach(a=>{if(Comparator.isObject(a)){if(!Comparator.isNumber(a.x)||!Comparator.isNumber(a.y))throw new Error(`positionOnSprite, positions json path returned a non-vec2 result. Value: "${a}".`)}else throw new Error(`positionOnSprite, positions json path returned a non-object result. Value: "${a}".`);let p=r.convertPositionToSpriteAnchor(a);p={x:Math.round(p.x),y:Math.round(p.y)},this.ɗbd.includeRotationFromAnchor?(a.rotationFromAnchor=r.getRotationFromAnchor(p),a.positionFromAnchor=p,delete a.x,delete a.y):(a.x=p.x,a.y=p.y);})),t};}};});var Tt,wt,xt,re=w(()=>{P();j();X();q();Tt=class{constructor(t){this.options=t;this.regex=/^[a-z]+([a-zA-Z0-9]+)*$/;}validatePropertyExistence(t,e,i){if(i?.additionalValidation){let r=m.ɗap(t,e),o=r?R.flatten(r):void 0,s=i.additionalValidation.validate(o);if(s.error)throw new Error(s.error.message)}}},wt=class extends Tt{constructor(e,i){super(i);this.validate=(e,i)=>{if(T.getValidationState(i)==="valid"){let o=this.ɗbl.find(s=>m.getDefinition(s,e));if(o)return this.validatePropertyExistence(o,e,this.options),this.ɗaw?{value:e,type:T.getDefinitionComponentName(o)}:e;if(this.ɗbl.find(a=>m.ɗax(a,e)))i.prefs.context.failSilently=true;else throw new Error(`There is no "${this.ɗbl.map(a=>T.getDefinitionComponentName(a)).join(" or ")}" definition found for "${e}"`)}else throw new Error(`Internal Error; joi validation context for reference validator: Path: "${i.state.path}", RawDefinition: "${JSON.stringify(i.prefs.context)}"`)};this.ɗbl=[];Comparator.isArray(e)?(this.ɗaw=true,this.ɗbl=e):(this.ɗaw=false,this.ɗbl=[e]);}},xt=class extends Tt{constructor(e,i){super(i);this.ɗg=e;this.validate=(e,i)=>{if(!l.componentInProgressData)ConsoleHelper.log("Unexpected error: Lazy reference validation has been called outside of the validation cycle.","red");else if(!l.componentInProgressData.meta.keyName)ConsoleHelper.log("Lazy reference can only be used for definitions with key name defined.","red");else if(l.componentInProgressData.meta.componentName!==this.ɗg)ConsoleHelper.log(`Lazy reference can only be used for self referencing. It is used under: "${this.ɗg}"`,"red");else if(l.componentInProgressData.meta.singleton)ConsoleHelper.log(`Lazy reference cannot be used for singleton components. It is used under: "${this.ɗg}"`,"red");else {let a=i.state.ancestors.at(-1)[l.componentInProgressData.meta.keyName];a?(l.componentInProgressData.idToReferencesMap.has(a)||l.componentInProgressData.idToReferencesMap.set(a,new Set),l.componentInProgressData.idToReferencesMap.get(a).add(e)):ConsoleHelper.log("Unexpected error: definitionId cannot be retrieved by keyname.","red");}let r=m.ɗak(this.ɗg);if(T.getValidationState(i)==="valid"){if(m.ɗax(r,e))return this.validatePropertyExistence(r,e,this.options),e;throw new Error(`There is no "${this.ɗg}" definition found for "${e}"`)}else throw new Error(`Internal Error; joi validation context for reference validator: Path: "${i.state.path}", RawDefinition: "${JSON.stringify(i.prefs.context)}"`)};}};});var vt,ne=w(()=>{vt=class{constructor(t){this.ɗbb=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(this.ɗbb.has(t))throw new Error(`Value "${t}" is not unique in the name space: "${Array.from(this.ɗbb).join(", ")}"`);return this.ɗbb.add(t),t};}};});var bt,ae=w(()=>{te();ie();re();At();ne();bt=class n{static decorate(t,e){t.string().__proto__.unique=function(i){let r=new vt(i);return n.ɗn(this,r)},t.string().__proto__.path=function(){let i=new St(e);return n.ɗn(this,i)},t.string().__proto__.sprite=function(){let i=new ht(e);return n.ɗn(this,i)},t.string().__proto__.reference=function(i,r){let o=new wt(i,r);return n.ɗn(this,o)},t.string().__proto__.lazyReference=function(i,r){let o=new xt(i,r);return n.ɗn(this,o)},t.object().__proto__.positionOnSprite=function(i){let r=new Ct(i);return this.custom(r.validate)},t!==h&&this.decorate(h,e);}static ɗn(t,e){return t.regex(e.regex).custom(e.validate)}};});var se=w(()=>{ae();bt.decorate(h,S__default);});function ge(n){return n.replace(/[-_]/g," ").replace(/([a-z])([A-Z])/g,"$1 $2").replace(/\s+/g," ").trim().toLowerCase().split(" ").map(t=>t.charAt(0).toUpperCase()+t.slice(1)).join("")}function C(n){return function(t){if(n.singleton){if(n.keyName!==void 0)throw new Error(`Singleton components should not have keyName! Component: ${n.componentName}`);if(!(t.prototype instanceof Q))throw new Error(`Singleton components should extend SingleDefinitionComponent! Component: ${n.componentName}`)}else if(!(t.prototype instanceof g))throw new Error(`Non singleton components should extend DefinitionComponent! Component: ${n.componentName}`);t.$meta={componentName:n.componentName,pascalCaseComponentName:ge(n.componentName),keyName:n.keyName,singleton:n.singleton,validationSchema:n.validationSchema};}}var g=class{static getSchema(){return this.$meta.validationSchema}},Q=class{static getSchema(){return this.$meta.validationSchema}};q();P();X();var O=class{static{this.definitionToRawDefintion=new Map;}static getRawDefinitions(t){return l.rawDefinitions.filter(e=>e.componentName===t)}static validateAndConvert(t,e){return this.getRawDefinitions(t).map(i=>{let r=this.ɗcd(i,e);if(this.definitionToRawDefintion.set(r,i),r)return {definition:r,rawDefinition:i}}).filter(i=>i)}static validateAndConvertSingular(t,e){let i=this.validateAndConvert(t,e);if(i.length===0){if(l.successful){let r={description:`Singleton definition has no declared entry "${t}"`,location:{line:0,path:"*"}};l.addErrorLog(r,"lowPriority");}}else if(i.length>1)l.rawDefinitions.filter(r=>r.componentName===t).forEach(r=>{let o={description:`Only one definition can be defined for "${t}"`,location:r.location};l.addErrorLog(o,"lowPriority");});else return i[0]}static ɗcd(t,e){let i={rawDefinition:t,failSilently:false},{value:r,error:o}=e.validate(R.flatten(t),{abortEarly:false,context:i});if(o?.details){let s=o.details.reverse().map(a=>({description:a.message,location:{line:R.findLine(t,a.path),path:t.location.path}}));l.addErrorLog(s.reverse());}else if(!i.failSilently)return r}};P();var Y="CONFIG",Ut=h.object().keys({projectRoot:h.string().regex(/^[\S]+$/).required(),compilerModulesPath:h.string().regex(/^[\S]+$/).optional()}),B=class{static{this.$meta={componentName:Y,validationSchema:Ut};}static process(){let t=O.validateAndConvertSingular(Y,Ut);if(t){let e=t.definition;l.config.projectRoot=e.projectRoot,e.compilerModulesPath&&(l.config.compilerModulesPath=`${e.projectRoot}${e.compilerModulesPath.replace("./","")}`);}}};P();j();var Pt=class{decorateDefinitionName(t,e){return `${this.kebabCaseToCamelCase(e)}${this.upperCaseFirstLetter(t)}`}kebabCaseToCamelCase(t){return t.toLowerCase().replace(/-./g,e=>e[1].toUpperCase())}lowerCaseFirstLetter(t){return t.charAt(0).toLowerCase()+t.slice(1)}upperCaseFirstLetter(t){return t.charAt(0).toUpperCase()+t.slice(1)}removeWhiteSpace(t){return t.replace(/\r?\n|\r/g,"").replace(/\/\/.*$/gm,"").trim().replace(/ {2,}/g," ")}removeComments(t){return t.replace(/\/\/.*$/gm,"").trimEnd()}},_=new Pt;var et=class{constructor(){this.ɗr=false;this.ɗo=[];this.ɗv=[];this.ɗl="";}process(t){return this.ɗr=false,this.ɗm=void 0,this.ɗo=[],this.ɗv=[],this.ɗl=t.path,t.content.split(`
|
|
8
|
-
`).forEach((e,i)=>{let r=
|
|
9
|
-
`)}}else throw {description:`Multiline string should end with backtick in new line "${i}"!`,location:{line:e.line+t.length,path:e.path}}}};var
|
|
5
|
+
`,i=o;}return t.variableType?e+=`export const ${t.variableName}: ${t.variableType} = ${this.ɗcb(t.variable)}`:e+=`export const ${t.variableName} = ${this.ɗcb(t.variable)}`,i&&(e=this.ɗbo(e,i)),t.replaceMap&&(e=this.ɗbo(e,t.replaceMap)),this.format(e)}static async format(t){return format(t,{parser:"typescript",trailingComma:"none",tabWidth:2,printWidth:130,singleQuote:true,arrowParens:"avoid",plugins:[ie,ee]})}static ɗj(t,e){let i=l.outputPath+t.substring(0,t.lastIndexOf("/")),r=l.config.projectRoot+e.substring(1);return dt__default.relative(i,r).replace(/\\/g,"/")}static ɗbo(t,e){return e.forEach(i=>{t=t.replace(new RegExp(i.target,"g"),i.replace);}),t}static ɗi(t,e,i){let r=t.map(p=>{let c=JsonHelper.deepFind(p,e);if(!c)throw new Error(`OutputHelperClass: Asset url is not found in the given variable! item: "${JSON.stringify(p)}", assetUrl: "${e}"`);return c}),o=new Map;r.forEach(p=>{if(!o.has(p)){let c=`asset${o.size}`;o.set(p,c);}});let s=Array.from(o,([p,c])=>({name:c,url:p})).map(p=>`import ${p.name} from '${this.ɗj(i,p.url)}';`).join(`
|
|
6
|
+
`),a=r.reduce((p,c)=>[...p,{target:`"${c}"`,replace:o.get(c)}],[]);return {assetImports:s,replaceMap:a}}static ɗcb(t){return JSON.stringify(t,(e,i)=>i===void 0?null:i).replace(/null/gm,"undefined")}};var l=class{static{this.compilerExecutionPath="";}static{this.outputPath="";}static{this.config={projectRoot:"",compilerModulesPath:""};}static{this.rawDefinitions=[];}static{this.files=[];}static{this.output=[];}static{this.exports=[];}static{this.componentInProgressData=void 0;}static async addFile(t){this.exports.push({variableName:t.variableName,path:t.path}),this.output.push({path:t.path,content:await N.generate({preText:Comparator.isArray(t.preText)?t.preText.join(`
|
|
7
|
+
`):t.preText,variableName:t.variableName,variableType:t.variableType,variable:t.variable,replaceMap:t.replaceMap,filePath:t.path,assetUrl:t.assetUrl})});}static get successful(){return this.errorLogs.length===0}static addErrorLog(t,e="default"){Comparator.isArray(t)?e==="lowPriority"?this.ɗu=[...t,...this.ɗu]:this.ɗu.push(...t):e==="lowPriority"?this.ɗu=[t,...this.ɗu]:this.ɗu.push(t);}static flushErrorLogs(){this.errorLogs=[...this.ɗu,...this.errorLogs],this.ɗu=[];}static{this.errorLogs=[];}static{this.ɗu=[];}static reset(){this.compilerExecutionPath="D:/test",this.outputPath="D:/test/.asset-build",this.config.projectRoot="D:/",this.files=[],this.rawDefinitions=[],this.errorLogs=[],this.ɗu=[],this.output=[];}};var G=class{constructor(t){this.ɗar=t;this.ɗav=new Set;this.ɗau=new Map;this.ɗb=new Set;this.ɗt=[];}newEntry(t,e){if(this.ɗav.has(t)){if(!this.ɗb.has(t)){this.ɗb.add(t);let i=this.ɗau.get(t);i&&this.ɗt.push({identifier:t,location:i});}return this.ɗt.push({identifier:t,location:e}),false}else return this.ɗav.add(t),this.ɗau.set(t,e),true}logDuplicateErrors(){this.ɗt.forEach(t=>{let e={description:`Value should be singular! Group: "${this.ɗar}", Value: "${t.identifier}"`,location:t.location};l.addErrorLog(e);});}};var C=class{static{this.ɗs=new Map;}static logDuplicates(){this.ɗs.forEach(t=>t.logDuplicateErrors());}static getDefinitionComponentName(t){return t.$meta.componentName}static getDefinitionComponentNamesFromArray(t){return Comparator.isArray(t)?t.map(e=>this.getDefinitionComponentName(e)):[this.getDefinitionComponentName(t)]}static getValidationState(t){return t.state.path&&(t.state.path.length===0||t.state.path[0]!==void 0&&t.prefs.context.rawDefinition)?"valid":"notValid"}static getPathAndRawDefinition(t){let e=t.state.path,i=t.prefs.context.rawDefinition;return {path:e,rawDefinition:i}}static getDuplicateHelper(t){let e=this.ɗs.get(t);return e||(e=new G(t),this.ɗs.set(t,e)),e}};var W=class{constructor(t){this.ɗac=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(C.getValidationState(e)==="valid"){let{rawDefinition:r}=C.getPathAndRawDefinition(e);if(t=r.location.path.substring(0,r.location.path.lastIndexOf("/")+1)+t,this.ɗac.existsSync(t))return t.replace(l.config.projectRoot,".");throw new Error(`No file is found in the path: "${t}"`)}else throw new Error(`Internal Error; joi validation context for path validator: Path: "${e.state.path}", RawDefinition: "${JSON.stringify(e.prefs.context.rawDefinition)}"`)};}};var K=class{constructor(t,e,i,r){t={x:t.x*i,y:t.y*i},this.ɗbq=i,this.ɗe=r||false,this.ɗc=this.ɗai(t,e),this.ɗd=this.ɗaj(t,this.ɗc);}convertPositionToSpriteAnchor(t){t={x:t.x*this.ɗbq,y:t.y*this.ɗbq};let e={x:t.x+this.ɗd.topLeft.x,y:t.y+this.ɗd.topLeft.y};if(this.ɗe&&!this.ɗce(e))throw new Error(`location is outside of the sprite boundaries. Entered position: {x: ${t.x}, y: ${t.y}}, position on sprite: {x: ${e.x}, y: ${e.y}}, bounding box: ${JSON.stringify(this.ɗd)}.`);return e}getRotationFromAnchor(t){return Vector.fromVec2(t).radian.value}ɗce(t){return !(t.x<this.ɗd.topLeft.x||t.x>this.ɗd.bottomRight.x||t.y<this.ɗd.topLeft.y||t.y>this.ɗd.bottomRight.y)}ɗai(t,e){return {x:t.x*e.x,y:t.y*e.y}}ɗaj(t,e){return {topLeft:{x:-e.x,y:-e.y},bottomRight:{x:t.x-e.x,y:t.y-e.y}}}};var Q=class{constructor(t){this.ɗbd=t;this.validate=(t,e)=>{let i=this.ɗbd.selectSpriteDefinition(t);if(!i)throw new Error("positionOnSprite - callback function did not return sprite definition.");let r=new K(i.url.size,i.anchor,i.scale,this.ɗbd.checkIfPositionIsOnSprite);return (Array.isArray(this.ɗbd.positionsJsonPath)?this.ɗbd.positionsJsonPath:[this.ɗbd.positionsJsonPath]).forEach(s=>JSONPath({json:t,path:s}).forEach(a=>{if(Comparator.isObject(a)){if(!Comparator.isNumber(a.x)||!Comparator.isNumber(a.y))throw new Error(`positionOnSprite, positions json path returned a non-vec2 result. Value: "${a}".`)}else throw new Error(`positionOnSprite, positions json path returned a non-object result. Value: "${a}".`);let p=r.convertPositionToSpriteAnchor(a);p={x:Math.round(p.x),y:Math.round(p.y)},this.ɗbd.includeRotationFromAnchor?(a.rotationFromAnchor=r.getRotationFromAnchor(p),a.positionFromAnchor=p,delete a.x,delete a.y):(a.x=p.x,a.y=p.y);})),t};}};var $=class{static findLine(t,e){if(e.length===0)return t.parsedStructure.line;{let i,r=[...e];for(;i===void 0&&r.length>0;)i=this.ɗz(t.parsedStructure.rawData,[...r]),r.pop();return i||t.parsedStructure.line}}static flatten(t){return this.ɗaa(t.parsedStructure.rawData)}static ɗz(t,e){let i=e.shift(),r;if(t&&i!==void 0&&(Comparator.isNumber(i)?Comparator.isArray(t)&&(r=t[i]):Comparator.isObject(t)&&(r=t[i])),r)return e.length===0?r.line:this.ɗz(r.rawData,e)}static ɗaa(t){if(Comparator.isArray(t))return t.map(e=>this.ɗaa(e.rawData));if(Comparator.isObject(t)){let e=t;return Object.keys(e).reduce((i,r)=>{let o=e[r];return i[r]=this.ɗaa(o.rawData),i},{})}else return t}};var m=class{static{this.ɗas=new Map;}static{this.ɗp=new Map;}static{this.ɗq=new Map;}static{this.ɗh=new Map;}static getDefinitions(t){let e=this.ɗq.get(this.ɗal(t));return e?Array.from(e.values()):[]}static getDefinition(t,e){if(!t.$meta.keyName)throw new Error(`"${t.name}" doesn't have a keyName, getDefinition cannot be called on it.`);return this.ɗq.get(this.ɗal(t))?.get(e)}static getDefinitionOrFail(t,e){let i=this.getDefinition(t,e);if(!i)throw new Error(`No result found for "${e}" in "${t.name}".`);return i}static getSingletonDefinition(t){return this.ɗq.get(this.ɗal(t))?.get(this.ɗal(t))}static getSingletonDefinitionOrFail(t){let e=this.getSingletonDefinition(t);if(!e)throw new Error(`No result found for "${t.name}".`);return e}static getLocationInFile(t,e,i){let r=this.ɗp.get(t.name)?.get(e);if(!r)throw new Error(`No raw definition found for "${e}" in "${t.name}".`);return {line:$.findLine(r,i),path:r.location.path}}static getLocationInFileById(t,e,i){let r=this.ɗap(t,e);if(!r)throw new Error(`No raw definition found for "${e}" in "${t.name}".`);return {line:$.findLine(r,i),path:r.location.path}}static ɗay(t){return this.ɗq.has(t)}static ɗak(t){let e=this.ɗh.get(t);if(!e)throw new Error(`No component found for "${t}".`);return e}static ɗbw(t){t.forEach((e,i)=>{this.ɗq.set(i,new Map);}),this.ɗh=t;}static ɗbx(t,e,i){let r=this.ɗq.get(this.ɗal(t));r&&r.set(e,JsonHelper.deepCopy(i));}static ɗca(t,e){let i=this.ɗal(t),r=this.ɗq.get(i);r&&r.set(i,JsonHelper.deepCopy(e));}static ɗax(t,e){return !!this.ɗas.get(t.name)?.has(e)}static ɗap(t,e){return this.ɗas.get(t.name)?.get(e)}static ɗbz(t,e,i){this.ɗas.has(t.name)||this.ɗas.set(t.name,new Map);let r=this.ɗas.get(t.name);r&&r.set(e,JsonHelper.deepCopy(i));}static ɗby(t,e,i){this.ɗp.has(t.name)||this.ɗp.set(t.name,new Map);let r=this.ɗp.get(t.name);r&&r.set(e,JsonHelper.deepCopy(i));}static ɗal(t){return t.$meta.componentName}};var X=class{constructor(t){this.options=t;this.regex=/^[a-z]+([a-zA-Z0-9]+)*$/;}validatePropertyExistence(t,e,i){if(i?.additionalValidation){let r=m.ɗap(t,e),o=r?$.flatten(r):void 0,s=i.additionalValidation.validate(o);if(s.error)throw new Error(s.error.message)}}},Y=class extends X{constructor(e,i){super(i);this.validate=(e,i)=>{if(C.getValidationState(i)==="valid"){let o=this.ɗbl.find(s=>m.getDefinition(s,e));if(o)return this.validatePropertyExistence(o,e,this.options),this.ɗaw?{value:e,type:C.getDefinitionComponentName(o)}:e;if(this.ɗbl.find(a=>m.ɗax(a,e)))i.prefs.context.failSilently=true;else throw new Error(`There is no "${this.ɗbl.map(a=>C.getDefinitionComponentName(a)).join(" or ")}" definition found for "${e}"`)}else throw new Error(`Internal Error; joi validation context for reference validator: Path: "${i.state.path}", RawDefinition: "${JSON.stringify(i.prefs.context)}"`)};this.ɗbl=[];Comparator.isArray(e)?(this.ɗaw=true,this.ɗbl=e):(this.ɗaw=false,this.ɗbl=[e]);}},tt=class extends X{constructor(e,i){super(i);this.ɗg=e;this.validate=(e,i)=>{if(!l.componentInProgressData)ConsoleHelper.log("Unexpected error: Lazy reference validation has been called outside of the validation cycle.","red");else if(!l.componentInProgressData.meta.keyName)ConsoleHelper.log("Lazy reference can only be used for definitions with key name defined.","red");else if(l.componentInProgressData.meta.componentName!==this.ɗg)ConsoleHelper.log(`Lazy reference can only be used for self referencing. It is used under: "${this.ɗg}"`,"red");else if(l.componentInProgressData.meta.singleton)ConsoleHelper.log(`Lazy reference cannot be used for singleton components. It is used under: "${this.ɗg}"`,"red");else {let a=i.state.ancestors.at(-1)[l.componentInProgressData.meta.keyName];a?(l.componentInProgressData.idToReferencesMap.has(a)||l.componentInProgressData.idToReferencesMap.set(a,new Set),l.componentInProgressData.idToReferencesMap.get(a).add(e)):ConsoleHelper.log("Unexpected error: definitionId cannot be retrieved by keyname.","red");}let r=m.ɗak(this.ɗg);if(C.getValidationState(i)==="valid"){if(m.ɗax(r,e))return this.validatePropertyExistence(r,e,this.options),e;throw new Error(`There is no "${this.ɗg}" definition found for "${e}"`)}else throw new Error(`Internal Error; joi validation context for reference validator: Path: "${i.state.path}", RawDefinition: "${JSON.stringify(i.prefs.context)}"`)};}};var et=class{constructor(t){this.ɗac=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(C.getValidationState(e)==="valid"){let{rawDefinition:r}=C.getPathAndRawDefinition(e);if(t=r.location.path.substring(0,r.location.path.lastIndexOf("/")+1)+t,this.ɗac.existsSync(t))try{let s=pe(t);return {url:t.replace(l.config.projectRoot,"."),size:{x:s.width,y:s.height}}}catch{throw new Error(`The file in the path "${t}" is not an image`)}else throw new Error(`No file is found in the path: "${t}"`)}else throw new Error(`Internal Error; joi validation context for image validator: Path: "${e.state.path}", RawDefinition: "${JSON.stringify(e.prefs.context.rawDefinition)}"`)};}};var it=class{constructor(t){this.ɗbb=t;this.regex=/^[\S]+$/;this.validate=(t,e)=>{if(this.ɗbb.has(t))throw new Error(`Value "${t}" is not unique in the name space: "${Array.from(this.ɗbb).join(", ")}"`);return this.ɗbb.add(t),t};}};var H=class n{static decorate(t,e){t.string().__proto__.unique=function(i){let r=new it(i);return n.ɗn(this,r)},t.string().__proto__.path=function(){let i=new W(e);return n.ɗn(this,i)},t.string().__proto__.sprite=function(){let i=new et(e);return n.ɗn(this,i)},t.string().__proto__.reference=function(i,r){let o=new Y(i,r);return n.ɗn(this,o)},t.string().__proto__.lazyReference=function(i,r){let o=new tt(i,r);return n.ɗn(this,o)},t.object().__proto__.positionOnSprite=function(i){let r=new Q(i);return this.custom(r.validate)},t!==h&&this.decorate(h,e);}static ɗn(t,e){return t.regex(e.regex).custom(e.validate)}};H.decorate(h,S__default);function me(n){return n.replace(/[-_]/g," ").replace(/([a-z])([A-Z])/g,"$1 $2").replace(/\s+/g," ").trim().toLowerCase().split(" ").map(t=>t.charAt(0).toUpperCase()+t.slice(1)).join("")}function T(n){return function(t){if(n.singleton){if(n.keyName!==void 0)throw new Error(`Singleton components should not have keyName! Component: ${n.componentName}`);if(!(t.prototype instanceof rt))throw new Error(`Singleton components should extend SingleDefinitionComponent! Component: ${n.componentName}`)}else if(!(t.prototype instanceof g))throw new Error(`Non singleton components should extend DefinitionComponent! Component: ${n.componentName}`);t.$meta={componentName:n.componentName,pascalCaseComponentName:me(n.componentName),keyName:n.keyName,singleton:n.singleton,validationSchema:n.validationSchema};}}var g=class{static getSchema(){return this.$meta.validationSchema}},rt=class{static getSchema(){return this.$meta.validationSchema}};var R=class{static{this.definitionToRawDefintion=new Map;}static getRawDefinitions(t){return l.rawDefinitions.filter(e=>e.componentName===t)}static validateAndConvert(t,e){return this.getRawDefinitions(t).map(i=>{let r=this.ɗcd(i,e);if(this.definitionToRawDefintion.set(r,i),r)return {definition:r,rawDefinition:i}}).filter(i=>i)}static validateAndConvertSingular(t,e){let i=this.validateAndConvert(t,e);if(i.length===0){if(l.successful){let r={description:`Singleton definition has no declared entry "${t}"`,location:{line:0,path:"*"}};l.addErrorLog(r,"lowPriority");}}else if(i.length>1)l.rawDefinitions.filter(r=>r.componentName===t).forEach(r=>{let o={description:`Only one definition can be defined for "${t}"`,location:r.location};l.addErrorLog(o,"lowPriority");});else return i[0]}static ɗcd(t,e){let i={rawDefinition:t,failSilently:false},{value:r,error:o}=e.validate($.flatten(t),{abortEarly:false,context:i});if(o?.details){let s=o.details.reverse().map(a=>({description:a.message,location:{line:$.findLine(t,a.path),path:t.location.path}}));l.addErrorLog(s.reverse());}else if(!i.failSilently)return r}};var nt="CONFIG",Jt=h.object().keys({projectRoot:h.string().regex(/^[\S]+$/).required(),compilerModulesPath:h.string().regex(/^[\S]+$/).optional()}),J=class{static{this.$meta={componentName:nt,validationSchema:Jt};}static process(){let t=R.validateAndConvertSingular(nt,Jt);if(t){let e=t.definition;l.config.projectRoot=e.projectRoot,e.compilerModulesPath&&(l.config.compilerModulesPath=`${e.projectRoot}${e.compilerModulesPath.replace("./","")}`);}}};var xt=class{decorateDefinitionName(t,e){return `${this.kebabCaseToCamelCase(e)}${this.upperCaseFirstLetter(t)}`}kebabCaseToCamelCase(t){return t.toLowerCase().replace(/-./g,e=>e[1].toUpperCase())}lowerCaseFirstLetter(t){return t.charAt(0).toLowerCase()+t.slice(1)}upperCaseFirstLetter(t){return t.charAt(0).toUpperCase()+t.slice(1)}removeWhiteSpace(t){return t.replace(/\r?\n|\r/g,"").replace(/\/\/.*$/gm,"").trim().replace(/ {2,}/g," ")}removeComments(t){return t.replace(/\/\/.*$/gm,"").trimEnd()}},q=new xt;var ot=class{constructor(){this.ɗr=false;this.ɗo=[];this.ɗv=[];this.ɗl="";}process(t){return this.ɗr=false,this.ɗm=void 0,this.ɗo=[],this.ɗv=[],this.ɗl=t.path,t.content.split(`
|
|
8
|
+
`).forEach((e,i)=>{let r=q.removeWhiteSpace(e);this.ɗr?r.startsWith("###")?(this.ɗab(),this.ɗbc(e,i,r.substring(4))):this.ɗm&&r.length>0&&this.ɗm.content.push(q.removeComments(e)):r==="# DEFINITIONS"&&(this.ɗr=true);}),this.ɗab(),{definitionPlaneTexts:this.ɗo,errorLogs:this.ɗv}}ɗab(){if(this.ɗm)if(this.ɗm.content.length>0)this.ɗo.push(this.ɗm);else {let t={description:"Definitions cannot be empty!",location:this.ɗm.location};this.ɗv.push(t);}this.ɗm=void 0;}ɗbc(t,e,i){if(m.ɗay(i))this.ɗm={type:i,location:{line:e+1,path:this.ɗl},content:[]};else {let r={description:`Invalid definition header: "${t.trim()}"`,location:{line:e+1,path:this.ɗl}};this.ɗv.push(r),this.ɗm=void 0;}}};var at=class{static parse(t,e){let i=[],r=e.line,o=[];if(t.forEach((s,a)=>{if(s.startsWith(" ")){if(a===0)throw {description:"Invalid coding indent!",location:{line:e.line+a,path:e.path}};i.push(s.substring(2));}else {if(s.match(/^- {2}/g)||s.match(/^-[\S]/g))throw {description:`There should be one space after dash operator! "${s}"`,location:{line:e.line+a,path:e.path}};if(s.startsWith("-")){if(i.length){let p=b.getParsedStructure(i,{line:r,path:e.path});o.push(p);}i=[s.substring(2)],r=e.line+a;}else throw s.startsWith(" ")?{description:"Invalid coding indent!",location:{line:e.line+a,path:e.path}}:{description:`Unexpected array element! "${s}"`,location:{line:e.line+a,path:e.path}}}}),i.length){let s=b.getParsedStructure(i,{line:r,path:e.path});o.push(s);}return {line:e.line,rawData:o}}};var st=class{static parse(t,e){let i=[],r="",o=0,s,a={};if(t.forEach((p,c)=>{if(!p.startsWith(" ")&&!p.startsWith("- ")&&s!=="multiLineString"){if(p.startsWith(":"))throw {description:`Invalid row, row cannot start with columns! "${p}"`,location:{line:e.line+c,path:e.path}};if(p.match(/[\w]*:[\w]*:/g))throw {description:`Invalid row, multiple columns! "${p}"`,location:{line:e.line+c,path:e.path}};if(p.match(/: {2}/g)||p.match(/^[\w]+:[\S]/g))throw {description:`There should be one space after column operator! "${p}"`,location:{line:e.line+c,path:e.path}};if(p.startsWith(" "))throw {description:`Invalid coding indent! "${p}"`,location:{line:e.line+c,path:e.path}};if(p.indexOf(":")===-1)throw {description:`Unexpected object element! "${p}"`,location:{line:e.line+c,path:e.path}};{if(i.length){let I=b.getParsedStructure(i,{line:o,path:e.path});I.line-=1,a[r]=I,i=[],r="",o=0;}let d=q.lowerCaseFirstLetter(p.substring(0,p.indexOf(":")));if(p.trimEnd().endsWith(":"))if(r=d,o=e.line+c+1,t[c+1])s=t[c+1].startsWith("-")?"array":"object";else throw {description:`No value found after column! "${p}"`,location:{line:e.line+c,path:e.path}};else if(p.trimEnd().endsWith("`")&&p.indexOf("`")===p.lastIndexOf("`"))i.push("`"),r=d,o=e.line+c+1,s="multiLineString";else {let I=p.substring(p.indexOf(":")+2),U=b.getParsedStructure([I],{line:e.line+c,path:e.path});a[d]=U;}}}else {if(c===0)throw p.startsWith("-")?{description:`Unexpected object element! "${p}"`,location:{line:e.line+c,path:e.path}}:{description:`Invalid coding indent! "${p}"`,location:{line:e.line+c,path:e.path}};if(p.startsWith("`")){i.push(p);let d=b.getParsedStructure(i,{line:o,path:e.path});d.line-=1,a[r]=d,i=[],r="",o=0;}else i.push(p.substring(s==="object"?2:0));}}),i.length){let p=b.getParsedStructure(i,{line:o,path:e.path});p.line-=1,a[r]=p;}return {line:e.line,rawData:a}}};var pt=class{static parse(t,e){let i=t[0];if(i.startsWith("`"))return t.length===1?this.ɗbg(i,e,"`"):this.ɗbe(t,e);if(t.length>1)throw {description:`Invalid row! "${t[1]}"`,location:{line:e.line+2,path:e.path}};return i.startsWith('"')?this.ɗbg(i,e,'"'):this.ɗbf(i,e)}static ɗbf(t,e){if(t.indexOf(" ")!==-1)throw {description:`Unexpected space! "${t}"`,location:e};return {line:e.line,rawData:t==="undefined"?void 0:t}}static ɗbg(t,e,i){let r=new RegExp(i,"g");if((t.match(r)||[]).length>2)throw {description:"There should be only one opening and one closeing quote!",location:e};if(t.endsWith(i))return {line:e.line,rawData:t.replace(r,"")};throw {description:"Quote is not get closed!",location:e}}static ɗbe(t,e){let i=t[t.length-1];if(t[0]!=="`")throw {description:`There should be new line after backtick "${t[0]}"!`,location:{line:e.line,path:e.path}};if(i.startsWith("`")&&i!=="`")throw {description:`There should be new line after backtick "${i}"!`,location:{line:e.line+t.length,path:e.path}};if(i.trim().startsWith("`")){if(i!=="`")throw {description:"Invalid coding indent!",location:{line:e.line+t.length,path:e.path}};return {line:e.line,rawData:t.slice(0,t.length-1).slice(1).join(`
|
|
9
|
+
`)}}else throw {description:`Multiline string should end with backtick in new line "${i}"!`,location:{line:e.line+t.length,path:e.path}}}};var b=class n{static getParsedStructure(t,e){switch(this.ɗaq(t[0])){case "object":return st.parse(t,e);case "array":return at.parse(t,e);case "primitive":return pt.parse(t,e)}}static ɗaq(t){return t.startsWith("-")&&!t.match(/^-?\d+(\.\d+)?$/)?"array":t.match(/^[\w]+:/)?"object":"primitive"}process(t){let e=[];return {rawDefinitions:t.map(r=>{try{if(r.content.length)return {componentName:r.type,location:r.location,parsedStructure:n.getParsedStructure(r.content,{line:r.location.line+1,path:r.location.path})}}catch(o){o?.description&&o?.location?e.push(o):e.push({description:`Unexpected Error! Error: "${o}"`,location:r.location});}}).filter(r=>r),errorLogs:e}}};var lt=class{static{this.ɗbv=new ot;}static{this.ɗcc=new b;}static process(){let t=l.files.reduce((i,r)=>{let o=this.ɗbv.process(r);return l.addErrorLog(o.errorLogs),i.push(...o.definitionPlaneTexts),i},[]),e=this.ɗcc.process(t);l.rawDefinitions.push(...e.rawDefinitions),l.addErrorLog(e.errorLogs),J.process();}};var Et="// ---- INDEX OUTPUT ----",fe="// ---- END ----",j=class{static{this.ɗbi=[];}static{this.ɗat=[];}static addPremadeInterface(t){this.ɗbi.push(t);}static addIdType(t,e){let i=`export type ${t}ID = ${e.map(r=>`'${r}'`).join(" | ")};`;this.ɗat.push(i);}static async generateFile(t,e){if(l.config.compilerModulesPath){let i=await this.ɗaf(t);i&&await this.ɗk(i);}else await this.ɗk(e);}static async ɗk(t){let e=t,i=this.generateTypes();i&&(e+=`
|
|
10
10
|
|
|
11
|
-
`+i),l.output.push({path:"/index.ts",content:await
|
|
11
|
+
`+i),l.output.push({path:"/index.ts",content:await N.format(e)});}static async ɗaf(t){let e=Pt.sync(`${l.config.compilerModulesPath}/**/*.ts`).map(o=>o.replace(/\\/g,"/"));e.length===0&&ConsoleHelper.log("No typescript file found to generate index.ts file.","red");let i=this.ɗae(),r=await this.ɗag(e);if(r!==void 0){let o=`${t}
|
|
12
12
|
${i}
|
|
13
13
|
|
|
14
|
-
${r}`;return o=await
|
|
14
|
+
${r}`;return o=await N.format(o),S.writeFileSync(`${l.compilerExecutionPath}/output-index-file.ts`,`// AUTO GENERATED - CHANGES WILL BE REPLACED
|
|
15
15
|
export const OutputIndexFile = \`${o}\`;
|
|
16
16
|
`),ConsoleHelper.log("Index content 'output-index-file.ts' is generated.","green"),o}}static ɗae(){return l.exports.map(t=>`export { ${t.variableName} } from '.${t.path.substring(0,t.path.lastIndexOf("."))}';`).join(`
|
|
17
17
|
`)}static async ɗag(t){let e=0,i=[];t.forEach(o=>{let s=o.substring(o.lastIndexOf("/")+1,o.lastIndexOf(".")),a=S.readFileSync(o,"utf-8");try{let p=this.ɗam(s,a);p&&i.push(p);}catch(p){e++,ConsoleHelper.log(`Error parsing file: ${o}, error: '${p.message}'`,"red");}});let r=`//-------------------------- DEFINITIONS --------------------------
|
|
@@ -19,25 +19,25 @@ export const OutputIndexFile = \`${o}\`;
|
|
|
19
19
|
`),r+=`
|
|
20
20
|
|
|
21
21
|
`),r+=i.join(`
|
|
22
|
-
`),e===0?r:void 0}static ɗam(t,e){let i=e.indexOf(
|
|
23
|
-
`,i+
|
|
22
|
+
`),e===0?r:void 0}static ɗam(t,e){let i=e.indexOf(Et),r=i!==-1,o=[];for(;i!==-1;){let s=e.indexOf(fe,i);if(s===-1)throw new Error("No end command found.");o.push(e.substring(e.indexOf(`
|
|
23
|
+
`,i+Et.length)+1,s)),i=e.indexOf(Et,s);}if(r)return `// ---- ${t} ----
|
|
24
24
|
${o.join(`
|
|
25
25
|
`)}`}static generateTypes(){let t="";return this.ɗat.length>0&&(t+=`//-------------------------- ID TYPES --------------------------
|
|
26
26
|
`,t+=this.ɗat.join(`
|
|
27
27
|
`),t+=`
|
|
28
|
-
`),t}};var
|
|
28
|
+
`),t}};var de=/^[a-z]+([a-zA-Z0-9]+)*$/,mt="======================================================",ue="------------------------------------------------------",Mt=n=>n.path.replace(l.compilerExecutionPath+"/","")+":"+n.line,ft=class{static async process(t,e,i){let r=new Map;r.set(nt,J),t.forEach(s=>{let a=s.$meta.componentName;if(r.has(a))throw new Error(`Component name "${a}" is used more than once.`);r.set(a,s);}),m.ɗbw(r),ConsoleHelper.log("Compilation is in progress.","white"),this.ɗbk();let o=await this.ɗah(t,e,i);this.ɗcf(o,l.outputPath);}static ɗbk(){l.compilerExecutionPath=dt.resolve("./").replace(/\\/g,"/"),l.outputPath=`${l.compilerExecutionPath}/.asset-build`,l.files=Pt.sync(`${l.compilerExecutionPath}/**/*.md`).map(t=>t.replace(/\\/g,"/")).map(t=>{let e=S.readFileSync(t).toString();return {path:t,content:e}});}static ɗcf(t,e){let i=new Set;Pt.sync(`${l.outputPath}/**/*`,{nodir:true}).map(a=>a.replace(/\\/g,"/")).forEach(a=>{i.add(a);}),t.forEach(a=>{a.path=e+a.path,i.delete(a.path);}),l.successful&&(ConsoleHelper.log(mt,"gray"),ConsoleHelper.log("Changes:","gray"),ConsoleHelper.newLine());let r=0;l.successful&&i.forEach(a=>{r++,console.info(`${ConsoleHelper.red}Erasing file:${ConsoleHelper.gray} "${this.ɗf(a)}"${ConsoleHelper.default}`),S.unlinkSync(a);});let o=0,s=0;t.forEach(a=>{let p=a.path.substring(0,a.path.lastIndexOf("/"));S.mkdirSync(p,{recursive:true});let c=S.existsSync(a.path);(c?S.readFileSync(a.path).toString():"")!==a.content&&(c?(o++,console.info(`${ConsoleHelper.blue}Modifying file:${ConsoleHelper.gray} "${this.ɗf(a.path)}"${ConsoleHelper.default}`)):(s++,console.info(`${ConsoleHelper.cyan}Creating file:${ConsoleHelper.gray} "${this.ɗf(a.path)}"${ConsoleHelper.default}`)),S.writeFileSync(a.path,a.content));}),this.ɗbn(e),s+o+r>0&&ConsoleHelper.newLine(),ConsoleHelper.log(`Created file count: ${s}`,"gray"),ConsoleHelper.log(`Modified file count: ${o}`,"gray"),ConsoleHelper.log(`Erased file count: ${r}`,"gray"),ConsoleHelper.log(mt,"gray"),l.successful?ConsoleHelper.log("Compilation is completed successfuly!","green"):ConsoleHelper.log("Compilation encountered errors!","red");}static ɗf(t){let e=l.compilerExecutionPath.length;return t.substring(e)}static ɗbn(t){let e=S.readdirSync(t),i=true;for(let r of e){let o=dt.join(t,r);S.statSync(o).isDirectory()&&this.ɗbn(o)?(S.rmdirSync(o),console.info(`${ConsoleHelper.red}Erasing folder:${ConsoleHelper.gray} "${o.substring(t.length).replace(/\\/g,"/")}"${ConsoleHelper.default}`)):i=false;}return i}static async ɗah(t,e,i){lt.process(),l.flushErrorLogs();let r=t.map(o=>{let s=o.$meta;l.componentInProgressData={meta:s,idToReferencesMap:new Map};let a={addFile:c=>l.addFile(c),addError:c=>l.addErrorLog(c),convertLocationInFileToLink:c=>Mt(c)};this.ɗaz(s.keyName,s.componentName,o);let p;if(s.singleton){let c=R.validateAndConvertSingular(s.componentName,s.validationSchema);c&&(p=c.definition,m.ɗby(o,c.definition,c.rawDefinition),m.ɗca(o,p));}else {let c=R.validateAndConvert(s.componentName,s.validationSchema);if(l.componentInProgressData.idToReferencesMap.size>0){let d=s.keyName;if(!d)throw new Error("Unexpected Error: KeyName should be defined for lazy references.");let I=l.componentInProgressData.idToReferencesMap,U=true;for(;U;){let Ut=c.length,Gt=new Set(c.map(Tt=>Tt.definition[d]));c=c.filter(Tt=>{let Vt=Tt.definition[d];if(I.has(Vt)){let Wt=I.get(Vt),Nt=true;return Wt.forEach(Kt=>Gt.has(Kt)||(Nt=false)),Nt}return true}),U=Ut!==c.length;}}c.forEach(d=>{m.ɗby(o,d.definition,d.rawDefinition);}),p=c.map(d=>d.definition),this.ɗbm(p,s.keyName,o);}return l.flushErrorLogs(),l.componentInProgressData=void 0,{definitionToProcess:p,output:a,moduleClass:o}});for(let o of r)if(o.definitionToProcess){let s=new o.moduleClass,a=o.moduleClass.$meta.keyName;a&&j.addIdType(o.moduleClass.$meta.pascalCaseComponentName,o.definitionToProcess.map(p=>p[a])),await s.process(o.definitionToProcess,o.output);}return l.flushErrorLogs(),C.logDuplicates(),l.successful&&await j.generateFile(e,i),this.ɗao()}static ɗaz(t,e,i){let r=R.getRawDefinitions(e);t&&r.forEach(o=>{let s=o.parsedStructure.rawData;if(!Comparator.isObject(s)||Comparator.isArray(s))l.addErrorLog({description:`KeyName shold not be used with a content which is not an object, keyName: "${t}" in "${e}"`,location:{line:o.parsedStructure.line,path:o.location.path}});else {let a=s[t]?.rawData;Comparator.isString(a)&&(de.test(a)===false?l.addErrorLog({description:`KeyValue should be a valid key, keyValue: "${a}"`,location:{line:s[t].line,path:o.location.path}}):m.ɗax(i,a)?l.addErrorLog({description:`Definition with key "${a}" already exists`,location:{line:s[t].line,path:o.location.path}}):m.ɗbz(i,a,o));}});}static ɗbm(t,e,i){e&&t.forEach(r=>{let o=r[e];m.ɗbx(i,o,r);});}static ɗao(){return l.successful?l.output:(ConsoleHelper.newLine(),ConsoleHelper.log("ERROR LOGS:","red"),ConsoleHelper.log(mt,"gray"),l.errorLogs.forEach((t,e)=>{e>0&&ConsoleHelper.log(ue,"gray"),ConsoleHelper.log("Error:","red"),console.info(`${ConsoleHelper.white}Details:${ConsoleHelper.green} ${t.description}`),console.info(`${ConsoleHelper.white}Location:${ConsoleHelper.green} ${Mt(t.location)}`);}),ConsoleHelper.log(mt,"gray"),[{path:"/error-logs.md",content:l.errorLogs.map(t=>`${t.description}\r
|
|
29
29
|
Path: '${t.location.path}', Line: '${t.location.line}'\r
|
|
30
30
|
`).join(`\r
|
|
31
|
-
`)}])}};var
|
|
31
|
+
`)}])}};var $t=class{constructor(t,e,i){u.setup(t,e,i);}setScriptInput(t,e){u.setScriptInput(t,e);}setEventInput(t,e){u.setEventInput(t,e);}addCustomScriptTestCase(t,e,i){u.addCustomScriptTestCase(e,i,t);}addCustomEventTestCase(t,e,i){u.addCustomEventTestCase(e,i,t);}},u=class{static{this.ɗbr=new Map;}static{this.ɗw=new Map;}static{this.ɗbt=new Map;}static{this.ɗy=new Map;}static get scriptSimulatorFunctionsConstructor(){if(!this.ɗbs)throw new Error("ScriptSimulatorFunctionsConstructor is not set");return this.ɗbs}static get eventSimulatorFunctionsConstructor(){if(!this.ɗx)throw new Error("ScriptSimulatorFunctionsConstructor is not set");return this.ɗx}static get richTextTags(){return this.ɗbp}static get isInitialized(){return this.ɗbs&&this.ɗx&&this.ɗbp!==void 0}static setup(t,e,i){this.ɗbs=t,this.ɗx=e,this.ɗbp=i;}static getScriptInput(t){return this.ɗbr.get(t)}static getEventInput(t){return this.ɗw.get(t)}static getCustomScriptTestCases(){return Array.from(this.ɗbt.values())}static getCustomEventTestCases(){return Array.from(this.ɗy.values())}static isCustomScriptTestCase(t){return this.ɗbt.has(t.script)}static isCustomEventTestCase(t){return this.ɗy.has(t.script)}static setScriptInput(t,e){if(this.ɗbr.has(t))throw new Error(`Script input for ${t} already set`);this.ɗbr.set(t,e);}static setEventInput(t,e){if(this.ɗw.has(t))throw new Error(`Event input for ${t} already set`);this.ɗw.set(t,e);}static addCustomScriptTestCase(t,e,i){let r={testDefinition:{script:t,cases:[e]},customMessage:`Prebuild Test Case:
|
|
32
32
|
${i}`};this.ɗbt.set(t,r);}static addCustomEventTestCase(t,e,i){let r={testDefinition:{script:t,cases:[e]},customMessage:`Prebuild Test Case:
|
|
33
|
-
${i}`};this.ɗy.set(t,r);}};var
|
|
33
|
+
${i}`};this.ɗy.set(t,r);}};var ut=class{static convert(t){let e=false,i=t.indexOf('"');for(;i>=0;){let r=e?'"</b>':'<b>"';t=t.substring(0,i)+r+t.substring(i+1),e=!e,i=t.indexOf('"',i+r.length);}if(e)throw new Error("Quote is not closed.");return RichTextValidator.validate(t,u.richTextTags),t}};var ht=()=>h.string().custom(n=>({type:"command",value:n})),gt=n=>h.object().keys({branchByCondition:h.array().items(h.object().keys({condition:h.string().optional(),actions:h.link("#"+n).default([]).optional()})).custom((t,e)=>{let i=t.length;if(i>1){for(let r=0;r<i-1;r++)if(t[r].condition===void 0)throw new Error(`Element at index ${r} must have "condition"`)}else if(i===1&&t[0].condition===void 0)throw new Error('Single element must have "condition"');return t})}).custom(t=>({type:"branchByCondition",value:t.branchByCondition})),Bt=n=>h.object().keys({branchByPlayerChoice:h.array().items(h.object().keys({text:h.string().min(2).required(),condition:h.string().optional(),actions:h.link("#"+n).default([]).optional()}))}).custom(t=>({type:"branchByPlayerChoice",value:t.branchByPlayerChoice})),yt=n=>h.object().keys({branchByChance:h.array().items(h.object().keys({label:h.string().optional(),weight:h.number().integer().min(1).max(100).required(),condition:h.string().optional(),actions:h.link("#"+n).default([]).optional()}))}).custom(t=>({type:"branchByChance",value:t.branchByChance})),Ht=()=>h.object().min(1).max(1).custom(n=>{let t=Object.keys(n);if(t.length!==1)throw new Error("object must have exactly one key/value pair");let e=t[0],i=n[e];if(typeof i!="string")throw new Error("value must be a string");return i=ut.convert(i),{type:"dialog",value:{text:i,speaker:e}}});var Rt=new Set,ye=()=>h.object().keys({jumpTo:h.string().lazyReference("SCRIPT").required()}).custom(n=>({type:"jumpTo",value:n.jumpTo})),It="ScriptActionsSchema",Se=()=>h.array().items(h.alternatives().conditional(h.string(),{then:ht()}).conditional(h.object({jumpTo:h.exist()}).unknown(),{then:ye()}).conditional(h.object({branchByChance:h.exist()}).unknown(),{then:yt(It)}).conditional(h.object({branchByCondition:h.exist()}).unknown(),{then:gt(It)}).conditional(h.object({branchByPlayerChoice:h.exist()}).unknown(),{then:h.forbidden().messages({"any.unknown":"branchByPlayerChoice is not allowed in scripts"})}).conditional(h.object().min(1).max(1).unknown(),{then:h.forbidden().messages({"any.unknown":"dialogs are not allowed in scripts"})}).error(n=>n.map(t=>{if(t.code==="alternatives.any"){let e="command, jumpToScript, branchByCondition, branchByChance";t.message=`${t.local.label} does not match any of the allowed types: ${e}`;}return t}))).custom(n=>{let t=false,e=false;if(n.forEach(i=>{e?t=true:(i.type==="branchByCondition"||i.type==="branchByChance")&&(e=true);}),t)throw new Error("There should not be any command after branching.");return n}).id(It),v=class extends g{async process(t,e){await e.addFile({path:"/_premade/script-engine-definitions/scripts.ts",preText:'import { ScriptDefinition } from "script-engine-lib";',variableName:"ScriptDefinitions",variableType:"Readonly<Record<string, ScriptDefinition>>",variable:JsonHelper.arrayToObject(t,"id")});}};v=w([T({componentName:"SCRIPT",keyName:"id",validationSchema:h.object().keys({id:h.string().unique(Rt).required(),actions:Se().min(1).required()}).required()})],v);var A=class{constructor(t,e,i){this.ɗad=e;this.ɗba=i;this.ɗbu=new ScriptTestSimulator(t);}runTests(t,e){let i=[];return t.forEach(r=>{let o=false;r.cases.forEach((s,a)=>{if(!o){let p=new JSEngine(new this.ɗad(r.scriptInput),{});try{this.ɗbu.simulateScript(r.script,p,s.actionsBeforeTesting);}catch(c){let d=this.ɗbj(c,r,a,e);i.push(d),o=true;}}});}),i}printErrors(t,e){t.length===0&&this.ɗbu.getUnvisitedBranchLocations().forEach(i=>e.addError({description:"Event branch is not reaced by any of the combinations during the tests.",location:this.ɗba.getLocationOfDefinition(i.scriptId,i.path)})),t.forEach(i=>e.addError(i));}ɗbj(t,e,i,r){if(t instanceof SimulationError)return {description:e.customMessage?e.customMessage+`
|
|
34
34
|
`+t.message:t.message,location:this.ɗba.getLocationOfDefinition(t.location.scriptId,t.location.path)};if(t instanceof ActionsBeforeTestingError){let o=e.customMessage?e.customMessage+`
|
|
35
35
|
`+t.message:t.message,s=this.ɗba.getLocationOfTestDefinition(e.testDefinitionRef,["cases",`${i}`,"actionsBeforeTesting",`${t.actionIndex}`]);return {description:o,location:s}}else if(t instanceof BranchingBeforeTestingError){let o=this.ɗba.getLocationOfTestDefinition(e.testDefinitionRef,[]),s=`Running the test: ${r.convertLocationInFileToLink(o)}
|
|
36
36
|
|
|
37
37
|
`,a=t.message.indexOf(`
|
|
38
38
|
`,t.message.indexOf("Execution history"))+1,p=t.message.slice(0,a)+s+t.message.slice(a);return {description:e.customMessage?e.customMessage+`
|
|
39
|
-
`+p:p,location:this.ɗba.getLocationOfDefinition(t.location.scriptId,t.location.path)}}else throw t}};var
|
|
39
|
+
`+p:p,location:this.ɗba.getLocationOfDefinition(t.location.scriptId,t.location.path)}}else throw t}};var xe=h.string().custom(n=>({type:"command",value:n})),be=h.object().keys({runScript:h.string().reference(v).required()}).custom(n=>({type:"runScript",value:n.runScript})),Ee=()=>h.array().items(h.alternatives().conditional(h.string(),{then:xe}).conditional(h.object({runScript:h.exist()}).unknown(),{then:be}).error(n=>n.map(t=>{if(t.code==="alternatives.any"){let e="command, runScript";t.message=`${t.local.label} does not match any of the allowed types: ${e}`;}return t}))).min(1),F=class extends g{async process(t,e){let i=m.getDefinitions(v),r=new A(i,u.scriptSimulatorFunctionsConstructor,this.ɗan()),o=t.map(c=>({cases:c.cases,script:m.getDefinitionOrFail(v,c.script),scriptInput:u.getScriptInput(c.script),testDefinitionRef:c})),s=u.getCustomScriptTestCases().map(c=>({cases:c.testDefinition.cases,script:m.getDefinitionOrFail(v,c.testDefinition.script),scriptInput:u.getScriptInput(c.testDefinition.script),testDefinitionRef:c.testDefinition,customMessage:c.customMessage})),a=o.concat(s),p=r.runTests(a,e);r.printErrors(p,e);}ɗan(){return {getLocationOfDefinition:(t,e)=>m.getLocationInFileById(v,t,e),getLocationOfTestDefinition:(t,e)=>{if(u.isCustomScriptTestCase(t)){let i=`Internal error: custom script test case is failing. Definition: ${JSON.stringify(t)}, Path: ${JSON.stringify(e)}`;throw new Error(i)}else return m.getLocationInFile(F,t,e)}}}};F=w([T({componentName:"SCRIPT-TEST",validationSchema:h.object().keys({script:h.string().reference(v).required(),cases:h.array().items(h.object().keys({actionsBeforeTesting:Ee().default([]).optional()}).required()).required()}).required()})],F);var Pe=h.object().keys({jumpTo:h.string().lazyReference("EVENT").required()}).custom(n=>({type:"jumpTo",value:n.jumpTo})),St="EventActionsSchema",$e=()=>h.array().items(h.alternatives().conditional(h.string(),{then:ht()}).conditional(h.object({jumpTo:h.exist()}).unknown(),{then:Pe}).conditional(h.object({branchByChance:h.exist()}).unknown(),{then:yt(St)}).conditional(h.object({branchByCondition:h.exist()}).unknown(),{then:gt(St)}).conditional(h.object({branchByPlayerChoice:h.exist()}).unknown(),{then:Bt(St)}).conditional(h.object().min(1).max(1).unknown(),{then:Ht()}).error(n=>n.map(t=>{if(t.code==="alternatives.any"){let e="command, jumpTo, branchByCondition, branchByPlayerChoice, branchByChance";t.message=`${t.local.label} does not match any of the allowed types: ${e}`;}return t}))).custom(n=>{let t=false,e=false;if(n.forEach(i=>{e?t=true:(i.type==="branchByCondition"||i.type==="branchByPlayerChoice"||i.type==="branchByChance")&&(e=true);}),t)throw new Error("There should not be any command after branching.");return n}).id(St),x=class extends g{async process(t,e){await e.addFile({path:"/_premade/script-engine-definitions/events.ts",preText:'import { ScriptDefinition } from "script-engine-lib";',variableName:"EventDefinitions",variableType:"Readonly<Record<string, ScriptDefinition>>",variable:JsonHelper.arrayToObject(t,"id")});}};x=w([T({componentName:"EVENT",keyName:"id",validationSchema:h.object().keys({id:h.string().unique(Rt).required(),actions:$e().min(1).required()}).required()})],x);var Ie=h.string().custom(n=>({type:"command",value:n})),Re=h.object().keys({runEvent:h.string().reference(x).required()}).custom(n=>({type:"runScript",value:n.runEvent})),Fe=()=>h.array().items(h.alternatives().conditional(h.string(),{then:Ie}).conditional(h.object({runEvent:h.exist()}).unknown(),{then:Re}).error(n=>n.map(t=>{if(t.code==="alternatives.any"){let e="command, runEvent";t.message=`${t.local.label} does not match any of the allowed types: ${e}`;}return t}))).min(1),O=class extends g{async process(t,e){let i=m.getDefinitions(x),r=new A(i,u.eventSimulatorFunctionsConstructor,this.ɗan()),o=r.runTests(t.map(s=>({cases:s.cases,script:m.getDefinitionOrFail(x,s.script),scriptInput:u.getEventInput(s.script),testDefinitionRef:s})),e);r.printErrors(o,e);}ɗan(){return {getLocationOfDefinition:(t,e)=>m.getLocationInFileById(x,t,e),getLocationOfTestDefinition:(t,e)=>m.getLocationInFile(O,t,e)}}};O=w([T({componentName:"EVENT-TEST",validationSchema:h.object().keys({event:h.string().reference(x).required(),cases:h.array().items(h.object().keys({actionsBeforeTesting:Fe().default([]).optional()}).required()).required()}).required().custom(n=>({script:n.event,cases:n.cases}))})],O);var qt=false;function Oe(n){return function(t){if(qt)console.error("There can be only one definition generator!");else {qt=true;let e=[...n.modules];u.isInitialized&&(e=[v,x,...e,F,O]),ft.process(e,n.indexFilePretext,n.outputIndexFile);}}}var Ft=class{};var Ot=()=>h.array().items(h.array().items(zt().required()).min(3).required()).min(1),zt=()=>h.object().keys({x:h.number().required(),y:h.number().required()}),je=()=>h.string().pattern(/^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/).custom(n=>ColorHelper.stringColorToRGBColor(n)),ke=()=>h.number().min(-Math.PI).max(Math.PI),Je=(n,t)=>h.array().items(n).max(t).custom(e=>{if(e.length>t)throw new Error(`Array exceeds maximum size of ${t}`);for(;e.length<t;)e.push(void 0);return e}).default(ArrayHelper.createEmptyArray(t)).optional();var P=class extends g{async process(t,e){await e.addFile({path:"/_premade/assets/sprites.ts",preText:"import { AssetDefinition } from 'bard-legends-framework';",variableName:"SpriteAssets",variableType:"readonly AssetDefinition[]",assetUrl:"url",variable:t.map(i=>({id:i.id,url:i.url.url}))}),await e.addFile({path:"/_premade/asset-definitions/sprites.ts",preText:'import { SpriteDefinition } from "bard-legends-framework";',variableName:"SpriteDefinitions",variableType:"Readonly<Record<string, SpriteDefinition>>",variable:JsonHelper.arrayToObject(t,"id",{transformFunction:i=>({id:i.id,size:i.url.size,scale:i.scale,anchor:i.anchor,boundingShapes:i.boundingShapes})})});}};P=w([T({componentName:"SPRITE",keyName:"id",validationSchema:h.object().keys({id:h.string().required(),url:h.string().sprite().required(),scale:h.number().min(.1).max(1).default(1).optional(),anchor:h.object().keys({x:h.number().min(0).max(1).required(),y:h.number().min(0).max(1).required()}).default({x:.5,y:.5}).optional(),boundingShapes:Ot().optional()}).positionOnSprite({selectSpriteDefinition:n=>n,positionsJsonPath:["$..boundingShapes[*][*]"],includeRotationFromAnchor:false}).required()})],P);var Me=()=>h.string().reference(P).custom(n=>{let t=m.getDefinitionOrFail(P,n);if(t.url.size.x%4!==0)throw new Error(`Sprite width must be multiplier of four in order to keep the pixel perfection. Got: '${t.url.size.x}'`);if(t.url.size.y%4!==0)throw new Error(`Sprite height must be multiplier of four in order to keep the pixel perfection. Got: '${t.url.size.y}'`);return n}),Be=n=>h.string().reference(P).custom(t=>{let e=m.getDefinitionOrFail(P,t);if(n?.size){if(e.url.size.x!==n.size.x)throw new Error(`Sprite width must be '${n.size.x}px'. Got: '${e.url.size.x}'`);if(e.url.size.y!==n.size.y)throw new Error(`Sprite height must be '${n.size.y}px'. Got: '${e.url.size.y}'`)}if(n?.scale&&e.scale!==n.scale)throw new Error(`Sprite '${t}' scale must be '${n.scale}'. Got: '${e.scale}'`);return t});var z=class extends g{async process(t,e){await e.addFile({path:"/_premade/asset-definitions/sprite-groups.ts",preText:"",variableName:"SpriteGroupDefinitions",variableType:"Readonly<Record<string, readonly string[]>>",variable:JsonHelper.arrayToObject(t,"id",{transformFunction:i=>i.group})});}};z=w([T({componentName:"SPRITE-GROUP",keyName:"id",validationSchema:h.object().keys({id:h.string().required(),group:h.array().items(h.string().reference(P)).unique().required()}).required()})],z);var ze=`
|
|
40
40
|
export interface FontDefinition {
|
|
41
41
|
readonly id: string;
|
|
42
42
|
readonly fontFamily: string;
|
|
43
|
-
}`,
|
|
43
|
+
}`,_=class extends g{constructor(){super(),j.addPremadeInterface(ze);}async process(t,e){await e.addFile({path:"/_premade/assets/fonts.ts",preText:"import { AssetDefinition } from 'bard-legends-framework';",variableName:"FontAssets",variableType:"readonly AssetDefinition[]",assetUrl:"url",variable:t.map(i=>({id:i.id,url:i.url}))}),await e.addFile({path:"/_premade/asset-definitions/fonts.ts",preText:'import { FontDefinition } from "../../";',variableName:"FontDefinitions",variableType:"Readonly<Record<string, FontDefinition>>",variable:JsonHelper.arrayToObject(t,"id",{transformFunction:i=>({id:i.id,fontFamily:i.fontFamily})})});}};_=w([T({componentName:"FONT",keyName:"id",validationSchema:h.object().keys({id:h.string().required(),fontFamily:h.string().required(),url:h.string().path().required()}).required()})],_);export{g as DefinitionComponent,T as DefinitionComponentDecorator,Ft as DefinitionGenerator,Oe as DefinitionGeneratorDecorator,m as DefinitionStore,x as EventComponent,O as EventTestComponent,Je as FixedArraySchema,_ as FontComponent,je as HexColorSchema,H as JoiCustomValidators,Me as PixelPerfectSpriteSchema,Ot as PoligonSchema,ke as RotationSchema,v as ScriptComponent,F as ScriptTestComponent,$t as ScriptTesting,rt as SingleDefinitionComponent,P as SpriteComponent,z as SpriteGroupComponent,Be as SpriteSchema,R as Validator,zt as Vec2Schema};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "definition-generator-framework",
|
|
3
|
-
"version": "2.0.0
|
|
3
|
+
"version": "2.0.0",
|
|
4
4
|
"description": "Definition Generator Framework",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"publishConfig": {
|
|
@@ -48,7 +48,7 @@
|
|
|
48
48
|
},
|
|
49
49
|
"peerDependencies": {
|
|
50
50
|
"helpers-lib": "^2.0.0",
|
|
51
|
-
"joi": "^17.11.
|
|
51
|
+
"joi": "^17.11.1",
|
|
52
52
|
"script-engine-lib": "^1.0.0"
|
|
53
53
|
},
|
|
54
54
|
"devDependencies": {
|