From dd137e24e62962f1d5221bfd4ddbbd791e7cd6be Mon Sep 17 00:00:00 2001 From: benStre Date: Mon, 12 Feb 2024 23:12:12 +0100 Subject: [PATCH 1/3] handle destructuring in fn argument parsing --- js_adapter/js_class_adapter.ts | 55 ++++++++++++++++++++++++++-------- types/function.ts | 29 +++++++++++++++++- 2 files changed, 70 insertions(+), 14 deletions(-) diff --git a/js_adapter/js_class_adapter.ts b/js_adapter/js_class_adapter.ts index caf65f88..f56f445b 100644 --- a/js_adapter/js_class_adapter.ts +++ b/js_adapter/js_class_adapter.ts @@ -1150,26 +1150,31 @@ function getMethodParams(target:Function, method_name:string, meta_param_index?: if (!(method_name in target)) return null; - let tuple = new Tuple(); - let metadata:any[] = MetadataReflect.getMetadata && MetadataReflect.getMetadata("design:paramtypes", target, method_name); + const tuple = new Tuple(); + const metadata:any[] = MetadataReflect.getMetadata && MetadataReflect.getMetadata("design:paramtypes", target, method_name); if (!metadata) return null; // get parmeters names from function body string const function_body:string = target[method_name]?.toString(); - const args_strings = function_body?.match(/^[^(]*\(([^)]*)\)/)?.[1]?.split(","); - if (args_strings) { - for (let i=0;i any = (...args: any) => any> e const args_match = function_body?.match(/^[^(]*\(([^)]*)\)/)?.[1]; if (!args_match?.length) return tuple; - const args_strings = args_match.split(","); + console.log("normalize",args_match, function_body) + const args_strings = this.normalizeFunctionParams(args_match).split(","); if (args_strings) { for (let arg of args_strings) { arg = arg.trim().split(/[ =]/)[0]; @@ -244,6 +245,32 @@ export class Function any = (...args: any) => any> e return tuple; } + /** + * Normalizes a function params string, replacing destructuring with a single variable + */ + private static normalizeFunctionParams(params: string) { + let scopes = 0; + let nestedIndex = undefined; + + let i=0; + let varCount = 0; + for (const x of params) { + if (x === "["||x === "{") scopes++; + if (x === "]"||x === "}") scopes--; + if (nestedIndex == undefined && scopes !== 0) { + nestedIndex = i; + } + else if(nestedIndex != undefined && scopes == 0) { + params = [...params].toSpliced(nestedIndex, i-nestedIndex+1, 'x_'+(varCount++)).join("") + i = nestedIndex + nestedIndex = undefined; + } + i++; + } + + return params; + } + // execute this function remotely, set the endpoint private setRemoteEndpoint(endpoint: Endpoint){ From a1ed410bbdb65f6e63488985661e7e1738ab1eb9 Mon Sep 17 00:00:00 2001 From: benStre Date: Mon, 12 Feb 2024 23:12:30 +0100 Subject: [PATCH 2/3] send reports to correct endpoint --- utils/error-reporting.ts | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/utils/error-reporting.ts b/utils/error-reporting.ts index 3ebd8bbe..9676f820 100644 --- a/utils/error-reporting.ts +++ b/utils/error-reporting.ts @@ -1,6 +1,7 @@ import { Compiler } from "../compiler/compiler.ts"; import { sendDatexViaHTTPChannel } from "../network/datex-http-channel.ts"; import { Runtime } from "../runtime/runtime.ts"; +import { LOCAL_ENDPOINT } from "../types/addressing.ts"; import { getCallerInfo } from "../utils/caller_metadata.ts"; import { logger } from "./global_values.ts"; @@ -24,7 +25,7 @@ export async function sendReport(identifier: string, reportData:Record await Compiler.compile(dx, [report], {sign: false, encrypt: false}); + const dxb = await Compiler.compile(dx, [report], {sign: false, encrypt: false, to: LOCAL_ENDPOINT}); sendDatexViaHTTPChannel(dxb, "https://status.unyt.org") } From 8b04800bd24a6ecb800513d4ac0e7b6879d6dab0 Mon Sep 17 00:00:00 2001 From: benStre Date: Mon, 12 Feb 2024 23:13:49 +0100 Subject: [PATCH 3/3] remove debug log --- types/function.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/types/function.ts b/types/function.ts index cefc66b4..aba7ceef 100644 --- a/types/function.ts +++ b/types/function.ts @@ -225,7 +225,6 @@ export class Function any = (...args: any) => any> e const args_match = function_body?.match(/^[^(]*\(([^)]*)\)/)?.[1]; if (!args_match?.length) return tuple; - console.log("normalize",args_match, function_body) const args_strings = this.normalizeFunctionParams(args_match).split(","); if (args_strings) { for (let arg of args_strings) {