From 7a853d21b973d5005c9f4971e5ba81a78addf41f Mon Sep 17 00:00:00 2001 From: AlanWalk <4654826+alanwalk@users.noreply.github.com> Date: Thu, 12 Dec 2024 10:57:48 +0800 Subject: [PATCH] =?UTF-8?q?[unity]=E6=B7=BB=E5=8A=A0=20webgl=20GetJSStackT?= =?UTF-8?q?race=20=E5=AE=9E=E7=8E=B0=20(#1943)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../upm/Javascripts~/PuertsDLLMock/dist/puerts-runtime.js | 7 +++++-- unity/Assets/webgl/upm/Javascripts~/PuertsDLLMock/index.ts | 3 +++ 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/unity/Assets/webgl/upm/Javascripts~/PuertsDLLMock/dist/puerts-runtime.js b/unity/Assets/webgl/upm/Javascripts~/PuertsDLLMock/dist/puerts-runtime.js index e98717eac94..8d89602e42d 100644 --- a/unity/Assets/webgl/upm/Javascripts~/PuertsDLLMock/dist/puerts-runtime.js +++ b/unity/Assets/webgl/upm/Javascripts~/PuertsDLLMock/dist/puerts-runtime.js @@ -1275,7 +1275,7 @@ exports["default"] = WebGLBackendSetToJSOutArgumentAPI; /******/ /************************************************************************/ var __webpack_exports__ = {}; -// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk. +// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. (() => { var exports = __webpack_exports__; /*!*************************!*\ @@ -1493,6 +1493,9 @@ library_1.global.PuertsWebGL = { InspectorTick: function (isolate) { }, LogicTick: function (isolate) { }, SetLogCallback: function (log, logWarning, logError) { + }, + GetJSStackTrace: function (isolate) { + return new Error().stack; } }); } @@ -1502,4 +1505,4 @@ library_1.global.PuertsWebGL = { /******/ })() ; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"puerts-runtime.js","mappings":";;;;;;;;;;AAAa;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,oBAAoB,GAAG,gBAAgB,GAAG,oBAAoB,GAAG,qBAAqB,GAAG,kBAAkB,GAAG,eAAe,GAAG,sBAAsB,GAAG,kBAAkB,GAAG,qBAAqB,GAAG,cAAc,GAAG,uBAAuB,GAAG,iCAAiC,GAAG,gBAAgB,GAAG,kBAAkB,GAAG,sCAAsC,GAAG,4BAA4B;AAClY;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B;AAC5B;AACA;AACA,yBAAyB;AACzB,iCAAiC;AACjC,kBAAkB;AAClB,iCAAiC;AACjC;AACA,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA,6CAA6C;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA,8FAA8F;AAC9F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kGAAkG;AAClG;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,yCAAyC;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA,cAAc,GAAG,qBAAM,GAAG,qBAAM;AAChC,qBAAM,UAAU,qBAAM;AACtB;AACA;AACA;AACA;AACA;AACA,yBAAyB,UAAU;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,qBAAM;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,iDAAiD;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,uPAAuP;AACvQ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,qBAAM,2DAA2D;AACzE,QAAQ,qBAAM;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,qBAAM;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA,oBAAoB;AACpB;AACA;AACA;AACA,gBAAgB;AAChB;AACA,wDAAwD;AACxD,wCAAwC;AACxC;AACA,oBAAoB;AACpB;AACA,mEAAmE;AACnE,gEAAgE;AAChE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;AC7pBa;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,kBAAe;AACf;;;;;;;;;;AC5Ha;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,kBAAe;AACf;;;;;;;;;;AC3Ea;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD,iCAAiC;AACnF,kDAAkD,WAAW;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,kBAAe;AACf;;;;;;;;;;AC1Ha;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,kBAAe;AACf;;;;;;;;;;ACxDa;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,4CAA4C;AAC5C,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,kBAAe;AACf;;;;;;;;;;ACpEa;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,0BAA0B;AAC1B,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,2BAA2B;AAC3B,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,kBAAe;AACf;;;;;;UChDA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA,GAAG;WACH;WACA;WACA,CAAC;;;;;;;;;;;ACPY;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,mBAAO,CAAC,sCAAW;AACrC,4BAA4B,mBAAO,CAAC,wEAA4B;AAChE,0BAA0B,mBAAO,CAAC,oEAA0B;AAC5D,mBAAmB,mBAAO,CAAC,sDAAmB;AAC9C,gCAAgC,mBAAO,CAAC,gFAAgC;AACxE,8BAA8B,mBAAO,CAAC,4EAA8B;AACpE,6BAA6B,mBAAO,CAAC,0EAA6B;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,0DAA0D;AAC1D,4CAA4C;AAC5C;AACA;AACA,aAAa;AACb,yDAAyD;AACzD,4DAA4D;AAC5D,2EAA2E;AAC3E,0EAA0E;AAC1E;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+GAA+G,KAAK;AACpH;AACA;AACA;AACA,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA,aAAa;AACb;AACA;AACA;AACA,iBAAiB;AACjB;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;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,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb,6CAA6C;AAC7C,yDAAyD;AACzD,oDAAoD;AACpD,iDAAiD;AACjD,6CAA6C;AAC7C;AACA;AACA,SAAS;AACT;AACA;AACA,iC","sources":["webpack:///./output/library.js","webpack:///./output/mixins/getFromJSArgument.js","webpack:///./output/mixins/getFromJSReturn.js","webpack:///./output/mixins/register.js","webpack:///./output/mixins/setToInvokeJSArgument.js","webpack:///./output/mixins/setToJSInvokeReturn.js","webpack:///./output/mixins/setToJSOutArgument.js","webpack:///webpack/bootstrap","webpack:///webpack/runtime/global","webpack:///./output/index.js"],"sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.returnBigInt = exports.isBigInt = exports.setOutValue8 = exports.setOutValue32 = exports.makeBigInt = exports.GetType = exports.PuertsJSEngine = exports.OnFinalize = exports.createWeakRef = exports.global = exports.CSharpObjectMap = exports.jsFunctionOrObjectFactory = exports.JSObject = exports.JSFunction = exports.FunctionCallbackInfoPtrManager = exports.FunctionCallbackInfo = void 0;\n/**\n * 一次函数调用的info\n * 对应v8::FunctionCallbackInfo\n */\nclass FunctionCallbackInfo {\n    args;\n    returnValue;\n    stack = 0;\n    constructor(args) {\n        this.args = args;\n    }\n    recycle() {\n        this.stack = 0;\n        this.args = null;\n        this.returnValue = void 0;\n    }\n}\nexports.FunctionCallbackInfo = FunctionCallbackInfo;\n// struct MockV8Value\n// {\n//     int JSValueType;  // 0\n//     int FinalValuePointer[2]; // 1 2 if value is bigint FinalValuePointer[0] for low, FinalValuePointer[1] for high\n//     int extra; // 3\n//     int FunctionCallbackInfo; // 4\n// };\nconst ArgumentValueLengthIn32 = 4; // int count\n/**\n * 把FunctionCallbackInfo以及其参数转化为c#可用的intptr\n */\nclass FunctionCallbackInfoPtrManager {\n    // FunctionCallbackInfo的列表，以列表的index作为IntPtr的值\n    infos = [new FunctionCallbackInfo([0])]; // 这里原本只是个普通的0\n    // FunctionCallbackInfo用完后，将其序号放入“回收列表”，下次就能继续服用该index，而不必让infos数组无限扩展下去\n    freeInfosIndex = [];\n    freeCallbackInfoMemoryByLength = {};\n    freeRefMemory = [];\n    engine;\n    constructor(engine) {\n        this.engine = engine;\n    }\n    allocCallbackInfoMemory(argsLength) {\n        const cacheArray = this.freeCallbackInfoMemoryByLength[argsLength];\n        if (cacheArray && cacheArray.length) {\n            return cacheArray.pop();\n        }\n        else {\n            return this.engine.unityApi._malloc((argsLength * ArgumentValueLengthIn32 + 1) << 2);\n        }\n    }\n    allocRefMemory() {\n        if (this.freeRefMemory.length)\n            return this.freeRefMemory.pop();\n        return this.engine.unityApi._malloc(ArgumentValueLengthIn32 << 2);\n    }\n    recycleRefMemory(bufferPtr) {\n        if (this.freeRefMemory.length > 20) {\n            this.engine.unityApi._free(bufferPtr);\n        }\n        else {\n            this.freeRefMemory.push(bufferPtr);\n        }\n    }\n    recycleCallbackInfoMemory(bufferPtr, args) {\n        const argsLength = args.length;\n        if (!this.freeCallbackInfoMemoryByLength[argsLength] && argsLength < 5) {\n            this.freeCallbackInfoMemoryByLength[argsLength] = [];\n        }\n        const cacheArray = this.freeCallbackInfoMemoryByLength[argsLength];\n        if (!cacheArray)\n            return;\n        const bufferPtrIn32 = bufferPtr << 2;\n        for (let i = 0; i < argsLength; ++i) {\n            if (args[i] instanceof Array && args[i].length == 1) {\n                this.recycleRefMemory(this.engine.unityApi.HEAP32[bufferPtrIn32 + i * ArgumentValueLengthIn32 + 1]);\n            }\n        }\n        // 拍脑袋定的最大缓存个数大小。 50 - 参数个数 * 10\n        if (cacheArray.length > (50 - argsLength * 10)) {\n            this.engine.unityApi._free(bufferPtr);\n        }\n        else {\n            cacheArray.push(bufferPtr);\n        }\n    }\n    /**\n     * intptr的格式为id左移四位\n     *\n     * 右侧四位，是为了在右四位存储参数的序号，这样可以用于表示callbackinfo参数的intptr\n     */\n    // static GetMockPointer(args: any[]): MockIntPtr {\n    //     let index: number;\n    //     index = this.freeInfosIndex.pop();\n    //     // index最小为1\n    //     if (index) {\n    //         this.infos[index].args = args;\n    //     } else {\n    //         index = this.infos.push(new FunctionCallbackInfo(args)) - 1;\n    //     }\n    //     return index << 4;\n    // }\n    GetMockPointer(args) {\n        const argsLength = args.length;\n        let bufferPtrIn8 = this.allocCallbackInfoMemory(argsLength);\n        let index = this.freeInfosIndex.pop();\n        let functionCallbackInfo;\n        // index最小为1\n        if (index) {\n            (functionCallbackInfo = this.infos[index]).args = args;\n        }\n        else {\n            index = this.infos.push(functionCallbackInfo = new FunctionCallbackInfo(args)) - 1;\n        }\n        let unityApi = this.engine.unityApi;\n        const bufferPtrIn32 = bufferPtrIn8 >> 2;\n        unityApi.HEAP32[bufferPtrIn32] = index;\n        for (let i = 0; i < argsLength; i++) {\n            let arg = args[i];\n            // init each value\n            const jsValueType = GetType(this.engine, arg);\n            const jsValuePtr = bufferPtrIn32 + i * ArgumentValueLengthIn32 + 1;\n            unityApi.HEAP32[jsValuePtr] = jsValueType; // jsvaluetype\n            if (jsValueType == 2 || jsValueType == 4 || jsValueType == 512) {\n                // bigint、number or date\n                $FillArgumentFinalNumberValue(this.engine, arg, jsValueType, jsValuePtr + 1); // value\n            }\n            else if (jsValueType == 8) {\n                if (functionCallbackInfo.stack == 0) {\n                    functionCallbackInfo.stack = unityApi.stackSave();\n                }\n                unityApi.HEAP32[jsValuePtr + 1] = $GetArgumentFinalValue(this.engine, arg, jsValueType, (jsValuePtr + 2) << 2);\n            }\n            else if (jsValueType == 64 && arg instanceof Array && arg.length == 1) {\n                // maybe a ref\n                unityApi.HEAP32[jsValuePtr + 1] = $GetArgumentFinalValue(this.engine, arg, jsValueType, 0);\n                const refPtrIn8 = unityApi.HEAP32[jsValuePtr + 2] = this.allocRefMemory();\n                const refPtr = refPtrIn8 >> 2;\n                const refValueType = unityApi.HEAP32[refPtr] = GetType(this.engine, arg[0]);\n                if (refValueType == 2 || refValueType == 4 || refValueType == 512) {\n                    // number or date\n                    $FillArgumentFinalNumberValue(this.engine, arg[0], refValueType, refPtr + 1); // value\n                }\n                else {\n                    unityApi.HEAP32[refPtr + 1] = $GetArgumentFinalValue(this.engine, arg[0], refValueType, (refPtr + 2) << 2);\n                }\n                unityApi.HEAP32[refPtr + 3] = bufferPtrIn8; // a pointer to the info\n            }\n            else {\n                // other\n                unityApi.HEAP32[jsValuePtr + 1] = $GetArgumentFinalValue(this.engine, arg, jsValueType, (jsValuePtr + 2) << 2);\n            }\n            unityApi.HEAP32[jsValuePtr + 3] = bufferPtrIn8; // a pointer to the info\n        }\n        return bufferPtrIn8;\n    }\n    // static GetByMockPointer(intptr: MockIntPtr): FunctionCallbackInfo {\n    //     return this.infos[intptr >> 4];\n    // }\n    GetByMockPointer(ptrIn8) {\n        const ptrIn32 = ptrIn8 >> 2;\n        const index = this.engine.unityApi.HEAP32[ptrIn32];\n        return this.infos[index];\n    }\n    GetReturnValueAndRecycle(ptrIn8) {\n        const ptrIn32 = ptrIn8 >> 2;\n        const index = this.engine.unityApi.HEAP32[ptrIn32];\n        let info = this.infos[index];\n        let ret = info.returnValue;\n        this.recycleCallbackInfoMemory(ptrIn8, info.args);\n        if (info.stack) {\n            this.engine.unityApi.stackRestore(info.stack);\n        }\n        info.recycle();\n        this.freeInfosIndex.push(index);\n        return ret;\n    }\n    ReleaseByMockIntPtr(ptrIn8) {\n        const ptrIn32 = ptrIn8 >> 2;\n        const index = this.engine.unityApi.HEAP32[ptrIn32];\n        let info = this.infos[index];\n        this.recycleCallbackInfoMemory(ptrIn8, info.args);\n        if (info.stack) {\n            this.engine.unityApi.stackRestore(info.stack);\n        }\n        info.recycle();\n        this.freeInfosIndex.push(index);\n    }\n    GetArgsByMockIntPtr(valuePtrIn8) {\n        let heap32 = this.engine.unityApi.HEAP32;\n        const infoPtrIn8 = heap32[(valuePtrIn8 >> 2) + 3];\n        const callbackInfoIndex = heap32[infoPtrIn8 >> 2];\n        const argsIndex = (valuePtrIn8 - infoPtrIn8 - 4) / (4 * ArgumentValueLengthIn32);\n        return this.infos[callbackInfoIndex].args[argsIndex];\n    }\n}\nexports.FunctionCallbackInfoPtrManager = FunctionCallbackInfoPtrManager;\n/**\n * 代表一个JSFunction\n */\nclass JSFunction {\n    _func;\n    id;\n    args = [];\n    lastException = null;\n    constructor(id, func) {\n        this._func = func;\n        this.id = id;\n    }\n    invoke() {\n        var args = [...this.args];\n        this.args.length = 0;\n        return this._func.apply(this, args);\n    }\n}\nexports.JSFunction = JSFunction;\n/**\n * 代表一个JSObject\n */\nclass JSObject {\n    _obj;\n    id;\n    constructor(id, obj) {\n        this._obj = obj;\n        this.id = id;\n    }\n    getObject() {\n        return this._obj;\n    }\n}\nexports.JSObject = JSObject;\nclass jsFunctionOrObjectFactory {\n    static regularID = 1;\n    static freeID = [];\n    static idMap = new WeakMap();\n    static jsFuncOrObjectKV = {};\n    static getOrCreateJSFunction(funcValue) {\n        let id = jsFunctionOrObjectFactory.idMap.get(funcValue);\n        if (id) {\n            return jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\n        }\n        if (this.freeID.length) {\n            id = this.freeID.pop();\n        }\n        else {\n            id = jsFunctionOrObjectFactory.regularID++;\n        }\n        const func = new JSFunction(id, funcValue);\n        jsFunctionOrObjectFactory.idMap.set(funcValue, id);\n        jsFunctionOrObjectFactory.jsFuncOrObjectKV[id] = func;\n        return func;\n    }\n    static getOrCreateJSObject(obj) {\n        let id = jsFunctionOrObjectFactory.idMap.get(obj);\n        if (id) {\n            return jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\n        }\n        if (this.freeID.length) {\n            id = this.freeID.pop();\n        }\n        else {\n            id = jsFunctionOrObjectFactory.regularID++;\n        }\n        const jsObject = new JSObject(id, obj);\n        jsFunctionOrObjectFactory.idMap.set(obj, id);\n        jsFunctionOrObjectFactory.jsFuncOrObjectKV[id] = jsObject;\n        return jsObject;\n    }\n    static getJSObjectById(id) {\n        return jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\n    }\n    static removeJSObjectById(id) {\n        const jsObject = jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\n        if (!jsObject)\n            return console.warn('removeJSObjectById failed: id is invalid: ' + id);\n        jsFunctionOrObjectFactory.idMap.delete(jsObject.getObject());\n        delete jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\n        this.freeID.push(id);\n    }\n    static getJSFunctionById(id) {\n        return jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\n    }\n    static removeJSFunctionById(id) {\n        const jsFunc = jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\n        if (!jsFunc)\n            return console.warn('removeJSFunctionById failed: id is invalid: ' + id);\n        jsFunctionOrObjectFactory.idMap.delete(jsFunc._func);\n        delete jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\n        this.freeID.push(id);\n    }\n}\nexports.jsFunctionOrObjectFactory = jsFunctionOrObjectFactory;\n/**\n * CSharp对象记录表，记录所有CSharp对象并分配id\n * 和puerts.dll所做的一样\n */\nclass CSharpObjectMap {\n    classes = [null];\n    nativeObjectKV = new Map();\n    // private nativeObjectKV: { [objectID: CSIdentifier]: WeakRef<any> } = {};\n    // private csIDWeakMap: WeakMap<any, CSIdentifier> = new WeakMap();\n    namesToClassesID = {};\n    classIDWeakMap = new WeakMap();\n    constructor() {\n        this._memoryDebug && setInterval(() => {\n            console.log('addCalled', this.addCalled);\n            console.log('removeCalled', this.removeCalled);\n            console.log('wr', this.nativeObjectKV.size);\n        }, 1000);\n    }\n    _memoryDebug = false;\n    addCalled = 0;\n    removeCalled = 0;\n    add(csID, obj) {\n        this._memoryDebug && this.addCalled++;\n        // this.nativeObjectKV[csID] = createWeakRef(obj);\n        // this.csIDWeakMap.set(obj, csID);\n        this.nativeObjectKV.set(csID, createWeakRef(obj));\n        obj['$csid'] = csID;\n    }\n    remove(csID) {\n        this._memoryDebug && this.removeCalled++;\n        // delete this.nativeObjectKV[csID];\n        this.nativeObjectKV.delete(csID);\n    }\n    findOrAddObject(csID, classID) {\n        let ret = this.nativeObjectKV.get(csID);\n        // let ret = this.nativeObjectKV[csID];\n        if (ret && (ret = ret.deref())) {\n            return ret;\n        }\n        ret = this.classes[classID].createFromCS(csID);\n        // this.add(csID, ret); 构造函数里负责调用\n        return ret;\n    }\n    getCSIdentifierFromObject(obj) {\n        // return this.csIDWeakMap.get(obj);\n        return obj ? obj.$csid : 0;\n    }\n}\nexports.CSharpObjectMap = CSharpObjectMap;\n;\nvar destructors = {};\nexports.global = global = global || globalThis || window;\nglobal.global = global;\nconst createWeakRef = (function () {\n    if (typeof WeakRef == 'undefined') {\n        if (typeof WXWeakRef == 'undefined') {\n            console.error(\"WeakRef is not defined. maybe you should use newer environment\");\n            return function (obj) {\n                return { deref() { return obj; } };\n            };\n        }\n        console.warn(\"using WXWeakRef\");\n        return function (obj) {\n            return new WXWeakRef(obj);\n        };\n    }\n    return function (obj) {\n        return new WeakRef(obj);\n    };\n})();\nexports.createWeakRef = createWeakRef;\nclass FinalizationRegistryMock {\n    _handler;\n    refs = [];\n    helds = [];\n    availableIndex = [];\n    constructor(handler) {\n        console.warn(\"FinalizationRegister is not defined. using FinalizationRegistryMock\");\n        global._puerts_registry = this;\n        this._handler = handler;\n    }\n    register(obj, heldValue) {\n        if (this.availableIndex.length) {\n            const index = this.availableIndex.pop();\n            this.refs[index] = createWeakRef(obj);\n            this.helds[index] = heldValue;\n        }\n        else {\n            this.refs.push(createWeakRef(obj));\n            this.helds.push(heldValue);\n        }\n    }\n    /**\n     * 清除可能已经失效的WeakRef\n     */\n    iteratePosition = 0;\n    cleanup(part = 1) {\n        const stepCount = this.refs.length / part;\n        let i = this.iteratePosition;\n        for (let currentStep = 0; i < this.refs.length && currentStep < stepCount; i = (i == this.refs.length - 1 ? 0 : i + 1), currentStep++) {\n            if (this.refs[i] == null) {\n                continue;\n            }\n            if (!this.refs[i].deref()) {\n                // 目前没有内存整理能力，如果游戏中期ref很多但后期少了，这里就会白费遍历次数\n                // 但遍历也只是一句==和continue，浪费影响不大\n                this.availableIndex.push(i);\n                this.refs[i] = null;\n                try {\n                    this._handler(this.helds[i]);\n                }\n                catch (e) {\n                    console.error(e);\n                }\n            }\n        }\n        this.iteratePosition = i;\n    }\n}\nvar registry = null;\nfunction init() {\n    registry = new (typeof FinalizationRegistry == 'undefined' ? FinalizationRegistryMock : FinalizationRegistry)(function (heldValue) {\n        var callback = destructors[heldValue];\n        if (!callback) {\n            throw new Error(\"cannot find destructor for \" + heldValue);\n        }\n        if (--callback.ref == 0) {\n            delete destructors[heldValue];\n            callback(heldValue);\n        }\n    });\n}\nfunction OnFinalize(obj, heldValue, callback) {\n    if (!registry) {\n        init();\n    }\n    let originCallback = destructors[heldValue];\n    if (originCallback) {\n        // WeakRef内容释放时机可能比finalizationRegistry的触发更早，前面如果发现weakRef为空会重新创建对象\n        // 但之前对象的finalizationRegistry最终又肯定会触发。\n        // 所以如果遇到这个情况，需要给destructor加计数\n        ++originCallback.ref;\n    }\n    else {\n        callback.ref = 1;\n        destructors[heldValue] = callback;\n    }\n    registry.register(obj, heldValue);\n}\nexports.OnFinalize = OnFinalize;\nclass PuertsJSEngine {\n    csharpObjectMap;\n    functionCallbackInfoPtrManager;\n    unityApi;\n    /** 字符串缓存，默认为256字节 */\n    strBuffer;\n    stringBufferSize = 256;\n    lastReturnCSResult = null;\n    lastException = null;\n    // 这两个是Puerts用的的真正的CSharp函数指针\n    GetJSArgumentsCallback;\n    generalDestructor;\n    constructor(ctorParam) {\n        this.csharpObjectMap = new CSharpObjectMap();\n        this.functionCallbackInfoPtrManager = new FunctionCallbackInfoPtrManager(this);\n        const { UTF8ToString, _malloc, _free, _setTempRet0, stringToUTF8, lengthBytesUTF8, stackSave, stackRestore, stackAlloc, _CallCSharpFunctionCallback, _CallCSharpConstructorCallback, _CallCSharpDestructorCallback, HEAP8, HEAPU8, HEAP32, HEAPF32, HEAPF64, } = ctorParam;\n        this.strBuffer = _malloc(this.stringBufferSize);\n        this.unityApi = {\n            UTF8ToString,\n            _malloc,\n            _free,\n            _setTempRet0,\n            stringToUTF8,\n            lengthBytesUTF8,\n            stackSave,\n            stackRestore,\n            stackAlloc,\n            _CallCSharpFunctionCallback,\n            _CallCSharpConstructorCallback,\n            _CallCSharpDestructorCallback,\n            HEAP8,\n            HEAPU8,\n            HEAP32,\n            HEAPF32,\n            HEAPF64,\n        };\n        global.__tgjsEvalScript = typeof eval == \"undefined\" ? () => { } : eval;\n        global.__tgjsSetPromiseRejectCallback = function (callback) {\n            if (typeof wx != 'undefined') {\n                wx.onUnhandledRejection(callback);\n            }\n            else {\n                window.addEventListener(\"unhandledrejection\", callback);\n            }\n        };\n        global.__puertsGetLastException = () => {\n            return this.lastException;\n        };\n    }\n    /** call when wasm grow memory */\n    updateGlobalBufferAndViews(HEAP8, HEAPU8, HEAP32, HEAPF32, HEAPF64) {\n        let unityApi = this.unityApi;\n        unityApi.HEAP8 = HEAP8;\n        unityApi.HEAPU8 = HEAPU8;\n        unityApi.HEAP32 = HEAP32;\n        unityApi.HEAPF32 = HEAPF32;\n        unityApi.HEAPF64 = HEAPF64;\n    }\n    memcpy(dest, src, num) {\n        this.unityApi.HEAPU8.copyWithin(dest, src, src + num);\n    }\n    JSStringToCSString(returnStr, /** out int */ lengthOffset) {\n        if (returnStr === null || returnStr === undefined) {\n            return 0;\n        }\n        var byteCount = this.unityApi.lengthBytesUTF8(returnStr);\n        setOutValue32(this, lengthOffset, byteCount);\n        let buffer = this.unityApi._malloc(byteCount + 1);\n        this.unityApi.stringToUTF8(returnStr, buffer, byteCount + 1);\n        return buffer;\n    }\n    JSStringToTempCSString(returnStr, /** out int */ lengthOffset) {\n        if (returnStr === null || returnStr === undefined) {\n            return 0;\n        }\n        var byteCount = this.unityApi.lengthBytesUTF8(returnStr);\n        setOutValue32(this, lengthOffset, byteCount);\n        if (this.stringBufferSize < byteCount + 1) {\n            this.unityApi._free(this.strBuffer);\n            this.strBuffer = this.unityApi._malloc(this.stringBufferSize = Math.max(2 * this.stringBufferSize, byteCount + 1));\n        }\n        this.unityApi.stringToUTF8(returnStr, this.strBuffer, byteCount + 1);\n        return this.strBuffer;\n    }\n    JSStringToCSStringOnStack(returnStr, /** out int */ lengthOffset) {\n        if (returnStr === null || returnStr === undefined) {\n            return 0;\n        }\n        var byteCount = this.unityApi.lengthBytesUTF8(returnStr);\n        setOutValue32(this, lengthOffset, byteCount);\n        var buffer = this.unityApi.stackAlloc(byteCount + 1);\n        this.unityApi.stringToUTF8(returnStr, buffer, byteCount + 1);\n        return buffer;\n    }\n    makeCSharpFunctionCallbackFunction(isStatic, functionPtr, callbackIdx) {\n        // 不能用箭头函数！此处返回的函数会赋值到具体的class上，其this指针有含义。\n        const engine = this;\n        return function (...args) {\n            let callbackInfoPtr = engine.functionCallbackInfoPtrManager.GetMockPointer(args);\n            try {\n                engine.callCSharpFunctionCallback(functionPtr, \n                // getIntPtrManager().GetPointerForJSValue(this),\n                isStatic ? 0 : engine.csharpObjectMap.getCSIdentifierFromObject(this), callbackInfoPtr, args.length, callbackIdx);\n                return engine.functionCallbackInfoPtrManager.GetReturnValueAndRecycle(callbackInfoPtr);\n            }\n            catch (e) {\n                engine.functionCallbackInfoPtrManager.ReleaseByMockIntPtr(callbackInfoPtr);\n                throw e;\n            }\n        };\n    }\n    callCSharpFunctionCallback(functionPtr, selfPtr, infoIntPtr, paramLen, callbackIdx) {\n        this.unityApi._CallCSharpFunctionCallback(functionPtr, infoIntPtr, selfPtr, paramLen, callbackIdx);\n    }\n    callCSharpConstructorCallback(functionPtr, infoIntPtr, paramLen, callbackIdx) {\n        return this.unityApi._CallCSharpConstructorCallback(functionPtr, infoIntPtr, paramLen, callbackIdx);\n    }\n    callCSharpDestructorCallback(functionPtr, selfPtr, callbackIdx) {\n        this.unityApi._CallCSharpDestructorCallback(functionPtr, selfPtr, callbackIdx);\n    }\n}\nexports.PuertsJSEngine = PuertsJSEngine;\nfunction GetType(engine, value) {\n    if (value === null || value === undefined) {\n        return 1;\n    }\n    if (isBigInt(value)) {\n        return 2;\n    }\n    if (typeof value == 'number') {\n        return 4;\n    }\n    if (typeof value == 'string') {\n        return 8;\n    }\n    if (typeof value == 'boolean') {\n        return 16;\n    }\n    if (typeof value == 'function') {\n        return 256;\n    }\n    if (value instanceof Date) {\n        return 512;\n    }\n    // if (value instanceof Array) { return 128 }\n    if (value instanceof Array) {\n        return 64;\n    }\n    if (value instanceof ArrayBuffer || value instanceof Uint8Array) {\n        return 1024;\n    }\n    if (engine.csharpObjectMap.getCSIdentifierFromObject(value)) {\n        return 32;\n    }\n    return 64;\n}\nexports.GetType = GetType;\nfunction makeBigInt(low, high) {\n    return (BigInt(high) << 32n) | BigInt(low >>> 0);\n}\nexports.makeBigInt = makeBigInt;\nfunction setOutValue32(engine, valuePtr, value) {\n    engine.unityApi.HEAP32[valuePtr >> 2] = value;\n}\nexports.setOutValue32 = setOutValue32;\nfunction setOutValue8(engine, valuePtr, value) {\n    engine.unityApi.HEAP8[valuePtr] = value;\n}\nexports.setOutValue8 = setOutValue8;\nfunction isBigInt(value) {\n    return value instanceof BigInt || typeof value === 'bigint';\n}\nexports.isBigInt = isBigInt;\nfunction returnBigInt(engine, value) {\n    engine.unityApi._setTempRet0(Number(value >> 32n)); // high\n    return Number(value & 0xffffffffn); // low\n}\nexports.returnBigInt = returnBigInt;\nfunction writeBigInt(engine, ptrIn32, value) {\n    engine.unityApi.HEAP32[ptrIn32] = Number(value & 0xffffffffn); // low\n    engine.unityApi.HEAP32[ptrIn32 + 1] = Number(value >> 32n); // high\n}\nconst tmpInt3Arr = new Int32Array(2);\nconst tmpFloat64Arr = new Float64Array(tmpInt3Arr.buffer);\nfunction writeNumber(engine, ptrIn32, value) {\n    // number in js is double\n    tmpFloat64Arr[0] = value;\n    engine.unityApi.HEAP32[ptrIn32] = tmpInt3Arr[0];\n    engine.unityApi.HEAP32[ptrIn32 + 1] = tmpInt3Arr[1];\n}\nfunction $FillArgumentFinalNumberValue(engine, val, jsValueType, valPtrIn32) {\n    if (val === null || val === undefined) {\n        return;\n    }\n    switch (jsValueType) {\n        case 2:\n            writeBigInt(engine, valPtrIn32, val);\n            break;\n        case 4:\n            writeNumber(engine, valPtrIn32, +val);\n            break;\n        case 512:\n            writeNumber(engine, valPtrIn32, val.getTime());\n            break;\n    }\n}\nfunction $GetArgumentFinalValue(engine, val, jsValueType, lengthOffset) {\n    if (!jsValueType)\n        jsValueType = GetType(engine, val);\n    switch (jsValueType) {\n        case 8: return engine.JSStringToCSStringOnStack(val, lengthOffset);\n        case 16: return +val;\n        case 32: return engine.csharpObjectMap.getCSIdentifierFromObject(val);\n        case 64: return jsFunctionOrObjectFactory.getOrCreateJSObject(val).id;\n        case 128: return jsFunctionOrObjectFactory.getOrCreateJSObject(val).id;\n        case 256: return jsFunctionOrObjectFactory.getOrCreateJSFunction(val).id;\n        case 1024: {\n            if (val instanceof ArrayBuffer)\n                val = new Uint8Array(val);\n            let ptr = engine.unityApi._malloc(val.byteLength);\n            engine.unityApi.HEAPU8.set(val, ptr);\n            setOutValue32(engine, lengthOffset, val.byteLength);\n            return ptr;\n        }\n    }\n}\n//# sourceMappingURL=library.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst library_1 = require(\"../library\");\n// export function GetNumberFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool): number {\n//     return engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n// }\n// export function GetDateFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool): number {\n//     return (engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value) as Date).getTime();\n// }\n// export function GetStringFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, /*out int */lengthOffset: number, isByRef: bool): number {\n//     var returnStr = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<string>(value);\n//     return engine.JSStringToCSString(returnStr, lengthOffset);\n// }\n// export function GetBooleanFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool): boolean {\n//     return engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n// }\n// export function ValueIsBigInt(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool): boolean {\n//     var bigint = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<any>(value);\n//     return bigint instanceof BigInt;\n// }\n// export function GetBigIntFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool) {\n//     var bigint = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<any>(value);\n//     return bigint;\n// }\n// export function GetObjectFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool) {\n//     var nativeObject = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n//     return engine.csharpObjectMap.getCSIdentifierFromObject(nativeObject);\n// }\n// export function GetFunctionFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool): JSFunctionPtr {\n//     var func = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<(...args: any[]) => any>(value);\n//     var jsfunc = jsFunctionOrObjectFactory.getOrCreateJSFunction(func);\n//     return jsfunc.id;\n// }\n// export function GetJSObjectFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool) {\n//     var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<(...args: any[]) => any>(value);\n//     var jsobj = jsFunctionOrObjectFactory.getOrCreateJSObject(obj);\n//     return jsobj.id;\n// }\n// export function GetArrayBufferFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, /*out int */lengthOffset: any, isOut: bool) {\n//     var ab = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<ArrayBuffer>(value);\n//     if (ab instanceof Uint8Array) {\n//         ab = ab.buffer;\n//     }\n//     var ptr = engine.unityApi._malloc(ab.byteLength);\n//     engine.unityApi.HEAP8.set(new Int8Array(ab), ptr);\n//     engine.unityApi.HEAP32[lengthOffset >> 2] = ab.byteLength;\n//     setOutValue32(engine, lengthOffset, ab.byteLength);\n//     return ptr;\n// }\n/**\n * mixin\n * JS调用C#时，C#侧获取JS调用参数的值\n *\n * @param engine\n * @returns\n */\nfunction WebGLBackendGetFromJSArgumentAPI(engine) {\n    return {\n        /***********这部分现在都是C++实现的************/\n        // GetNumberFromValue: GetNumberFromValue.bind(null, engine),\n        // GetDateFromValue: GetDateFromValue.bind(null, engine),\n        // GetStringFromValue: GetStringFromValue.bind(null, engine),\n        // GetBooleanFromValue: GetBooleanFromValue.bind(null, engine),\n        // ValueIsBigInt: ValueIsBigInt.bind(null, engine),\n        // GetBigIntFromValue: GetBigIntFromValue.bind(null, engine),\n        // GetObjectFromValue: GetObjectFromValue.bind(null, engine),\n        // GetFunctionFromValue: GetFunctionFromValue.bind(null, engine),\n        // GetJSObjectFromValue: GetJSObjectFromValue.bind(null, engine),\n        // GetArrayBufferFromValue: GetArrayBufferFromValue.bind(null, engine),\n        // GetArgumentType: function (isolate: IntPtr, info: MockIntPtr, index: int, isByRef: bool) {\n        //     var value = FunctionCallbackInfoPtrManager.GetByMockPointer(info, engine).args[index];\n        //     return GetType(engine, value);\n        // },\n        // /**\n        //  * 为c#侧提供一个获取callbackinfo里jsvalue的intptr的接口\n        //  * 并不是得的到这个argument的值\n        //  *\n        //  * 该接口只有位运算，由C++实现\n        //  */\n        // GetArgumentValue/*inCallbackInfo*/: function (infoptr: MockIntPtr, index: int) {\n        //     return infoptr | index;\n        // },\n        // GetJsValueType: function (isolate: IntPtr, val: MockIntPtr, isByRef: bool) {\n        //     // public enum JsValueType\n        //     // {\n        //     //     NullOrUndefined = 1,\n        //     //     BigInt = 2,\n        //     //     Number = 4,\n        //     //     String = 8,\n        //     //     Boolean = 16,\n        //     //     NativeObject = 32,\n        //     //     JsObject = 64,\n        //     //     Array = 128,\n        //     //     Function = 256,\n        //     //     Date = 512,\n        //     //     ArrayBuffer = 1024,\n        //     //     Unknow = 2048,\n        //     //     Any = NullOrUndefined | BigInt | Number | String | Boolean | NativeObject | Array | Function | Date | ArrayBuffer,\n        //     // };\n        //     var value: any = FunctionCallbackInfoPtrManager.GetArgsByMockIntPtr(val, engine);\n        //     return GetType(engine, value);\n        // },\n        /***********以上现在都是C++实现的************/\n        GetTypeIdFromValue: function (isolate, value, isByRef) {\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n            if (isByRef) {\n                // @ts-ignore\n                obj = obj[0];\n            }\n            var typeid = 0;\n            if (obj instanceof library_1.JSFunction) {\n                typeid = obj._func[\"$cid\"];\n            }\n            else {\n                typeid = obj[\"$cid\"];\n            }\n            if (!typeid) {\n                throw new Error('cannot find typeid for' + value);\n            }\n            return typeid;\n        },\n    };\n}\nexports.default = WebGLBackendGetFromJSArgumentAPI;\n//# sourceMappingURL=getFromJSArgument.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst library_1 = require(\"../library\");\n/**\n * mixin\n * C#调用JS时，获取JS函数返回值\n *\n * 原有的resultInfo设计出来只是为了让多isolate时能在不同的isolate里保持不同的result\n * 在WebGL模式下没有这个烦恼，因此直接用engine的即可\n * resultInfo固定为1024\n *\n * @param engine\n * @returns\n */\nfunction WebGLBackendGetFromJSReturnAPI(engine) {\n    return {\n        GetNumberFromResult: function (resultInfo) {\n            return engine.lastReturnCSResult;\n        },\n        GetDateFromResult: function (resultInfo) {\n            return engine.lastReturnCSResult.getTime();\n        },\n        GetStringFromResult: function (resultInfo, /*out int */ length) {\n            return engine.JSStringToTempCSString(engine.lastReturnCSResult, length);\n        },\n        GetBooleanFromResult: function (resultInfo) {\n            return engine.lastReturnCSResult;\n        },\n        ResultIsBigInt: function (resultInfo) {\n            return (0, library_1.isBigInt)(engine.lastReturnCSResult);\n        },\n        GetBigIntFromResult: function (resultInfo) {\n            // puerts core v2.0.4开始支持\n            return (0, library_1.returnBigInt)(engine, engine.lastReturnCSResult);\n        },\n        GetObjectFromResult: function (resultInfo) {\n            return engine.csharpObjectMap.getCSIdentifierFromObject(engine.lastReturnCSResult);\n        },\n        GetTypeIdFromResult: function (resultInfo) {\n            var value = engine.lastReturnCSResult;\n            var typeid = 0;\n            if (value instanceof library_1.JSFunction) {\n                typeid = value._func[\"$cid\"];\n            }\n            else {\n                typeid = value[\"$cid\"];\n            }\n            if (!typeid) {\n                throw new Error('cannot find typeid for' + value);\n            }\n            return typeid;\n        },\n        GetFunctionFromResult: function (resultInfo) {\n            var jsfunc = library_1.jsFunctionOrObjectFactory.getOrCreateJSFunction(engine.lastReturnCSResult);\n            return jsfunc.id;\n        },\n        GetJSObjectFromResult: function (resultInfo) {\n            var jsobj = library_1.jsFunctionOrObjectFactory.getOrCreateJSObject(engine.lastReturnCSResult);\n            return jsobj.id;\n        },\n        GetArrayBufferFromResult: function (resultInfo, /*out int */ length) {\n            var ab = engine.lastReturnCSResult;\n            var ptr = engine.unityApi._malloc(ab.byteLength);\n            engine.unityApi.HEAP8.set(new Int8Array(ab), ptr);\n            (0, library_1.setOutValue32)(engine, length, ab.byteLength);\n            return ptr;\n        },\n        //保守方案\n        GetResultType: function (resultInfo) {\n            var value = engine.lastReturnCSResult;\n            return (0, library_1.GetType)(engine, value);\n        },\n    };\n}\nexports.default = WebGLBackendGetFromJSReturnAPI;\n//# sourceMappingURL=getFromJSReturn.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst library_1 = require(\"../library\");\n/**\n * mixin\n * 注册类API，如注册全局函数、注册类，以及类的属性方法等\n *\n * @param engine\n * @returns\n */\nfunction WebGLBackendRegisterAPI(engine) {\n    const returnee = {\n        SetGlobalFunction: function (isolate, nameString, v8FunctionCallback, jsEnvIdx, callbackidx) {\n            const name = engine.unityApi.UTF8ToString(nameString);\n            library_1.global[name] = engine.makeCSharpFunctionCallbackFunction(true, v8FunctionCallback, callbackidx);\n        },\n        _RegisterClass: function (isolate, BaseTypeId, fullNameString, constructor, destructor, jsEnvIdx, callbackidx, size) {\n            const fullName = engine.unityApi.UTF8ToString(fullNameString);\n            const csharpObjectMap = engine.csharpObjectMap;\n            const id = csharpObjectMap.classes.length;\n            let tempExternalCSID = 0;\n            const ctor = function NativeObject() {\n                // 设置类型ID\n                this[\"$cid\"] = id;\n                // nativeObject的构造函数\n                // 构造函数有两个调用的地方：1. js侧new一个它的时候 2. cs侧创建了一个对象要传到js侧时\n                // 第一个情况，cs对象ID或者是callV8ConstructorCallback返回的。\n                // 第二个情况，则cs对象ID是cs new完之后一并传给js的。\n                let csID = tempExternalCSID; // 如果是第二个情况，此ID由createFromCS设置\n                tempExternalCSID = 0;\n                if (csID === 0) {\n                    const args = Array.prototype.slice.call(arguments, 0);\n                    const callbackInfoPtr = engine.functionCallbackInfoPtrManager.GetMockPointer(args);\n                    // 虽然puerts内Constructor的返回值叫self，但它其实就是CS对象的一个id而已。\n                    try {\n                        csID = engine.callCSharpConstructorCallback(constructor, callbackInfoPtr, args.length, callbackidx);\n                    }\n                    catch (e) {\n                        engine.functionCallbackInfoPtrManager.ReleaseByMockIntPtr(callbackInfoPtr);\n                        throw e;\n                    }\n                    engine.functionCallbackInfoPtrManager.ReleaseByMockIntPtr(callbackInfoPtr);\n                }\n                // blittable\n                if (size) {\n                    let csNewID = engine.unityApi._malloc(size);\n                    engine.memcpy(csNewID, csID, size);\n                    csharpObjectMap.add(csNewID, this);\n                    (0, library_1.OnFinalize)(this, csNewID, (csIdentifier) => {\n                        csharpObjectMap.remove(csIdentifier);\n                        engine.unityApi._free(csIdentifier);\n                    });\n                }\n                else {\n                    csharpObjectMap.add(csID, this);\n                    (0, library_1.OnFinalize)(this, csID, (csIdentifier) => {\n                        csharpObjectMap.remove(csIdentifier);\n                        engine.callCSharpDestructorCallback(destructor || engine.generalDestructor, csIdentifier, callbackidx);\n                    });\n                }\n            };\n            ctor.createFromCS = function (csID) {\n                tempExternalCSID = csID;\n                return new ctor();\n            };\n            ctor.__puertsMetadata = new Map();\n            Object.defineProperty(ctor, \"name\", { value: fullName + \"Constructor\" });\n            Object.defineProperty(ctor, \"$cid\", { value: id });\n            csharpObjectMap.classes.push(ctor);\n            csharpObjectMap.classIDWeakMap.set(ctor, id);\n            if (BaseTypeId > 0) {\n                ctor.prototype.__proto__ = csharpObjectMap.classes[BaseTypeId].prototype;\n            }\n            csharpObjectMap.namesToClassesID[fullName] = id;\n            return id;\n        },\n        RegisterStruct: function (isolate, BaseTypeId, fullNameString, constructor, destructor, /*long */ jsEnvIdx, callbackidx, size) {\n            return returnee._RegisterClass(isolate, BaseTypeId, fullNameString, constructor, destructor, callbackidx, callbackidx, size);\n        },\n        RegisterFunction: function (isolate, classID, nameString, isStatic, callback, /*long */ jsEnvIdx, callbackidx) {\n            var cls = engine.csharpObjectMap.classes[classID];\n            if (!cls) {\n                return false;\n            }\n            var fn = engine.makeCSharpFunctionCallbackFunction(isStatic, callback, callbackidx);\n            const name = engine.unityApi.UTF8ToString(nameString);\n            if (isStatic) {\n                cls[name] = fn;\n            }\n            else {\n                cls.prototype[name] = fn;\n            }\n        },\n        RegisterProperty: function (isolate, classID, nameString, isStatic, getter, \n        /*long */ getterjsEnvIdx, \n        /*long */ gettercallbackidx, setter, \n        /*long */ setterjsEnvIdx, \n        /*long */ settercallbackidx, dontDelete) {\n            var cls = engine.csharpObjectMap.classes[classID];\n            if (!cls) {\n                return false;\n            }\n            const name = engine.unityApi.UTF8ToString(nameString);\n            var attr = {\n                configurable: !dontDelete,\n                enumerable: false\n            };\n            attr.get = engine.makeCSharpFunctionCallbackFunction(isStatic, getter, gettercallbackidx);\n            if (setter) {\n                attr.set = engine.makeCSharpFunctionCallbackFunction(isStatic, setter, settercallbackidx);\n            }\n            if (isStatic) {\n                Object.defineProperty(cls, name, attr);\n            }\n            else {\n                Object.defineProperty(cls.prototype, name, attr);\n            }\n        },\n    };\n    return returnee;\n}\nexports.default = WebGLBackendRegisterAPI;\n//# sourceMappingURL=register.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst library_1 = require(\"../library\");\n/**\n * mixin\n * C#调用JS时，设置调用参数的值\n *\n * @param engine\n * @returns\n */\nfunction WebGLBackendSetToInvokeJSArgumentApi(engine) {\n    return {\n        //begin cs call js\n        PushNullForJSFunction: function (_function) {\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n            func.args.push(null);\n        },\n        PushDateForJSFunction: function (_function, dateValue) {\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n            func.args.push(new Date(dateValue));\n        },\n        PushBooleanForJSFunction: function (_function, b) {\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n            func.args.push(!!b);\n        },\n        PushBigIntForJSFunction: function (_function, /*long */ longlow, longhigh) {\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n            func.args.push((0, library_1.makeBigInt)(longlow, longhigh));\n        },\n        PushStringForJSFunction: function (_function, strString) {\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n            func.args.push(engine.unityApi.UTF8ToString(strString));\n        },\n        PushNumberForJSFunction: function (_function, d) {\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n            func.args.push(d);\n        },\n        PushObjectForJSFunction: function (_function, classID, objectID) {\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n            func.args.push(engine.csharpObjectMap.findOrAddObject(objectID, classID));\n        },\n        PushJSFunctionForJSFunction: function (_function, JSFunction) {\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n            func.args.push(library_1.jsFunctionOrObjectFactory.getJSFunctionById(JSFunction)._func);\n        },\n        PushJSObjectForJSFunction: function (_function, JSObject) {\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n            func.args.push(library_1.jsFunctionOrObjectFactory.getJSObjectById(JSObject).getObject());\n        },\n        PushArrayBufferForJSFunction: function (_function, /*byte[] */ index, length) {\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n            func.args.push(engine.unityApi.HEAP8.buffer.slice(index, index + length));\n        }\n    };\n}\nexports.default = WebGLBackendSetToInvokeJSArgumentApi;\n//# sourceMappingURL=setToInvokeJSArgument.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst library_1 = require(\"../library\");\n/**\n * mixin\n * JS调用C#时，C#设置返回到JS的值\n *\n * @param engine\n * @returns\n */\nfunction WebGLBackendSetToJSInvokeReturnApi(engine) {\n    return {\n        ReturnClass: function (isolate, info, classID) {\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            callbackInfo.returnValue = engine.csharpObjectMap.classes[classID];\n        },\n        ReturnObject: function (isolate, info, classID, self) {\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            callbackInfo.returnValue = engine.csharpObjectMap.findOrAddObject(self, classID);\n        },\n        ReturnNumber: function (isolate, info, number) {\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            callbackInfo.returnValue = number;\n        },\n        ReturnString: function (isolate, info, strString) {\n            const str = engine.unityApi.UTF8ToString(strString);\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            callbackInfo.returnValue = str;\n        },\n        ReturnBigInt: function (isolate, info, longLow, longHigh) {\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            callbackInfo.returnValue = (0, library_1.makeBigInt)(longLow, longHigh);\n        },\n        ReturnBoolean: function (isolate, info, b) {\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            callbackInfo.returnValue = !!b; // 传过来的是1和0\n        },\n        ReturnDate: function (isolate, info, date) {\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            callbackInfo.returnValue = new Date(date);\n        },\n        ReturnNull: function (isolate, info) {\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            callbackInfo.returnValue = null;\n        },\n        ReturnFunction: function (isolate, info, JSFunctionPtr) {\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            const jsFunc = library_1.jsFunctionOrObjectFactory.getJSFunctionById(JSFunctionPtr);\n            callbackInfo.returnValue = jsFunc._func;\n        },\n        ReturnJSObject: function (isolate, info, JSObjectPtr) {\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            const jsObject = library_1.jsFunctionOrObjectFactory.getJSObjectById(JSObjectPtr);\n            callbackInfo.returnValue = jsObject.getObject();\n        },\n        ReturnCSharpFunctionCallback: function (isolate, info, v8FunctionCallback, \n        /*long */ pointerLow, \n        /*long */ pointerHigh) {\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            callbackInfo.returnValue = engine.makeCSharpFunctionCallbackFunction(false, v8FunctionCallback, pointerHigh);\n        },\n        ReturnArrayBuffer: function (isolate, info, /*byte[] */ index, length) {\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\n            callbackInfo.returnValue = engine.unityApi.HEAP8.buffer.slice(index, index + length);\n        },\n    };\n}\nexports.default = WebGLBackendSetToJSInvokeReturnApi;\n//# sourceMappingURL=setToJSInvokeReturn.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst library_1 = require(\"../library\");\n/**\n * mixin\n * JS调用C#时，C#侧设置out参数值\n *\n * @param engine\n * @returns\n */\nfunction WebGLBackendSetToJSOutArgumentAPI(engine) {\n    return {\n        SetNumberToOutValue: function (isolate, value, number) {\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n            obj[0] = number;\n        },\n        SetDateToOutValue: function (isolate, value, date) {\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n            obj[0] = new Date(date);\n        },\n        SetStringToOutValue: function (isolate, value, strString) {\n            const str = engine.unityApi.UTF8ToString(strString);\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n            obj[0] = str;\n        },\n        SetBooleanToOutValue: function (isolate, value, b) {\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n            obj[0] = !!b; // 传过来的是1和0\n        },\n        SetBigIntToOutValue: function (isolate, value, low, high) {\n            const obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n            obj[0] = (0, library_1.makeBigInt)(low, high);\n        },\n        SetObjectToOutValue: function (isolate, value, classID, self) {\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n            obj[0] = engine.csharpObjectMap.findOrAddObject(self, classID);\n        },\n        SetNullToOutValue: function (isolate, value) {\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n            obj[0] = null; // 传过来的是1和0\n        },\n        SetArrayBufferToOutValue: function (isolate, value, /*Byte[] */ index, length) {\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\n            obj[0] = engine.unityApi.HEAP8.buffer.slice(index, index + length);\n        },\n    };\n}\nexports.default = WebGLBackendSetToJSOutArgumentAPI;\n//# sourceMappingURL=setToJSOutArgument.js.map","// 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","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n/**\n * 根据 https://docs.unity3d.com/2018.4/Documentation/Manual/webgl-interactingwithbrowserscripting.html\n * 我们的目的就是在WebGL模式下，实现和puerts.dll的效果。具体在于实现一个jslib，里面应包含PuertsDLL.cs的所有接口\n * 实验发现这个jslib虽然也是运行在v8的js，但对devtool调试并不友好，且只支持到es5。\n * 因此应该通过一个独立的js实现接口，puerts.jslib通过全局的方式调用它。\n *\n * 最终形成如下架构\n * 业务JS <-> WASM <-> unity jslib <-> 本js\n * 但整条链路其实都在一个v8(jscore)虚拟机里\n */\nconst library_1 = require(\"./library\");\nconst getFromJSArgument_1 = require(\"./mixins/getFromJSArgument\");\nconst getFromJSReturn_1 = require(\"./mixins/getFromJSReturn\");\nconst register_1 = require(\"./mixins/register\");\nconst setToInvokeJSArgument_1 = require(\"./mixins/setToInvokeJSArgument\");\nconst setToJSInvokeReturn_1 = require(\"./mixins/setToJSInvokeReturn\");\nconst setToJSOutArgument_1 = require(\"./mixins/setToJSOutArgument\");\nlibrary_1.global.wxRequire = library_1.global.require;\nlibrary_1.global.PuertsWebGL = {\n    inited: false,\n    debug: false,\n    // puerts首次初始化时会调用这里，并把Unity的通信接口传入\n    Init(ctorParam) {\n        const engine = new library_1.PuertsJSEngine(ctorParam);\n        const executeModuleCache = {};\n        let jsEngineReturned = false;\n        let loader;\n        // PuertsDLL的所有接口实现\n        library_1.global.PuertsWebGL = Object.assign(library_1.global.PuertsWebGL, {\n            updateGlobalBufferAndViews: engine.updateGlobalBufferAndViews.bind(engine)\n        }, (0, getFromJSArgument_1.default)(engine), (0, getFromJSReturn_1.default)(engine), (0, setToInvokeJSArgument_1.default)(engine), (0, setToJSInvokeReturn_1.default)(engine), (0, setToJSOutArgument_1.default)(engine), (0, register_1.default)(engine), {\n            // bridgeLog: true,\n            GetLibVersion: function () {\n                return 32;\n            },\n            GetApiLevel: function () {\n                return 32;\n            },\n            GetLibBackend: function () {\n                return 0;\n            },\n            CreateJSEngine: function () {\n                if (jsEngineReturned) {\n                    throw new Error(\"only one available jsEnv is allowed in WebGL mode\");\n                }\n                jsEngineReturned = true;\n                return 1024;\n            },\n            CreateJSEngineWithExternalEnv: function () { },\n            DestroyJSEngine: function () { },\n            GetLastExceptionInfo: function (isolate, /* out int */ strlen) {\n                return engine.JSStringToCSString(engine.lastException.stack, strlen);\n            },\n            LowMemoryNotification: function (isolate) { },\n            IdleNotificationDeadline: function (isolate) { },\n            RequestMinorGarbageCollectionForTesting: function (isolate) { },\n            RequestFullGarbageCollectionForTesting: function (isolate) { },\n            SetGeneralDestructor: function (isolate, _generalDestructor) {\n                engine.generalDestructor = _generalDestructor;\n            },\n            GetModuleExecutor: function () {\n                loader = typeof __tgjsGetLoader != 'undefined' ? __tgjsGetLoader() : null;\n                const loaderResolve = loader.Resolve ? (function (fileName, to = \"\") {\n                    const resolvedName = loader.Resolve(fileName, to);\n                    if (!resolvedName) {\n                        throw new Error('module not found: ' + fileName);\n                    }\n                    return resolvedName;\n                }) : null;\n                var jsfunc = library_1.jsFunctionOrObjectFactory.getOrCreateJSFunction(function (fileName) {\n                    if (['puerts/log.mjs', 'puerts/timer.mjs'].indexOf(fileName) != -1) {\n                        return {};\n                    }\n                    if (loaderResolve) {\n                        fileName = loaderResolve(fileName, \"\");\n                    }\n                    if (typeof wx != 'undefined') {\n                        const result = wxRequire('puerts_minigame_js_resources/' + (fileName.endsWith('.js') ? fileName : fileName + \".js\"));\n                        return result;\n                    }\n                    else {\n                        function normalize(name, to) {\n                            if (typeof CS != void 0) {\n                                if (CS.Puerts.PathHelper.IsRelative(to)) {\n                                    const ret = CS.Puerts.PathHelper.normalize(CS.Puerts.PathHelper.Dirname(name) + \"/\" + to);\n                                    return ret;\n                                }\n                            }\n                            return to;\n                        }\n                        function mockRequire(specifier) {\n                            const result = { exports: {} };\n                            const foundCacheSpecifier = tryFindAndGetFindedSpecifier(specifier, executeModuleCache);\n                            if (foundCacheSpecifier) {\n                                result.exports = executeModuleCache[foundCacheSpecifier];\n                            }\n                            else {\n                                const foundSpecifier = tryFindAndGetFindedSpecifier(specifier, PUERTS_JS_RESOURCES);\n                                if (!foundSpecifier) {\n                                    throw new Error('module not found: ' + specifier);\n                                }\n                                specifier = foundSpecifier;\n                                executeModuleCache[specifier] = -1;\n                                try {\n                                    PUERTS_JS_RESOURCES[specifier](result.exports, function mRequire(specifierTo) {\n                                        return mockRequire(loaderResolve ? loaderResolve(specifierTo, specifier) : normalize(specifier, specifierTo));\n                                    }, result);\n                                }\n                                catch (e) {\n                                    delete executeModuleCache[specifier];\n                                    throw e;\n                                }\n                                executeModuleCache[specifier] = result.exports;\n                            }\n                            return result.exports;\n                            function tryFindAndGetFindedSpecifier(specifier, obj) {\n                                let tryFindName = [specifier];\n                                if (specifier.indexOf('.') == -1)\n                                    tryFindName = tryFindName.concat([specifier + '.js', specifier + '.ts', specifier + '.mjs', specifier + '.mts']);\n                                let finded = tryFindName.reduce((ret, name, index) => {\n                                    if (ret !== false)\n                                        return ret;\n                                    if (name in obj) {\n                                        if (obj[name] == -1)\n                                            throw new Error(`circular dependency is detected when requiring \"${name}\"`);\n                                        return index;\n                                    }\n                                    return false;\n                                }, false);\n                                if (finded === false) {\n                                    return null;\n                                }\n                                else {\n                                    return tryFindName[finded];\n                                }\n                            }\n                        }\n                        const requireRet = mockRequire(fileName);\n                        return requireRet;\n                    }\n                });\n                return jsfunc.id;\n            },\n            GetJSObjectValueGetter: function () {\n                var jsfunc = library_1.jsFunctionOrObjectFactory.getOrCreateJSFunction(function (obj, key) {\n                    return obj[key];\n                });\n                return jsfunc.id;\n            },\n            Eval: function (isolate, codeString, path) {\n                if (!library_1.global.eval) {\n                    throw new Error(\"eval is not supported\");\n                }\n                try {\n                    const code = engine.unityApi.UTF8ToString(codeString);\n                    const result = library_1.global.eval(code);\n                    // return getIntPtrManager().GetPointerForJSValue(result);\n                    engine.lastReturnCSResult = result;\n                    return /*FResultInfo */ 1024;\n                }\n                catch (e) {\n                    engine.lastException = e;\n                }\n            },\n            SetPushJSFunctionArgumentsCallback: function (isolate, callback, jsEnvIdx) {\n                engine.GetJSArgumentsCallback = callback;\n            },\n            ThrowException: function (isolate, /*byte[] */ messageString) {\n                throw new Error(engine.unityApi.UTF8ToString(messageString));\n            },\n            InvokeJSFunction: function (_function, hasResult) {\n                const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n                if (func instanceof library_1.JSFunction) {\n                    try {\n                        engine.lastReturnCSResult = func.invoke();\n                        return 1024;\n                    }\n                    catch (err) {\n                        func.lastException = err;\n                        return 0;\n                    }\n                }\n                else {\n                    throw new Error('ptr is not a jsfunc');\n                }\n            },\n            GetFunctionLastExceptionInfo: function (_function, /*out int */ length) {\n                const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\n                if (func instanceof library_1.JSFunction) {\n                    return engine.JSStringToCSString(func.lastException.stack || func.lastException.message || '', length);\n                }\n                else {\n                    throw new Error('ptr is not a jsfunc');\n                }\n            },\n            ReleaseJSFunction: function (isolate, _function) {\n                library_1.jsFunctionOrObjectFactory.removeJSFunctionById(_function);\n            },\n            ReleaseJSObject: function (isolate, obj) {\n                library_1.jsFunctionOrObjectFactory.removeJSObjectById(obj);\n            },\n            ResetResult: function (resultInfo) {\n                engine.lastReturnCSResult = null;\n            },\n            ClearModuleCache: function () { },\n            CreateInspector: function (isolate, port) { },\n            DestroyInspector: function (isolate) { },\n            InspectorTick: function (isolate) { },\n            LogicTick: function (isolate) { },\n            SetLogCallback: function (log, logWarning, logError) {\n            }\n        });\n    }\n};\n//# sourceMappingURL=index.js.map"],"names":[],"sourceRoot":""} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"puerts-runtime.js","mappings":";;;;;;;;;;AAAa;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,oBAAoB,GAAG,gBAAgB,GAAG,oBAAoB,GAAG,qBAAqB,GAAG,kBAAkB,GAAG,eAAe,GAAG,sBAAsB,GAAG,kBAAkB,GAAG,qBAAqB,GAAG,cAAc,GAAG,uBAAuB,GAAG,iCAAiC,GAAG,gBAAgB,GAAG,kBAAkB,GAAG,sCAAsC,GAAG,4BAA4B;AAClY;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B;AAC5B;AACA;AACA,yBAAyB;AACzB,iCAAiC;AACjC,kBAAkB;AAClB,iCAAiC;AACjC;AACA,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA,6CAA6C;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA,8FAA8F;AAC9F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kGAAkG;AAClG;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,yCAAyC;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA,cAAc,GAAG,qBAAM,GAAG,qBAAM;AAChC,qBAAM,UAAU,qBAAM;AACtB;AACA;AACA;AACA;AACA;AACA,yBAAyB,UAAU;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,qBAAM;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,iDAAiD;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,uPAAuP;AACvQ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,qBAAM,2DAA2D;AACzE,QAAQ,qBAAM;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,qBAAM;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA,oBAAoB;AACpB;AACA;AACA;AACA,gBAAgB;AAChB;AACA,wDAAwD;AACxD,wCAAwC;AACxC;AACA,oBAAoB;AACpB;AACA,mEAAmE;AACnE,gEAAgE;AAChE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;AC7pBa;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,kBAAe;AACf;;;;;;;;;;AC5Ha;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,kBAAe;AACf;;;;;;;;;;AC3Ea;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD,iCAAiC;AACnF,kDAAkD,WAAW;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,kBAAe;AACf;;;;;;;;;;AC1Ha;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,kBAAe;AACf;;;;;;;;;;ACxDa;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,4CAA4C;AAC5C,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,kBAAe;AACf;;;;;;;;;;ACpEa;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,kBAAkB,mBAAO,CAAC,uCAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,0BAA0B;AAC1B,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,2BAA2B;AAC3B,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,kBAAe;AACf;;;;;;UChDA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA,GAAG;WACH;WACA;WACA,CAAC;;;;;;;;;;;ACPY;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,mBAAO,CAAC,sCAAW;AACrC,4BAA4B,mBAAO,CAAC,wEAA4B;AAChE,0BAA0B,mBAAO,CAAC,oEAA0B;AAC5D,mBAAmB,mBAAO,CAAC,sDAAmB;AAC9C,gCAAgC,mBAAO,CAAC,gFAAgC;AACxE,8BAA8B,mBAAO,CAAC,4EAA8B;AACpE,6BAA6B,mBAAO,CAAC,0EAA6B;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,0DAA0D;AAC1D,4CAA4C;AAC5C;AACA;AACA,aAAa;AACb,yDAAyD;AACzD,4DAA4D;AAC5D,2EAA2E;AAC3E,0EAA0E;AAC1E;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+GAA+G,KAAK;AACpH;AACA;AACA;AACA,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA,aAAa;AACb;AACA;AACA;AACA,iBAAiB;AACjB;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;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,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb,6CAA6C;AAC7C,yDAAyD;AACzD,oDAAoD;AACpD,iDAAiD;AACjD,6CAA6C;AAC7C;AACA,aAAa;AACb;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,iC","sources":["webpack:///./output/library.js","webpack:///./output/mixins/getFromJSArgument.js","webpack:///./output/mixins/getFromJSReturn.js","webpack:///./output/mixins/register.js","webpack:///./output/mixins/setToInvokeJSArgument.js","webpack:///./output/mixins/setToJSInvokeReturn.js","webpack:///./output/mixins/setToJSOutArgument.js","webpack:///webpack/bootstrap","webpack:///webpack/runtime/global","webpack:///./output/index.js"],"sourcesContent":["\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.returnBigInt = exports.isBigInt = exports.setOutValue8 = exports.setOutValue32 = exports.makeBigInt = exports.GetType = exports.PuertsJSEngine = exports.OnFinalize = exports.createWeakRef = exports.global = exports.CSharpObjectMap = exports.jsFunctionOrObjectFactory = exports.JSObject = exports.JSFunction = exports.FunctionCallbackInfoPtrManager = exports.FunctionCallbackInfo = void 0;\r\n/**\r\n * 一次函数调用的info\r\n * 对应v8::FunctionCallbackInfo\r\n */\r\nclass FunctionCallbackInfo {\r\n    args;\r\n    returnValue;\r\n    stack = 0;\r\n    constructor(args) {\r\n        this.args = args;\r\n    }\r\n    recycle() {\r\n        this.stack = 0;\r\n        this.args = null;\r\n        this.returnValue = void 0;\r\n    }\r\n}\r\nexports.FunctionCallbackInfo = FunctionCallbackInfo;\r\n// struct MockV8Value\r\n// {\r\n//     int JSValueType;  // 0\r\n//     int FinalValuePointer[2]; // 1 2 if value is bigint FinalValuePointer[0] for low, FinalValuePointer[1] for high\r\n//     int extra; // 3\r\n//     int FunctionCallbackInfo; // 4\r\n// };\r\nconst ArgumentValueLengthIn32 = 4; // int count\r\n/**\r\n * 把FunctionCallbackInfo以及其参数转化为c#可用的intptr\r\n */\r\nclass FunctionCallbackInfoPtrManager {\r\n    // FunctionCallbackInfo的列表，以列表的index作为IntPtr的值\r\n    infos = [new FunctionCallbackInfo([0])]; // 这里原本只是个普通的0\r\n    // FunctionCallbackInfo用完后，将其序号放入“回收列表”，下次就能继续服用该index，而不必让infos数组无限扩展下去\r\n    freeInfosIndex = [];\r\n    freeCallbackInfoMemoryByLength = {};\r\n    freeRefMemory = [];\r\n    engine;\r\n    constructor(engine) {\r\n        this.engine = engine;\r\n    }\r\n    allocCallbackInfoMemory(argsLength) {\r\n        const cacheArray = this.freeCallbackInfoMemoryByLength[argsLength];\r\n        if (cacheArray && cacheArray.length) {\r\n            return cacheArray.pop();\r\n        }\r\n        else {\r\n            return this.engine.unityApi._malloc((argsLength * ArgumentValueLengthIn32 + 1) << 2);\r\n        }\r\n    }\r\n    allocRefMemory() {\r\n        if (this.freeRefMemory.length)\r\n            return this.freeRefMemory.pop();\r\n        return this.engine.unityApi._malloc(ArgumentValueLengthIn32 << 2);\r\n    }\r\n    recycleRefMemory(bufferPtr) {\r\n        if (this.freeRefMemory.length > 20) {\r\n            this.engine.unityApi._free(bufferPtr);\r\n        }\r\n        else {\r\n            this.freeRefMemory.push(bufferPtr);\r\n        }\r\n    }\r\n    recycleCallbackInfoMemory(bufferPtr, args) {\r\n        const argsLength = args.length;\r\n        if (!this.freeCallbackInfoMemoryByLength[argsLength] && argsLength < 5) {\r\n            this.freeCallbackInfoMemoryByLength[argsLength] = [];\r\n        }\r\n        const cacheArray = this.freeCallbackInfoMemoryByLength[argsLength];\r\n        if (!cacheArray)\r\n            return;\r\n        const bufferPtrIn32 = bufferPtr << 2;\r\n        for (let i = 0; i < argsLength; ++i) {\r\n            if (args[i] instanceof Array && args[i].length == 1) {\r\n                this.recycleRefMemory(this.engine.unityApi.HEAP32[bufferPtrIn32 + i * ArgumentValueLengthIn32 + 1]);\r\n            }\r\n        }\r\n        // 拍脑袋定的最大缓存个数大小。 50 - 参数个数 * 10\r\n        if (cacheArray.length > (50 - argsLength * 10)) {\r\n            this.engine.unityApi._free(bufferPtr);\r\n        }\r\n        else {\r\n            cacheArray.push(bufferPtr);\r\n        }\r\n    }\r\n    /**\r\n     * intptr的格式为id左移四位\r\n     *\r\n     * 右侧四位，是为了在右四位存储参数的序号，这样可以用于表示callbackinfo参数的intptr\r\n     */\r\n    // static GetMockPointer(args: any[]): MockIntPtr {\r\n    //     let index: number;\r\n    //     index = this.freeInfosIndex.pop();\r\n    //     // index最小为1\r\n    //     if (index) {\r\n    //         this.infos[index].args = args;\r\n    //     } else {\r\n    //         index = this.infos.push(new FunctionCallbackInfo(args)) - 1;\r\n    //     }\r\n    //     return index << 4;\r\n    // }\r\n    GetMockPointer(args) {\r\n        const argsLength = args.length;\r\n        let bufferPtrIn8 = this.allocCallbackInfoMemory(argsLength);\r\n        let index = this.freeInfosIndex.pop();\r\n        let functionCallbackInfo;\r\n        // index最小为1\r\n        if (index) {\r\n            (functionCallbackInfo = this.infos[index]).args = args;\r\n        }\r\n        else {\r\n            index = this.infos.push(functionCallbackInfo = new FunctionCallbackInfo(args)) - 1;\r\n        }\r\n        let unityApi = this.engine.unityApi;\r\n        const bufferPtrIn32 = bufferPtrIn8 >> 2;\r\n        unityApi.HEAP32[bufferPtrIn32] = index;\r\n        for (let i = 0; i < argsLength; i++) {\r\n            let arg = args[i];\r\n            // init each value\r\n            const jsValueType = GetType(this.engine, arg);\r\n            const jsValuePtr = bufferPtrIn32 + i * ArgumentValueLengthIn32 + 1;\r\n            unityApi.HEAP32[jsValuePtr] = jsValueType; // jsvaluetype\r\n            if (jsValueType == 2 || jsValueType == 4 || jsValueType == 512) {\r\n                // bigint、number or date\r\n                $FillArgumentFinalNumberValue(this.engine, arg, jsValueType, jsValuePtr + 1); // value\r\n            }\r\n            else if (jsValueType == 8) {\r\n                if (functionCallbackInfo.stack == 0) {\r\n                    functionCallbackInfo.stack = unityApi.stackSave();\r\n                }\r\n                unityApi.HEAP32[jsValuePtr + 1] = $GetArgumentFinalValue(this.engine, arg, jsValueType, (jsValuePtr + 2) << 2);\r\n            }\r\n            else if (jsValueType == 64 && arg instanceof Array && arg.length == 1) {\r\n                // maybe a ref\r\n                unityApi.HEAP32[jsValuePtr + 1] = $GetArgumentFinalValue(this.engine, arg, jsValueType, 0);\r\n                const refPtrIn8 = unityApi.HEAP32[jsValuePtr + 2] = this.allocRefMemory();\r\n                const refPtr = refPtrIn8 >> 2;\r\n                const refValueType = unityApi.HEAP32[refPtr] = GetType(this.engine, arg[0]);\r\n                if (refValueType == 2 || refValueType == 4 || refValueType == 512) {\r\n                    // number or date\r\n                    $FillArgumentFinalNumberValue(this.engine, arg[0], refValueType, refPtr + 1); // value\r\n                }\r\n                else {\r\n                    unityApi.HEAP32[refPtr + 1] = $GetArgumentFinalValue(this.engine, arg[0], refValueType, (refPtr + 2) << 2);\r\n                }\r\n                unityApi.HEAP32[refPtr + 3] = bufferPtrIn8; // a pointer to the info\r\n            }\r\n            else {\r\n                // other\r\n                unityApi.HEAP32[jsValuePtr + 1] = $GetArgumentFinalValue(this.engine, arg, jsValueType, (jsValuePtr + 2) << 2);\r\n            }\r\n            unityApi.HEAP32[jsValuePtr + 3] = bufferPtrIn8; // a pointer to the info\r\n        }\r\n        return bufferPtrIn8;\r\n    }\r\n    // static GetByMockPointer(intptr: MockIntPtr): FunctionCallbackInfo {\r\n    //     return this.infos[intptr >> 4];\r\n    // }\r\n    GetByMockPointer(ptrIn8) {\r\n        const ptrIn32 = ptrIn8 >> 2;\r\n        const index = this.engine.unityApi.HEAP32[ptrIn32];\r\n        return this.infos[index];\r\n    }\r\n    GetReturnValueAndRecycle(ptrIn8) {\r\n        const ptrIn32 = ptrIn8 >> 2;\r\n        const index = this.engine.unityApi.HEAP32[ptrIn32];\r\n        let info = this.infos[index];\r\n        let ret = info.returnValue;\r\n        this.recycleCallbackInfoMemory(ptrIn8, info.args);\r\n        if (info.stack) {\r\n            this.engine.unityApi.stackRestore(info.stack);\r\n        }\r\n        info.recycle();\r\n        this.freeInfosIndex.push(index);\r\n        return ret;\r\n    }\r\n    ReleaseByMockIntPtr(ptrIn8) {\r\n        const ptrIn32 = ptrIn8 >> 2;\r\n        const index = this.engine.unityApi.HEAP32[ptrIn32];\r\n        let info = this.infos[index];\r\n        this.recycleCallbackInfoMemory(ptrIn8, info.args);\r\n        if (info.stack) {\r\n            this.engine.unityApi.stackRestore(info.stack);\r\n        }\r\n        info.recycle();\r\n        this.freeInfosIndex.push(index);\r\n    }\r\n    GetArgsByMockIntPtr(valuePtrIn8) {\r\n        let heap32 = this.engine.unityApi.HEAP32;\r\n        const infoPtrIn8 = heap32[(valuePtrIn8 >> 2) + 3];\r\n        const callbackInfoIndex = heap32[infoPtrIn8 >> 2];\r\n        const argsIndex = (valuePtrIn8 - infoPtrIn8 - 4) / (4 * ArgumentValueLengthIn32);\r\n        return this.infos[callbackInfoIndex].args[argsIndex];\r\n    }\r\n}\r\nexports.FunctionCallbackInfoPtrManager = FunctionCallbackInfoPtrManager;\r\n/**\r\n * 代表一个JSFunction\r\n */\r\nclass JSFunction {\r\n    _func;\r\n    id;\r\n    args = [];\r\n    lastException = null;\r\n    constructor(id, func) {\r\n        this._func = func;\r\n        this.id = id;\r\n    }\r\n    invoke() {\r\n        var args = [...this.args];\r\n        this.args.length = 0;\r\n        return this._func.apply(this, args);\r\n    }\r\n}\r\nexports.JSFunction = JSFunction;\r\n/**\r\n * 代表一个JSObject\r\n */\r\nclass JSObject {\r\n    _obj;\r\n    id;\r\n    constructor(id, obj) {\r\n        this._obj = obj;\r\n        this.id = id;\r\n    }\r\n    getObject() {\r\n        return this._obj;\r\n    }\r\n}\r\nexports.JSObject = JSObject;\r\nclass jsFunctionOrObjectFactory {\r\n    static regularID = 1;\r\n    static freeID = [];\r\n    static idMap = new WeakMap();\r\n    static jsFuncOrObjectKV = {};\r\n    static getOrCreateJSFunction(funcValue) {\r\n        let id = jsFunctionOrObjectFactory.idMap.get(funcValue);\r\n        if (id) {\r\n            return jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\r\n        }\r\n        if (this.freeID.length) {\r\n            id = this.freeID.pop();\r\n        }\r\n        else {\r\n            id = jsFunctionOrObjectFactory.regularID++;\r\n        }\r\n        const func = new JSFunction(id, funcValue);\r\n        jsFunctionOrObjectFactory.idMap.set(funcValue, id);\r\n        jsFunctionOrObjectFactory.jsFuncOrObjectKV[id] = func;\r\n        return func;\r\n    }\r\n    static getOrCreateJSObject(obj) {\r\n        let id = jsFunctionOrObjectFactory.idMap.get(obj);\r\n        if (id) {\r\n            return jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\r\n        }\r\n        if (this.freeID.length) {\r\n            id = this.freeID.pop();\r\n        }\r\n        else {\r\n            id = jsFunctionOrObjectFactory.regularID++;\r\n        }\r\n        const jsObject = new JSObject(id, obj);\r\n        jsFunctionOrObjectFactory.idMap.set(obj, id);\r\n        jsFunctionOrObjectFactory.jsFuncOrObjectKV[id] = jsObject;\r\n        return jsObject;\r\n    }\r\n    static getJSObjectById(id) {\r\n        return jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\r\n    }\r\n    static removeJSObjectById(id) {\r\n        const jsObject = jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\r\n        if (!jsObject)\r\n            return console.warn('removeJSObjectById failed: id is invalid: ' + id);\r\n        jsFunctionOrObjectFactory.idMap.delete(jsObject.getObject());\r\n        delete jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\r\n        this.freeID.push(id);\r\n    }\r\n    static getJSFunctionById(id) {\r\n        return jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\r\n    }\r\n    static removeJSFunctionById(id) {\r\n        const jsFunc = jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\r\n        if (!jsFunc)\r\n            return console.warn('removeJSFunctionById failed: id is invalid: ' + id);\r\n        jsFunctionOrObjectFactory.idMap.delete(jsFunc._func);\r\n        delete jsFunctionOrObjectFactory.jsFuncOrObjectKV[id];\r\n        this.freeID.push(id);\r\n    }\r\n}\r\nexports.jsFunctionOrObjectFactory = jsFunctionOrObjectFactory;\r\n/**\r\n * CSharp对象记录表，记录所有CSharp对象并分配id\r\n * 和puerts.dll所做的一样\r\n */\r\nclass CSharpObjectMap {\r\n    classes = [null];\r\n    nativeObjectKV = new Map();\r\n    // private nativeObjectKV: { [objectID: CSIdentifier]: WeakRef<any> } = {};\r\n    // private csIDWeakMap: WeakMap<any, CSIdentifier> = new WeakMap();\r\n    namesToClassesID = {};\r\n    classIDWeakMap = new WeakMap();\r\n    constructor() {\r\n        this._memoryDebug && setInterval(() => {\r\n            console.log('addCalled', this.addCalled);\r\n            console.log('removeCalled', this.removeCalled);\r\n            console.log('wr', this.nativeObjectKV.size);\r\n        }, 1000);\r\n    }\r\n    _memoryDebug = false;\r\n    addCalled = 0;\r\n    removeCalled = 0;\r\n    add(csID, obj) {\r\n        this._memoryDebug && this.addCalled++;\r\n        // this.nativeObjectKV[csID] = createWeakRef(obj);\r\n        // this.csIDWeakMap.set(obj, csID);\r\n        this.nativeObjectKV.set(csID, createWeakRef(obj));\r\n        obj['$csid'] = csID;\r\n    }\r\n    remove(csID) {\r\n        this._memoryDebug && this.removeCalled++;\r\n        // delete this.nativeObjectKV[csID];\r\n        this.nativeObjectKV.delete(csID);\r\n    }\r\n    findOrAddObject(csID, classID) {\r\n        let ret = this.nativeObjectKV.get(csID);\r\n        // let ret = this.nativeObjectKV[csID];\r\n        if (ret && (ret = ret.deref())) {\r\n            return ret;\r\n        }\r\n        ret = this.classes[classID].createFromCS(csID);\r\n        // this.add(csID, ret); 构造函数里负责调用\r\n        return ret;\r\n    }\r\n    getCSIdentifierFromObject(obj) {\r\n        // return this.csIDWeakMap.get(obj);\r\n        return obj ? obj.$csid : 0;\r\n    }\r\n}\r\nexports.CSharpObjectMap = CSharpObjectMap;\r\n;\r\nvar destructors = {};\r\nexports.global = global = global || globalThis || window;\r\nglobal.global = global;\r\nconst createWeakRef = (function () {\r\n    if (typeof WeakRef == 'undefined') {\r\n        if (typeof WXWeakRef == 'undefined') {\r\n            console.error(\"WeakRef is not defined. maybe you should use newer environment\");\r\n            return function (obj) {\r\n                return { deref() { return obj; } };\r\n            };\r\n        }\r\n        console.warn(\"using WXWeakRef\");\r\n        return function (obj) {\r\n            return new WXWeakRef(obj);\r\n        };\r\n    }\r\n    return function (obj) {\r\n        return new WeakRef(obj);\r\n    };\r\n})();\r\nexports.createWeakRef = createWeakRef;\r\nclass FinalizationRegistryMock {\r\n    _handler;\r\n    refs = [];\r\n    helds = [];\r\n    availableIndex = [];\r\n    constructor(handler) {\r\n        console.warn(\"FinalizationRegister is not defined. using FinalizationRegistryMock\");\r\n        global._puerts_registry = this;\r\n        this._handler = handler;\r\n    }\r\n    register(obj, heldValue) {\r\n        if (this.availableIndex.length) {\r\n            const index = this.availableIndex.pop();\r\n            this.refs[index] = createWeakRef(obj);\r\n            this.helds[index] = heldValue;\r\n        }\r\n        else {\r\n            this.refs.push(createWeakRef(obj));\r\n            this.helds.push(heldValue);\r\n        }\r\n    }\r\n    /**\r\n     * 清除可能已经失效的WeakRef\r\n     */\r\n    iteratePosition = 0;\r\n    cleanup(part = 1) {\r\n        const stepCount = this.refs.length / part;\r\n        let i = this.iteratePosition;\r\n        for (let currentStep = 0; i < this.refs.length && currentStep < stepCount; i = (i == this.refs.length - 1 ? 0 : i + 1), currentStep++) {\r\n            if (this.refs[i] == null) {\r\n                continue;\r\n            }\r\n            if (!this.refs[i].deref()) {\r\n                // 目前没有内存整理能力，如果游戏中期ref很多但后期少了，这里就会白费遍历次数\r\n                // 但遍历也只是一句==和continue，浪费影响不大\r\n                this.availableIndex.push(i);\r\n                this.refs[i] = null;\r\n                try {\r\n                    this._handler(this.helds[i]);\r\n                }\r\n                catch (e) {\r\n                    console.error(e);\r\n                }\r\n            }\r\n        }\r\n        this.iteratePosition = i;\r\n    }\r\n}\r\nvar registry = null;\r\nfunction init() {\r\n    registry = new (typeof FinalizationRegistry == 'undefined' ? FinalizationRegistryMock : FinalizationRegistry)(function (heldValue) {\r\n        var callback = destructors[heldValue];\r\n        if (!callback) {\r\n            throw new Error(\"cannot find destructor for \" + heldValue);\r\n        }\r\n        if (--callback.ref == 0) {\r\n            delete destructors[heldValue];\r\n            callback(heldValue);\r\n        }\r\n    });\r\n}\r\nfunction OnFinalize(obj, heldValue, callback) {\r\n    if (!registry) {\r\n        init();\r\n    }\r\n    let originCallback = destructors[heldValue];\r\n    if (originCallback) {\r\n        // WeakRef内容释放时机可能比finalizationRegistry的触发更早，前面如果发现weakRef为空会重新创建对象\r\n        // 但之前对象的finalizationRegistry最终又肯定会触发。\r\n        // 所以如果遇到这个情况，需要给destructor加计数\r\n        ++originCallback.ref;\r\n    }\r\n    else {\r\n        callback.ref = 1;\r\n        destructors[heldValue] = callback;\r\n    }\r\n    registry.register(obj, heldValue);\r\n}\r\nexports.OnFinalize = OnFinalize;\r\nclass PuertsJSEngine {\r\n    csharpObjectMap;\r\n    functionCallbackInfoPtrManager;\r\n    unityApi;\r\n    /** 字符串缓存，默认为256字节 */\r\n    strBuffer;\r\n    stringBufferSize = 256;\r\n    lastReturnCSResult = null;\r\n    lastException = null;\r\n    // 这两个是Puerts用的的真正的CSharp函数指针\r\n    GetJSArgumentsCallback;\r\n    generalDestructor;\r\n    constructor(ctorParam) {\r\n        this.csharpObjectMap = new CSharpObjectMap();\r\n        this.functionCallbackInfoPtrManager = new FunctionCallbackInfoPtrManager(this);\r\n        const { UTF8ToString, _malloc, _free, _setTempRet0, stringToUTF8, lengthBytesUTF8, stackSave, stackRestore, stackAlloc, _CallCSharpFunctionCallback, _CallCSharpConstructorCallback, _CallCSharpDestructorCallback, HEAP8, HEAPU8, HEAP32, HEAPF32, HEAPF64, } = ctorParam;\r\n        this.strBuffer = _malloc(this.stringBufferSize);\r\n        this.unityApi = {\r\n            UTF8ToString,\r\n            _malloc,\r\n            _free,\r\n            _setTempRet0,\r\n            stringToUTF8,\r\n            lengthBytesUTF8,\r\n            stackSave,\r\n            stackRestore,\r\n            stackAlloc,\r\n            _CallCSharpFunctionCallback,\r\n            _CallCSharpConstructorCallback,\r\n            _CallCSharpDestructorCallback,\r\n            HEAP8,\r\n            HEAPU8,\r\n            HEAP32,\r\n            HEAPF32,\r\n            HEAPF64,\r\n        };\r\n        global.__tgjsEvalScript = typeof eval == \"undefined\" ? () => { } : eval;\r\n        global.__tgjsSetPromiseRejectCallback = function (callback) {\r\n            if (typeof wx != 'undefined') {\r\n                wx.onUnhandledRejection(callback);\r\n            }\r\n            else {\r\n                window.addEventListener(\"unhandledrejection\", callback);\r\n            }\r\n        };\r\n        global.__puertsGetLastException = () => {\r\n            return this.lastException;\r\n        };\r\n    }\r\n    /** call when wasm grow memory */\r\n    updateGlobalBufferAndViews(HEAP8, HEAPU8, HEAP32, HEAPF32, HEAPF64) {\r\n        let unityApi = this.unityApi;\r\n        unityApi.HEAP8 = HEAP8;\r\n        unityApi.HEAPU8 = HEAPU8;\r\n        unityApi.HEAP32 = HEAP32;\r\n        unityApi.HEAPF32 = HEAPF32;\r\n        unityApi.HEAPF64 = HEAPF64;\r\n    }\r\n    memcpy(dest, src, num) {\r\n        this.unityApi.HEAPU8.copyWithin(dest, src, src + num);\r\n    }\r\n    JSStringToCSString(returnStr, /** out int */ lengthOffset) {\r\n        if (returnStr === null || returnStr === undefined) {\r\n            return 0;\r\n        }\r\n        var byteCount = this.unityApi.lengthBytesUTF8(returnStr);\r\n        setOutValue32(this, lengthOffset, byteCount);\r\n        let buffer = this.unityApi._malloc(byteCount + 1);\r\n        this.unityApi.stringToUTF8(returnStr, buffer, byteCount + 1);\r\n        return buffer;\r\n    }\r\n    JSStringToTempCSString(returnStr, /** out int */ lengthOffset) {\r\n        if (returnStr === null || returnStr === undefined) {\r\n            return 0;\r\n        }\r\n        var byteCount = this.unityApi.lengthBytesUTF8(returnStr);\r\n        setOutValue32(this, lengthOffset, byteCount);\r\n        if (this.stringBufferSize < byteCount + 1) {\r\n            this.unityApi._free(this.strBuffer);\r\n            this.strBuffer = this.unityApi._malloc(this.stringBufferSize = Math.max(2 * this.stringBufferSize, byteCount + 1));\r\n        }\r\n        this.unityApi.stringToUTF8(returnStr, this.strBuffer, byteCount + 1);\r\n        return this.strBuffer;\r\n    }\r\n    JSStringToCSStringOnStack(returnStr, /** out int */ lengthOffset) {\r\n        if (returnStr === null || returnStr === undefined) {\r\n            return 0;\r\n        }\r\n        var byteCount = this.unityApi.lengthBytesUTF8(returnStr);\r\n        setOutValue32(this, lengthOffset, byteCount);\r\n        var buffer = this.unityApi.stackAlloc(byteCount + 1);\r\n        this.unityApi.stringToUTF8(returnStr, buffer, byteCount + 1);\r\n        return buffer;\r\n    }\r\n    makeCSharpFunctionCallbackFunction(isStatic, functionPtr, callbackIdx) {\r\n        // 不能用箭头函数！此处返回的函数会赋值到具体的class上，其this指针有含义。\r\n        const engine = this;\r\n        return function (...args) {\r\n            let callbackInfoPtr = engine.functionCallbackInfoPtrManager.GetMockPointer(args);\r\n            try {\r\n                engine.callCSharpFunctionCallback(functionPtr, \r\n                // getIntPtrManager().GetPointerForJSValue(this),\r\n                isStatic ? 0 : engine.csharpObjectMap.getCSIdentifierFromObject(this), callbackInfoPtr, args.length, callbackIdx);\r\n                return engine.functionCallbackInfoPtrManager.GetReturnValueAndRecycle(callbackInfoPtr);\r\n            }\r\n            catch (e) {\r\n                engine.functionCallbackInfoPtrManager.ReleaseByMockIntPtr(callbackInfoPtr);\r\n                throw e;\r\n            }\r\n        };\r\n    }\r\n    callCSharpFunctionCallback(functionPtr, selfPtr, infoIntPtr, paramLen, callbackIdx) {\r\n        this.unityApi._CallCSharpFunctionCallback(functionPtr, infoIntPtr, selfPtr, paramLen, callbackIdx);\r\n    }\r\n    callCSharpConstructorCallback(functionPtr, infoIntPtr, paramLen, callbackIdx) {\r\n        return this.unityApi._CallCSharpConstructorCallback(functionPtr, infoIntPtr, paramLen, callbackIdx);\r\n    }\r\n    callCSharpDestructorCallback(functionPtr, selfPtr, callbackIdx) {\r\n        this.unityApi._CallCSharpDestructorCallback(functionPtr, selfPtr, callbackIdx);\r\n    }\r\n}\r\nexports.PuertsJSEngine = PuertsJSEngine;\r\nfunction GetType(engine, value) {\r\n    if (value === null || value === undefined) {\r\n        return 1;\r\n    }\r\n    if (isBigInt(value)) {\r\n        return 2;\r\n    }\r\n    if (typeof value == 'number') {\r\n        return 4;\r\n    }\r\n    if (typeof value == 'string') {\r\n        return 8;\r\n    }\r\n    if (typeof value == 'boolean') {\r\n        return 16;\r\n    }\r\n    if (typeof value == 'function') {\r\n        return 256;\r\n    }\r\n    if (value instanceof Date) {\r\n        return 512;\r\n    }\r\n    // if (value instanceof Array) { return 128 }\r\n    if (value instanceof Array) {\r\n        return 64;\r\n    }\r\n    if (value instanceof ArrayBuffer || value instanceof Uint8Array) {\r\n        return 1024;\r\n    }\r\n    if (engine.csharpObjectMap.getCSIdentifierFromObject(value)) {\r\n        return 32;\r\n    }\r\n    return 64;\r\n}\r\nexports.GetType = GetType;\r\nfunction makeBigInt(low, high) {\r\n    return (BigInt(high) << 32n) | BigInt(low >>> 0);\r\n}\r\nexports.makeBigInt = makeBigInt;\r\nfunction setOutValue32(engine, valuePtr, value) {\r\n    engine.unityApi.HEAP32[valuePtr >> 2] = value;\r\n}\r\nexports.setOutValue32 = setOutValue32;\r\nfunction setOutValue8(engine, valuePtr, value) {\r\n    engine.unityApi.HEAP8[valuePtr] = value;\r\n}\r\nexports.setOutValue8 = setOutValue8;\r\nfunction isBigInt(value) {\r\n    return value instanceof BigInt || typeof value === 'bigint';\r\n}\r\nexports.isBigInt = isBigInt;\r\nfunction returnBigInt(engine, value) {\r\n    engine.unityApi._setTempRet0(Number(value >> 32n)); // high\r\n    return Number(value & 0xffffffffn); // low\r\n}\r\nexports.returnBigInt = returnBigInt;\r\nfunction writeBigInt(engine, ptrIn32, value) {\r\n    engine.unityApi.HEAP32[ptrIn32] = Number(value & 0xffffffffn); // low\r\n    engine.unityApi.HEAP32[ptrIn32 + 1] = Number(value >> 32n); // high\r\n}\r\nconst tmpInt3Arr = new Int32Array(2);\r\nconst tmpFloat64Arr = new Float64Array(tmpInt3Arr.buffer);\r\nfunction writeNumber(engine, ptrIn32, value) {\r\n    // number in js is double\r\n    tmpFloat64Arr[0] = value;\r\n    engine.unityApi.HEAP32[ptrIn32] = tmpInt3Arr[0];\r\n    engine.unityApi.HEAP32[ptrIn32 + 1] = tmpInt3Arr[1];\r\n}\r\nfunction $FillArgumentFinalNumberValue(engine, val, jsValueType, valPtrIn32) {\r\n    if (val === null || val === undefined) {\r\n        return;\r\n    }\r\n    switch (jsValueType) {\r\n        case 2:\r\n            writeBigInt(engine, valPtrIn32, val);\r\n            break;\r\n        case 4:\r\n            writeNumber(engine, valPtrIn32, +val);\r\n            break;\r\n        case 512:\r\n            writeNumber(engine, valPtrIn32, val.getTime());\r\n            break;\r\n    }\r\n}\r\nfunction $GetArgumentFinalValue(engine, val, jsValueType, lengthOffset) {\r\n    if (!jsValueType)\r\n        jsValueType = GetType(engine, val);\r\n    switch (jsValueType) {\r\n        case 8: return engine.JSStringToCSStringOnStack(val, lengthOffset);\r\n        case 16: return +val;\r\n        case 32: return engine.csharpObjectMap.getCSIdentifierFromObject(val);\r\n        case 64: return jsFunctionOrObjectFactory.getOrCreateJSObject(val).id;\r\n        case 128: return jsFunctionOrObjectFactory.getOrCreateJSObject(val).id;\r\n        case 256: return jsFunctionOrObjectFactory.getOrCreateJSFunction(val).id;\r\n        case 1024: {\r\n            if (val instanceof ArrayBuffer)\r\n                val = new Uint8Array(val);\r\n            let ptr = engine.unityApi._malloc(val.byteLength);\r\n            engine.unityApi.HEAPU8.set(val, ptr);\r\n            setOutValue32(engine, lengthOffset, val.byteLength);\r\n            return ptr;\r\n        }\r\n    }\r\n}\r\n//# sourceMappingURL=library.js.map","\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nconst library_1 = require(\"../library\");\r\n// export function GetNumberFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool): number {\r\n//     return engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n// }\r\n// export function GetDateFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool): number {\r\n//     return (engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value) as Date).getTime();\r\n// }\r\n// export function GetStringFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, /*out int */lengthOffset: number, isByRef: bool): number {\r\n//     var returnStr = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<string>(value);\r\n//     return engine.JSStringToCSString(returnStr, lengthOffset);\r\n// }\r\n// export function GetBooleanFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool): boolean {\r\n//     return engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n// }\r\n// export function ValueIsBigInt(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool): boolean {\r\n//     var bigint = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<any>(value);\r\n//     return bigint instanceof BigInt;\r\n// }\r\n// export function GetBigIntFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool) {\r\n//     var bigint = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<any>(value);\r\n//     return bigint;\r\n// }\r\n// export function GetObjectFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool) {\r\n//     var nativeObject = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n//     return engine.csharpObjectMap.getCSIdentifierFromObject(nativeObject);\r\n// }\r\n// export function GetFunctionFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool): JSFunctionPtr {\r\n//     var func = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<(...args: any[]) => any>(value);\r\n//     var jsfunc = jsFunctionOrObjectFactory.getOrCreateJSFunction(func);\r\n//     return jsfunc.id;\r\n// }\r\n// export function GetJSObjectFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, isByRef: bool) {\r\n//     var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<(...args: any[]) => any>(value);\r\n//     var jsobj = jsFunctionOrObjectFactory.getOrCreateJSObject(obj);\r\n//     return jsobj.id;\r\n// }\r\n// export function GetArrayBufferFromValue(engine: PuertsJSEngine, isolate: IntPtr, value: MockIntPtr, /*out int */lengthOffset: any, isOut: bool) {\r\n//     var ab = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr<ArrayBuffer>(value);\r\n//     if (ab instanceof Uint8Array) {\r\n//         ab = ab.buffer;\r\n//     }\r\n//     var ptr = engine.unityApi._malloc(ab.byteLength);\r\n//     engine.unityApi.HEAP8.set(new Int8Array(ab), ptr);\r\n//     engine.unityApi.HEAP32[lengthOffset >> 2] = ab.byteLength;\r\n//     setOutValue32(engine, lengthOffset, ab.byteLength);\r\n//     return ptr;\r\n// }\r\n/**\r\n * mixin\r\n * JS调用C#时，C#侧获取JS调用参数的值\r\n *\r\n * @param engine\r\n * @returns\r\n */\r\nfunction WebGLBackendGetFromJSArgumentAPI(engine) {\r\n    return {\r\n        /***********这部分现在都是C++实现的************/\r\n        // GetNumberFromValue: GetNumberFromValue.bind(null, engine),\r\n        // GetDateFromValue: GetDateFromValue.bind(null, engine),\r\n        // GetStringFromValue: GetStringFromValue.bind(null, engine),\r\n        // GetBooleanFromValue: GetBooleanFromValue.bind(null, engine),\r\n        // ValueIsBigInt: ValueIsBigInt.bind(null, engine),\r\n        // GetBigIntFromValue: GetBigIntFromValue.bind(null, engine),\r\n        // GetObjectFromValue: GetObjectFromValue.bind(null, engine),\r\n        // GetFunctionFromValue: GetFunctionFromValue.bind(null, engine),\r\n        // GetJSObjectFromValue: GetJSObjectFromValue.bind(null, engine),\r\n        // GetArrayBufferFromValue: GetArrayBufferFromValue.bind(null, engine),\r\n        // GetArgumentType: function (isolate: IntPtr, info: MockIntPtr, index: int, isByRef: bool) {\r\n        //     var value = FunctionCallbackInfoPtrManager.GetByMockPointer(info, engine).args[index];\r\n        //     return GetType(engine, value);\r\n        // },\r\n        // /**\r\n        //  * 为c#侧提供一个获取callbackinfo里jsvalue的intptr的接口\r\n        //  * 并不是得的到这个argument的值\r\n        //  *\r\n        //  * 该接口只有位运算，由C++实现\r\n        //  */\r\n        // GetArgumentValue/*inCallbackInfo*/: function (infoptr: MockIntPtr, index: int) {\r\n        //     return infoptr | index;\r\n        // },\r\n        // GetJsValueType: function (isolate: IntPtr, val: MockIntPtr, isByRef: bool) {\r\n        //     // public enum JsValueType\r\n        //     // {\r\n        //     //     NullOrUndefined = 1,\r\n        //     //     BigInt = 2,\r\n        //     //     Number = 4,\r\n        //     //     String = 8,\r\n        //     //     Boolean = 16,\r\n        //     //     NativeObject = 32,\r\n        //     //     JsObject = 64,\r\n        //     //     Array = 128,\r\n        //     //     Function = 256,\r\n        //     //     Date = 512,\r\n        //     //     ArrayBuffer = 1024,\r\n        //     //     Unknow = 2048,\r\n        //     //     Any = NullOrUndefined | BigInt | Number | String | Boolean | NativeObject | Array | Function | Date | ArrayBuffer,\r\n        //     // };\r\n        //     var value: any = FunctionCallbackInfoPtrManager.GetArgsByMockIntPtr(val, engine);\r\n        //     return GetType(engine, value);\r\n        // },\r\n        /***********以上现在都是C++实现的************/\r\n        GetTypeIdFromValue: function (isolate, value, isByRef) {\r\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n            if (isByRef) {\r\n                // @ts-ignore\r\n                obj = obj[0];\r\n            }\r\n            var typeid = 0;\r\n            if (obj instanceof library_1.JSFunction) {\r\n                typeid = obj._func[\"$cid\"];\r\n            }\r\n            else {\r\n                typeid = obj[\"$cid\"];\r\n            }\r\n            if (!typeid) {\r\n                throw new Error('cannot find typeid for' + value);\r\n            }\r\n            return typeid;\r\n        },\r\n    };\r\n}\r\nexports.default = WebGLBackendGetFromJSArgumentAPI;\r\n//# sourceMappingURL=getFromJSArgument.js.map","\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nconst library_1 = require(\"../library\");\r\n/**\r\n * mixin\r\n * C#调用JS时，获取JS函数返回值\r\n *\r\n * 原有的resultInfo设计出来只是为了让多isolate时能在不同的isolate里保持不同的result\r\n * 在WebGL模式下没有这个烦恼，因此直接用engine的即可\r\n * resultInfo固定为1024\r\n *\r\n * @param engine\r\n * @returns\r\n */\r\nfunction WebGLBackendGetFromJSReturnAPI(engine) {\r\n    return {\r\n        GetNumberFromResult: function (resultInfo) {\r\n            return engine.lastReturnCSResult;\r\n        },\r\n        GetDateFromResult: function (resultInfo) {\r\n            return engine.lastReturnCSResult.getTime();\r\n        },\r\n        GetStringFromResult: function (resultInfo, /*out int */ length) {\r\n            return engine.JSStringToTempCSString(engine.lastReturnCSResult, length);\r\n        },\r\n        GetBooleanFromResult: function (resultInfo) {\r\n            return engine.lastReturnCSResult;\r\n        },\r\n        ResultIsBigInt: function (resultInfo) {\r\n            return (0, library_1.isBigInt)(engine.lastReturnCSResult);\r\n        },\r\n        GetBigIntFromResult: function (resultInfo) {\r\n            // puerts core v2.0.4开始支持\r\n            return (0, library_1.returnBigInt)(engine, engine.lastReturnCSResult);\r\n        },\r\n        GetObjectFromResult: function (resultInfo) {\r\n            return engine.csharpObjectMap.getCSIdentifierFromObject(engine.lastReturnCSResult);\r\n        },\r\n        GetTypeIdFromResult: function (resultInfo) {\r\n            var value = engine.lastReturnCSResult;\r\n            var typeid = 0;\r\n            if (value instanceof library_1.JSFunction) {\r\n                typeid = value._func[\"$cid\"];\r\n            }\r\n            else {\r\n                typeid = value[\"$cid\"];\r\n            }\r\n            if (!typeid) {\r\n                throw new Error('cannot find typeid for' + value);\r\n            }\r\n            return typeid;\r\n        },\r\n        GetFunctionFromResult: function (resultInfo) {\r\n            var jsfunc = library_1.jsFunctionOrObjectFactory.getOrCreateJSFunction(engine.lastReturnCSResult);\r\n            return jsfunc.id;\r\n        },\r\n        GetJSObjectFromResult: function (resultInfo) {\r\n            var jsobj = library_1.jsFunctionOrObjectFactory.getOrCreateJSObject(engine.lastReturnCSResult);\r\n            return jsobj.id;\r\n        },\r\n        GetArrayBufferFromResult: function (resultInfo, /*out int */ length) {\r\n            var ab = engine.lastReturnCSResult;\r\n            var ptr = engine.unityApi._malloc(ab.byteLength);\r\n            engine.unityApi.HEAP8.set(new Int8Array(ab), ptr);\r\n            (0, library_1.setOutValue32)(engine, length, ab.byteLength);\r\n            return ptr;\r\n        },\r\n        //保守方案\r\n        GetResultType: function (resultInfo) {\r\n            var value = engine.lastReturnCSResult;\r\n            return (0, library_1.GetType)(engine, value);\r\n        },\r\n    };\r\n}\r\nexports.default = WebGLBackendGetFromJSReturnAPI;\r\n//# sourceMappingURL=getFromJSReturn.js.map","\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nconst library_1 = require(\"../library\");\r\n/**\r\n * mixin\r\n * 注册类API，如注册全局函数、注册类，以及类的属性方法等\r\n *\r\n * @param engine\r\n * @returns\r\n */\r\nfunction WebGLBackendRegisterAPI(engine) {\r\n    const returnee = {\r\n        SetGlobalFunction: function (isolate, nameString, v8FunctionCallback, jsEnvIdx, callbackidx) {\r\n            const name = engine.unityApi.UTF8ToString(nameString);\r\n            library_1.global[name] = engine.makeCSharpFunctionCallbackFunction(true, v8FunctionCallback, callbackidx);\r\n        },\r\n        _RegisterClass: function (isolate, BaseTypeId, fullNameString, constructor, destructor, jsEnvIdx, callbackidx, size) {\r\n            const fullName = engine.unityApi.UTF8ToString(fullNameString);\r\n            const csharpObjectMap = engine.csharpObjectMap;\r\n            const id = csharpObjectMap.classes.length;\r\n            let tempExternalCSID = 0;\r\n            const ctor = function NativeObject() {\r\n                // 设置类型ID\r\n                this[\"$cid\"] = id;\r\n                // nativeObject的构造函数\r\n                // 构造函数有两个调用的地方：1. js侧new一个它的时候 2. cs侧创建了一个对象要传到js侧时\r\n                // 第一个情况，cs对象ID或者是callV8ConstructorCallback返回的。\r\n                // 第二个情况，则cs对象ID是cs new完之后一并传给js的。\r\n                let csID = tempExternalCSID; // 如果是第二个情况，此ID由createFromCS设置\r\n                tempExternalCSID = 0;\r\n                if (csID === 0) {\r\n                    const args = Array.prototype.slice.call(arguments, 0);\r\n                    const callbackInfoPtr = engine.functionCallbackInfoPtrManager.GetMockPointer(args);\r\n                    // 虽然puerts内Constructor的返回值叫self，但它其实就是CS对象的一个id而已。\r\n                    try {\r\n                        csID = engine.callCSharpConstructorCallback(constructor, callbackInfoPtr, args.length, callbackidx);\r\n                    }\r\n                    catch (e) {\r\n                        engine.functionCallbackInfoPtrManager.ReleaseByMockIntPtr(callbackInfoPtr);\r\n                        throw e;\r\n                    }\r\n                    engine.functionCallbackInfoPtrManager.ReleaseByMockIntPtr(callbackInfoPtr);\r\n                }\r\n                // blittable\r\n                if (size) {\r\n                    let csNewID = engine.unityApi._malloc(size);\r\n                    engine.memcpy(csNewID, csID, size);\r\n                    csharpObjectMap.add(csNewID, this);\r\n                    (0, library_1.OnFinalize)(this, csNewID, (csIdentifier) => {\r\n                        csharpObjectMap.remove(csIdentifier);\r\n                        engine.unityApi._free(csIdentifier);\r\n                    });\r\n                }\r\n                else {\r\n                    csharpObjectMap.add(csID, this);\r\n                    (0, library_1.OnFinalize)(this, csID, (csIdentifier) => {\r\n                        csharpObjectMap.remove(csIdentifier);\r\n                        engine.callCSharpDestructorCallback(destructor || engine.generalDestructor, csIdentifier, callbackidx);\r\n                    });\r\n                }\r\n            };\r\n            ctor.createFromCS = function (csID) {\r\n                tempExternalCSID = csID;\r\n                return new ctor();\r\n            };\r\n            ctor.__puertsMetadata = new Map();\r\n            Object.defineProperty(ctor, \"name\", { value: fullName + \"Constructor\" });\r\n            Object.defineProperty(ctor, \"$cid\", { value: id });\r\n            csharpObjectMap.classes.push(ctor);\r\n            csharpObjectMap.classIDWeakMap.set(ctor, id);\r\n            if (BaseTypeId > 0) {\r\n                ctor.prototype.__proto__ = csharpObjectMap.classes[BaseTypeId].prototype;\r\n            }\r\n            csharpObjectMap.namesToClassesID[fullName] = id;\r\n            return id;\r\n        },\r\n        RegisterStruct: function (isolate, BaseTypeId, fullNameString, constructor, destructor, /*long */ jsEnvIdx, callbackidx, size) {\r\n            return returnee._RegisterClass(isolate, BaseTypeId, fullNameString, constructor, destructor, callbackidx, callbackidx, size);\r\n        },\r\n        RegisterFunction: function (isolate, classID, nameString, isStatic, callback, /*long */ jsEnvIdx, callbackidx) {\r\n            var cls = engine.csharpObjectMap.classes[classID];\r\n            if (!cls) {\r\n                return false;\r\n            }\r\n            var fn = engine.makeCSharpFunctionCallbackFunction(isStatic, callback, callbackidx);\r\n            const name = engine.unityApi.UTF8ToString(nameString);\r\n            if (isStatic) {\r\n                cls[name] = fn;\r\n            }\r\n            else {\r\n                cls.prototype[name] = fn;\r\n            }\r\n        },\r\n        RegisterProperty: function (isolate, classID, nameString, isStatic, getter, \r\n        /*long */ getterjsEnvIdx, \r\n        /*long */ gettercallbackidx, setter, \r\n        /*long */ setterjsEnvIdx, \r\n        /*long */ settercallbackidx, dontDelete) {\r\n            var cls = engine.csharpObjectMap.classes[classID];\r\n            if (!cls) {\r\n                return false;\r\n            }\r\n            const name = engine.unityApi.UTF8ToString(nameString);\r\n            var attr = {\r\n                configurable: !dontDelete,\r\n                enumerable: false\r\n            };\r\n            attr.get = engine.makeCSharpFunctionCallbackFunction(isStatic, getter, gettercallbackidx);\r\n            if (setter) {\r\n                attr.set = engine.makeCSharpFunctionCallbackFunction(isStatic, setter, settercallbackidx);\r\n            }\r\n            if (isStatic) {\r\n                Object.defineProperty(cls, name, attr);\r\n            }\r\n            else {\r\n                Object.defineProperty(cls.prototype, name, attr);\r\n            }\r\n        },\r\n    };\r\n    return returnee;\r\n}\r\nexports.default = WebGLBackendRegisterAPI;\r\n//# sourceMappingURL=register.js.map","\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nconst library_1 = require(\"../library\");\r\n/**\r\n * mixin\r\n * C#调用JS时，设置调用参数的值\r\n *\r\n * @param engine\r\n * @returns\r\n */\r\nfunction WebGLBackendSetToInvokeJSArgumentApi(engine) {\r\n    return {\r\n        //begin cs call js\r\n        PushNullForJSFunction: function (_function) {\r\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n            func.args.push(null);\r\n        },\r\n        PushDateForJSFunction: function (_function, dateValue) {\r\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n            func.args.push(new Date(dateValue));\r\n        },\r\n        PushBooleanForJSFunction: function (_function, b) {\r\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n            func.args.push(!!b);\r\n        },\r\n        PushBigIntForJSFunction: function (_function, /*long */ longlow, longhigh) {\r\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n            func.args.push((0, library_1.makeBigInt)(longlow, longhigh));\r\n        },\r\n        PushStringForJSFunction: function (_function, strString) {\r\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n            func.args.push(engine.unityApi.UTF8ToString(strString));\r\n        },\r\n        PushNumberForJSFunction: function (_function, d) {\r\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n            func.args.push(d);\r\n        },\r\n        PushObjectForJSFunction: function (_function, classID, objectID) {\r\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n            func.args.push(engine.csharpObjectMap.findOrAddObject(objectID, classID));\r\n        },\r\n        PushJSFunctionForJSFunction: function (_function, JSFunction) {\r\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n            func.args.push(library_1.jsFunctionOrObjectFactory.getJSFunctionById(JSFunction)._func);\r\n        },\r\n        PushJSObjectForJSFunction: function (_function, JSObject) {\r\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n            func.args.push(library_1.jsFunctionOrObjectFactory.getJSObjectById(JSObject).getObject());\r\n        },\r\n        PushArrayBufferForJSFunction: function (_function, /*byte[] */ index, length) {\r\n            const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n            func.args.push(engine.unityApi.HEAP8.buffer.slice(index, index + length));\r\n        }\r\n    };\r\n}\r\nexports.default = WebGLBackendSetToInvokeJSArgumentApi;\r\n//# sourceMappingURL=setToInvokeJSArgument.js.map","\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nconst library_1 = require(\"../library\");\r\n/**\r\n * mixin\r\n * JS调用C#时，C#设置返回到JS的值\r\n *\r\n * @param engine\r\n * @returns\r\n */\r\nfunction WebGLBackendSetToJSInvokeReturnApi(engine) {\r\n    return {\r\n        ReturnClass: function (isolate, info, classID) {\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            callbackInfo.returnValue = engine.csharpObjectMap.classes[classID];\r\n        },\r\n        ReturnObject: function (isolate, info, classID, self) {\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            callbackInfo.returnValue = engine.csharpObjectMap.findOrAddObject(self, classID);\r\n        },\r\n        ReturnNumber: function (isolate, info, number) {\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            callbackInfo.returnValue = number;\r\n        },\r\n        ReturnString: function (isolate, info, strString) {\r\n            const str = engine.unityApi.UTF8ToString(strString);\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            callbackInfo.returnValue = str;\r\n        },\r\n        ReturnBigInt: function (isolate, info, longLow, longHigh) {\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            callbackInfo.returnValue = (0, library_1.makeBigInt)(longLow, longHigh);\r\n        },\r\n        ReturnBoolean: function (isolate, info, b) {\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            callbackInfo.returnValue = !!b; // 传过来的是1和0\r\n        },\r\n        ReturnDate: function (isolate, info, date) {\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            callbackInfo.returnValue = new Date(date);\r\n        },\r\n        ReturnNull: function (isolate, info) {\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            callbackInfo.returnValue = null;\r\n        },\r\n        ReturnFunction: function (isolate, info, JSFunctionPtr) {\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            const jsFunc = library_1.jsFunctionOrObjectFactory.getJSFunctionById(JSFunctionPtr);\r\n            callbackInfo.returnValue = jsFunc._func;\r\n        },\r\n        ReturnJSObject: function (isolate, info, JSObjectPtr) {\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            const jsObject = library_1.jsFunctionOrObjectFactory.getJSObjectById(JSObjectPtr);\r\n            callbackInfo.returnValue = jsObject.getObject();\r\n        },\r\n        ReturnCSharpFunctionCallback: function (isolate, info, v8FunctionCallback, \r\n        /*long */ pointerLow, \r\n        /*long */ pointerHigh) {\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            callbackInfo.returnValue = engine.makeCSharpFunctionCallbackFunction(false, v8FunctionCallback, pointerHigh);\r\n        },\r\n        ReturnArrayBuffer: function (isolate, info, /*byte[] */ index, length) {\r\n            var callbackInfo = engine.functionCallbackInfoPtrManager.GetByMockPointer(info);\r\n            callbackInfo.returnValue = engine.unityApi.HEAP8.buffer.slice(index, index + length);\r\n        },\r\n    };\r\n}\r\nexports.default = WebGLBackendSetToJSInvokeReturnApi;\r\n//# sourceMappingURL=setToJSInvokeReturn.js.map","\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nconst library_1 = require(\"../library\");\r\n/**\r\n * mixin\r\n * JS调用C#时，C#侧设置out参数值\r\n *\r\n * @param engine\r\n * @returns\r\n */\r\nfunction WebGLBackendSetToJSOutArgumentAPI(engine) {\r\n    return {\r\n        SetNumberToOutValue: function (isolate, value, number) {\r\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n            obj[0] = number;\r\n        },\r\n        SetDateToOutValue: function (isolate, value, date) {\r\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n            obj[0] = new Date(date);\r\n        },\r\n        SetStringToOutValue: function (isolate, value, strString) {\r\n            const str = engine.unityApi.UTF8ToString(strString);\r\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n            obj[0] = str;\r\n        },\r\n        SetBooleanToOutValue: function (isolate, value, b) {\r\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n            obj[0] = !!b; // 传过来的是1和0\r\n        },\r\n        SetBigIntToOutValue: function (isolate, value, low, high) {\r\n            const obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n            obj[0] = (0, library_1.makeBigInt)(low, high);\r\n        },\r\n        SetObjectToOutValue: function (isolate, value, classID, self) {\r\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n            obj[0] = engine.csharpObjectMap.findOrAddObject(self, classID);\r\n        },\r\n        SetNullToOutValue: function (isolate, value) {\r\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n            obj[0] = null; // 传过来的是1和0\r\n        },\r\n        SetArrayBufferToOutValue: function (isolate, value, /*Byte[] */ index, length) {\r\n            var obj = engine.functionCallbackInfoPtrManager.GetArgsByMockIntPtr(value);\r\n            obj[0] = engine.unityApi.HEAP8.buffer.slice(index, index + length);\r\n        },\r\n    };\r\n}\r\nexports.default = WebGLBackendSetToJSOutArgumentAPI;\r\n//# sourceMappingURL=setToJSOutArgument.js.map","// 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","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\n/**\r\n * 根据 https://docs.unity3d.com/2018.4/Documentation/Manual/webgl-interactingwithbrowserscripting.html\r\n * 我们的目的就是在WebGL模式下，实现和puerts.dll的效果。具体在于实现一个jslib，里面应包含PuertsDLL.cs的所有接口\r\n * 实验发现这个jslib虽然也是运行在v8的js，但对devtool调试并不友好，且只支持到es5。\r\n * 因此应该通过一个独立的js实现接口，puerts.jslib通过全局的方式调用它。\r\n *\r\n * 最终形成如下架构\r\n * 业务JS <-> WASM <-> unity jslib <-> 本js\r\n * 但整条链路其实都在一个v8(jscore)虚拟机里\r\n */\r\nconst library_1 = require(\"./library\");\r\nconst getFromJSArgument_1 = require(\"./mixins/getFromJSArgument\");\r\nconst getFromJSReturn_1 = require(\"./mixins/getFromJSReturn\");\r\nconst register_1 = require(\"./mixins/register\");\r\nconst setToInvokeJSArgument_1 = require(\"./mixins/setToInvokeJSArgument\");\r\nconst setToJSInvokeReturn_1 = require(\"./mixins/setToJSInvokeReturn\");\r\nconst setToJSOutArgument_1 = require(\"./mixins/setToJSOutArgument\");\r\nlibrary_1.global.wxRequire = library_1.global.require;\r\nlibrary_1.global.PuertsWebGL = {\r\n    inited: false,\r\n    debug: false,\r\n    // puerts首次初始化时会调用这里，并把Unity的通信接口传入\r\n    Init(ctorParam) {\r\n        const engine = new library_1.PuertsJSEngine(ctorParam);\r\n        const executeModuleCache = {};\r\n        let jsEngineReturned = false;\r\n        let loader;\r\n        // PuertsDLL的所有接口实现\r\n        library_1.global.PuertsWebGL = Object.assign(library_1.global.PuertsWebGL, {\r\n            updateGlobalBufferAndViews: engine.updateGlobalBufferAndViews.bind(engine)\r\n        }, (0, getFromJSArgument_1.default)(engine), (0, getFromJSReturn_1.default)(engine), (0, setToInvokeJSArgument_1.default)(engine), (0, setToJSInvokeReturn_1.default)(engine), (0, setToJSOutArgument_1.default)(engine), (0, register_1.default)(engine), {\r\n            // bridgeLog: true,\r\n            GetLibVersion: function () {\r\n                return 34;\r\n            },\r\n            GetApiLevel: function () {\r\n                return 34;\r\n            },\r\n            GetLibBackend: function () {\r\n                return 0;\r\n            },\r\n            CreateJSEngine: function () {\r\n                if (jsEngineReturned) {\r\n                    throw new Error(\"only one available jsEnv is allowed in WebGL mode\");\r\n                }\r\n                jsEngineReturned = true;\r\n                return 1024;\r\n            },\r\n            CreateJSEngineWithExternalEnv: function () { },\r\n            DestroyJSEngine: function () { },\r\n            GetLastExceptionInfo: function (isolate, /* out int */ strlen) {\r\n                return engine.JSStringToCSString(engine.lastException.stack, strlen);\r\n            },\r\n            LowMemoryNotification: function (isolate) { },\r\n            IdleNotificationDeadline: function (isolate) { },\r\n            RequestMinorGarbageCollectionForTesting: function (isolate) { },\r\n            RequestFullGarbageCollectionForTesting: function (isolate) { },\r\n            SetGeneralDestructor: function (isolate, _generalDestructor) {\r\n                engine.generalDestructor = _generalDestructor;\r\n            },\r\n            GetModuleExecutor: function () {\r\n                loader = typeof __tgjsGetLoader != 'undefined' ? __tgjsGetLoader() : null;\r\n                const loaderResolve = loader.Resolve ? (function (fileName, to = \"\") {\r\n                    const resolvedName = loader.Resolve(fileName, to);\r\n                    if (!resolvedName) {\r\n                        throw new Error('module not found: ' + fileName);\r\n                    }\r\n                    return resolvedName;\r\n                }) : null;\r\n                var jsfunc = library_1.jsFunctionOrObjectFactory.getOrCreateJSFunction(function (fileName) {\r\n                    if (['puerts/log.mjs', 'puerts/timer.mjs'].indexOf(fileName) != -1) {\r\n                        return {};\r\n                    }\r\n                    if (loaderResolve) {\r\n                        fileName = loaderResolve(fileName, \"\");\r\n                    }\r\n                    if (typeof wx != 'undefined') {\r\n                        const result = wxRequire('puerts_minigame_js_resources/' + (fileName.endsWith('.js') ? fileName : fileName + \".js\"));\r\n                        return result;\r\n                    }\r\n                    else {\r\n                        function normalize(name, to) {\r\n                            if (typeof CS != void 0) {\r\n                                if (CS.Puerts.PathHelper.IsRelative(to)) {\r\n                                    const ret = CS.Puerts.PathHelper.normalize(CS.Puerts.PathHelper.Dirname(name) + \"/\" + to);\r\n                                    return ret;\r\n                                }\r\n                            }\r\n                            return to;\r\n                        }\r\n                        function mockRequire(specifier) {\r\n                            const result = { exports: {} };\r\n                            const foundCacheSpecifier = tryFindAndGetFindedSpecifier(specifier, executeModuleCache);\r\n                            if (foundCacheSpecifier) {\r\n                                result.exports = executeModuleCache[foundCacheSpecifier];\r\n                            }\r\n                            else {\r\n                                const foundSpecifier = tryFindAndGetFindedSpecifier(specifier, PUERTS_JS_RESOURCES);\r\n                                if (!foundSpecifier) {\r\n                                    throw new Error('module not found: ' + specifier);\r\n                                }\r\n                                specifier = foundSpecifier;\r\n                                executeModuleCache[specifier] = -1;\r\n                                try {\r\n                                    PUERTS_JS_RESOURCES[specifier](result.exports, function mRequire(specifierTo) {\r\n                                        return mockRequire(loaderResolve ? loaderResolve(specifierTo, specifier) : normalize(specifier, specifierTo));\r\n                                    }, result);\r\n                                }\r\n                                catch (e) {\r\n                                    delete executeModuleCache[specifier];\r\n                                    throw e;\r\n                                }\r\n                                executeModuleCache[specifier] = result.exports;\r\n                            }\r\n                            return result.exports;\r\n                            function tryFindAndGetFindedSpecifier(specifier, obj) {\r\n                                let tryFindName = [specifier];\r\n                                if (specifier.indexOf('.') == -1)\r\n                                    tryFindName = tryFindName.concat([specifier + '.js', specifier + '.ts', specifier + '.mjs', specifier + '.mts']);\r\n                                let finded = tryFindName.reduce((ret, name, index) => {\r\n                                    if (ret !== false)\r\n                                        return ret;\r\n                                    if (name in obj) {\r\n                                        if (obj[name] == -1)\r\n                                            throw new Error(`circular dependency is detected when requiring \"${name}\"`);\r\n                                        return index;\r\n                                    }\r\n                                    return false;\r\n                                }, false);\r\n                                if (finded === false) {\r\n                                    return null;\r\n                                }\r\n                                else {\r\n                                    return tryFindName[finded];\r\n                                }\r\n                            }\r\n                        }\r\n                        const requireRet = mockRequire(fileName);\r\n                        return requireRet;\r\n                    }\r\n                });\r\n                return jsfunc.id;\r\n            },\r\n            GetJSObjectValueGetter: function () {\r\n                var jsfunc = library_1.jsFunctionOrObjectFactory.getOrCreateJSFunction(function (obj, key) {\r\n                    return obj[key];\r\n                });\r\n                return jsfunc.id;\r\n            },\r\n            Eval: function (isolate, codeString, path) {\r\n                if (!library_1.global.eval) {\r\n                    throw new Error(\"eval is not supported\");\r\n                }\r\n                try {\r\n                    const code = engine.unityApi.UTF8ToString(codeString);\r\n                    const result = library_1.global.eval(code);\r\n                    // return getIntPtrManager().GetPointerForJSValue(result);\r\n                    engine.lastReturnCSResult = result;\r\n                    return /*FResultInfo */ 1024;\r\n                }\r\n                catch (e) {\r\n                    engine.lastException = e;\r\n                }\r\n            },\r\n            SetPushJSFunctionArgumentsCallback: function (isolate, callback, jsEnvIdx) {\r\n                engine.GetJSArgumentsCallback = callback;\r\n            },\r\n            ThrowException: function (isolate, /*byte[] */ messageString) {\r\n                throw new Error(engine.unityApi.UTF8ToString(messageString));\r\n            },\r\n            InvokeJSFunction: function (_function, hasResult) {\r\n                const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n                if (func instanceof library_1.JSFunction) {\r\n                    try {\r\n                        engine.lastReturnCSResult = func.invoke();\r\n                        return 1024;\r\n                    }\r\n                    catch (err) {\r\n                        func.lastException = err;\r\n                        return 0;\r\n                    }\r\n                }\r\n                else {\r\n                    throw new Error('ptr is not a jsfunc');\r\n                }\r\n            },\r\n            GetFunctionLastExceptionInfo: function (_function, /*out int */ length) {\r\n                const func = library_1.jsFunctionOrObjectFactory.getJSFunctionById(_function);\r\n                if (func instanceof library_1.JSFunction) {\r\n                    return engine.JSStringToCSString(func.lastException.stack || func.lastException.message || '', length);\r\n                }\r\n                else {\r\n                    throw new Error('ptr is not a jsfunc');\r\n                }\r\n            },\r\n            ReleaseJSFunction: function (isolate, _function) {\r\n                library_1.jsFunctionOrObjectFactory.removeJSFunctionById(_function);\r\n            },\r\n            ReleaseJSObject: function (isolate, obj) {\r\n                library_1.jsFunctionOrObjectFactory.removeJSObjectById(obj);\r\n            },\r\n            ResetResult: function (resultInfo) {\r\n                engine.lastReturnCSResult = null;\r\n            },\r\n            ClearModuleCache: function () { },\r\n            CreateInspector: function (isolate, port) { },\r\n            DestroyInspector: function (isolate) { },\r\n            InspectorTick: function (isolate) { },\r\n            LogicTick: function (isolate) { },\r\n            SetLogCallback: function (log, logWarning, logError) {\r\n            },\r\n            GetJSStackTrace: function (isolate) {\r\n                return new Error().stack;\r\n            }\r\n        });\r\n    }\r\n};\r\n//# sourceMappingURL=index.js.map"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/unity/Assets/webgl/upm/Javascripts~/PuertsDLLMock/index.ts b/unity/Assets/webgl/upm/Javascripts~/PuertsDLLMock/index.ts index 5d38f1a089b..d0616e265eb 100644 --- a/unity/Assets/webgl/upm/Javascripts~/PuertsDLLMock/index.ts +++ b/unity/Assets/webgl/upm/Javascripts~/PuertsDLLMock/index.ts @@ -236,6 +236,9 @@ global.PuertsWebGL = { LogicTick: function (isolate: IntPtr) { }, SetLogCallback: function (log: IntPtr, logWarning: IntPtr, logError: IntPtr) { + }, + GetJSStackTrace: function (isolate: IntPtr) { + return new Error().stack; } } )