New & Noteworthy 1.2
Add a library documentation to a project
since 1.2M1
By adding a .doclua
file describing an API in Lua Documentation Language in your project source path, you will have auto-completion for described API.
data:image/s3,"s3://crabby-images/b7038/b7038880805c1f9f5922062b8ce9d734e02e983a" alt="ScreenDoclua.png ScreenDoclua.png"
Debugging fix and enhancements
since 1.2M1
Here are some fixes to improve debugging experience and troubleshooting:
- Avoid a crash when evaluating an expression from the watch view.
- Use of interpreter's
LUA_PATH
ifLUA_PATH
environment variable is not available. - The debugger now logs his version and his connection status.
- Better error logging during remote debug sessions.
data:image/s3,"s3://crabby-images/0ec81/0ec81dd9498bfe1f3510ca8db911855967b42820" alt="ScreenDebuggerVersion.png ScreenDebuggerVersion.png"
Extending a type
since 1.2M1
Using the @extend
keyword in a module
or type
will extend it with all fields and functions of given super type. See detailed documentation.
data:image/s3,"s3://crabby-images/13ca5/13ca5747b4526ed8363d2dd40829011798e2b54a" alt="ScreenExtendingType.png ScreenExtendingType.png"
Handling table field
since 1.2M1
On a variable documented with type #table, its fields are now displayed in the outline and available from auto-completion.
Rename
since 1.2M1
Pressing ALT+SHIFT+R
on a Lua variable enables to rename it and all its occurrences.
Integration of Metalua 0.7.2
since 1.2M1
LDT is now based on Metalua 0.7.2
.
Add map/list support
since 1.2M2
Using the #list
or #map
to type a variable or a field. See detailed documentation.
data:image/s3,"s3://crabby-images/5d2fa/5d2fa7c7ad0ca6baed848e2d36591e39e0e5689c" alt="ScreenInlineMap.png ScreenInlineMap.png"
Using map
in-line notation on a field
data:image/s3,"s3://crabby-images/e62d0/e62d0de46375c7d6747144e0cfb44e8fd4fa8a98" alt="ScreenInlineList.png ScreenInlineList.png"
Using list
in-line notation on variable to describe function result
It is also possible to give a map or list behavior to a type by using @map
or @list
keywords.
data:image/s3,"s3://crabby-images/ebc0b/ebc0b7e4be829bcaf4ae930c575b7dc4ff385167" alt="ScreenMap.png ScreenMap.png"
Using @map
on a type
data:image/s3,"s3://crabby-images/60162/601624682b740cae67d57b31eeed185fef174692" alt="ScreenList.png ScreenList.png"
Using @list
on a type
Add __call support
since 1.2M2
Using the @callof
keyword in a function
to make a type callable. See detailed documentation.
data:image/s3,"s3://crabby-images/dab5d/dab5dffc87aca406942629dcfc92d940ea62e276" alt="ScreenCallOf.png ScreenCallOf.png"
@callof
in action
Choose interpreter automatically
since 1.2M2
Interpreters are now linked to Execution Environments, this allows LDT to run applications with a compatible interpreter automatically.
data:image/s3,"s3://crabby-images/34b97/34b97b53e696d34ebb639a208a99498098405fb3" alt="ScreenAddInterpreterEE.png ScreenAddInterpreterEE.png"
Specify an Execution Environment which match your interpreter
data:image/s3,"s3://crabby-images/ca4a8/ca4a80f3c3b8d1b6eb25f03120fd0632a541b3ca" alt="ScreenLaunchConf.png ScreenLaunchConf.png"
You are warned when you launch an application with an inappropriate interpreter
LuaJIT Integration
Now, when you add your LuaJit
to LDT, you can inspect FFI CData.
data:image/s3,"s3://crabby-images/6dbe8/6dbe8bafc9a00bb757317f317a538dd4b2c8a23b" alt="ScreenAddLuaJITInterpreter.png ScreenAddLuaJITInterpreter.png"
Adding a LuaJit
interpreter to LDT
data:image/s3,"s3://crabby-images/6c08e/6c08ee0dc40c3f272301887739755bc8ffeec63f" alt="ScreenLuaJITDebug.png ScreenLuaJITDebug.png"
How Cdata
are displayed in debugger