xdbc 1.0.177 → 1.0.178

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/bundle.js CHANGED
@@ -241,7 +241,7 @@ class DBC {
241
241
  * May contain :: to separate multiple paths.
242
242
  *
243
243
  * @returns The **(target: object, methodName: string | symbol, parameterIndex: number ) => void** invoked by Typescript- */
244
- static decPrecondition(check, dbc, path = undefined) {
244
+ static decPrecondition(check, dbc, path = undefined, hint = undefined) {
245
245
  return (target, methodName, parameterIndex) => {
246
246
  DBC.requestParamValue(target, methodName, parameterIndex, (value) => {
247
247
  if (!DBC.resolveDBCPath(window, dbc).executionSettings
@@ -254,7 +254,7 @@ class DBC {
254
254
  const realValue = singlePath ? DBC.resolve(value, singlePath) : value;
255
255
  const result = check(realValue, target, methodName, parameterIndex);
256
256
  if (typeof result === "string") {
257
- DBC.resolveDBCPath(window, dbc).reportParameterInfringement(result, target, singlePath, methodName, parameterIndex, realValue);
257
+ DBC.resolveDBCPath(window, dbc).reportParameterInfringement(result, target, singlePath, methodName, parameterIndex, realValue, hint);
258
258
  }
259
259
  }
260
260
  });
@@ -276,7 +276,7 @@ class DBC {
276
276
  * @param message The {@link string } describing the infringement and it's provenience.
277
277
  * @param violator The {@link string } describing or naming the violator. */
278
278
  reportInfringement(message, violator, target, value, path) {
279
- const finalMessage = `[ From "${violator}"${typeof target === "function" ? ` in "${target.name}"` : typeof target === "object" && target !== null && typeof target.constructor === "function" ? ` in "${target.constructor.name}"` : `in "${target === undefined ? "UNDEFINED" : target === null ? "NULL" : target}"`}${value ? ` >"${value}"` : ""}${value ? ` > "${path}"` : "UNDEFINED | NULL"}: ${message}]`;
279
+ const finalMessage = `[ From "${violator}"${typeof target === "function" ? ` in "${target.name}"` : typeof target === "object" && target !== null && typeof target.constructor === "function" ? ` in "${target.constructor.name}"` : `in "${target === undefined ? "UNDEFINED" : target === null ? "NULL" : target}"`}${value ? ` > "${path}"` : "UNDEFINED | NULL"}: ${message}]`;
280
280
  if (this.infringementSettings.throwException) {
281
281
  throw new DBC.Infringement(finalMessage);
282
282
  }
@@ -292,9 +292,9 @@ class DBC {
292
292
  * @param method The {@link string } describing or naming the violator.
293
293
  * @param index The index of the parameter within the argument listing.
294
294
  * @param value The parameter's value. */
295
- reportParameterInfringement(message, target, path, method, index, value) {
295
+ reportParameterInfringement(message, target, path, method, index, value, hint = undefined) {
296
296
  const properIndex = index + 1;
297
- this.reportInfringement(`[ Parameter-value "${value}" of the ${properIndex}${properIndex === 1 ? "st" : properIndex === 2 ? "nd" : properIndex === 3 ? "rd" : "th"} parameter did not fulfill one of it's contracts: ${message}]`, method, target, value, path);
297
+ this.reportInfringement(`[ Parameter-value "${value}" of the ${properIndex}${properIndex === 1 ? "st" : properIndex === 2 ? "nd" : properIndex === 3 ? "rd" : "th"} parameter did not fulfill one of it's contracts: ${message}. ${hint ? `✨ ${hint} ✨` : ""}]`, method, target, value, path);
298
298
  }
299
299
  /**
300
300
  * Reports a field-infringement via {@link reportInfringement } also generating a proper {@link string }-wrapper
@@ -1979,4 +1979,4 @@ catch (X) {
1979
1979
 
1980
1980
  /******/ })()
1981
1981
  ;
1982
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"bundle.js","mappings":";;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,UAAU,GAAG,mBAAmB;AAClD;AACA;AACA,gGAAgG,cAAc;AAC9G,sCAAsC,2BAA2B,kBAAkB,0BAA0B;AAC7G;AACA,mEAAmE,yBAAyB;AAC5F;AACA,2BAA2B,eAAe;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,2BAA2B;AAC3E;AACA,iFAAiF,yBAAyB;AAC1G;AACA;AACA,4BAA4B,eAAe;AAC3C;AACA,+BAA+B,2BAA2B;AAC1D;AACA,qBAAqB,2BAA2B;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,WAAW;AACxC;AACA,mBAAmB,yBAAyB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,WAAW;AACxC;AACA,mBAAmB,yBAAyB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,0BAA0B;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,0BAA0B;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,6BAA6B,0BAA0B,cAAc;AACtH;AACA;AACA,2BAA2B,eAAe;AAC1C,6BAA6B,eAAe;AAC5C;AACA,wCAAwC,SAAS,GAAG,uCAAuC,YAAY,yGAAyG,wBAAwB,YAAY,uEAAuE,GAAG,EAAE,cAAc,MAAM,QAAQ,EAAE,eAAe,KAAK,wBAAwB,IAAI,QAAQ;AACtZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,2BAA2B,0BAA0B,cAAc;AAChH;AACA;AACA,2BAA2B,eAAe;AAC1C,2BAA2B,eAAe;AAC1C;AACA;AACA;AACA;AACA,sDAAsD,MAAM,WAAW,YAAY,EAAE,uFAAuF,mDAAmD,QAAQ;AACvO;AACA;AACA,yCAAyC,2BAA2B,0BAA0B,cAAc;AAC5G;AACA;AACA,yBAAyB,eAAe;AACxC;AACA,qCAAqC,eAAe;AACpD;AACA;AACA;AACA,oDAAoD,IAAI,GAAG,8BAA8B,KAAK,GAAG,cAAc,MAAM,2CAA2C,QAAQ;AACxK;AACA;AACA,yDAAyD,2BAA2B,0BAA0B,cAAc;AAC5H;AACA;AACA,2BAA2B,eAAe;AAC1C,2BAA2B,eAAe;AAC1C;AACA;AACA;AACA;AACA,mDAAmD,MAAM,2CAA2C,QAAQ;AAC5G;AACA;AACA,wBAAwB,YAAY,gBAAgB,gCAAgC;AACpF,0GAA0G,WAAW;AACrH;AACA,yCAAyC,gCAAgC;AACzE,sCAAsC,6BAA6B;AACnE,yCAAyC,2CAA2C;AACpF;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC;AACjC;AACA;AACA;AACA,sCAAsC;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,eAAe;AAC5C;AACA,iCAAiC,eAAe;AAChD,sCAAsC,cAAc;AACpD;AACA;AACA;AACA;AACA;AACA,+BAA+B,cAAc;AAC7C;AACA;AACA;AACA;AACA,6EAA6E;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0EAA0E;AAC1E;AACA;AACA;AACA;AACA,sCAAsC;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2DAA2D,uBAAuB;AAClF;AACA;AACA;AACA,QAAQ,cAAc;AACtB;AACA;AACA,wBAAwB,cAAc,kCAAkC,eAAe;AACvF;AACA,2BAA2B,eAAe;AAC1C;AACA,qCAAqC,QAAQ;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,cAAc,YAAY,WAAW;AACvE;AACA,oBAAoB,eAAe;AACnC,4BAA4B,cAAc,sBAAsB,WAAW;AAC3E;AACA,2BAA2B,WAAW;AACtC;AACA;AACA;AACA;;;;;;;;;;;;;;;;AC3Z6B;AAC7B;AACA,MAAM,YAAY,kCAAkC,cAAc;AAClE,YAAY,cAAc;AAC1B;AACA;AACA;AACO,iBAAiB,qCAAG;AAC3B;AACA;AACA,6CAA6C,qBAAqB;AAClE;AACA;AACA,8BAA8B,4CAA4C;AAC1E,uCAAuC,oBAAoB;AAC3D;AACA,yEAAyE,eAAe;AACxF,uBAAuB,aAAa,wCAAwC,cAAc;AAC1F;AACA;AACA,oCAAoC,aAAa;AACjD,0FAA0F,cAAc;AACxG,mEAAmE,aAAa;AAChF;AACA;AACA,wDAAwD,cAAc;AACtE,yCAAyC,aAAa;AACtD;AACA;AACA;AACA;AACA;AACA;AACA,mEAAmE,MAAM,gBAAgB,aAAa,KAAK,OAAO;AAClH;AACA;AACA,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,YAAY;AACxD;AACA;AACA,8DAA8D,EAAE,IAAI,OAAO;AAC3E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,0BAA0B;AAC1E;AACA,gFAAgF,aAAa;AAC7F;AACA,eAAe,cAAc,uCAAuC,4CAA4C;AAChH;AACA;AACA,yEAAyE,cAAc;AACvF;AACA;AACA,kDAAkD,4CAA4C;AAC9F;AACA,gCAAgC,yBAAyB;AACzD,gCAAgC,yBAAyB;AACzD,2BAA2B,2BAA2B;AACtD,0BAA0B,2BAA2B;AACrD;AACA,mBAAmB,eAAe,iBAAiB,4CAA4C;AAC/F;AACA;AACA,eAAe,qCAAG;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,6CAA6C,0BAA0B;AACvE;AACA;AACA,kDAAkD,4CAA4C;AAC9F;AACA,gCAAgC,yBAAyB;AACzD,gCAAgC,yBAAyB;AACzD,2BAA2B,2BAA2B;AACtD,0BAA0B,2BAA2B;AACrD;AACA,mBAAmB,eAAe,iBAAiB,4CAA4C;AAC/F;AACA;AACA,eAAe,qCAAG;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,4CAA4C,0BAA0B;AACtE;AACA;AACA,kDAAkD,4CAA4C;AAC9F;AACA,gCAAgC,yBAAyB;AACzD,gCAAgC,yBAAyB;AACzD,2BAA2B,wBAAwB;AACnD,0BAA0B,wBAAwB;AAClD;AACA,qBAAqB,wBAAwB;AAC7C;AACA,eAAe,qCAAG;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,0BAA0B,UAAU,sBAAsB,SAAS,gBAAgB,eAAe;AACtH,QAAQ,iBAAiB,GAAG,iBAAiB;AAC7C;AACA,2BAA2B,yBAAyB;AACpD;AACA,qBAAqB,wBAAwB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC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BAAsB,EAAE;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,SAAS,WAAW,OAAO;AAC7C;AACA;AACA;AACA,IAAI,6CAAK;AACT;AACA;AACA;AACA,IAAI,6CAAK;AACT,IAAI,qCAAG;AACP,eAAe,6CAAK;AACpB;AACA;AACA;AACA;AACA;AACA,IAAI,6CAAK;AACT;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE;AACjB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE;AACjB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,2CAAI;AACnB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE,UAAU,2CAAI;AAC/B;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE,SAAS,6CAAK;AAC/B;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP;AACA;AACA,eAAe,mDAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE,UAAU,2CAAI,gBAAgB,6CAAK;AACpD;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE,UAAU,2CAAI,gBAAgB,6CAAK;AACpD;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,4DAAO;AACtB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,8EAAgB;AAC/B;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,sDAAI;AACnB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,wEAAa;AAC5B;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,yDAAS;AACxB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,2CAAI;AACnB,eAAe,2CAAI;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://xdbc/./src/DBC.ts","webpack://xdbc/./src/DBC/AE.ts","webpack://xdbc/./src/DBC/COMPARISON.ts","webpack://xdbc/./src/DBC/COMPARISON/GREATER.ts","webpack://xdbc/./src/DBC/COMPARISON/GREATER_OR_EQUAL.ts","webpack://xdbc/./src/DBC/COMPARISON/LESS.ts","webpack://xdbc/./src/DBC/COMPARISON/LESS_OR_EQUAL.ts","webpack://xdbc/./src/DBC/EQ.ts","webpack://xdbc/./src/DBC/EQ/DIFFERENT.ts","webpack://xdbc/./src/DBC/INSTANCE.ts","webpack://xdbc/./src/DBC/REGEX.ts","webpack://xdbc/./src/DBC/TYPE.ts","webpack://xdbc/webpack/bootstrap","webpack://xdbc/webpack/runtime/define property getters","webpack://xdbc/webpack/runtime/hasOwnProperty shorthand","webpack://xdbc/webpack/runtime/make namespace object","webpack://xdbc/./src/Demo.ts"],"sourcesContent":["/**\n * Provides a **D**esign **B**y **C**ontract Framework using decorators.\n *\n * @remarks\n * Maintainer: Callari, Salvatore (XDBC@WaXCode.net) */\nexport class DBC {\n    /**\n     * Generate a unique key for storing parameter value requests.\n     * Format: \"ClassName:methodName\"\n     */\n    static getRequestKey(target, methodName) {\n        var _a;\n        const className = typeof target === 'function' ? target.name : ((_a = target.constructor) === null || _a === void 0 ? void 0 : _a.name) || 'Unknown';\n        return `${className}:${String(methodName)}`;\n    }\n    /**\n     * Make a request to get the value of a certain parameter of specific method in a specific {@link object }.\n     * That request gets enlisted in {@link paramValueRequests } which is used by {@link ParamvalueProvider} to invoke the\n     * given \"receptor\" with the parameter value stored in there. Thus a parameter decorator using this method will\n     * not receive any value of the top method is not tagged with {@link ParamvalueProvider}.\n     *\n     * @param target\t\tThe {@link object } containing the method with the parameter which's value is requested.\n     * @param methodName\tThe name of the method with the parameter which's value is requested.\n     * @param index\t\t\tThe index of the parameter which's value is requested.\n     * @param receptor\t\tThe method the requested parameter-value shall be passed to when it becomes available. */\n    static requestParamValue(target, methodName, index, \n    // biome-ignore lint/suspicious/noExplicitAny: Gotta be any since parameter-values may be undefined.\n    receptor) {\n        const key = DBC.getRequestKey(target, methodName);\n        if (DBC.paramValueRequests.has(key)) {\n            if (DBC.paramValueRequests.get(key).has(index)) {\n                DBC.paramValueRequests.get(key).get(index).push(receptor);\n            }\n            else {\n                DBC.paramValueRequests.get(key).set(index, new Array(receptor));\n            }\n        }\n        else {\n            DBC.paramValueRequests.set(key, new Map([\n                [index, new Array(receptor)],\n            ]));\n        }\n        return undefined;\n    }\n    /**\n     * A method-decorator factory checking the {@link paramValueRequests } for value-requests of the method's parameter thus\n     * also usable on setters.\n     * When found it will invoke the \"receptor\" registered there, inter alia by {@link requestParamValue }, with the\n     * parameter's value.\n     *\n     * @param target \t\tThe {@link object } hosting the tagged method as provided by the runtime.\n     * @param propertyKey \tThe tagged method's name as provided by the runtime.\n     * @param descriptor \tThe {@link PropertyDescriptor } as provided by the runtime.\n     *\n     * @returns The {@link PropertyDescriptor } that was passed by the runtime. */\n    static ParamvalueProvider(target, propertyKey, descriptor) {\n        const originalMethod = descriptor.value;\n        const isStatic = typeof target === 'function';\n        // biome-ignore lint/suspicious/noExplicitAny: Gotta be any since parameter-values may be undefined.\n        descriptor.value = function (...args) {\n            // #region   Check if a value of one of the method's parameter has been requested and pass it to the\n            //           receptor, if so.\n            const actualTarget = isStatic ? this : this.constructor;\n            const key = DBC.getRequestKey(actualTarget, propertyKey);\n            if (DBC.paramValueRequests.has(key)) {\n                for (const index of DBC.paramValueRequests.get(key).keys()) {\n                    if (index < args.length) {\n                        for (const receptor of DBC.paramValueRequests.get(key).get(index)) {\n                            receptor(args[index]);\n                        }\n                    }\n                }\n            }\n            else {\n                console.warn(\"No parameter value requests found for key:\", key);\n            }\n            // #endregion\tCheck if a value of one of the method's parameter has been requested and pass it to the\n            //              receptor, if so.\n            return originalMethod.apply(this, args);\n        };\n        return descriptor;\n    }\n    // #endregion Parameter-value requests.\n    // #region Class\n    /**\n     * A property-decorator factory serving as a **D**esign **B**y **C**ontract Invariant.\n     * This invariant aims to check the instance of the class not the value to be get or set.\n     *\n     * @param contracts The {@link DBC }-Contracts the value shall uphold.\n     *\n     * @throws \tA {@link DBC.Infringement } whenever the property is tried to be get or set without the instance of it's class\n     * \t\t\tfulfilling the specified **contracts**. */\n    static decClassInvariant(contracts, path = undefined, dbc = \"WaXCode.DBC\") {\n        return (target, propertyKey, descriptor) => {\n            if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkInvariants) {\n                return;\n            }\n            const originalSetter = descriptor.set;\n            const originalGetter = descriptor.get;\n            // biome-ignore lint/suspicious/noExplicitAny: Necessary to intercept UNDEFINED and NULL.\n            let value;\n            // #region Replace original property.\n            Object.defineProperty(target, propertyKey, {\n                get() {\n                    if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkInvariants) {\n                        return;\n                    }\n                    const realValue = path ? DBC.resolve(this, path) : this;\n                    // #region Check if all \"contracts\" are fulfilled.\n                    for (const contract of contracts) {\n                        const result = contract.check(realValue);\n                        if (typeof result === \"string\") {\n                            DBC.resolveDBCPath(window, dbc).reportFieldInfringement(result, target, path, propertyKey, realValue);\n                        }\n                    }\n                    // #endregion Check if all \"contracts\" are fulfilled.\n                    return originalGetter[propertyKey];\n                },\n                set(newValue) {\n                    if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkInvariants) {\n                        return;\n                    }\n                    const realValue = path ? DBC.resolve(this, path) : this;\n                    // #region Check if all \"contracts\" are fulfilled.\n                    for (const contract of contracts) {\n                        const result = contract.check(realValue);\n                        if (typeof result === \"string\") {\n                            DBC.resolveDBCPath(window, dbc).reportFieldInfringement(result, target, path, propertyKey, realValue);\n                        }\n                    }\n                    // #endregion Check if all \"contracts\" are fulfilled.\n                    value = newValue;\n                },\n                enumerable: true,\n                configurable: true,\n            });\n            // #endregion Replace original property.\n        };\n    }\n    // #endregion Class\n    // #region Invariant\n    /**\n     * A property-decorator factory serving as a **D**esign **B**y **C**ontract Invariant.\n     * Since the value must be initialized or set according to the specified **contracts** the value will only be checked\n     * when assigning it.\n     *\n     * @param contracts The {@link DBC }-Contracts the value shall uphold.\n     *\n     * @throws \tA {@link DBC.Infringement } whenever the property is tried to be set to a value that does not comply to the\n     * \t\t\tspecified **contracts**, by the returned method.*/\n    static decInvariant(contracts, path = undefined, dbc = \"WaXCode.DBC\") {\n        return (target, propertyKey) => {\n            if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkInvariants) {\n                return;\n            }\n            // biome-ignore lint/suspicious/noExplicitAny: Necessary to intercept UNDEFINED and NULL.\n            let value;\n            // #region Replace original property.\n            Object.defineProperty(target, propertyKey, {\n                set(newValue) {\n                    if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkInvariants) {\n                        return;\n                    }\n                    const realValue = path ? DBC.resolve(newValue, path) : newValue;\n                    // #region Check if all \"contracts\" are fulfilled.\n                    for (const contract of contracts) {\n                        const result = contract.check(realValue);\n                        if (typeof result === \"string\") {\n                            DBC.resolveDBCPath(window, dbc).reportFieldInfringement(result, target, path, propertyKey, realValue);\n                        }\n                    }\n                    // #endregion Check if all \"contracts\" are fulfilled.\n                    value = newValue;\n                },\n                enumerable: true,\n                configurable: true,\n            });\n            // #endregion Replace original property.\n        };\n    }\n    // #endregion Invariant\n    // #region Postcondition\n    /**\n     * A method decorator factory checking the result of a method whenever it is invoked thus also usable on getters.\n     *\n     * @param check\tThe **(toCheck: any, object, string) => boolean | string** to use for checking.\n     * @param dbc\tSee {@link DBC.resolveDBCPath }.\n     * @param path\tThe dotted path referring to the actual value to check, starting form the specified one.\n     *\n     * @returns The **( target : object, propertyKey : string, descriptor : PropertyDescriptor ) : PropertyDescriptor**\n     * \t\t\tinvoked by Typescript.\n     */\n    static decPostcondition(\n    // biome-ignore lint/suspicious/noExplicitAny: Necessary to intercept UNDEFINED and NULL.\n    check, dbc, path = undefined) {\n        return (target, propertyKey, descriptor) => {\n            const originalMethod = descriptor.value;\n            // biome-ignore lint/suspicious/noExplicitAny: Necessary to intercept UNDEFINED and NULL.\n            descriptor.value = (...args) => {\n                if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkPostconditions) {\n                    console.log(\"Postcondition checks are disabled.\");\n                    return;\n                }\n                // biome-ignore lint/complexity/noThisInStatic: <explanation>\n                const result = originalMethod.apply(this, args);\n                const realValue = path ? DBC.resolve(result, path) : result;\n                const checkResult = check(realValue, target, propertyKey);\n                if (typeof checkResult === \"string\") {\n                    DBC.resolveDBCPath(window, dbc).reportReturnvalueInfringement(checkResult, target, path, propertyKey, realValue);\n                }\n                return result;\n            };\n            return descriptor;\n        };\n    }\n    // #endregion Postcondition\n    // #region Decorator\n    // #region Precondition\n    /**\n     * A parameter-decorator factory that requests the tagged parameter's value passing it to the provided\n     * \"check\"-method when the value becomes available.\n     *\n     * @param check\tThe \"( unknown ) => void\" to be invoked along with the tagged parameter's value as soon\n     * \t\t\t\tas it becomes available.\n     * @param dbc  \tSee {@link DBC.resolveDBCPath }.\n     * @param path\tThe dotted path referring to the actual value to check, starting form the specified one.\n     * \t\t\t\tMay contain :: to separate multiple paths.\n     *\n     * @returns The **(target: object, methodName: string | symbol, parameterIndex: number ) => void** invoked by Typescript- */\n    static decPrecondition(check, dbc, path = undefined) {\n        return (target, methodName, parameterIndex) => {\n            DBC.requestParamValue(target, methodName, parameterIndex, (value) => {\n                if (!DBC.resolveDBCPath(window, dbc).executionSettings\n                    .checkPreconditions) {\n                    console.log(\"Precondition checks are disabled.\");\n                    return;\n                }\n                const paths = path ? path.replace(/ /g, \"\").split(\"::\") : [undefined];\n                for (const singlePath of paths) {\n                    const realValue = singlePath ? DBC.resolve(value, singlePath) : value;\n                    const result = check(realValue, target, methodName, parameterIndex);\n                    if (typeof result === \"string\") {\n                        DBC.resolveDBCPath(window, dbc).reportParameterInfringement(result, target, singlePath, methodName, parameterIndex, realValue);\n                    }\n                }\n            });\n        };\n    }\n    /**\n     * Reports a warning.\n     *\n     * @param message The message containing the warning. */\n    reportWarning(message) {\n        if (this.warningSettings.logToConsole) {\n            console.warn(message);\n        }\n    }\n    /**\n     * Reports an infringement according to the {@link infringementSettings } also generating a proper {@link string }-wrapper\n     * for the given \"message\" & violator.\n     *\n     * @param message\tThe {@link string } describing the infringement and it's provenience.\n     * @param violator \tThe {@link string } describing or naming the violator. */\n    reportInfringement(message, violator, target, value, path) {\n        const finalMessage = `[ From \"${violator}\"${typeof target === \"function\" ? ` in \"${target.name}\"` : typeof target === \"object\" && target !== null && typeof target.constructor === \"function\" ? ` in \"${target.constructor.name}\"` : `in \"${target === undefined ? \"UNDEFINED\" : target === null ? \"NULL\" : target}\"`}${value ? ` >\"${value}\"` : \"\"}${value ? ` > \"${path}\"` : \"UNDEFINED | NULL\"}: ${message}]`;\n        if (this.infringementSettings.throwException) {\n            throw new DBC.Infringement(finalMessage);\n        }\n        if (this.infringementSettings.logToConsole) {\n            console.log(finalMessage);\n        }\n    }\n    /**\n     * Reports a parameter-infringement via {@link reportInfringement } also generating a proper {@link string }-wrapper\n     * for the given \"message\",\"method\", parameter-\"index\" & value.\n     *\n     * @param message\tThe {@link string } describing the infringement and it's provenience.\n     * @param method \tThe {@link string } describing or naming the violator.\n     * @param index\t\tThe index of the parameter within the argument listing.\n     * @param value \tThe parameter's value. */\n    reportParameterInfringement(message, target, path, method, index, value) {\n        const properIndex = index + 1;\n        this.reportInfringement(`[ Parameter-value \"${value}\" of the ${properIndex}${properIndex === 1 ? \"st\" : properIndex === 2 ? \"nd\" : properIndex === 3 ? \"rd\" : \"th\"} parameter did not fulfill one of it's contracts: ${message}]`, method, target, value, path);\n    }\n    /**\n     * Reports a field-infringement via {@link reportInfringement } also generating a proper {@link string }-wrapper\n     * for the given **message** & **name**.\n     *\n     * @param message\tA {@link string } describing the infringement and it's provenience.\n     * @param key \t\tThe property key.\n     * @param path\t\tThe dotted-path {@link string } that leads to the value not fulfilling the contract starting from\n     * \t\t\t\t\tthe tagged one.\n     * @param value\t\tThe value not fulfilling a contract. */\n    reportFieldInfringement(message, target, path, key, value) {\n        this.reportInfringement(`[ New value for \"${key}\"${path === undefined ? \"\" : `.${path}`} with value \"${value}\" did not fulfill one of it's contracts: ${message}]`, key, target, value, path);\n    }\n    /**\n     * Reports a returnvalue-infringement according via {@link reportInfringement } also generating a proper {@link string }-wrapper\n     * for the given \"message\",\"method\" & value.\n     *\n     * @param message\tThe {@link string } describing the infringement and it's provenience.\n     * @param method \tThe {@link string } describing or naming the violator.\n     * @param value\t\tThe parameter's value. */\n    reportReturnvalueInfringement(message, target, path, method, \n    // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n    value) {\n        this.reportInfringement(`[ Return-value \"${value}\" did not fulfill one of it's contracts: ${message}]`, method, target, value, path);\n    }\n    /**\n     * Constructs this {@link DBC } by setting the {@link DBC.infringementSettings }, define the **WaXCode** namespace in\n     * **window** if not yet available and setting the property **DBC** in there to the instance of this {@link DBC }.\n     *\n     * @param infringementSettings \tSee {@link DBC.infringementSettings }.\n     * @param executionSettings\t\tSee {@link DBC.executionSettings }. */\n    constructor(infringementSettings = { throwException: true, logToConsole: false }, executionSettings = {\n        checkPreconditions: true,\n        checkPostconditions: true,\n        checkInvariants: true,\n    }) {\n        // #endregion Precondition\n        // #endregion Decorator\n        // #region Execution Handling\n        /** Stores settings concerning the execution of checks. */\n        this.executionSettings = {\n            checkPreconditions: true,\n            checkPostconditions: true,\n            checkInvariants: true,\n        };\n        // #endregion Execution Handling\n        // #region Warning handling.\n        /** Stores settings concerning warnings. */\n        this.warningSettings = { logToConsole: true };\n        // #endregion Warning handling.\n        // #region infringement handling.\n        /** Stores the settings concerning infringements */\n        this.infringementSettings = { throwException: true, logToConsole: false };\n        this.infringementSettings = infringementSettings;\n        // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n        if (window.WaXCode === undefined)\n            window.WaXCode = {};\n        // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n        window.WaXCode.DBC = this;\n    }\n    /**\n     * Resolves the desired {@link object } out a given one **toResolveFrom** using the specified **path**.\n     *\n     * @param toResolveFrom The {@link object } starting to resolve from.\n     * @param path\t\t\tThe dotted path-{@link string }.\n     * \t\t\t\t\t\tThis string uses ., [...], and () to represent accessing nested properties,\n     * \t\t\t\t\t\tarray elements/object keys, and calling methods, respectively, mimicking JavaScript syntax to navigate\n     * \t\t\t\t\t\tan object's structure. Code, e.g. something like a.b( 1 as number ).c, will not be executed and\n     * \t\t\t\t\t\tthus make the retrieval fail.\n     *\n     * @returns The requested {@link object }, NULL or UNDEFINED. */\n    static resolve(toResolveFrom, path) {\n        if (!toResolveFrom || typeof path !== \"string\") {\n            return undefined;\n        }\n        const parts = path.replace(/\\[(['\"]?)(.*?)\\1\\]/g, \".$2\").split(\".\"); // Handle indexers\n        let current = toResolveFrom;\n        for (const part of parts) {\n            if (current === null || typeof current === \"undefined\") {\n                return undefined;\n            }\n            const methodMatch = part.match(/(\\w+)\\((.*)\\)/);\n            if (methodMatch) {\n                const methodName = methodMatch[1];\n                const argsStr = methodMatch[2];\n                const args = argsStr.split(\",\").map((arg) => arg.trim()); // Simple argument parsing\n                if (typeof current[methodName] === \"function\") {\n                    current = current[methodName].apply(current, args);\n                }\n                else {\n                    return undefined; // Method not found or not a function\n                }\n            }\n            else {\n                current = current[part];\n            }\n        }\n        return current;\n    }\n}\n// #region Parameter-value requests.\n/** Stores all request for parameter values registered by {@link decPrecondition }. */\nDBC.paramValueRequests = new Map();\n// #region Classes\n// #region Errors\n/** An {@link Error } to be thrown whenever an infringement is detected. */\nDBC.Infringement = class extends Error {\n    /**\n     * Constructs this {@link Error } by tagging the specified message-{@link string } as an XDBC-Infringement.\n     *\n     * @param message The {@link string } describing the infringement. */\n    constructor(message) {\n        super(`[ XDBC Infringement ${message}]`);\n    }\n};\n// #endregion Errors\n// #endregion Classes\n// #endregion infringement handling.\n/**\n * Resolves the specified dotted {@link string }-path to a {@link DBC }.\n *\n * @param obj \tThe {@link object } to start resolving from.\n * @param path \tThe dotted {@link string }-path leading to the {@link DBC }.\n *\n * @returns The requested {@link DBC }.\n */\nDBC.resolveDBCPath = (obj, path) => path === null || path === void 0 ? void 0 : path.split(\".\").reduce((accumulator, current) => accumulator[current], obj);\n// Set the main instance with standard **DBC.infringementSettings**.\nnew DBC();\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } defining that all elements of an {@link object }s have to fulfill\n * a given {@link object }'s check-method (**( toCheck : any ) => boolean | string**).\n *\n * @remarks\n * Maintainer: Callari, Salvatore (XDBC@WaXCode.net) */\nexport class AE extends DBC {\n    // #region Condition checking.\n    /**\n     * Checks each element of the **value**-{@link Array < any >} against the given **condition**, if it is one. If it is not\n     * the **value** itself will be checked.\n     *\n     * @param condition\tThe { check: (toCheck: any) => boolean | string } to check the **value** against.\n     * @param value\t\tEither **value**-{@link Array < any >}, which's elements will be checked, or the value to be\n     * \t\t\t\t\tchecked itself.\n     * @param index\t\tIf specified with **idxEnd** being undefined, this {@link Number } will be seen as the index of\n     * \t\t\t\t\tthe value-{@link Array }'s element to check. If value isn't an {@link Array } this parameter\n     * \t\t\t\t\twill not have any effect.\n     * \t\t\t\t\tWith **idxEnd** not undefined this parameter indicates the beginning of the span of elements to\n     * \t\t\t\t\tcheck within the value-{@link Array }.\n     * @param idxEnd\tIndicates the last element's index (including) of the span of value-{@link Array } elements to check.\n     * \t\t\t\t\tSetting this parameter to -1 specifies that all value-{@link Array }'s elements beginning from the\n     * \t\t\t\t\tspecified **index** shall be checked.\n     *\n     * @returns As soon as the **condition** returns a {@link string }, instead of TRUE, the returned string. TRUE if the\n     * \t\t\t**condition** never returns a {@link string}. */\n    static checkAlgorithm(condition, value, index, idxEnd) {\n        if (Array.isArray(value)) {\n            if (index !== undefined && idxEnd === undefined) {\n                if (index > -1 && index < value.length) {\n                    const result = condition.check(value[index]);\n                    if (typeof result === \"string\") {\n                        return `Violating-Arrayelement at index \"${index}\" with value \"${value[index]}\". ${result}`;\n                    }\n                }\n                return true; // In order for optional parameter to not cause an error if they are omitted.\n            }\n            const ending = idxEnd !== undefined\n                ? idxEnd !== -1\n                    ? idxEnd + 1\n                    : value.length\n                : value.length;\n            for (let i = index ? index : 0; i < ending; i++) {\n                const result = condition.check(value[i]);\n                if (result !== true) {\n                    return `Violating-Arrayelement at index ${i}. ${result}`;\n                }\n            }\n        }\n        else {\n            return condition.check(value);\n        }\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link AE.checkAlgorithm } with either multiple or a single one\n     * of the **realConditions** to check the tagged parameter-value against with.\n     * When specifying an **index** and the tagged parameter's **value** is an {@link Array }, the **realConditions** apply to the\n     * element at the specified **index**.\n     * If the {@link Array } is too short the currently processed { check: (toCheck: any) => boolean | string } of\n     * **realConditions** will be verified to TRUE automatically, considering optional parameters.\n     * If an **index** is specified but the tagged parameter's value isn't an array, the **index** is treated as being undefined.\n     * If **index** is undefined and the tagged parameter's value is an {@link Array } each element of it will be checked\n     * against the **realConditions**.\n     *\n     * @param realConditions\tEither one or more { check: (toCheck: any) => boolean | string } to check the tagged parameter-value\n     * \t\t\t\t\t\t\tagainst with.\n     * @param index\t\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param idxEnd\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param path\t\t\t\tSee {@link DBC.decPrecondition }.\n     * @param dbc\t\t\t\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns\tA {@link string } as soon as one { check: (toCheck: any) => boolean | string } of **realConditions** returns one.\n     * \t\t\tOtherwise TRUE. */\n    static PRE(realConditions, index = undefined, idxEnd = undefined, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            if (Array.isArray(realConditions)) {\n                for (const currentCondition of realConditions) {\n                    const result = AE.checkAlgorithm(currentCondition, value, index, idxEnd);\n                    if (typeof result !== \"boolean\")\n                        return result;\n                }\n            }\n            else {\n                return AE.checkAlgorithm(realConditions, value, index, idxEnd);\n            }\n            return true;\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link AE.checkAlgorithm } with either multiple or a single one\n     * of the **realConditions** to check the tagged method's return-value against with.\n     *\n     * @param realConditions\tEither one or more { check: (toCheck: any) => boolean | string } to check the tagged parameter-value\n     * \t\t\t\t\t\t\tagainst with.\n     * @param index\t\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param idxEnd\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param path\t\t\t\tSee {@link DBC.decPrecondition }.\n     * @param dbc\t\t\t\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns\tA {@link string } as soon as one { check: (toCheck: any) => boolean | string } of **realConditions** return one.\n     * \t\t\tOtherwise TRUE. */\n    static POST(realConditions, index = undefined, idxEnd = undefined, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            if (Array.isArray(realConditions)) {\n                for (const currentCondition of realConditions) {\n                    const result = AE.checkAlgorithm(currentCondition, value, index, idxEnd);\n                    if (typeof result !== \"boolean\")\n                        return result;\n                }\n            }\n            else {\n                return AE.checkAlgorithm(\n                // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n                realConditions, value, index, idxEnd);\n            }\n            return true;\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link AE.checkAlgorithm } with either multiple or a single one\n     * of the **realConditions** to check the tagged field.\n     *\n     * @param realConditions\tEither one or more { check: (toCheck: any) => boolean | string } to check the tagged parameter-value\n     * \t\t\t\t\t\t\tagainst with.\n     * @param index\t\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param idxEnd\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param path\t\t\t\tSee {@link DBC.decInvariant }.\n     * @param dbc\t\t\t\tSee {@link DBC.decInvariant }.\n     *\n     * @returns\tSee {@link DBC.decInvariant }. */\n    static INVARIANT(realConditions, index = undefined, idxEnd = undefined, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new AE(realConditions, index, idxEnd)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    //\n    // For usage in dynamic scenarios (like global functions).\n    //\n    /**\n     * Invokes the {@link AE.checkAlgorithm } with all {@link AE.conditions } and the {@link object } {@link toCheck },\n     * {@link AE.index } & {@link AE.idxEnd }.\n     *\n     * @param toCheck See {@link AE.checkAlgorithm }.\n     *\n     * @returns See {@link EQ.checkAlgorithm}. */\n    check(toCheck) {\n        if (Array.isArray(this.conditions)) {\n            for (const currentCondition of this.conditions) {\n                const result = AE.checkAlgorithm(currentCondition, toCheck, this.index, this.idxEnd);\n                if (typeof result !== \"boolean\")\n                    return result;\n            }\n        }\n        else {\n            return AE.checkAlgorithm(\n            // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n            this.conditions, toCheck, this.index, this.idxEnd);\n        }\n        return true;\n    }\n    /**\n     * Creates this {@link AE } by setting the protected property {@link AE.conditions }, {@link AE.index } and {@link AE.idxEnd } used by {@link AE.check }.\n     *\n     * @param equivalent See {@link EQ.check }. */\n    constructor(conditions, index = undefined, idxEnd = undefined) {\n        super();\n        this.conditions = conditions;\n        this.index = index;\n        this.idxEnd = idxEnd;\n    }\n}\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } defining a comparison between two {@link object }s.\n *\n * @remarks\n * Maintainer: Callari, Salvatore (XDBC@WaXCode.net) */\nexport class COMPARISON extends DBC {\n    // #region Condition checking.\n    /**\n     * Does a comparison between the {@link object } **toCheck** and the **equivalent**.\n     *\n     * @param toCheck\t\tThe value that has to be equal to it's possible **equivalent** for this {@link DBC } to be fulfilled.\n     * @param equivalent\tThe {@link object } the one **toCheck** has to be equal to in order for this {@link DBC } to be\n     * \t\t\t\t\t\tfulfilled.\n     *\n     * @returns TRUE if the value **toCheck** and the **equivalent** are equal to each other, otherwise FALSE. */\n    static checkAlgorithm(toCheck, equivalent, equalityPermitted, invert) {\n        if (equalityPermitted && !invert && toCheck < equivalent) {\n            return `Value has to to be greater than or equal to \"${equivalent}\"`;\n        }\n        if (equalityPermitted && invert && toCheck > equivalent) {\n            return `Value has to be less than or equal to \"${equivalent}\"`;\n        }\n        if (!equalityPermitted && !invert && toCheck <= equivalent) {\n            return `Value has to to be greater than \"${equivalent}\"`;\n        }\n        if (!equalityPermitted && invert && toCheck >= equivalent) {\n            return `Value has to be less than \"${equivalent}\"`;\n        }\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link COMPARISON.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged parameter.\n     *\n     * @param equivalent\t    See {@link COMPARISON.checkAlgorithm }.\n     * @param equalityPermitted See {@link COMPARISON.checkAlgorithm }.\n     * @param path\t\t\t    See {@link DBC.decPrecondition }.\n     * @param dbc\t\t\t    See {@link DBC.decPrecondition }.\n     *\n     * @returns See {@link DBC.decPrecondition }. */\n    static PRE(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            return COMPARISON.checkAlgorithm(value, equivalent, equalityPermitted, invert);\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link COMPARISON.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param equivalent\t    See {@link COMPARISON.checkAlgorithm }.\n     * @param equalityPermitted See {@link COMPARISON.checkAlgorithm }.\n     * @param path\t\t\t    See {@link DBC.Postcondition }.\n     * @param dbc\t\t\t    See {@link DBC.decPostcondition }.\n     *\n     * @returns See {@link DBC.decPostcondition }. */\n    static POST(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            return COMPARISON.checkAlgorithm(value, equalityPermitted, equivalent, invert);\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link COMPARISON.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged field.\n     *\n     * @param equivalent\t    See {@link COMPARISON.checkAlgorithm }.\n     * @param equalityPermitted See {@link COMPARISON.checkAlgorithm }.\n     * @param path\t\t\t    See {@link DBC.decInvariant }.\n     * @param dbc\t\t\t    See {@link DBC.decInvariant }.\n     *\n     * @returns See {@link DBC.decInvariant }. */\n    static INVARIANT(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new COMPARISON(equivalent, equalityPermitted, invert)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    // #region Dynamic usage.\n    /**\n     * Invokes the {@link COMPARISON.checkAlgorithm } passing the value **toCheck**, {@link COMPARISON.equivalent } and {@link COMPARISON.invert }.\n     *\n     * @param toCheck See {@link COMPARISON.checkAlgorithm }.\n     *\n     * @returns See {@link COMPARISON.checkAlgorithm}. */\n    check(toCheck) {\n        return COMPARISON.checkAlgorithm(toCheck, this.equivalent, this.equalityPermitted, this.invert);\n    }\n    /**\n     * Creates this {@link COMPARISON } by setting the protected property {@link COMPARISON.equivalent }, {@link COMPARISON.equalityPermitted } and {@link COMPARISON.invert } used by {@link COMPARISON.check }.\n     *\n     * @param equivalent        See {@link COMPARISON.check }.\n     * @param equalityPermitted See {@link COMPARISON.check }.\n     * @param invert            See {@link COMPARISON.check }. */\n    constructor(equivalent, equalityPermitted = false, invert = false) {\n        super();\n        this.equivalent = equivalent;\n        this.equalityPermitted = equalityPermitted;\n        this.invert = invert;\n    }\n}\n","import { COMPARISON } from \"../COMPARISON\";\n/** See {@link COMPARISON }. */\nexport class GREATER extends COMPARISON {\n    /** See {@link COMPARISON.PRE }. */\n    static PRE(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.PRE(equivalent, false, false, path, dbc);\n    }\n    /** See {@link COMPARISON.POST }. */\n    static POST(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.POST(equivalent, false, false, path, dbc);\n    }\n    /** See {@link COMPARISON.INVARIANT }. */\n    static INVARIANT(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.INVARIANT(equivalent, false, false, path, dbc);\n    }\n    /** See {@link COMPARISON.constructor }. */\n    constructor(equivalent) {\n        super(equivalent, false, false);\n        this.equivalent = equivalent;\n    }\n}\n","import { COMPARISON } from \"../COMPARISON\";\n/** See {@link COMPARISON }. */\nexport class GREATER_OR_EQUAL extends COMPARISON {\n    /** See {@link COMPARISON.PRE }. */\n    static PRE(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.PRE(equivalent, true, false, path, dbc);\n    }\n    /** See {@link COMPARISON.POST }. */\n    static POST(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.POST(equivalent, true, false, path, dbc);\n    }\n    /** See {@link COMPARISON.INVARIANT }. */\n    static INVARIANT(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.INVARIANT(equivalent, true, false, path, dbc);\n    }\n    /** See {@link COMPARISON.constructor }. */\n    constructor(equivalent) {\n        super(equivalent, true, false);\n        this.equivalent = equivalent;\n    }\n}\n","import { COMPARISON } from \"../COMPARISON\";\n/** See {@link COMPARISON }. */\nexport class LESS extends COMPARISON {\n    /** See {@link COMPARISON.PRE }. */\n    static PRE(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.PRE(equivalent, false, true, path, dbc);\n    }\n    /** See {@link COMPARISON.POST }. */\n    static POST(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.POST(equivalent, false, true, path, dbc);\n    }\n    /** See {@link COMPARISON.INVARIANT }. */\n    static INVARIANT(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.INVARIANT(equivalent, false, true, path, dbc);\n    }\n    /** See {@link COMPARISON.constructor }. */\n    constructor(equivalent) {\n        super(equivalent, false, true);\n        this.equivalent = equivalent;\n    }\n}\n","import { COMPARISON } from \"../COMPARISON\";\n/** See {@link COMPARISON }. */\nexport class LESS_OR_EQUAL extends COMPARISON {\n    /** See {@link COMPARISON.PRE }. */\n    static PRE(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.PRE(equivalent, true, true, path, dbc);\n    }\n    /** See {@link COMPARISON.POST }. */\n    static POST(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.POST(equivalent, true, true, path, dbc);\n    }\n    /** See {@link COMPARISON.INVARIANT }. */\n    static INVARIANT(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.INVARIANT(equivalent, true, true, path, dbc);\n    }\n    /** See {@link COMPARISON.constructor }. */\n    constructor(equivalent) {\n        super(equivalent, true, true);\n        this.equivalent = equivalent;\n    }\n}\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } defining that two {@link object }s gotta be equal.\n *\n * @remarks\n * Maintainer: Callari, Salvatore (XDBC@WaXCode.net) */\nexport class EQ extends DBC {\n    // #region Condition checking.\n    /**\n     * Checks if the value **toCheck** is equal to the specified **equivalent**.\n     *\n     * @param toCheck\t\tThe value that has to be equal to it's possible **equivalent** for this {@link DBC } to be fulfilled.\n     * @param equivalent\tThe {@link object } the one **toCheck** has to be equal to in order for this {@link DBC } to be\n     * \t\t\t\t\t\tfulfilled.\n     *\n     * @returns TRUE if the value **toCheck** and the **equivalent** are equal to each other, otherwise FALSE. */\n    static checkAlgorithm(\n    // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n    toCheck, equivalent, invert) {\n        if (!invert && equivalent !== toCheck) {\n            return `Value has to to be equal to \"${equivalent}\"`;\n        }\n        if (invert && equivalent === toCheck) {\n            return `Value must not to be equal to \"${equivalent}\"`;\n        }\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link EQ.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged parameter.\n     *\n     * @param equivalent\tSee {@link EQ.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.decPrecondition }.\n     * @param dbc\t\t\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns See {@link DBC.decPrecondition }. */\n    static PRE(\n    // biome-ignore lint/suspicious/noExplicitAny: To check for UNDEFINED and NULL.\n    equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            return EQ.checkAlgorithm(value, equivalent, invert);\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link EQ.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param equivalent\tSee {@link EQ.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.Postcondition }.\n     * @param dbc\t\t\tSee {@link DBC.decPostcondition }.\n     *\n     * @returns See {@link DBC.decPostcondition }. */\n    static POST(\n    // biome-ignore lint/suspicious/noExplicitAny: To check for UNDEFINED and NULL.\n    equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            return EQ.checkAlgorithm(value, equivalent, invert);\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link EQ.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged field.\n     *\n     * @param equivalent\tSee {@link EQ.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.decInvariant }.\n     * @param dbc\t\t\tSee {@link DBC.decInvariant }.\n     *\n     * @returns See {@link DBC.decInvariant }. */\n    static INVARIANT(\n    // biome-ignore lint/suspicious/noExplicitAny: To check for UNDEFINED and NULL.\n    equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new EQ(equivalent, invert)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    //\n    // For usage in dynamic scenarios (like with AE-DBC).\n    //\n    /**\n     * Invokes the {@link EQ.checkAlgorithm } passing the value **toCheck**, {@link EQ.equivalent } and {@link EQ.invert }.\n     *\n     * @param toCheck See {@link EQ.checkAlgorithm }.\n     *\n     * @returns See {@link EQ.checkAlgorithm}. */\n    // biome-ignore lint/suspicious/noExplicitAny: Necessary to check against NULL & UNDEFINED.\n    check(toCheck) {\n        return EQ.checkAlgorithm(toCheck, this.equivalent, this.invert);\n    }\n    /**\n     * Invokes the {@link EQ.checkAlgorithm } passing the value **toCheck** and the specified **type** .\n     *\n     * @param toCheck See {@link EQ.checkAlgorithm }.\n     *\n     * @returns The **CANDIDATE** **toCheck** doesn't fulfill this {@link EQ }.\n     *\n     * @throws A {@link DBC.Infringement } if the **CANDIDATE** **toCheck** does not fulfill this {@link EQ }.*/\n    static tsCheck(toCheck, equivalent) {\n        const result = EQ.checkAlgorithm(toCheck, equivalent, false);\n        if (result) {\n            return toCheck;\n        }\n        else {\n            throw new DBC.Infringement(result);\n        }\n    }\n    /**\n     * Creates this {@link EQ } by setting the protected property {@link EQ.equivalent } used by {@link EQ.check }.\n     *\n     * @param equivalent See {@link EQ.check }. */\n    constructor(\n    // biome-ignore lint/suspicious/noExplicitAny: To be able to match UNDEFINED and NULL.\n    equivalent, invert = false) {\n        super();\n        this.equivalent = equivalent;\n        this.invert = invert;\n    }\n}\n","import { EQ } from \"../EQ\";\n/** See {@link COMPARISON }. */\nexport class DIFFERENT extends EQ {\n    /** See {@link COMPARISON.PRE }. */\n    static PRE(equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return EQ.PRE(equivalent, true, path, dbc);\n    }\n    /** See {@link COMPARISON.POST }. */\n    static POST(equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return EQ.POST(equivalent, true, path, dbc);\n    }\n    /** See {@link COMPARISON.INVARIANT }. */\n    static INVARIANT(equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return EQ.INVARIANT(equivalent, true, path, dbc);\n    }\n    /** See {@link COMPARISON.constructor }. */\n    constructor(equivalent) {\n        super(equivalent, true);\n        this.equivalent = equivalent;\n    }\n}\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } defining that the an {@link object }s gotta be an instance of a certain {@link INSTANCE.reference }.\n *\n * @remarks\n * Maintainer: Salvatore Callari (XDBC@WaXCode.net) */\nexport class INSTANCE extends DBC {\n    /**\n     * Checks if the value **toCheck** is an instance of the specified **reference**.\n     *\n     * @param toCheck\tThe value that has to be an instance of the **reference** in order for this {@link DBC }\n     * \t\t\t\t\tto be fulfilled.\n     * @param reference\tThe {@link object } the one **toCheck** has to be an instance of.\n     *\n     * @returns TRUE if the value **toCheck** is is an instance of the *reference**, otherwise FALSE. */\n    // biome-ignore lint/suspicious/noExplicitAny: In order to perform an \"instanceof\" check.\n    static checkAlgorithm(toCheck, reference) {\n        if (!(toCheck instanceof reference)) {\n            return `Value has to be an instance of \"${reference}\" but is of type \"${typeof toCheck}\"`;\n        }\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link INSTANCE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged parameter.\n     *\n     * @param reference\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param path\tSee {@link DBC.decPrecondition }.\n     * @param dbc\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns See {@link DBC.decPrecondition }. */\n    static PRE(\n    // biome-ignore lint/suspicious/noExplicitAny: In order to perform an \"instanceof\" check.\n    reference, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            return INSTANCE.checkAlgorithm(value, reference);\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link INSTANCE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param reference\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param path\tSee {@link DBC.Postcondition }.\n     * @param dbc\tSee {@link DBC.decPostcondition }.\n     *\n     * @returns See {@link DBC.decPostcondition }. */\n    static POST(\n    // biome-ignore lint/suspicious/noExplicitAny: In order to perform an \"instanceof\" check.\n    reference, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            return INSTANCE.checkAlgorithm(value, reference);\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link INSTANCE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param reference\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param path\tSee {@link DBC.decInvariant }.\n     * @param dbc\tSee {@link DBC.decInvariant }.\n     *\n     * @returns See {@link DBC.decInvariant }. */\n    static INVARIANT(\n    // biome-ignore lint/suspicious/noExplicitAny: In order to perform an \"instanceof\" check.\n    reference, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new INSTANCE(reference)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    //\n    // For usage in dynamic scenarios (like with AE-DBC).\n    //\n    /**\n     * Invokes the {@link INSTANCE.checkAlgorithm } passing the value **toCheck** and the {@link INSTANCE.reference } .\n     *\n     * @param toCheck See {@link INSTANCE.checkAlgorithm }.\n     *\n     * @returns See {@link INSTANCE.checkAlgorithm}. */\n    // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n    check(toCheck) {\n        return INSTANCE.checkAlgorithm(toCheck, this.reference);\n    }\n    /**\n     * Invokes the {@link INSTANCE.checkAlgorithm } passing the value **toCheck** and the {@link INSTANCE.reference } .\n     *\n     * @param toCheck \tSee {@link INSTANCE.checkAlgorithm }.\n     * @param reference\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param id\t\tA {@link string } identifying this {@link INSTANCE } via the {@link DBC.Infringement }-Message.\n     * @param hint\t\tAn optional {@link string } providing extra information in case of an infringement.\n     *\n     * @returns The **CANDIDATE** **toCheck** doesn't fulfill this {@link INSTANCE }.\n     *\n     * @throws A {@link DBC.Infringement } if the **CANDIDATE** **toCheck** does not fulfill this {@link DEFINED }. */\n    static tsCheck(toCheck, reference, hint = undefined, id = undefined) {\n        const result = INSTANCE.checkAlgorithm(toCheck, reference);\n        if (result === true) {\n            return toCheck;\n        }\n        else {\n            throw new DBC.Infringement(`${id ? `(${id}) ` : \"\"}${result} ${hint ? `< ${hint} >` : \"\"}`);\n        }\n    }\n    /**\n     * Creates this {@link INSTANCE } by setting the protected property {@link INSTANCE.reference } used by {@link INSTANCE.check }.\n     *\n     * @param reference See {@link INSTANCE.check }. */\n    // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n    constructor(reference) {\n        super();\n        this.reference = reference;\n    }\n}\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } providing {@link REGEX }-contracts and standard {@link RegExp } for common use cases in {@link REGEX.stdExp }.\n *\n * @remarks\n * Maintainer: Callari, Salvatore (XDBC@WaXCode.net) */\nexport class REGEX extends DBC {\n    // #region Condition checking.\n    /**\n     * Checks if the value **toCheck** is complies to the {@link RegExp } **expression**.\n     *\n     * @param toCheck\t\tThe value that has comply to the {@link RegExp } **expression** for this {@link DBC } to be fulfilled.\n     * @param expression\tThe {@link RegExp } the one **toCheck** has comply to in order for this {@link DBC } to be\n     * \t\t\t\t\t\tfulfilled.\n     *\n     * @returns TRUE if the value **toCheck** complies with the {@link RegExp } **expression**, otherwise FALSE. */\n    static checkAlgorithm(toCheck, expression) {\n        if (toCheck === undefined || toCheck === null)\n            return true;\n        if (!expression.test(toCheck)) {\n            return `Value has to comply to regular expression \"${expression}\"`;\n        }\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link REGEX.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged parameter.\n     *\n     * @param expression\tSee {@link REGEX.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.decPrecondition }.\n     * @param dbc\t\t\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns See {@link DBC.decPrecondition }. */\n    static PRE(expression, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            return REGEX.checkAlgorithm(value, expression);\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link REGEX.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param expression\tSee {@link REGEX.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.Postcondition }.\n     * @param dbc\t\t\tSee {@link DBC.decPostcondition }.\n     *\n     * @returns See {@link DBC.decPostcondition }. */\n    static POST(expression, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            return REGEX.checkAlgorithm(value, expression);\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link REGEX.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged field.\n     *\n     * @param expression\tSee {@link REGEX.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.decInvariant }.\n     * @param dbc\t\t\tSee {@link DBC.decInvariant }.\n     *\n     * @returns See {@link DBC.decInvariant }. */\n    static INVARIANT(expression, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new REGEX(expression)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    //\n    // For usage in dynamic scenarios (like with AE-DBC).\n    //\n    /**\n     * Invokes the {@link REGEX.checkAlgorithm } passing the value **toCheck** and {@link REGEX.equivalent }.\n     *\n     * @param toCheck See {@link REGEX.checkAlgorithm }.\n     *\n     * @returns See {@link EQ.checkAlgorithm}. */\n    check(toCheck) {\n        return REGEX.checkAlgorithm(toCheck, this.expression);\n    }\n    /**\n     * Creates this {@link REGEX } by setting the protected property {@link REGEX.expression } used by {@link REGEX.check }.\n     *\n     * @param expression See {@link REGEX.check }. */\n    constructor(expression) {\n        super();\n        this.expression = expression;\n    }\n    // #endregion Referenced Condition checking.\n    // #region In-Method checking.\n    /**\n     * Invokes the {@link REGEX.checkAlgorithm } passing the value **toCheck** and {@link REGEX.expression }.\n     *\n     * @param toCheck\t\tSee {@link REGEX.checkAlgorithm}.\n     * @param expression\tSee {@link REGEX.checkAlgorithm}.\n     */\n    static check(toCheck, expression) {\n        const checkResult = REGEX.checkAlgorithm(toCheck, expression);\n        if (typeof checkResult === \"string\") {\n            throw new DBC.Infringement(checkResult);\n        }\n    }\n}\n/** Stores often used {@link RegExp }s. */\nREGEX.stdExp = {\n    htmlAttributeName: /^[a-zA-Z_:][a-zA-Z0-9_.:-]*$/,\n    eMail: /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/i,\n    property: /^[$_A-Za-z][$_A-Za-z0-9]*$/,\n    url: /^(?:(?:http:|https?|ftp):\\/\\/)?(?:\\S+(?::\\S*)?@)?(?:localhost|(?:[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,})(?::\\d{2,5})?(?:\\/(?:[\\w\\-\\.]*\\/)*[\\w\\-\\.]+(?:\\?\\S*)?(?:#\\S*)?)?$/i,\n    keyPath: /^([a-zA-Z_$][a-zA-Z0-9_$]*\\.)*[a-zA-Z_$][a-zA-Z0-9_$]*$/,\n    date: /^\\d{1,4}[.\\/-]\\d{1,2}[.\\/-]\\d{1,4}$/i,\n    dateFormat: /^((D{1,2}[./-]M{1,2}[./-]Y{1,4})|(M{1,2}[./-]D{1,2}[./-]Y{1,4})|Y{1,4}[./-]D{1,2}[./-]M{1,2}|(Y{1,4}[./-]M{1,2}[./-]D{1,2}))$/i,\n    cssSelector: /^(?:\\*|#[\\w-]+|\\.[\\w-]+|(?:[\\w-]+|\\*)(?::(?:[\\w-]+(?:\\([\\w-]+\\))?)+)?(?:\\[(?:[\\w-]+(?:(?:=|~=|\\|=|\\*=|\\$=|\\^=)\\s*(?:\"[^\"]*\"|'[^']*'|[\\w-]+)\\s*)?)?\\])+|\\[\\s*[\\w-]+\\s*=\\s*(?:\"[^\"]*\"|'[^']*'|[\\w-]+)\\s*\\])(?:,\\s*(?:\\*|#[\\w-]+|\\.[\\w-]+|(?:[\\w-]+|\\*)(?::(?:[\\w-]+(?:\\([\\w-]+\\))?)+)?(?:\\[(?:[\\w-]+(?:(?:=|~=|\\|=|\\*=|\\$=|\\^=)\\s*(?:\"[^\"]*\"|'[^']*'|[\\w-]+)\\s*)?)?\\])+|\\[\\s*[\\w-]+\\s*=\\s*(?:\"[^\"]*\"|'[^']*'|[\\w-]+)\\s*\\]))*$/,\n    boolean: /^(TRUE|FALSE|T|F)$/i\n};\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } defining that an {@link object }s gotta be of certain {@link TYPE.type }.\n *\n * @remarks\n * Author: \t\tSalvatore Callari (Callari@WaXCode.net) / 2025\n * Maintainer:\tSalvatore Callari (XDBC@WaXCode.net) */\nexport class TYPE extends DBC {\n    /**\n     * Checks if the value **toCheck** is of the **type** specified.\n     *\n     * @param toCheck\tThe {@link Object } which's **type** to check.\n     * @param type\t\tThe type the {@link object} **toCheck** has to be of. Can be a single type or multiple types separated by \"|\".\n     *\n     * @returns TRUE if the value **toCheck** is of the specified **type**, otherwise FALSE. */\n    // biome-ignore lint/suspicious/noExplicitAny: Necessary for dynamic type checking of also UNDEFINED.\n    static checkAlgorithm(toCheck, type) {\n        if (toCheck === undefined || toCheck === null)\n            return true;\n        const types = type.split(\"|\").map(t => t.trim());\n        const actualType = typeof toCheck;\n        // #region Check if the actual type matches at least one of the specified types\n        // biome-ignore lint/suspicious/useValidTypeof: Necessary\n        const isValid = types.some(t => actualType === t);\n        if (!isValid) {\n            if (types.length === 1) {\n                return `Value has to to be of type \"${type}\" but is of type \"${actualType}\"`;\n            }\n            return `Value has to to be of type \"${types.join(\" | \")}\" but is of type \"${actualType}\"`;\n        }\n        // #endregion Check if the actual type matches at least one of the specified types\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link TYPE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged parameter.\n     *\n     * @param type\tSee {@link TYPE.checkAlgorithm }.\n     * @param path\tA ::-separated list of dotted paths to check. Each path points to a property within the parameter value.\n     * \t\t\t\tUndefined properties are skipped. See {@link DBC.decPrecondition }.\n     * @param dbc\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns See {@link DBC.decPrecondition }. */\n    static PRE(type, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            return TYPE.checkAlgorithm(value, type);\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link TYPE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param type\tSee {@link TYPE.checkAlgorithm }.\n     * @param path\tA ::-separated list of dotted paths to check. Each path points to a property within the parameter value.\n     * \t\t\t\tUndefined properties are skipped. See {@link DBC.decPrecondition }.\n     * @param dbc\tSee {@link DBC.decPostcondition }.\n     *\n     * @returns See {@link DBC.decPostcondition }. */\n    static POST(type, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            return TYPE.checkAlgorithm(value, type);\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link TYPE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged field.\n     *\n     * @param type\tSee {@link TYPE.checkAlgorithm }.\n     * @param path\tA ::-separated list of dotted paths to check. Each path points to a property within the parameter value.\n     * \t\t\t\tUndefined properties are skipped. See {@link DBC.decPrecondition }.\n     * @param dbc\tSee {@link DBC.decInvariant }.\n     *\n     * @returns See {@link DBC.decInvariant }. */\n    static INVARIANT(type, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new TYPE(type)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    //\n    // For usage in dynamic scenarios (like with AE-DBC).\n    //\n    /**\n     * Invokes the {@link TYPE.checkAlgorithm } passing the value **toCheck** and the {@link TYPE.type } .\n     *\n     * @param toCheck See {@link TYPE.checkAlgorithm }.\n     *\n     * @returns See {@link TYPE.checkAlgorithm}. */\n    // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n    check(toCheck) {\n        return TYPE.checkAlgorithm(toCheck, this.type);\n    }\n    /**\n     * Invokes the {@link TYPE.checkAlgorithm } passing the value **toCheck** and the {@link TYPE.type } .\n     *\n     * @param toCheck\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param type\t\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param id\t\tA {@link string } identifying this {@link TYPE } via the {@link DBC.Infringement }-Message.\n     * @param hint\t\tAn optional {@link string } providing extra information in case of an infringement.\n     *\n     * @returns The **CANDIDATE** **toCheck** doesn't fulfill this {@link TYPE }.\n     *\n     * @throws A {@link DBC.Infringement } if the **CANDIDATE** **toCheck** does not fulfill this {@link DEFINED }. */\n    static tsCheck(toCheck, type, hint = undefined, id = undefined) {\n        const result = TYPE.checkAlgorithm(toCheck, type);\n        if (result === true) {\n            return toCheck;\n        }\n        else {\n            throw new DBC.Infringement(`${id ? `(${id}) ` : \"\"}${result}${hint ? ` < ${hint} >` : \"\"}`);\n        }\n    }\n    /**\n     * Creates this {@link TYPE } by setting the protected property {@link TYPE.type } used by {@link TYPE.check }.\n     *\n     * @param type See {@link TYPE.check }. */\n    constructor(type) {\n        super();\n        this.type = type;\n    }\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __metadata = (this && this.__metadata) || function (k, v) {\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(k, v);\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n    return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { DBC } from \"./DBC\";\nimport { REGEX } from \"./DBC/REGEX\";\nimport { EQ } from \"./DBC/EQ\";\nimport { TYPE } from \"./DBC/TYPE\";\nimport { AE } from \"./DBC/AE\";\nimport { INSTANCE } from \"./DBC/INSTANCE\";\nimport { GREATER } from \"./DBC/COMPARISON/GREATER\";\nimport { GREATER_OR_EQUAL } from \"./DBC/COMPARISON/GREATER_OR_EQUAL\";\nimport { LESS } from \"./DBC/COMPARISON/LESS\";\nimport { LESS_OR_EQUAL } from \"./DBC/COMPARISON/LESS_OR_EQUAL\";\nimport { DIFFERENT } from \"./DBC/EQ/DIFFERENT\";\n/** Demonstrative use of **D**esign **B**y **C**ontract Decorators */\nexport class Demo {\n    constructor() {\n        // #region Check Property Decorator\n        this.testProperty = \"a\";\n        // #endregion Check Static Method with ParamvalueProvider\n    }\n    // #endregion Check Property Decorator\n    // #region Check Parameter. & Returnvalue Decorator\n    testParamvalueAndReturnvalue(a) {\n        return `xxxx${a}`;\n    }\n    // #endregion Check Parameter. & Returnvalue Decorator\n    // #region Check Returnvalue Decorator\n    testReturnvalue(a) {\n        return a;\n    }\n    // #endregion Check Returnvalue Decorator\n    // #region Check EQ-DBC & Path to property of Parameter-value\n    testEQAndPath(o) { }\n    // #endregion Check EQ-DBC & Path to property of Parameter-value\n    // #region Check EQ-DBC & Path to property of Parameter-value with Inversion\n    testEQAndPathWithInversion(o) { }\n    // #endregion Check EQ-DBC & Path to property of Parameter-value with Inversion\n    // #region Check TYPE\n    testTYPE(o) { }\n    // #endregion Check TYPE\n    // #region Check AE\n    testAE(x) { }\n    // #endregion Check AE\n    // #region Check REGEX with AE\n    testREGEXWithAE(x) { }\n    // #endregion Check REGEX with AE\n    // #region Check INSTANCE\n    testINSTANCE(candidate) { }\n    // #endregion Check INSTANCE\n    // #region Check AE Range\n    testAERange(x) { }\n    // #endregion Check AE Range\n    // #region Check AE Index\n    testAEIndex(x) { }\n    // #endregion Check AE Index\n    // #region Check Comparison\n    testGREATER(input) { }\n    testGREATER_OR_EQUAL(input) { }\n    testLESS(input) { }\n    testLESS_OR_EQUAL(input) { }\n    testDIFFERENT(input) { }\n    // #endregion Check Comparison\n    // #region Check Static Method with ParamvalueProvider\n    static testStaticMethod(message, count) {\n        return `${message} repeated ${count} times`;\n    }\n}\n__decorate([\n    REGEX.INVARIANT(/^a$/),\n    __metadata(\"design:type\", Object)\n], Demo.prototype, \"testProperty\", void 0);\n__decorate([\n    REGEX.POST(/^xxxx.*$/),\n    DBC.ParamvalueProvider,\n    __param(0, REGEX.PRE(/holla*/g)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [String]),\n    __metadata(\"design:returntype\", String)\n], Demo.prototype, \"testParamvalueAndReturnvalue\", null);\n__decorate([\n    REGEX.POST(/^xxxx.*$/),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [String]),\n    __metadata(\"design:returntype\", String)\n], Demo.prototype, \"testReturnvalue\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, EQ.PRE(\"SELECT\", false, \"tagName\")),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [HTMLElement]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testEQAndPath\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, EQ.PRE(\"SELECT\", true, \"tagName\")),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [HTMLElement]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testEQAndPathWithInversion\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, TYPE.PRE(\"string\")),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Object]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testTYPE\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, AE.PRE([new TYPE(\"string\")])),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Array]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testAE\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, AE.PRE(new REGEX(/^(?i:(NOW)|([+-]\\d+[dmy]))$/i))),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Array]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testREGEXWithAE\", null);\n__decorate([\n    DBC.ParamvalueProvider\n    // biome-ignore lint/suspicious/noExplicitAny: Test\n    ,\n    __param(0, INSTANCE.PRE(Date)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Object]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testINSTANCE\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, AE.PRE([new TYPE(\"string\"), new REGEX(/^abc$/)], 1, 2)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Array]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testAERange\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, AE.PRE([new TYPE(\"string\"), new REGEX(/^abc$/)], 1)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Array]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testAEIndex\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, GREATER.PRE(2)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Number]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testGREATER\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, GREATER_OR_EQUAL.PRE(2)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Number]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testGREATER_OR_EQUAL\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, LESS.PRE(20)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Number]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testLESS\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, LESS_OR_EQUAL.PRE(20)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Number]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testLESS_OR_EQUAL\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, DIFFERENT.PRE(20)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Number]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testDIFFERENT\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, TYPE.PRE(\"string\")),\n    __param(1, TYPE.PRE(\"number\")),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [String, Number]),\n    __metadata(\"design:returntype\", String)\n], Demo, \"testStaticMethod\", null);\nconst demo = new Demo();\ntry {\n    demo.testProperty = \"abd\";\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INVARIANT Infringement\", \"OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testProperty = \"a\";\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"INVARIANT OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ndemo.testParamvalueAndReturnvalue(\"holla\");\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"PARAMETER- & RETURNVALUE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testParamvalueAndReturnvalue(\"yyyy\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"PARAMETER- & RETURNVALUE Infringement\", \"OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testReturnvalue(\"xxxx\");\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"RETURNVALUE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testReturnvalue(\"yyyy\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"RETURNVALUE Infringement\", \"OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testEQAndPath(document.createElement(\"select\"));\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"EQ with Path Infringement OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testEQAndPathWithInversion(document.createElement(\"select\"));\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"EQ with Path and Inversion Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testTYPE(\"x\");\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"TYPE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testTYPE(0);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"TYPE Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testAE([\"11\", \"10\", \"b\"]);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"AE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testAE([\"11\", 11, \"b\"]);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"AE Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testREGEXWithAE([\"+1d\", \"NOW\", \"-10y\"]);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"REGEX with AE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testREGEXWithAE([\"+1d\", \"+5d\", \"-x10y\"]);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"REGEX with AE Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testINSTANCE(new Date());\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"INSTANCE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testINSTANCE(demo);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INSTANCE Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testAERange([11, \"abc\", \"abc\"]);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"AE Range OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testAERange([11, \"abc\", /a/g]);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"AE Range Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testAEIndex([11, \"abc\", \"abc\"]);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"AE Index OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testAEIndex([\"11\", 12, \"/a/g\"]);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"AE Index Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testGREATER(11);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"GREATER OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testGREATER(2);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"GREATER Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testGREATER_OR_EQUAL(2);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"GREATER_OR_EQUAL OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testGREATER_OR_EQUAL(1);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"GREATER_OR_EQUAL Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testLESS(10);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"LESS OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testLESS(20);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"LESS Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testLESS_OR_EQUAL(20);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"LESS OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testLESS_OR_EQUAL(21);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"LESS_OR_EQUAL Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testDIFFERENT(21);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"DIFFERENT OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testDIFFERENT(20);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"DIFFERENT Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\n// #region Inactivity Checks\nwindow.WaXCode.DBC.executionSettings.checkPreconditions = false;\ntry {\n    demo.testLESS_OR_EQUAL(21);\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE PRECONDITIONS OK\");\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE PRECONDITIONS FAILED\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\nwindow.WaXCode.DBC.executionSettings.checkPostconditions = false;\ntry {\n    demo.testReturnvalue(\"qqqqq\");\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE POSTCONDITIONS OK\");\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE POSTCONDITIONS FAILED\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\nwindow.WaXCode.DBC.executionSettings.checkInvariants = false;\ntry {\n    demo.testProperty = \"b\";\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE INVARIANTS OK\");\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE INVARIANTS FAILED\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\n// #endregion Inactivity Checks\n// Re-enable all checks for subsequent tests\nwindow.WaXCode.DBC.executionSettings.checkPreconditions = true;\nwindow.WaXCode.DBC.executionSettings.checkPostconditions = true;\nwindow.WaXCode.DBC.executionSettings.checkInvariants = true;\n// #region Static Method Test\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"TESTING STATIC METHOD WITH PARAMVALUEPROVIDER\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\nDemo.testStaticMethod(\"Hello\", 3);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"STATIC METHOD OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    Demo.testStaticMethod(\"Hello\", \"not a number\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"STATIC METHOD Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ntry {\n    Demo.testStaticMethod(123, 5);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"STATIC METHOD Infringement (first param) OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\n// #endregion Static Method Test\n"],"names":[],"sourceRoot":""}
1982
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"bundle.js","mappings":";;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,UAAU,GAAG,mBAAmB;AAClD;AACA;AACA,gGAAgG,cAAc;AAC9G,sCAAsC,2BAA2B,kBAAkB,0BAA0B;AAC7G;AACA,mEAAmE,yBAAyB;AAC5F;AACA,2BAA2B,eAAe;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,2BAA2B;AAC3E;AACA,iFAAiF,yBAAyB;AAC1G;AACA;AACA,4BAA4B,eAAe;AAC3C;AACA,+BAA+B,2BAA2B;AAC1D;AACA,qBAAqB,2BAA2B;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,WAAW;AACxC;AACA,mBAAmB,yBAAyB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,WAAW;AACxC;AACA,mBAAmB,yBAAyB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,0BAA0B;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,0BAA0B;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,6BAA6B,0BAA0B,cAAc;AACtH;AACA;AACA,2BAA2B,eAAe;AAC1C,6BAA6B,eAAe;AAC5C;AACA,wCAAwC,SAAS,GAAG,uCAAuC,YAAY,yGAAyG,wBAAwB,YAAY,uEAAuE,GAAG,EAAE,eAAe,KAAK,wBAAwB,IAAI,QAAQ;AACxX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,2BAA2B,0BAA0B,cAAc;AAChH;AACA;AACA,2BAA2B,eAAe;AAC1C,2BAA2B,eAAe;AAC1C;AACA;AACA;AACA;AACA,sDAAsD,MAAM,WAAW,YAAY,EAAE,uFAAuF,mDAAmD,QAAQ,IAAI,YAAY,MAAM,QAAQ;AACrQ;AACA;AACA,yCAAyC,2BAA2B,0BAA0B,cAAc;AAC5G;AACA;AACA,yBAAyB,eAAe;AACxC;AACA,qCAAqC,eAAe;AACpD;AACA;AACA;AACA,oDAAoD,IAAI,GAAG,8BAA8B,KAAK,GAAG,cAAc,MAAM,2CAA2C,QAAQ;AACxK;AACA;AACA,yDAAyD,2BAA2B,0BAA0B,cAAc;AAC5H;AACA;AACA,2BAA2B,eAAe;AAC1C,2BAA2B,eAAe;AAC1C;AACA;AACA;AACA;AACA,mDAAmD,MAAM,2CAA2C,QAAQ;AAC5G;AACA;AACA,wBAAwB,YAAY,gBAAgB,gCAAgC;AACpF,0GAA0G,WAAW;AACrH;AACA,yCAAyC,gCAAgC;AACzE,sCAAsC,6BAA6B;AACnE,yCAAyC,2CAA2C;AACpF;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC;AACjC;AACA;AACA;AACA,sCAAsC;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,eAAe;AAC5C;AACA,iCAAiC,eAAe;AAChD,sCAAsC,cAAc;AACpD;AACA;AACA;AACA;AACA;AACA,+BAA+B,cAAc;AAC7C;AACA;AACA;AACA;AACA,6EAA6E;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0EAA0E;AAC1E;AACA;AACA;AACA;AACA,sCAAsC;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2DAA2D,uBAAuB;AAClF;AACA;AACA;AACA,QAAQ,cAAc;AACtB;AACA;AACA,wBAAwB,cAAc,kCAAkC,eAAe;AACvF;AACA,2BAA2B,eAAe;AAC1C;AACA,qCAAqC,QAAQ;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,cAAc,YAAY,WAAW;AACvE;AACA,oBAAoB,eAAe;AACnC,4BAA4B,cAAc,sBAAsB,WAAW;AAC3E;AACA,2BAA2B,WAAW;AACtC;AACA;AACA;AACA;;;;;;;;;;;;;;;;AC3Z6B;AAC7B;AACA,MAAM,YAAY,kCAAkC,cAAc;AAClE,YAAY,cAAc;AAC1B;AACA;AACA;AACO,iBAAiB,qCAAG;AAC3B;AACA;AACA,6CAA6C,qBAAqB;AAClE;AACA;AACA,8BAA8B,4CAA4C;AAC1E,uCAAuC,oBAAoB;AAC3D;AACA,yEAAyE,eAAe;AACxF,uBAAuB,aAAa,wCAAwC,cAAc;AAC1F;AACA;AACA,oCAAoC,aAAa;AACjD,0FAA0F,cAAc;AACxG,mEAAmE,aAAa;AAChF;AACA;AACA,wDAAwD,cAAc;AACtE,yCAAyC,aAAa;AACtD;AACA;AACA;AACA;AACA;AACA;AACA,mEAAmE,MAAM,gBAAgB,aAAa,KAAK,OAAO;AAClH;AACA;AACA,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,YAAY;AACxD;AACA;AACA,8DAA8D,EAAE,IAAI,OAAO;AAC3E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,0BAA0B;AAC1E;AACA,gFAAgF,aAAa;AAC7F;AACA,eAAe,cAAc,uCAAuC,4CAA4C;AAChH;AACA;AACA,yEAAyE,cAAc;AACvF;AACA;AACA,kDAAkD,4CAA4C;AAC9F;AACA,gCAAgC,yBAAyB;AACzD,gCAAgC,yBAAyB;AACzD,2BAA2B,2BAA2B;AACtD,0BAA0B,2BAA2B;AACrD;AACA,mBAAmB,eAAe,iBAAiB,4CAA4C;AAC/F;AACA;AACA,eAAe,qCAAG;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,6CAA6C,0BAA0B;AACvE;AACA;AACA,kDAAkD,4CAA4C;AAC9F;AACA,gCAAgC,yBAAyB;AACzD,gCAAgC,yBAAyB;AACzD,2BAA2B,2BAA2B;AACtD,0BAA0B,2BAA2B;AACrD;AACA,mBAAmB,eAAe,iBAAiB,4CAA4C;AAC/F;AACA;AACA,eAAe,qCAAG;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,4CAA4C,0BAA0B;AACtE;AACA;AACA,kDAAkD,4CAA4C;AAC9F;AACA,gCAAgC,yBAAyB;AACzD,gCAAgC,yBAAyB;AACzD,2BAA2B,wBAAwB;AACnD,0BAA0B,wBAAwB;AAClD;AACA,qBAAqB,wBAAwB;AAC7C;AACA,eAAe,qCAAG;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,0BAA0B,UAAU,sBAAsB,SAAS,gBAAgB,eAAe;AACtH,QAAQ,iBAAiB,GAAG,iBAAiB;AAC7C;AACA,2BAA2B,yBAAyB;AACpD;AACA,qBAAqB,wBAAwB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC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BAAsB,EAAE;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,SAAS,WAAW,OAAO;AAC7C;AACA;AACA;AACA,IAAI,6CAAK;AACT;AACA;AACA;AACA,IAAI,6CAAK;AACT,IAAI,qCAAG;AACP,eAAe,6CAAK;AACpB;AACA;AACA;AACA;AACA;AACA,IAAI,6CAAK;AACT;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE;AACjB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE;AACjB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,2CAAI;AACnB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE,UAAU,2CAAI;AAC/B;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE,SAAS,6CAAK;AAC/B;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP;AACA;AACA,eAAe,mDAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE,UAAU,2CAAI,gBAAgB,6CAAK;AACpD;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,uCAAE,UAAU,2CAAI,gBAAgB,6CAAK;AACpD;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,4DAAO;AACtB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,8EAAgB;AAC/B;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,sDAAI;AACnB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,wEAAa;AAC5B;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,yDAAS;AACxB;AACA;AACA;AACA;AACA;AACA,IAAI,qCAAG;AACP,eAAe,2CAAI;AACnB,eAAe,2CAAI;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://xdbc/./src/DBC.ts","webpack://xdbc/./src/DBC/AE.ts","webpack://xdbc/./src/DBC/COMPARISON.ts","webpack://xdbc/./src/DBC/COMPARISON/GREATER.ts","webpack://xdbc/./src/DBC/COMPARISON/GREATER_OR_EQUAL.ts","webpack://xdbc/./src/DBC/COMPARISON/LESS.ts","webpack://xdbc/./src/DBC/COMPARISON/LESS_OR_EQUAL.ts","webpack://xdbc/./src/DBC/EQ.ts","webpack://xdbc/./src/DBC/EQ/DIFFERENT.ts","webpack://xdbc/./src/DBC/INSTANCE.ts","webpack://xdbc/./src/DBC/REGEX.ts","webpack://xdbc/./src/DBC/TYPE.ts","webpack://xdbc/webpack/bootstrap","webpack://xdbc/webpack/runtime/define property getters","webpack://xdbc/webpack/runtime/hasOwnProperty shorthand","webpack://xdbc/webpack/runtime/make namespace object","webpack://xdbc/./src/Demo.ts"],"sourcesContent":["/**\n * Provides a **D**esign **B**y **C**ontract Framework using decorators.\n *\n * @remarks\n * Maintainer: Callari, Salvatore (XDBC@WaXCode.net) */\nexport class DBC {\n    /**\n     * Generate a unique key for storing parameter value requests.\n     * Format: \"ClassName:methodName\"\n     */\n    static getRequestKey(target, methodName) {\n        var _a;\n        const className = typeof target === 'function' ? target.name : ((_a = target.constructor) === null || _a === void 0 ? void 0 : _a.name) || 'Unknown';\n        return `${className}:${String(methodName)}`;\n    }\n    /**\n     * Make a request to get the value of a certain parameter of specific method in a specific {@link object }.\n     * That request gets enlisted in {@link paramValueRequests } which is used by {@link ParamvalueProvider} to invoke the\n     * given \"receptor\" with the parameter value stored in there. Thus a parameter decorator using this method will\n     * not receive any value of the top method is not tagged with {@link ParamvalueProvider}.\n     *\n     * @param target\t\tThe {@link object } containing the method with the parameter which's value is requested.\n     * @param methodName\tThe name of the method with the parameter which's value is requested.\n     * @param index\t\t\tThe index of the parameter which's value is requested.\n     * @param receptor\t\tThe method the requested parameter-value shall be passed to when it becomes available. */\n    static requestParamValue(target, methodName, index, \n    // biome-ignore lint/suspicious/noExplicitAny: Gotta be any since parameter-values may be undefined.\n    receptor) {\n        const key = DBC.getRequestKey(target, methodName);\n        if (DBC.paramValueRequests.has(key)) {\n            if (DBC.paramValueRequests.get(key).has(index)) {\n                DBC.paramValueRequests.get(key).get(index).push(receptor);\n            }\n            else {\n                DBC.paramValueRequests.get(key).set(index, new Array(receptor));\n            }\n        }\n        else {\n            DBC.paramValueRequests.set(key, new Map([\n                [index, new Array(receptor)],\n            ]));\n        }\n        return undefined;\n    }\n    /**\n     * A method-decorator factory checking the {@link paramValueRequests } for value-requests of the method's parameter thus\n     * also usable on setters.\n     * When found it will invoke the \"receptor\" registered there, inter alia by {@link requestParamValue }, with the\n     * parameter's value.\n     *\n     * @param target \t\tThe {@link object } hosting the tagged method as provided by the runtime.\n     * @param propertyKey \tThe tagged method's name as provided by the runtime.\n     * @param descriptor \tThe {@link PropertyDescriptor } as provided by the runtime.\n     *\n     * @returns The {@link PropertyDescriptor } that was passed by the runtime. */\n    static ParamvalueProvider(target, propertyKey, descriptor) {\n        const originalMethod = descriptor.value;\n        const isStatic = typeof target === 'function';\n        // biome-ignore lint/suspicious/noExplicitAny: Gotta be any since parameter-values may be undefined.\n        descriptor.value = function (...args) {\n            // #region   Check if a value of one of the method's parameter has been requested and pass it to the\n            //           receptor, if so.\n            const actualTarget = isStatic ? this : this.constructor;\n            const key = DBC.getRequestKey(actualTarget, propertyKey);\n            if (DBC.paramValueRequests.has(key)) {\n                for (const index of DBC.paramValueRequests.get(key).keys()) {\n                    if (index < args.length) {\n                        for (const receptor of DBC.paramValueRequests.get(key).get(index)) {\n                            receptor(args[index]);\n                        }\n                    }\n                }\n            }\n            else {\n                console.warn(\"No parameter value requests found for key:\", key);\n            }\n            // #endregion\tCheck if a value of one of the method's parameter has been requested and pass it to the\n            //              receptor, if so.\n            return originalMethod.apply(this, args);\n        };\n        return descriptor;\n    }\n    // #endregion Parameter-value requests.\n    // #region Class\n    /**\n     * A property-decorator factory serving as a **D**esign **B**y **C**ontract Invariant.\n     * This invariant aims to check the instance of the class not the value to be get or set.\n     *\n     * @param contracts The {@link DBC }-Contracts the value shall uphold.\n     *\n     * @throws \tA {@link DBC.Infringement } whenever the property is tried to be get or set without the instance of it's class\n     * \t\t\tfulfilling the specified **contracts**. */\n    static decClassInvariant(contracts, path = undefined, dbc = \"WaXCode.DBC\") {\n        return (target, propertyKey, descriptor) => {\n            if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkInvariants) {\n                return;\n            }\n            const originalSetter = descriptor.set;\n            const originalGetter = descriptor.get;\n            // biome-ignore lint/suspicious/noExplicitAny: Necessary to intercept UNDEFINED and NULL.\n            let value;\n            // #region Replace original property.\n            Object.defineProperty(target, propertyKey, {\n                get() {\n                    if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkInvariants) {\n                        return;\n                    }\n                    const realValue = path ? DBC.resolve(this, path) : this;\n                    // #region Check if all \"contracts\" are fulfilled.\n                    for (const contract of contracts) {\n                        const result = contract.check(realValue);\n                        if (typeof result === \"string\") {\n                            DBC.resolveDBCPath(window, dbc).reportFieldInfringement(result, target, path, propertyKey, realValue);\n                        }\n                    }\n                    // #endregion Check if all \"contracts\" are fulfilled.\n                    return originalGetter[propertyKey];\n                },\n                set(newValue) {\n                    if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkInvariants) {\n                        return;\n                    }\n                    const realValue = path ? DBC.resolve(this, path) : this;\n                    // #region Check if all \"contracts\" are fulfilled.\n                    for (const contract of contracts) {\n                        const result = contract.check(realValue);\n                        if (typeof result === \"string\") {\n                            DBC.resolveDBCPath(window, dbc).reportFieldInfringement(result, target, path, propertyKey, realValue);\n                        }\n                    }\n                    // #endregion Check if all \"contracts\" are fulfilled.\n                    value = newValue;\n                },\n                enumerable: true,\n                configurable: true,\n            });\n            // #endregion Replace original property.\n        };\n    }\n    // #endregion Class\n    // #region Invariant\n    /**\n     * A property-decorator factory serving as a **D**esign **B**y **C**ontract Invariant.\n     * Since the value must be initialized or set according to the specified **contracts** the value will only be checked\n     * when assigning it.\n     *\n     * @param contracts The {@link DBC }-Contracts the value shall uphold.\n     *\n     * @throws \tA {@link DBC.Infringement } whenever the property is tried to be set to a value that does not comply to the\n     * \t\t\tspecified **contracts**, by the returned method.*/\n    static decInvariant(contracts, path = undefined, dbc = \"WaXCode.DBC\") {\n        return (target, propertyKey) => {\n            if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkInvariants) {\n                return;\n            }\n            // biome-ignore lint/suspicious/noExplicitAny: Necessary to intercept UNDEFINED and NULL.\n            let value;\n            // #region Replace original property.\n            Object.defineProperty(target, propertyKey, {\n                set(newValue) {\n                    if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkInvariants) {\n                        return;\n                    }\n                    const realValue = path ? DBC.resolve(newValue, path) : newValue;\n                    // #region Check if all \"contracts\" are fulfilled.\n                    for (const contract of contracts) {\n                        const result = contract.check(realValue);\n                        if (typeof result === \"string\") {\n                            DBC.resolveDBCPath(window, dbc).reportFieldInfringement(result, target, path, propertyKey, realValue);\n                        }\n                    }\n                    // #endregion Check if all \"contracts\" are fulfilled.\n                    value = newValue;\n                },\n                enumerable: true,\n                configurable: true,\n            });\n            // #endregion Replace original property.\n        };\n    }\n    // #endregion Invariant\n    // #region Postcondition\n    /**\n     * A method decorator factory checking the result of a method whenever it is invoked thus also usable on getters.\n     *\n     * @param check\tThe **(toCheck: any, object, string) => boolean | string** to use for checking.\n     * @param dbc\tSee {@link DBC.resolveDBCPath }.\n     * @param path\tThe dotted path referring to the actual value to check, starting form the specified one.\n     *\n     * @returns The **( target : object, propertyKey : string, descriptor : PropertyDescriptor ) : PropertyDescriptor**\n     * \t\t\tinvoked by Typescript.\n     */\n    static decPostcondition(\n    // biome-ignore lint/suspicious/noExplicitAny: Necessary to intercept UNDEFINED and NULL.\n    check, dbc, path = undefined) {\n        return (target, propertyKey, descriptor) => {\n            const originalMethod = descriptor.value;\n            // biome-ignore lint/suspicious/noExplicitAny: Necessary to intercept UNDEFINED and NULL.\n            descriptor.value = (...args) => {\n                if (!DBC.resolveDBCPath(window, dbc).executionSettings.checkPostconditions) {\n                    console.log(\"Postcondition checks are disabled.\");\n                    return;\n                }\n                // biome-ignore lint/complexity/noThisInStatic: <explanation>\n                const result = originalMethod.apply(this, args);\n                const realValue = path ? DBC.resolve(result, path) : result;\n                const checkResult = check(realValue, target, propertyKey);\n                if (typeof checkResult === \"string\") {\n                    DBC.resolveDBCPath(window, dbc).reportReturnvalueInfringement(checkResult, target, path, propertyKey, realValue);\n                }\n                return result;\n            };\n            return descriptor;\n        };\n    }\n    // #endregion Postcondition\n    // #region Decorator\n    // #region Precondition\n    /**\n     * A parameter-decorator factory that requests the tagged parameter's value passing it to the provided\n     * \"check\"-method when the value becomes available.\n     *\n     * @param check\tThe \"( unknown ) => void\" to be invoked along with the tagged parameter's value as soon\n     * \t\t\t\tas it becomes available.\n     * @param dbc  \tSee {@link DBC.resolveDBCPath }.\n     * @param path\tThe dotted path referring to the actual value to check, starting form the specified one.\n     * \t\t\t\tMay contain :: to separate multiple paths.\n     *\n     * @returns The **(target: object, methodName: string | symbol, parameterIndex: number ) => void** invoked by Typescript- */\n    static decPrecondition(check, dbc, path = undefined, hint = undefined) {\n        return (target, methodName, parameterIndex) => {\n            DBC.requestParamValue(target, methodName, parameterIndex, (value) => {\n                if (!DBC.resolveDBCPath(window, dbc).executionSettings\n                    .checkPreconditions) {\n                    console.log(\"Precondition checks are disabled.\");\n                    return;\n                }\n                const paths = path ? path.replace(/ /g, \"\").split(\"::\") : [undefined];\n                for (const singlePath of paths) {\n                    const realValue = singlePath ? DBC.resolve(value, singlePath) : value;\n                    const result = check(realValue, target, methodName, parameterIndex);\n                    if (typeof result === \"string\") {\n                        DBC.resolveDBCPath(window, dbc).reportParameterInfringement(result, target, singlePath, methodName, parameterIndex, realValue, hint);\n                    }\n                }\n            });\n        };\n    }\n    /**\n     * Reports a warning.\n     *\n     * @param message The message containing the warning. */\n    reportWarning(message) {\n        if (this.warningSettings.logToConsole) {\n            console.warn(message);\n        }\n    }\n    /**\n     * Reports an infringement according to the {@link infringementSettings } also generating a proper {@link string }-wrapper\n     * for the given \"message\" & violator.\n     *\n     * @param message\tThe {@link string } describing the infringement and it's provenience.\n     * @param violator \tThe {@link string } describing or naming the violator. */\n    reportInfringement(message, violator, target, value, path) {\n        const finalMessage = `[ From \"${violator}\"${typeof target === \"function\" ? ` in \"${target.name}\"` : typeof target === \"object\" && target !== null && typeof target.constructor === \"function\" ? ` in \"${target.constructor.name}\"` : `in \"${target === undefined ? \"UNDEFINED\" : target === null ? \"NULL\" : target}\"`}${value ? ` > \"${path}\"` : \"UNDEFINED | NULL\"}: ${message}]`;\n        if (this.infringementSettings.throwException) {\n            throw new DBC.Infringement(finalMessage);\n        }\n        if (this.infringementSettings.logToConsole) {\n            console.log(finalMessage);\n        }\n    }\n    /**\n     * Reports a parameter-infringement via {@link reportInfringement } also generating a proper {@link string }-wrapper\n     * for the given \"message\",\"method\", parameter-\"index\" & value.\n     *\n     * @param message\tThe {@link string } describing the infringement and it's provenience.\n     * @param method \tThe {@link string } describing or naming the violator.\n     * @param index\t\tThe index of the parameter within the argument listing.\n     * @param value \tThe parameter's value. */\n    reportParameterInfringement(message, target, path, method, index, value, hint = undefined) {\n        const properIndex = index + 1;\n        this.reportInfringement(`[ Parameter-value \"${value}\" of the ${properIndex}${properIndex === 1 ? \"st\" : properIndex === 2 ? \"nd\" : properIndex === 3 ? \"rd\" : \"th\"} parameter did not fulfill one of it's contracts: ${message}. ${hint ? `✨ ${hint} ✨` : \"\"}]`, method, target, value, path);\n    }\n    /**\n     * Reports a field-infringement via {@link reportInfringement } also generating a proper {@link string }-wrapper\n     * for the given **message** & **name**.\n     *\n     * @param message\tA {@link string } describing the infringement and it's provenience.\n     * @param key \t\tThe property key.\n     * @param path\t\tThe dotted-path {@link string } that leads to the value not fulfilling the contract starting from\n     * \t\t\t\t\tthe tagged one.\n     * @param value\t\tThe value not fulfilling a contract. */\n    reportFieldInfringement(message, target, path, key, value) {\n        this.reportInfringement(`[ New value for \"${key}\"${path === undefined ? \"\" : `.${path}`} with value \"${value}\" did not fulfill one of it's contracts: ${message}]`, key, target, value, path);\n    }\n    /**\n     * Reports a returnvalue-infringement according via {@link reportInfringement } also generating a proper {@link string }-wrapper\n     * for the given \"message\",\"method\" & value.\n     *\n     * @param message\tThe {@link string } describing the infringement and it's provenience.\n     * @param method \tThe {@link string } describing or naming the violator.\n     * @param value\t\tThe parameter's value. */\n    reportReturnvalueInfringement(message, target, path, method, \n    // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n    value) {\n        this.reportInfringement(`[ Return-value \"${value}\" did not fulfill one of it's contracts: ${message}]`, method, target, value, path);\n    }\n    /**\n     * Constructs this {@link DBC } by setting the {@link DBC.infringementSettings }, define the **WaXCode** namespace in\n     * **window** if not yet available and setting the property **DBC** in there to the instance of this {@link DBC }.\n     *\n     * @param infringementSettings \tSee {@link DBC.infringementSettings }.\n     * @param executionSettings\t\tSee {@link DBC.executionSettings }. */\n    constructor(infringementSettings = { throwException: true, logToConsole: false }, executionSettings = {\n        checkPreconditions: true,\n        checkPostconditions: true,\n        checkInvariants: true,\n    }) {\n        // #endregion Precondition\n        // #endregion Decorator\n        // #region Execution Handling\n        /** Stores settings concerning the execution of checks. */\n        this.executionSettings = {\n            checkPreconditions: true,\n            checkPostconditions: true,\n            checkInvariants: true,\n        };\n        // #endregion Execution Handling\n        // #region Warning handling.\n        /** Stores settings concerning warnings. */\n        this.warningSettings = { logToConsole: true };\n        // #endregion Warning handling.\n        // #region infringement handling.\n        /** Stores the settings concerning infringements */\n        this.infringementSettings = { throwException: true, logToConsole: false };\n        this.infringementSettings = infringementSettings;\n        // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n        if (window.WaXCode === undefined)\n            window.WaXCode = {};\n        // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n        window.WaXCode.DBC = this;\n    }\n    /**\n     * Resolves the desired {@link object } out a given one **toResolveFrom** using the specified **path**.\n     *\n     * @param toResolveFrom The {@link object } starting to resolve from.\n     * @param path\t\t\tThe dotted path-{@link string }.\n     * \t\t\t\t\t\tThis string uses ., [...], and () to represent accessing nested properties,\n     * \t\t\t\t\t\tarray elements/object keys, and calling methods, respectively, mimicking JavaScript syntax to navigate\n     * \t\t\t\t\t\tan object's structure. Code, e.g. something like a.b( 1 as number ).c, will not be executed and\n     * \t\t\t\t\t\tthus make the retrieval fail.\n     *\n     * @returns The requested {@link object }, NULL or UNDEFINED. */\n    static resolve(toResolveFrom, path) {\n        if (!toResolveFrom || typeof path !== \"string\") {\n            return undefined;\n        }\n        const parts = path.replace(/\\[(['\"]?)(.*?)\\1\\]/g, \".$2\").split(\".\"); // Handle indexers\n        let current = toResolveFrom;\n        for (const part of parts) {\n            if (current === null || typeof current === \"undefined\") {\n                return undefined;\n            }\n            const methodMatch = part.match(/(\\w+)\\((.*)\\)/);\n            if (methodMatch) {\n                const methodName = methodMatch[1];\n                const argsStr = methodMatch[2];\n                const args = argsStr.split(\",\").map((arg) => arg.trim()); // Simple argument parsing\n                if (typeof current[methodName] === \"function\") {\n                    current = current[methodName].apply(current, args);\n                }\n                else {\n                    return undefined; // Method not found or not a function\n                }\n            }\n            else {\n                current = current[part];\n            }\n        }\n        return current;\n    }\n}\n// #region Parameter-value requests.\n/** Stores all request for parameter values registered by {@link decPrecondition }. */\nDBC.paramValueRequests = new Map();\n// #region Classes\n// #region Errors\n/** An {@link Error } to be thrown whenever an infringement is detected. */\nDBC.Infringement = class extends Error {\n    /**\n     * Constructs this {@link Error } by tagging the specified message-{@link string } as an XDBC-Infringement.\n     *\n     * @param message The {@link string } describing the infringement. */\n    constructor(message) {\n        super(`[ XDBC Infringement ${message}]`);\n    }\n};\n// #endregion Errors\n// #endregion Classes\n// #endregion infringement handling.\n/**\n * Resolves the specified dotted {@link string }-path to a {@link DBC }.\n *\n * @param obj \tThe {@link object } to start resolving from.\n * @param path \tThe dotted {@link string }-path leading to the {@link DBC }.\n *\n * @returns The requested {@link DBC }.\n */\nDBC.resolveDBCPath = (obj, path) => path === null || path === void 0 ? void 0 : path.split(\".\").reduce((accumulator, current) => accumulator[current], obj);\n// Set the main instance with standard **DBC.infringementSettings**.\nnew DBC();\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } defining that all elements of an {@link object }s have to fulfill\n * a given {@link object }'s check-method (**( toCheck : any ) => boolean | string**).\n *\n * @remarks\n * Maintainer: Callari, Salvatore (XDBC@WaXCode.net) */\nexport class AE extends DBC {\n    // #region Condition checking.\n    /**\n     * Checks each element of the **value**-{@link Array < any >} against the given **condition**, if it is one. If it is not\n     * the **value** itself will be checked.\n     *\n     * @param condition\tThe { check: (toCheck: any) => boolean | string } to check the **value** against.\n     * @param value\t\tEither **value**-{@link Array < any >}, which's elements will be checked, or the value to be\n     * \t\t\t\t\tchecked itself.\n     * @param index\t\tIf specified with **idxEnd** being undefined, this {@link Number } will be seen as the index of\n     * \t\t\t\t\tthe value-{@link Array }'s element to check. If value isn't an {@link Array } this parameter\n     * \t\t\t\t\twill not have any effect.\n     * \t\t\t\t\tWith **idxEnd** not undefined this parameter indicates the beginning of the span of elements to\n     * \t\t\t\t\tcheck within the value-{@link Array }.\n     * @param idxEnd\tIndicates the last element's index (including) of the span of value-{@link Array } elements to check.\n     * \t\t\t\t\tSetting this parameter to -1 specifies that all value-{@link Array }'s elements beginning from the\n     * \t\t\t\t\tspecified **index** shall be checked.\n     *\n     * @returns As soon as the **condition** returns a {@link string }, instead of TRUE, the returned string. TRUE if the\n     * \t\t\t**condition** never returns a {@link string}. */\n    static checkAlgorithm(condition, value, index, idxEnd) {\n        if (Array.isArray(value)) {\n            if (index !== undefined && idxEnd === undefined) {\n                if (index > -1 && index < value.length) {\n                    const result = condition.check(value[index]);\n                    if (typeof result === \"string\") {\n                        return `Violating-Arrayelement at index \"${index}\" with value \"${value[index]}\". ${result}`;\n                    }\n                }\n                return true; // In order for optional parameter to not cause an error if they are omitted.\n            }\n            const ending = idxEnd !== undefined\n                ? idxEnd !== -1\n                    ? idxEnd + 1\n                    : value.length\n                : value.length;\n            for (let i = index ? index : 0; i < ending; i++) {\n                const result = condition.check(value[i]);\n                if (result !== true) {\n                    return `Violating-Arrayelement at index ${i}. ${result}`;\n                }\n            }\n        }\n        else {\n            return condition.check(value);\n        }\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link AE.checkAlgorithm } with either multiple or a single one\n     * of the **realConditions** to check the tagged parameter-value against with.\n     * When specifying an **index** and the tagged parameter's **value** is an {@link Array }, the **realConditions** apply to the\n     * element at the specified **index**.\n     * If the {@link Array } is too short the currently processed { check: (toCheck: any) => boolean | string } of\n     * **realConditions** will be verified to TRUE automatically, considering optional parameters.\n     * If an **index** is specified but the tagged parameter's value isn't an array, the **index** is treated as being undefined.\n     * If **index** is undefined and the tagged parameter's value is an {@link Array } each element of it will be checked\n     * against the **realConditions**.\n     *\n     * @param realConditions\tEither one or more { check: (toCheck: any) => boolean | string } to check the tagged parameter-value\n     * \t\t\t\t\t\t\tagainst with.\n     * @param index\t\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param idxEnd\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param path\t\t\t\tSee {@link DBC.decPrecondition }.\n     * @param dbc\t\t\t\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns\tA {@link string } as soon as one { check: (toCheck: any) => boolean | string } of **realConditions** returns one.\n     * \t\t\tOtherwise TRUE. */\n    static PRE(realConditions, index = undefined, idxEnd = undefined, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            if (Array.isArray(realConditions)) {\n                for (const currentCondition of realConditions) {\n                    const result = AE.checkAlgorithm(currentCondition, value, index, idxEnd);\n                    if (typeof result !== \"boolean\")\n                        return result;\n                }\n            }\n            else {\n                return AE.checkAlgorithm(realConditions, value, index, idxEnd);\n            }\n            return true;\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link AE.checkAlgorithm } with either multiple or a single one\n     * of the **realConditions** to check the tagged method's return-value against with.\n     *\n     * @param realConditions\tEither one or more { check: (toCheck: any) => boolean | string } to check the tagged parameter-value\n     * \t\t\t\t\t\t\tagainst with.\n     * @param index\t\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param idxEnd\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param path\t\t\t\tSee {@link DBC.decPrecondition }.\n     * @param dbc\t\t\t\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns\tA {@link string } as soon as one { check: (toCheck: any) => boolean | string } of **realConditions** return one.\n     * \t\t\tOtherwise TRUE. */\n    static POST(realConditions, index = undefined, idxEnd = undefined, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            if (Array.isArray(realConditions)) {\n                for (const currentCondition of realConditions) {\n                    const result = AE.checkAlgorithm(currentCondition, value, index, idxEnd);\n                    if (typeof result !== \"boolean\")\n                        return result;\n                }\n            }\n            else {\n                return AE.checkAlgorithm(\n                // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n                realConditions, value, index, idxEnd);\n            }\n            return true;\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link AE.checkAlgorithm } with either multiple or a single one\n     * of the **realConditions** to check the tagged field.\n     *\n     * @param realConditions\tEither one or more { check: (toCheck: any) => boolean | string } to check the tagged parameter-value\n     * \t\t\t\t\t\t\tagainst with.\n     * @param index\t\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param idxEnd\t\t\tSee the {@link AE.checkAlgorithm }.\n     * @param path\t\t\t\tSee {@link DBC.decInvariant }.\n     * @param dbc\t\t\t\tSee {@link DBC.decInvariant }.\n     *\n     * @returns\tSee {@link DBC.decInvariant }. */\n    static INVARIANT(realConditions, index = undefined, idxEnd = undefined, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new AE(realConditions, index, idxEnd)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    //\n    // For usage in dynamic scenarios (like global functions).\n    //\n    /**\n     * Invokes the {@link AE.checkAlgorithm } with all {@link AE.conditions } and the {@link object } {@link toCheck },\n     * {@link AE.index } & {@link AE.idxEnd }.\n     *\n     * @param toCheck See {@link AE.checkAlgorithm }.\n     *\n     * @returns See {@link EQ.checkAlgorithm}. */\n    check(toCheck) {\n        if (Array.isArray(this.conditions)) {\n            for (const currentCondition of this.conditions) {\n                const result = AE.checkAlgorithm(currentCondition, toCheck, this.index, this.idxEnd);\n                if (typeof result !== \"boolean\")\n                    return result;\n            }\n        }\n        else {\n            return AE.checkAlgorithm(\n            // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n            this.conditions, toCheck, this.index, this.idxEnd);\n        }\n        return true;\n    }\n    /**\n     * Creates this {@link AE } by setting the protected property {@link AE.conditions }, {@link AE.index } and {@link AE.idxEnd } used by {@link AE.check }.\n     *\n     * @param equivalent See {@link EQ.check }. */\n    constructor(conditions, index = undefined, idxEnd = undefined) {\n        super();\n        this.conditions = conditions;\n        this.index = index;\n        this.idxEnd = idxEnd;\n    }\n}\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } defining a comparison between two {@link object }s.\n *\n * @remarks\n * Maintainer: Callari, Salvatore (XDBC@WaXCode.net) */\nexport class COMPARISON extends DBC {\n    // #region Condition checking.\n    /**\n     * Does a comparison between the {@link object } **toCheck** and the **equivalent**.\n     *\n     * @param toCheck\t\tThe value that has to be equal to it's possible **equivalent** for this {@link DBC } to be fulfilled.\n     * @param equivalent\tThe {@link object } the one **toCheck** has to be equal to in order for this {@link DBC } to be\n     * \t\t\t\t\t\tfulfilled.\n     *\n     * @returns TRUE if the value **toCheck** and the **equivalent** are equal to each other, otherwise FALSE. */\n    static checkAlgorithm(toCheck, equivalent, equalityPermitted, invert) {\n        if (equalityPermitted && !invert && toCheck < equivalent) {\n            return `Value has to to be greater than or equal to \"${equivalent}\"`;\n        }\n        if (equalityPermitted && invert && toCheck > equivalent) {\n            return `Value has to be less than or equal to \"${equivalent}\"`;\n        }\n        if (!equalityPermitted && !invert && toCheck <= equivalent) {\n            return `Value has to to be greater than \"${equivalent}\"`;\n        }\n        if (!equalityPermitted && invert && toCheck >= equivalent) {\n            return `Value has to be less than \"${equivalent}\"`;\n        }\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link COMPARISON.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged parameter.\n     *\n     * @param equivalent\t    See {@link COMPARISON.checkAlgorithm }.\n     * @param equalityPermitted See {@link COMPARISON.checkAlgorithm }.\n     * @param path\t\t\t    See {@link DBC.decPrecondition }.\n     * @param dbc\t\t\t    See {@link DBC.decPrecondition }.\n     *\n     * @returns See {@link DBC.decPrecondition }. */\n    static PRE(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            return COMPARISON.checkAlgorithm(value, equivalent, equalityPermitted, invert);\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link COMPARISON.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param equivalent\t    See {@link COMPARISON.checkAlgorithm }.\n     * @param equalityPermitted See {@link COMPARISON.checkAlgorithm }.\n     * @param path\t\t\t    See {@link DBC.Postcondition }.\n     * @param dbc\t\t\t    See {@link DBC.decPostcondition }.\n     *\n     * @returns See {@link DBC.decPostcondition }. */\n    static POST(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            return COMPARISON.checkAlgorithm(value, equalityPermitted, equivalent, invert);\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link COMPARISON.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged field.\n     *\n     * @param equivalent\t    See {@link COMPARISON.checkAlgorithm }.\n     * @param equalityPermitted See {@link COMPARISON.checkAlgorithm }.\n     * @param path\t\t\t    See {@link DBC.decInvariant }.\n     * @param dbc\t\t\t    See {@link DBC.decInvariant }.\n     *\n     * @returns See {@link DBC.decInvariant }. */\n    static INVARIANT(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new COMPARISON(equivalent, equalityPermitted, invert)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    // #region Dynamic usage.\n    /**\n     * Invokes the {@link COMPARISON.checkAlgorithm } passing the value **toCheck**, {@link COMPARISON.equivalent } and {@link COMPARISON.invert }.\n     *\n     * @param toCheck See {@link COMPARISON.checkAlgorithm }.\n     *\n     * @returns See {@link COMPARISON.checkAlgorithm}. */\n    check(toCheck) {\n        return COMPARISON.checkAlgorithm(toCheck, this.equivalent, this.equalityPermitted, this.invert);\n    }\n    /**\n     * Creates this {@link COMPARISON } by setting the protected property {@link COMPARISON.equivalent }, {@link COMPARISON.equalityPermitted } and {@link COMPARISON.invert } used by {@link COMPARISON.check }.\n     *\n     * @param equivalent        See {@link COMPARISON.check }.\n     * @param equalityPermitted See {@link COMPARISON.check }.\n     * @param invert            See {@link COMPARISON.check }. */\n    constructor(equivalent, equalityPermitted = false, invert = false) {\n        super();\n        this.equivalent = equivalent;\n        this.equalityPermitted = equalityPermitted;\n        this.invert = invert;\n    }\n}\n","import { COMPARISON } from \"../COMPARISON\";\n/** See {@link COMPARISON }. */\nexport class GREATER extends COMPARISON {\n    /** See {@link COMPARISON.PRE }. */\n    static PRE(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.PRE(equivalent, false, false, path, dbc);\n    }\n    /** See {@link COMPARISON.POST }. */\n    static POST(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.POST(equivalent, false, false, path, dbc);\n    }\n    /** See {@link COMPARISON.INVARIANT }. */\n    static INVARIANT(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.INVARIANT(equivalent, false, false, path, dbc);\n    }\n    /** See {@link COMPARISON.constructor }. */\n    constructor(equivalent) {\n        super(equivalent, false, false);\n        this.equivalent = equivalent;\n    }\n}\n","import { COMPARISON } from \"../COMPARISON\";\n/** See {@link COMPARISON }. */\nexport class GREATER_OR_EQUAL extends COMPARISON {\n    /** See {@link COMPARISON.PRE }. */\n    static PRE(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.PRE(equivalent, true, false, path, dbc);\n    }\n    /** See {@link COMPARISON.POST }. */\n    static POST(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.POST(equivalent, true, false, path, dbc);\n    }\n    /** See {@link COMPARISON.INVARIANT }. */\n    static INVARIANT(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.INVARIANT(equivalent, true, false, path, dbc);\n    }\n    /** See {@link COMPARISON.constructor }. */\n    constructor(equivalent) {\n        super(equivalent, true, false);\n        this.equivalent = equivalent;\n    }\n}\n","import { COMPARISON } from \"../COMPARISON\";\n/** See {@link COMPARISON }. */\nexport class LESS extends COMPARISON {\n    /** See {@link COMPARISON.PRE }. */\n    static PRE(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.PRE(equivalent, false, true, path, dbc);\n    }\n    /** See {@link COMPARISON.POST }. */\n    static POST(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.POST(equivalent, false, true, path, dbc);\n    }\n    /** See {@link COMPARISON.INVARIANT }. */\n    static INVARIANT(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.INVARIANT(equivalent, false, true, path, dbc);\n    }\n    /** See {@link COMPARISON.constructor }. */\n    constructor(equivalent) {\n        super(equivalent, false, true);\n        this.equivalent = equivalent;\n    }\n}\n","import { COMPARISON } from \"../COMPARISON\";\n/** See {@link COMPARISON }. */\nexport class LESS_OR_EQUAL extends COMPARISON {\n    /** See {@link COMPARISON.PRE }. */\n    static PRE(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.PRE(equivalent, true, true, path, dbc);\n    }\n    /** See {@link COMPARISON.POST }. */\n    static POST(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.POST(equivalent, true, true, path, dbc);\n    }\n    /** See {@link COMPARISON.INVARIANT }. */\n    static INVARIANT(equivalent, equalityPermitted = false, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return COMPARISON.INVARIANT(equivalent, true, true, path, dbc);\n    }\n    /** See {@link COMPARISON.constructor }. */\n    constructor(equivalent) {\n        super(equivalent, true, true);\n        this.equivalent = equivalent;\n    }\n}\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } defining that two {@link object }s gotta be equal.\n *\n * @remarks\n * Maintainer: Callari, Salvatore (XDBC@WaXCode.net) */\nexport class EQ extends DBC {\n    // #region Condition checking.\n    /**\n     * Checks if the value **toCheck** is equal to the specified **equivalent**.\n     *\n     * @param toCheck\t\tThe value that has to be equal to it's possible **equivalent** for this {@link DBC } to be fulfilled.\n     * @param equivalent\tThe {@link object } the one **toCheck** has to be equal to in order for this {@link DBC } to be\n     * \t\t\t\t\t\tfulfilled.\n     *\n     * @returns TRUE if the value **toCheck** and the **equivalent** are equal to each other, otherwise FALSE. */\n    static checkAlgorithm(\n    // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n    toCheck, equivalent, invert) {\n        if (!invert && equivalent !== toCheck) {\n            return `Value has to to be equal to \"${equivalent}\"`;\n        }\n        if (invert && equivalent === toCheck) {\n            return `Value must not to be equal to \"${equivalent}\"`;\n        }\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link EQ.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged parameter.\n     *\n     * @param equivalent\tSee {@link EQ.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.decPrecondition }.\n     * @param dbc\t\t\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns See {@link DBC.decPrecondition }. */\n    static PRE(\n    // biome-ignore lint/suspicious/noExplicitAny: To check for UNDEFINED and NULL.\n    equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            return EQ.checkAlgorithm(value, equivalent, invert);\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link EQ.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param equivalent\tSee {@link EQ.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.Postcondition }.\n     * @param dbc\t\t\tSee {@link DBC.decPostcondition }.\n     *\n     * @returns See {@link DBC.decPostcondition }. */\n    static POST(\n    // biome-ignore lint/suspicious/noExplicitAny: To check for UNDEFINED and NULL.\n    equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            return EQ.checkAlgorithm(value, equivalent, invert);\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link EQ.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged field.\n     *\n     * @param equivalent\tSee {@link EQ.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.decInvariant }.\n     * @param dbc\t\t\tSee {@link DBC.decInvariant }.\n     *\n     * @returns See {@link DBC.decInvariant }. */\n    static INVARIANT(\n    // biome-ignore lint/suspicious/noExplicitAny: To check for UNDEFINED and NULL.\n    equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new EQ(equivalent, invert)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    //\n    // For usage in dynamic scenarios (like with AE-DBC).\n    //\n    /**\n     * Invokes the {@link EQ.checkAlgorithm } passing the value **toCheck**, {@link EQ.equivalent } and {@link EQ.invert }.\n     *\n     * @param toCheck See {@link EQ.checkAlgorithm }.\n     *\n     * @returns See {@link EQ.checkAlgorithm}. */\n    // biome-ignore lint/suspicious/noExplicitAny: Necessary to check against NULL & UNDEFINED.\n    check(toCheck) {\n        return EQ.checkAlgorithm(toCheck, this.equivalent, this.invert);\n    }\n    /**\n     * Invokes the {@link EQ.checkAlgorithm } passing the value **toCheck** and the specified **type** .\n     *\n     * @param toCheck See {@link EQ.checkAlgorithm }.\n     *\n     * @returns The **CANDIDATE** **toCheck** doesn't fulfill this {@link EQ }.\n     *\n     * @throws A {@link DBC.Infringement } if the **CANDIDATE** **toCheck** does not fulfill this {@link EQ }.*/\n    static tsCheck(toCheck, equivalent) {\n        const result = EQ.checkAlgorithm(toCheck, equivalent, false);\n        if (result) {\n            return toCheck;\n        }\n        else {\n            throw new DBC.Infringement(result);\n        }\n    }\n    /**\n     * Creates this {@link EQ } by setting the protected property {@link EQ.equivalent } used by {@link EQ.check }.\n     *\n     * @param equivalent See {@link EQ.check }. */\n    constructor(\n    // biome-ignore lint/suspicious/noExplicitAny: To be able to match UNDEFINED and NULL.\n    equivalent, invert = false) {\n        super();\n        this.equivalent = equivalent;\n        this.invert = invert;\n    }\n}\n","import { EQ } from \"../EQ\";\n/** See {@link COMPARISON }. */\nexport class DIFFERENT extends EQ {\n    /** See {@link COMPARISON.PRE }. */\n    static PRE(equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return EQ.PRE(equivalent, true, path, dbc);\n    }\n    /** See {@link COMPARISON.POST }. */\n    static POST(equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return EQ.POST(equivalent, true, path, dbc);\n    }\n    /** See {@link COMPARISON.INVARIANT }. */\n    static INVARIANT(equivalent, invert = false, path = undefined, dbc = \"WaXCode.DBC\") {\n        return EQ.INVARIANT(equivalent, true, path, dbc);\n    }\n    /** See {@link COMPARISON.constructor }. */\n    constructor(equivalent) {\n        super(equivalent, true);\n        this.equivalent = equivalent;\n    }\n}\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } defining that the an {@link object }s gotta be an instance of a certain {@link INSTANCE.reference }.\n *\n * @remarks\n * Maintainer: Salvatore Callari (XDBC@WaXCode.net) */\nexport class INSTANCE extends DBC {\n    /**\n     * Checks if the value **toCheck** is an instance of the specified **reference**.\n     *\n     * @param toCheck\tThe value that has to be an instance of the **reference** in order for this {@link DBC }\n     * \t\t\t\t\tto be fulfilled.\n     * @param reference\tThe {@link object } the one **toCheck** has to be an instance of.\n     *\n     * @returns TRUE if the value **toCheck** is is an instance of the *reference**, otherwise FALSE. */\n    // biome-ignore lint/suspicious/noExplicitAny: In order to perform an \"instanceof\" check.\n    static checkAlgorithm(toCheck, reference) {\n        if (!(toCheck instanceof reference)) {\n            return `Value has to be an instance of \"${reference}\" but is of type \"${typeof toCheck}\"`;\n        }\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link INSTANCE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged parameter.\n     *\n     * @param reference\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param path\tSee {@link DBC.decPrecondition }.\n     * @param dbc\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns See {@link DBC.decPrecondition }. */\n    static PRE(\n    // biome-ignore lint/suspicious/noExplicitAny: In order to perform an \"instanceof\" check.\n    reference, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            return INSTANCE.checkAlgorithm(value, reference);\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link INSTANCE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param reference\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param path\tSee {@link DBC.Postcondition }.\n     * @param dbc\tSee {@link DBC.decPostcondition }.\n     *\n     * @returns See {@link DBC.decPostcondition }. */\n    static POST(\n    // biome-ignore lint/suspicious/noExplicitAny: In order to perform an \"instanceof\" check.\n    reference, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            return INSTANCE.checkAlgorithm(value, reference);\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link INSTANCE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param reference\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param path\tSee {@link DBC.decInvariant }.\n     * @param dbc\tSee {@link DBC.decInvariant }.\n     *\n     * @returns See {@link DBC.decInvariant }. */\n    static INVARIANT(\n    // biome-ignore lint/suspicious/noExplicitAny: In order to perform an \"instanceof\" check.\n    reference, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new INSTANCE(reference)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    //\n    // For usage in dynamic scenarios (like with AE-DBC).\n    //\n    /**\n     * Invokes the {@link INSTANCE.checkAlgorithm } passing the value **toCheck** and the {@link INSTANCE.reference } .\n     *\n     * @param toCheck See {@link INSTANCE.checkAlgorithm }.\n     *\n     * @returns See {@link INSTANCE.checkAlgorithm}. */\n    // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n    check(toCheck) {\n        return INSTANCE.checkAlgorithm(toCheck, this.reference);\n    }\n    /**\n     * Invokes the {@link INSTANCE.checkAlgorithm } passing the value **toCheck** and the {@link INSTANCE.reference } .\n     *\n     * @param toCheck \tSee {@link INSTANCE.checkAlgorithm }.\n     * @param reference\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param id\t\tA {@link string } identifying this {@link INSTANCE } via the {@link DBC.Infringement }-Message.\n     * @param hint\t\tAn optional {@link string } providing extra information in case of an infringement.\n     *\n     * @returns The **CANDIDATE** **toCheck** doesn't fulfill this {@link INSTANCE }.\n     *\n     * @throws A {@link DBC.Infringement } if the **CANDIDATE** **toCheck** does not fulfill this {@link DEFINED }. */\n    static tsCheck(toCheck, reference, hint = undefined, id = undefined) {\n        const result = INSTANCE.checkAlgorithm(toCheck, reference);\n        if (result === true) {\n            return toCheck;\n        }\n        else {\n            throw new DBC.Infringement(`${id ? `(${id}) ` : \"\"}${result} ${hint ? `< ${hint} >` : \"\"}`);\n        }\n    }\n    /**\n     * Creates this {@link INSTANCE } by setting the protected property {@link INSTANCE.reference } used by {@link INSTANCE.check }.\n     *\n     * @param reference See {@link INSTANCE.check }. */\n    // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n    constructor(reference) {\n        super();\n        this.reference = reference;\n    }\n}\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } providing {@link REGEX }-contracts and standard {@link RegExp } for common use cases in {@link REGEX.stdExp }.\n *\n * @remarks\n * Maintainer: Callari, Salvatore (XDBC@WaXCode.net) */\nexport class REGEX extends DBC {\n    // #region Condition checking.\n    /**\n     * Checks if the value **toCheck** is complies to the {@link RegExp } **expression**.\n     *\n     * @param toCheck\t\tThe value that has comply to the {@link RegExp } **expression** for this {@link DBC } to be fulfilled.\n     * @param expression\tThe {@link RegExp } the one **toCheck** has comply to in order for this {@link DBC } to be\n     * \t\t\t\t\t\tfulfilled.\n     *\n     * @returns TRUE if the value **toCheck** complies with the {@link RegExp } **expression**, otherwise FALSE. */\n    static checkAlgorithm(toCheck, expression) {\n        if (toCheck === undefined || toCheck === null)\n            return true;\n        if (!expression.test(toCheck)) {\n            return `Value has to comply to regular expression \"${expression}\"`;\n        }\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link REGEX.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged parameter.\n     *\n     * @param expression\tSee {@link REGEX.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.decPrecondition }.\n     * @param dbc\t\t\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns See {@link DBC.decPrecondition }. */\n    static PRE(expression, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            return REGEX.checkAlgorithm(value, expression);\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link REGEX.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param expression\tSee {@link REGEX.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.Postcondition }.\n     * @param dbc\t\t\tSee {@link DBC.decPostcondition }.\n     *\n     * @returns See {@link DBC.decPostcondition }. */\n    static POST(expression, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            return REGEX.checkAlgorithm(value, expression);\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link REGEX.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged field.\n     *\n     * @param expression\tSee {@link REGEX.checkAlgorithm }.\n     * @param path\t\t\tSee {@link DBC.decInvariant }.\n     * @param dbc\t\t\tSee {@link DBC.decInvariant }.\n     *\n     * @returns See {@link DBC.decInvariant }. */\n    static INVARIANT(expression, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new REGEX(expression)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    //\n    // For usage in dynamic scenarios (like with AE-DBC).\n    //\n    /**\n     * Invokes the {@link REGEX.checkAlgorithm } passing the value **toCheck** and {@link REGEX.equivalent }.\n     *\n     * @param toCheck See {@link REGEX.checkAlgorithm }.\n     *\n     * @returns See {@link EQ.checkAlgorithm}. */\n    check(toCheck) {\n        return REGEX.checkAlgorithm(toCheck, this.expression);\n    }\n    /**\n     * Creates this {@link REGEX } by setting the protected property {@link REGEX.expression } used by {@link REGEX.check }.\n     *\n     * @param expression See {@link REGEX.check }. */\n    constructor(expression) {\n        super();\n        this.expression = expression;\n    }\n    // #endregion Referenced Condition checking.\n    // #region In-Method checking.\n    /**\n     * Invokes the {@link REGEX.checkAlgorithm } passing the value **toCheck** and {@link REGEX.expression }.\n     *\n     * @param toCheck\t\tSee {@link REGEX.checkAlgorithm}.\n     * @param expression\tSee {@link REGEX.checkAlgorithm}.\n     */\n    static check(toCheck, expression) {\n        const checkResult = REGEX.checkAlgorithm(toCheck, expression);\n        if (typeof checkResult === \"string\") {\n            throw new DBC.Infringement(checkResult);\n        }\n    }\n}\n/** Stores often used {@link RegExp }s. */\nREGEX.stdExp = {\n    htmlAttributeName: /^[a-zA-Z_:][a-zA-Z0-9_.:-]*$/,\n    eMail: /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/i,\n    property: /^[$_A-Za-z][$_A-Za-z0-9]*$/,\n    url: /^(?:(?:http:|https?|ftp):\\/\\/)?(?:\\S+(?::\\S*)?@)?(?:localhost|(?:[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,})(?::\\d{2,5})?(?:\\/(?:[\\w\\-\\.]*\\/)*[\\w\\-\\.]+(?:\\?\\S*)?(?:#\\S*)?)?$/i,\n    keyPath: /^([a-zA-Z_$][a-zA-Z0-9_$]*\\.)*[a-zA-Z_$][a-zA-Z0-9_$]*$/,\n    date: /^\\d{1,4}[.\\/-]\\d{1,2}[.\\/-]\\d{1,4}$/i,\n    dateFormat: /^((D{1,2}[./-]M{1,2}[./-]Y{1,4})|(M{1,2}[./-]D{1,2}[./-]Y{1,4})|Y{1,4}[./-]D{1,2}[./-]M{1,2}|(Y{1,4}[./-]M{1,2}[./-]D{1,2}))$/i,\n    cssSelector: /^(?:\\*|#[\\w-]+|\\.[\\w-]+|(?:[\\w-]+|\\*)(?::(?:[\\w-]+(?:\\([\\w-]+\\))?)+)?(?:\\[(?:[\\w-]+(?:(?:=|~=|\\|=|\\*=|\\$=|\\^=)\\s*(?:\"[^\"]*\"|'[^']*'|[\\w-]+)\\s*)?)?\\])+|\\[\\s*[\\w-]+\\s*=\\s*(?:\"[^\"]*\"|'[^']*'|[\\w-]+)\\s*\\])(?:,\\s*(?:\\*|#[\\w-]+|\\.[\\w-]+|(?:[\\w-]+|\\*)(?::(?:[\\w-]+(?:\\([\\w-]+\\))?)+)?(?:\\[(?:[\\w-]+(?:(?:=|~=|\\|=|\\*=|\\$=|\\^=)\\s*(?:\"[^\"]*\"|'[^']*'|[\\w-]+)\\s*)?)?\\])+|\\[\\s*[\\w-]+\\s*=\\s*(?:\"[^\"]*\"|'[^']*'|[\\w-]+)\\s*\\]))*$/,\n    boolean: /^(TRUE|FALSE|T|F)$/i\n};\n","import { DBC } from \"../DBC\";\n/**\n * A {@link DBC } defining that an {@link object }s gotta be of certain {@link TYPE.type }.\n *\n * @remarks\n * Author: \t\tSalvatore Callari (Callari@WaXCode.net) / 2025\n * Maintainer:\tSalvatore Callari (XDBC@WaXCode.net) */\nexport class TYPE extends DBC {\n    /**\n     * Checks if the value **toCheck** is of the **type** specified.\n     *\n     * @param toCheck\tThe {@link Object } which's **type** to check.\n     * @param type\t\tThe type the {@link object} **toCheck** has to be of. Can be a single type or multiple types separated by \"|\".\n     *\n     * @returns TRUE if the value **toCheck** is of the specified **type**, otherwise FALSE. */\n    // biome-ignore lint/suspicious/noExplicitAny: Necessary for dynamic type checking of also UNDEFINED.\n    static checkAlgorithm(toCheck, type) {\n        if (toCheck === undefined || toCheck === null)\n            return true;\n        const types = type.split(\"|\").map(t => t.trim());\n        const actualType = typeof toCheck;\n        // #region Check if the actual type matches at least one of the specified types\n        // biome-ignore lint/suspicious/useValidTypeof: Necessary\n        const isValid = types.some(t => actualType === t);\n        if (!isValid) {\n            if (types.length === 1) {\n                return `Value has to to be of type \"${type}\" but is of type \"${actualType}\"`;\n            }\n            return `Value has to to be of type \"${types.join(\" | \")}\" but is of type \"${actualType}\"`;\n        }\n        // #endregion Check if the actual type matches at least one of the specified types\n        return true;\n    }\n    /**\n     * A parameter-decorator factory using the {@link TYPE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged parameter.\n     *\n     * @param type\tSee {@link TYPE.checkAlgorithm }.\n     * @param path\tA ::-separated list of dotted paths to check. Each path points to a property within the parameter value.\n     * \t\t\t\tUndefined properties are skipped. See {@link DBC.decPrecondition }.\n     * @param dbc\tSee {@link DBC.decPrecondition }.\n     *\n     * @returns See {@link DBC.decPrecondition }. */\n    static PRE(type, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPrecondition((value, target, methodName, parameterIndex) => {\n            return TYPE.checkAlgorithm(value, type);\n        }, dbc, path);\n    }\n    /**\n     * A method-decorator factory using the {@link TYPE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged method's returnvalue.\n     *\n     * @param type\tSee {@link TYPE.checkAlgorithm }.\n     * @param path\tA ::-separated list of dotted paths to check. Each path points to a property within the parameter value.\n     * \t\t\t\tUndefined properties are skipped. See {@link DBC.decPrecondition }.\n     * @param dbc\tSee {@link DBC.decPostcondition }.\n     *\n     * @returns See {@link DBC.decPostcondition }. */\n    static POST(type, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decPostcondition((value, target, propertyKey) => {\n            return TYPE.checkAlgorithm(value, type);\n        }, dbc, path);\n    }\n    /**\n     * A field-decorator factory using the {@link TYPE.checkAlgorithm } to determine whether this {@link DBC } is fulfilled\n     * by the tagged field.\n     *\n     * @param type\tSee {@link TYPE.checkAlgorithm }.\n     * @param path\tA ::-separated list of dotted paths to check. Each path points to a property within the parameter value.\n     * \t\t\t\tUndefined properties are skipped. See {@link DBC.decPrecondition }.\n     * @param dbc\tSee {@link DBC.decInvariant }.\n     *\n     * @returns See {@link DBC.decInvariant }. */\n    static INVARIANT(type, path = undefined, dbc = \"WaXCode.DBC\") {\n        return DBC.decInvariant([new TYPE(type)], path, dbc);\n    }\n    // #endregion Condition checking.\n    // #region Referenced Condition checking.\n    //\n    // For usage in dynamic scenarios (like with AE-DBC).\n    //\n    /**\n     * Invokes the {@link TYPE.checkAlgorithm } passing the value **toCheck** and the {@link TYPE.type } .\n     *\n     * @param toCheck See {@link TYPE.checkAlgorithm }.\n     *\n     * @returns See {@link TYPE.checkAlgorithm}. */\n    // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n    check(toCheck) {\n        return TYPE.checkAlgorithm(toCheck, this.type);\n    }\n    /**\n     * Invokes the {@link TYPE.checkAlgorithm } passing the value **toCheck** and the {@link TYPE.type } .\n     *\n     * @param toCheck\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param type\t\tSee {@link INSTANCE.checkAlgorithm }.\n     * @param id\t\tA {@link string } identifying this {@link TYPE } via the {@link DBC.Infringement }-Message.\n     * @param hint\t\tAn optional {@link string } providing extra information in case of an infringement.\n     *\n     * @returns The **CANDIDATE** **toCheck** doesn't fulfill this {@link TYPE }.\n     *\n     * @throws A {@link DBC.Infringement } if the **CANDIDATE** **toCheck** does not fulfill this {@link DEFINED }. */\n    static tsCheck(toCheck, type, hint = undefined, id = undefined) {\n        const result = TYPE.checkAlgorithm(toCheck, type);\n        if (result === true) {\n            return toCheck;\n        }\n        else {\n            throw new DBC.Infringement(`${id ? `(${id}) ` : \"\"}${result}${hint ? ` < ${hint} >` : \"\"}`);\n        }\n    }\n    /**\n     * Creates this {@link TYPE } by setting the protected property {@link TYPE.type } used by {@link TYPE.check }.\n     *\n     * @param type See {@link TYPE.check }. */\n    constructor(type) {\n        super();\n        this.type = type;\n    }\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __metadata = (this && this.__metadata) || function (k, v) {\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(k, v);\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n    return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { DBC } from \"./DBC\";\nimport { REGEX } from \"./DBC/REGEX\";\nimport { EQ } from \"./DBC/EQ\";\nimport { TYPE } from \"./DBC/TYPE\";\nimport { AE } from \"./DBC/AE\";\nimport { INSTANCE } from \"./DBC/INSTANCE\";\nimport { GREATER } from \"./DBC/COMPARISON/GREATER\";\nimport { GREATER_OR_EQUAL } from \"./DBC/COMPARISON/GREATER_OR_EQUAL\";\nimport { LESS } from \"./DBC/COMPARISON/LESS\";\nimport { LESS_OR_EQUAL } from \"./DBC/COMPARISON/LESS_OR_EQUAL\";\nimport { DIFFERENT } from \"./DBC/EQ/DIFFERENT\";\n/** Demonstrative use of **D**esign **B**y **C**ontract Decorators */\nexport class Demo {\n    constructor() {\n        // #region Check Property Decorator\n        this.testProperty = \"a\";\n        // #endregion Check Static Method with ParamvalueProvider\n    }\n    // #endregion Check Property Decorator\n    // #region Check Parameter. & Returnvalue Decorator\n    testParamvalueAndReturnvalue(a) {\n        return `xxxx${a}`;\n    }\n    // #endregion Check Parameter. & Returnvalue Decorator\n    // #region Check Returnvalue Decorator\n    testReturnvalue(a) {\n        return a;\n    }\n    // #endregion Check Returnvalue Decorator\n    // #region Check EQ-DBC & Path to property of Parameter-value\n    testEQAndPath(o) { }\n    // #endregion Check EQ-DBC & Path to property of Parameter-value\n    // #region Check EQ-DBC & Path to property of Parameter-value with Inversion\n    testEQAndPathWithInversion(o) { }\n    // #endregion Check EQ-DBC & Path to property of Parameter-value with Inversion\n    // #region Check TYPE\n    testTYPE(o) { }\n    // #endregion Check TYPE\n    // #region Check AE\n    testAE(x) { }\n    // #endregion Check AE\n    // #region Check REGEX with AE\n    testREGEXWithAE(x) { }\n    // #endregion Check REGEX with AE\n    // #region Check INSTANCE\n    testINSTANCE(candidate) { }\n    // #endregion Check INSTANCE\n    // #region Check AE Range\n    testAERange(x) { }\n    // #endregion Check AE Range\n    // #region Check AE Index\n    testAEIndex(x) { }\n    // #endregion Check AE Index\n    // #region Check Comparison\n    testGREATER(input) { }\n    testGREATER_OR_EQUAL(input) { }\n    testLESS(input) { }\n    testLESS_OR_EQUAL(input) { }\n    testDIFFERENT(input) { }\n    // #endregion Check Comparison\n    // #region Check Static Method with ParamvalueProvider\n    static testStaticMethod(message, count) {\n        return `${message} repeated ${count} times`;\n    }\n}\n__decorate([\n    REGEX.INVARIANT(/^a$/),\n    __metadata(\"design:type\", Object)\n], Demo.prototype, \"testProperty\", void 0);\n__decorate([\n    REGEX.POST(/^xxxx.*$/),\n    DBC.ParamvalueProvider,\n    __param(0, REGEX.PRE(/holla*/g)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [String]),\n    __metadata(\"design:returntype\", String)\n], Demo.prototype, \"testParamvalueAndReturnvalue\", null);\n__decorate([\n    REGEX.POST(/^xxxx.*$/),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [String]),\n    __metadata(\"design:returntype\", String)\n], Demo.prototype, \"testReturnvalue\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, EQ.PRE(\"SELECT\", false, \"tagName\")),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [HTMLElement]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testEQAndPath\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, EQ.PRE(\"SELECT\", true, \"tagName\")),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [HTMLElement]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testEQAndPathWithInversion\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, TYPE.PRE(\"string\")),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Object]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testTYPE\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, AE.PRE([new TYPE(\"string\")])),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Array]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testAE\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, AE.PRE(new REGEX(/^(?i:(NOW)|([+-]\\d+[dmy]))$/i))),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Array]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testREGEXWithAE\", null);\n__decorate([\n    DBC.ParamvalueProvider\n    // biome-ignore lint/suspicious/noExplicitAny: Test\n    ,\n    __param(0, INSTANCE.PRE(Date)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Object]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testINSTANCE\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, AE.PRE([new TYPE(\"string\"), new REGEX(/^abc$/)], 1, 2)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Array]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testAERange\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, AE.PRE([new TYPE(\"string\"), new REGEX(/^abc$/)], 1)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Array]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testAEIndex\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, GREATER.PRE(2)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Number]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testGREATER\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, GREATER_OR_EQUAL.PRE(2)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Number]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testGREATER_OR_EQUAL\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, LESS.PRE(20)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Number]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testLESS\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, LESS_OR_EQUAL.PRE(20)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Number]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testLESS_OR_EQUAL\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, DIFFERENT.PRE(20)),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [Number]),\n    __metadata(\"design:returntype\", void 0)\n], Demo.prototype, \"testDIFFERENT\", null);\n__decorate([\n    DBC.ParamvalueProvider,\n    __param(0, TYPE.PRE(\"string\")),\n    __param(1, TYPE.PRE(\"number\")),\n    __metadata(\"design:type\", Function),\n    __metadata(\"design:paramtypes\", [String, Number]),\n    __metadata(\"design:returntype\", String)\n], Demo, \"testStaticMethod\", null);\nconst demo = new Demo();\ntry {\n    demo.testProperty = \"abd\";\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INVARIANT Infringement\", \"OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testProperty = \"a\";\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"INVARIANT OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ndemo.testParamvalueAndReturnvalue(\"holla\");\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"PARAMETER- & RETURNVALUE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testParamvalueAndReturnvalue(\"yyyy\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"PARAMETER- & RETURNVALUE Infringement\", \"OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testReturnvalue(\"xxxx\");\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"RETURNVALUE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testReturnvalue(\"yyyy\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"RETURNVALUE Infringement\", \"OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testEQAndPath(document.createElement(\"select\"));\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"EQ with Path Infringement OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testEQAndPathWithInversion(document.createElement(\"select\"));\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"EQ with Path and Inversion Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testTYPE(\"x\");\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"TYPE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testTYPE(0);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"TYPE Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testAE([\"11\", \"10\", \"b\"]);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"AE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testAE([\"11\", 11, \"b\"]);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"AE Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testREGEXWithAE([\"+1d\", \"NOW\", \"-10y\"]);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"REGEX with AE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testREGEXWithAE([\"+1d\", \"+5d\", \"-x10y\"]);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"REGEX with AE Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testINSTANCE(new Date());\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"INSTANCE OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testINSTANCE(demo);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INSTANCE Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testAERange([11, \"abc\", \"abc\"]);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"AE Range OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testAERange([11, \"abc\", /a/g]);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"AE Range Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testAEIndex([11, \"abc\", \"abc\"]);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"AE Index OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testAEIndex([\"11\", 12, \"/a/g\"]);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"AE Index Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testGREATER(11);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"GREATER OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testGREATER(2);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"GREATER Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testGREATER_OR_EQUAL(2);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"GREATER_OR_EQUAL OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testGREATER_OR_EQUAL(1);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"GREATER_OR_EQUAL Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testLESS(10);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"LESS OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testLESS(20);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"LESS Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testLESS_OR_EQUAL(20);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"LESS OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testLESS_OR_EQUAL(21);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"LESS_OR_EQUAL Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ndemo.testDIFFERENT(21);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"DIFFERENT OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    demo.testDIFFERENT(20);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"DIFFERENT Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\n// #region Inactivity Checks\nwindow.WaXCode.DBC.executionSettings.checkPreconditions = false;\ntry {\n    demo.testLESS_OR_EQUAL(21);\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE PRECONDITIONS OK\");\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE PRECONDITIONS FAILED\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\nwindow.WaXCode.DBC.executionSettings.checkPostconditions = false;\ntry {\n    demo.testReturnvalue(\"qqqqq\");\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE POSTCONDITIONS OK\");\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE POSTCONDITIONS FAILED\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\nwindow.WaXCode.DBC.executionSettings.checkInvariants = false;\ntry {\n    demo.testProperty = \"b\";\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE INVARIANTS OK\");\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"INACTIVE INVARIANTS FAILED\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\n// #endregion Inactivity Checks\n// Re-enable all checks for subsequent tests\nwindow.WaXCode.DBC.executionSettings.checkPreconditions = true;\nwindow.WaXCode.DBC.executionSettings.checkPostconditions = true;\nwindow.WaXCode.DBC.executionSettings.checkInvariants = true;\n// #region Static Method Test\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"TESTING STATIC METHOD WITH PARAMVALUEPROVIDER\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\nDemo.testStaticMethod(\"Hello\", 3);\nconsole.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\nconsole.log(\"STATIC METHOD OK\");\nconsole.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\ntry {\n    Demo.testStaticMethod(\"Hello\", \"not a number\");\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"STATIC METHOD Infringement OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\ntry {\n    Demo.testStaticMethod(123, 5);\n}\ncatch (X) {\n    console.log(\"⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄⌄\");\n    console.log(\"STATIC METHOD Infringement (first param) OK\");\n    console.log(X);\n    console.log(\"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\");\n}\n// #endregion Static Method Test\n"],"names":[],"sourceRoot":""}
package/package.json CHANGED
@@ -1,5 +1,5 @@
1
1
  {
2
- "version": "1.0.177",
2
+ "version": "1.0.178",
3
3
  "name": "xdbc",
4
4
  "scripts": {
5
5
  "docs": "typedoc",
package/src/DBC/IF.ts CHANGED
@@ -18,17 +18,17 @@ export class IF extends DBC {
18
18
  public static checkAlgorithm(
19
19
  // biome-ignore lint/suspicious/noExplicitAny: <explanation>
20
20
  toCheck: any,
21
- condition: {check: (toCheck: unknown | undefined | null | object) => boolean | string;},
22
- inCase:{
21
+ condition: { check: (toCheck: unknown | undefined | null | object) => boolean | string; },
22
+ inCase: {
23
23
  check: (toCheck: unknown | undefined | null | object) => boolean | string;
24
24
  },
25
25
  invert,
26
26
  ): boolean | string {
27
- if (!invert && condition.check(toCheck)&&!inCase.check(toCheck)) {
27
+ if (invert && !condition.check(toCheck) && !inCase.check(toCheck)) {
28
28
  return `In case that the value complies to "${condition}" it also has to comply to "${inCase}"`;
29
29
  }
30
30
 
31
- if (!invert && !condition.check(toCheck)&&!inCase.check(toCheck)) {
31
+ if (!invert && condition.check(toCheck) && !inCase.check(toCheck)) {
32
32
  return `In case that the value does not comply to "${condition}" it has to comply to "${inCase}"`;
33
33
  }
34
34
 
@@ -45,8 +45,8 @@ export class IF extends DBC {
45
45
  *
46
46
  * @returns See {@link DBC.decPrecondition }. */
47
47
  public static PRE(
48
- condition: {check: (toCheck: unknown | undefined | null | object) => boolean | string;},
49
- inCase: {check: (toCheck: unknown | undefined | null | object) => boolean | string;},
48
+ condition: { check: (toCheck: unknown | undefined | null | object) => boolean | string; },
49
+ inCase: { check: (toCheck: unknown | undefined | null | object) => boolean | string; },
50
50
  invert = false,
51
51
  path: string | undefined = undefined,
52
52
  dbc = "WaXCode.DBC",
@@ -79,8 +79,8 @@ export class IF extends DBC {
79
79
  *
80
80
  * @returns See {@link DBC.decPostcondition }. */
81
81
  public static POST(
82
- condition: {check: (toCheck: unknown | undefined | null | object) => boolean | string;},
83
- inCase: {check: (toCheck: unknown | undefined | null | object) => boolean | string;},
82
+ condition: { check: (toCheck: unknown | undefined | null | object) => boolean | string; },
83
+ inCase: { check: (toCheck: unknown | undefined | null | object) => boolean | string; },
84
84
  invert = false,
85
85
  path: string | undefined = undefined,
86
86
  dbc = "WaXCode.DBC",
@@ -108,8 +108,8 @@ export class IF extends DBC {
108
108
  *
109
109
  * @returns See {@link DBC.decInvariant }. */
110
110
  public static INVARIANT(
111
- condition: {check: (toCheck: unknown | undefined | null | object) => boolean | string;},
112
- inCase: {check: (toCheck: unknown | undefined | null | object) => boolean | string;},
111
+ condition: { check: (toCheck: unknown | undefined | null | object) => boolean | string; },
112
+ inCase: { check: (toCheck: unknown | undefined | null | object) => boolean | string; },
113
113
  invert = false,
114
114
  path: string | undefined = undefined,
115
115
  dbc = "WaXCode.DBC",
@@ -137,8 +137,8 @@ export class IF extends DBC {
137
137
  * @param equivalent See {@link IF.check }. */
138
138
  public constructor(
139
139
  // biome-ignore lint/suspicious/noExplicitAny: To be able to match UNDEFINED and NULL.
140
- protected condition: {check: (toCheck: unknown | undefined | null | object) => boolean | string;},
141
- protected inCase: {check: (toCheck: unknown | undefined | null | object) => boolean | string;},
140
+ protected condition: { check: (toCheck: unknown | undefined | null | object) => boolean | string; },
141
+ protected inCase: { check: (toCheck: unknown | undefined | null | object) => boolean | string; },
142
142
  protected invert = false,
143
143
  ) {
144
144
  super();
package/src/DBC.ts CHANGED
@@ -314,6 +314,7 @@ export class DBC {
314
314
  check: (unknown, object, string, number) => boolean | string,
315
315
  dbc: string,
316
316
  path: string | undefined = undefined,
317
+ hint: string | undefined = undefined,
317
318
  ): (
318
319
  target: object,
319
320
  methodName: string | symbol,
@@ -351,6 +352,7 @@ export class DBC {
351
352
  methodName as string,
352
353
  parameterIndex,
353
354
  realValue,
355
+ hint
354
356
  );
355
357
  }
356
358
  }
@@ -406,7 +408,7 @@ export class DBC {
406
408
  value: unknown,
407
409
  path: string,
408
410
  ): undefined {
409
- const finalMessage: string = `[ From "${violator}"${typeof target === "function" ? ` in "${target.name}"` : typeof target === "object" && target !== null && typeof target.constructor === "function" ? ` in "${target.constructor.name}"` : `in "${target === undefined ? "UNDEFINED" : target === null ? "NULL" : target}"`}${value ? ` >"${value}"` : ""}${value ? ` > "${path}"` : "UNDEFINED | NULL"}: ${message}]`;
411
+ const finalMessage: string = `[ From "${violator}"${typeof target === "function" ? ` in "${target.name}"` : typeof target === "object" && target !== null && typeof target.constructor === "function" ? ` in "${target.constructor.name}"` : `in "${target === undefined ? "UNDEFINED" : target === null ? "NULL" : target}"`}${value ? ` > "${path}"` : "UNDEFINED | NULL"}: ${message}]`;
410
412
 
411
413
  if (this.infringementSettings.throwException) {
412
414
  throw new DBC.Infringement(finalMessage);
@@ -431,11 +433,12 @@ export class DBC {
431
433
  method: string,
432
434
  index: number,
433
435
  value: unknown,
436
+ hint: string | undefined = undefined,
434
437
  ): undefined {
435
438
  const properIndex = index + 1;
436
439
 
437
440
  this.reportInfringement(
438
- `[ Parameter-value "${value}" of the ${properIndex}${properIndex === 1 ? "st" : properIndex === 2 ? "nd" : properIndex === 3 ? "rd" : "th"} parameter did not fulfill one of it's contracts: ${message}]`,
441
+ `[ Parameter-value "${value}" of the ${properIndex}${properIndex === 1 ? "st" : properIndex === 2 ? "nd" : properIndex === 3 ? "rd" : "th"} parameter did not fulfill one of it's contracts: ${message}. ${hint ? `✨ ${hint} ✨` : ""}]`,
439
442
  method,
440
443
  target,
441
444
  value,