All notable changes to this package will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
you can get the english version change log at Github Release
- Disable JIT on the HarmonyOS platform.
- Compatibility with higher versions of V8.
- Upgrade QuickJS to the latest version.
- V8 backend, add WebSocket support to QuickJS.
- Add support for lazy loading and automatic unloading in the CJS implementation.
- Resolve the issue of incomplete locking in V8 when defining the THREAD_SAFE macro in the plugin.
- Add compilation support for NS (Nintendo Switch).
- Fix memory leak in clearModuleCache.
- Use the trimmed version by default on Android.
- Feature: Support for specifying whether the Backend is V8 or quickjs through JsEnv parameters.
- Fix: Unity crashes when there are syntax errors in the loaded module during the execution of ExecuteModule in C#.
- Feature: Allow puer.getLastException to retrieve errors from ExecuteModule (#1686).
- Optimization: Refactor quickjs's esm to prevent the mixed use of quickjs api and v8 api in the same function, improving the previous situation where esm was heavily dependent on a certain version of quickjs backend, which prevented the upgrade of quickjs backend. Also, upgrade quickjs backend.
- Fix: Issue of not finding symbols in the nodejs backend under Linux.
- Fix: Issue of failing to load empty module files, fix #1700.
- Optimization: Correct the gc issue of value type parameters, fix #1527.
- Fix: Resolve the String leaks in the quickjs version.
- Feature: Support for HarmonyOS compilation.
- Fix: Encoding.UTF8.GetBytes returns bytes without a 0 at the end, which needs to be added manually, otherwise it will crash under AOT, fix #1691.
- Feature: Record js stack when creating GenericDelegate in the editor, attach the stack when CheckLiveness fails for easy positioning (#1704).
- Feature: Enable debugger support by default during debug builds (#1707).
- Feature: Added support for v8 10.6.194.
- Fix: Avoid properties with the same key in FunctionTemplate, fix #1714.
- Optimization: console.log should output through Console.Error in non-unity environments.
- Optimization: Refactor v8 esm implementation, support top-level-await.
- Feature: Add v8.getHeapStatistics, v8.getHeapSpaceStatistics.
- Optimization: Do not allow the new operator to be used on static functions.
- Fix: Support for Explicit Interface Implementation, fix #1741.
- Fix: quickjs backend js throw null/undefined will cause a crash, fix #1747.
- Optimization: Remove the value field in $Ref, fix #1752.
- Optimization: Increment CtxGroupID for debugging each time (previously a fixed ID might have multiple JsEnv, single JsEnv multiple inspectors might have problems).
- fix: compat with zombieyang/puerts_unity_webgl_demo#53
- fix: the error when invoking extension method with out/ref args.
- fix: the error when set a JSObject to
null
. - fix: the error when getting the arg index when invoking extension method with default arguments value.
- fix: members of valuetype created by paramless ctor will be random value.
- important!: to follow the rules of Assetstore, move the generation menu from
PuerTS
toTools/PuerTS
- feature: support dynamic import (
import()
) #1540 - fix: a bug in access control #1512
- fix: a bug about Interface in DTS generation #1541
- fix: a bug about functions returning Datetime in DTS generation #1565
- fix: a bug in invoking ctors with params in xil2cpp mode #1519
- fix: compating the latest Thread::GetThreadStaticDataForThread in xil2cpp mode #1503
- fix: some generation error in xil2cpp mode #1520
- fix: a memory issue after invoking paramless ctor of valuetype #1563
- fix: defaultParam's value is not as expected when StaticWrapper in generated @ctxdegithub
- fix: could not build puerts with v8_8.4. In Unity2020-, the xil2cpp mode binary with v8_9.4 of android armv7 may not work. #1469
- optimize: combine
libwee8.a
andlibpuerts.a
in android for xil2cpp mode @mingxxming - optimize: use universal binary instead of two binary with different arch in OSX now. @mikejurka
- optimize:
JsEnv
now have a publicIsolate
field to get the pointer ofv8::Isolate
@mingxxming - optimize: remove our
SnapshotBlob.h
. Use v8's builtin snapshot instead. #1477 - optimize: The build script can now run with low Node.js version @xiezheng-XD #1495
- optimize: support inspector by default in Linux @geequlim
- Fix: NestedType was not declared correctly in
link.xml
#1460 - Fix:
out
parameters with ValueType might cause crash in xil2cpp mode. #1460 - Fix: default value of parameters in extension method was not correct in xil2cpp mode #1456
- Fix: JSObject was not recycle correctly
- Fix:
debugpath
was not work and make VSCode debug not availabled - Fix:
puer.$genericMethod
cannot get the genericMethod from super class in xil2cpp mode #1417 @danij91 - Fix:
GetFriendlyName is not a function
when generating extensionInfo #1437
This is the first stable version of 2.0.0
. Shout out to everyone who attending the test.
If you need any help in upgrading. See upgrade guide
- Fix: BlitableCopy was broken issue #1427
- Fix: two wrapper generation issue #1433 #1432
- Fix: struct's paramless default ctor was unable to use #1301
- Fix: op_xxxx method was unable to use after generated #1399
- Fix:
GetFriendlyName
was not defined after generated - Fix: the Constructor of BlittableCopy Type didn't invoked
- Optimization: isESM check optimize #1391
- Fix: Error occurs when generating classes with
op_explicit
#1363. - Fix: Issue with
ClearModuleCache
causing a crash #1364. - Fix: Error in generating when struct produces recursive definition through pointers in xil2cpp mode #1365.
- Fix: Crash when printing struct in xil2cpp mode #1376.
- Fix: Crash when assigning JSObject to numeric type C# Field/Property #1383.
- Fix: Issue with ineffective
Filter
. - Optimization: Changed xil2cpp mode's c plugin code to be generated instead of being included in the package.
- Optimization: Added FAQHelper to optimize code generation and error prompts during build.
- Optimization: Improved error messages for reflection calls, compatible with trimmed interfaces.
- Optimization: Changed the separator for console.log elements from comma to space.
- Optimization: Improved Node.js event loop #1093 #1279.
- Optimization: Suppressed warnings from DefaultMode's StaticWrapper.
- Feature: Added
JSObject.Get<T>(string)
and refactored ExecuteModule to use this Get interface. - Feature: Added Filter for xil2cpp valuetype declaration.
- Fix: the Error message threw from JS to CS would have unexpected character.
- Fix: doc generating fix #1322 #1329
- Fix: if an error is thrown in constructor, some valuetype would become null unexpectly.
- optimize: performance in WebGL is optimized.
- Fix: dts with Enumerable would throw compile error #1322
- To distinguish the meaning between Unity Il2cpp backend, we named the new il2cpp binding mode(v2 mode) to xIl2cpp mode.
- Fix: in xIl2cpp mode, create Puerts.ArrayBuffer in csharp would make its memory unstable. #1340
- Fix: in xIl2cpp mode, it would crash when returning a valuetype in a method with returntype
System.Object
. - Fix: in xIl2cpp mode, it would crash when transfering nullable valuetype. #1320
- Fix: in xIl2cpp mode, it would crash when setting a valuetype to ref/out arguments. #1343
- Register logic refactor: #1317. Now we have a new access control ability.
- Fix: ios Node.js cannot start for PuerTS's openupm version #1302
- Fix: the dependencies of DontBinding methods are still generated in DTS generation #1295
- Fix: some properties only have setters will report errors in wrapper generation #1298
- Fix: several problems with static fields in il2cpp binding mode #1288
- Fix: il2cpp binding mode + Unity2021 will crash when using structs reflecting #1288
- Fix: still cannot find generic classes after link.xml generation #1288
- Feature: add C# Enumerable forof support on JS side #1234
- Feature: refactor old ExecuteModule implementation to be consistent with il2cpp binding mode. At the same time, import 'csharp' and import 'puerts' are no longer supported, and it is recommended to use global variables.
- Feature: add
IResolvableLoader
to implement node_modules loading and solve #1270. - Feature: add
IBuiltinLoadedListener
to allow Loader to do some operations after the built-in script is executed, which is convenient for encapsulating third-party Loader.
- Add a new language binding directly based on il2cpp and there will be huge performance benifit. see our docsite for more information.
- The package layout of unity code in this repository is changed to UPM layout.
- Move the commonjs-support package into this package.
breaking change since 1.x
System.DateTime
will no longer translate toDate
in Javascript #1145- TypedValue could pass to a object only. You will no longer use it to select overload.
- If a method has no overload and default param, PuerTS will not check the type of the params in ReflectionMode(SlowBinding).
- The accessor key of ref object change to
[0]
instead of['value']
. (If all your code was usingpuer.$ref
orpuer.$unref
, it will take no effect) - As what we mentioned in changelog of 1.4: there will be no
require
by default in 2.0.
changelog since 1.4.0
- fix: the crashed after getting a StackOverflowException #1208
- fix: could not get any log in inspector with Node.js backend. #1201
- fix: if a error is thrown in ESM and the message contains line ends, the error message could be incorrect. #1188
- fix: did not filt a obsoleted property setter/getter. #1152
- fix:when passing a JS number to C#
object
. the number would be cut to a Int. - feature: JsEnv.ClearModuleCache can clear ESM module cache now.
- feature: now you can use JSObject to store a JS function. #1143 #1144
- feature: add
EXPERIMENTAL_PUERTS_DISABLE_SLOWBINDING
. It will be useful in somewhere need to do access control. This feature is still experimental and will be changed in the future. - optimize: do not lock the mutex when destroying a JSFunction or JSObject.
- fix: could not get any log in inspector with Node.js backend. #1201
- fix: if a error is thrown in ESM and the message contains line ends, the error message could be incorrect. #1188
- optimize: do not lock the mutex when destroying a JSFunction.
- feature: JsEnv.ClearModuleCache can clear ESM module cache now.
- fix: did not filt a obsoleted property setter/getter. #1152
- feature: add console.time. #1170
- feature: now you can use JSObject to store a JS function. #1143 #1144
- fix:when passing a JS number to C#
object
. the number will be cut to a Int. - feature: add
PUERTS_DISABLE_SLOWBINDING
. It will be useful in somewhere need to do access control.
- fix: requiring failed when searching directory named with
.
- fix:ts error when some methods are returning Task without GenericType #1027
- fix:Nested class in Generic class will cause error in StaticWrapper #1030
- fix:illegal unity api access erro when creating JsEnv not in main thread#1049
- fix:
IsByRefLike
missing error in Unity2021.1 #1050 - feature:add support for Android x86_64 (v8/quickjs)
- feature:add
Puerts.IModuleChecker
. if yourILoader
implement this interface. Then you can indicate which extname of jsfile will be treated as ESM Module.
- support ambigious methods calling after generated staticwrapper. #1020
- fix a bug that after blittablecopy staticwrapper generated, passing two or more struct from C# to a JSFunction will get wrong JS arguments #1018
- fix Array Type arguments will cause error in staticwrapper #1015
- refactor the template of wrapper and get a little performance improvement report
- add missing '--jitless' flag for ios PuerTS with nodejs backend
- full platform support for Node.js (i.e. Android and iOS support added). upm package now uses Node.js Backend by default.
- In order to make the Node.js function more convenient to use, and also to solve the problem of WebGL version in WeChat mini-game, from this version on, add global variables
CS
andpuer
, corresponding to the originalrequire('csharp')
andrequire('puerts')
. Please change the using ofrequire
toglobal.CS
,global.puer
,import 'xxx'
. Therequire
in PuerTS will be considered to be removed in version 1.5. - Add
JsEnv.Backend
and add some GC API.LowMemoryNotification
has moved into it too. - refactor
NodeRunner
ExecuteModule
handling of multi-level dependencies fixed.- GeneralSetterManager/GeneralGetterManager optimization #688
- fix the bug that inspector break point +
setInterval
will cause crash #707 - support multiple inspectors connection for one single JsEnv,
hotreload
can also be used with inspector at the same time now #841 - remove
Node.js backend
's--no-browser-globals
- fix the problem that circular dependency will cause crash when loading ESM
- fix the problem that ESM throws error when loading dependency with relative path
- add
import.meta.url
when module is loading - fix the problem that dts reports an error when generating nullable types
- support multi inspector client
- fix the inspector crash problem in unity2021.3.4+
- fix #708
- disable generic wrapper in unity2018-
- downgrade the v8 to 8.4 in android、ios building. to avoid #908
- fix #907
- merge 1.3.5
- fix #899
- fix android arm64 plugin meta
- support apple silicon #591
- upgrade the default v8 to 9.4,nodejs to 16
- make all members become configurable #667
- add
require('puerts').getLastException
to get the Error instance #629 - change LC_RPATH setter to support silicon
- fix: didn't check NativeObject's type when setting fields. #954
- fix: easy to cause
task.GetAwaiter(...).OnCompleted is not a function
error in Unity's Ilcpp mode #966 - optimize: the memory usage for JSObject #947
- optimize: disable setting constructor's BindingMode to Lazy
- optimize: disable reflect extension feature in Editor's Playmode
- disable generic wrapper by default in 1.3 #937 #918
- fix: arguments number mismatch when generating BlittableCopy #938
- fix: MJSImporter will cause warning in 2018
- fix: #912
- fix: UnityMenu.cs code bug fix.
- fix: thrown error when generating generic type with constrained generic argument.
- fix: duplicated key error during generating: #657
- fix: cannot $generic a Type with Enum #856
- fix: did not filter the pointer type in delegate during generating: #857
- fix: in the d.ts, the return type of an interface's extension method would be wrong: #857
- fix: do not generate extension method for enum #857
- fix: some order of parameters with ArrayBuffer will throw an Error. #853
- feature: support invoking generic method without constraint: #819
- feature: the wrapper file of a generic type can now combine into one single file. #816
- feature: TypedValue can now pass to the argument of the corresponding type. #833
- optimize: add a reusable Github action for downloading JS backend artifact.
- optimize: can download the backend file by a URL in action.
- the module csharp in d.ts will use export = just like what Node.js did #750
- fix: ignored assemblies which path is with Editor when generating extension method #735
- add try catch for builtin script running. and will destroy the jsengine when error is thrown.
- the Debug build of Plugin will now have the global.gc function.
- fix: some event members did not generated as LazyMember #739
- fix: some parameters with in modifier would use ref modifier to invoke in the generated code. #758
- fix: the op_Implicit method could not be called #767
- fix: unity would not ignore iOS library when in Android Mode.
- fix: old filter wrongly return BindingMode.SlowBinding
- add .asmdef in main repository
- rearrange the directory layout to support UPM
- Generator refactored. Generator is seperated to many small file now.
- Rename LibVersion to ApiLevel。
- JSFunction::Invoke refactored,fix #681 。
- Deleted some deprecated v8 calls. to make puerts compat with v8 8.4++。
- New concept
LazyBinding
: In 1.3- when you writereturn false
in filter for some c# member. That member will still do TypeRegist by reflection could be call during runtime. Now, this feature will still work. But that kind of member will do reflection during first invoke but not during TypeRegister. - New form of
filter
To compat with the newLazyBinding
mode.Filter
now can not only return a boolean but can return aBindingMode
. Which is a enum inculdeFastBinding
(means will generate static wrapper)、LazyBinding
(mentioned above)、DontBinding
(can not be called during runtime)。you can find an example inU2018Compatible.cs