VSCode 使用 EmmyLua 对lua进行调试

server/2024/10/18 22:27:34/

时间:2024年10月
其他:win10,EmmyLua v0.8.20

参考:https://blog.csdn.net/ShenHaoDeHao/article/details/140268354

有几个概念搞清楚就好理解了。一般开发中,我们编写的lua文件由宿主程序的来解析、执行;当然对于我们写的单个的测试文件,我们直接使用 lua.exe test.lua 运行即可,这里可以认为lua.exe 就是宿主程序。

EmmyLua 通过在lua代码中加载 emmy_core.dll到宿主程序中,并启动调试内核代码。调试内核通过socket与VSCode侧连互通;通信有Server端和Client端角色之分。默认情况下:

  • IDE connect Debugger 即被调试的程序充当Server端,这时被调试的程序应先启动,再启动IDE侧的调试功能连接到调试内核

另外一种就是:

  • Debugger connect IDE 即IDE充当Server侧,这时应先启动IDE侧的调试功能,等待被调试的程序启动并主动连接到IDE

我们做个简单的测试,在vscode的搜索、安装EmmyLua扩展。我们新建一个testLua文件夹,拖入vscode中打开,新建hello.lua文件:

lua">print("hello!")

点击vscode 右上角的 Toggle Panel ,IDE下方切换到终端页签,输入 lua .\hello.lua ,回车,发现可以打印出“hello!”。
在这里插入图片描述
如果报错,找不到lua,网上搜索安装lua for windows 即可。

接下来进行调试前,我们要在lua代码中引入 EmmyLua 的 Debug 代码。 ctrl + p打开搜索输入>EmmyLua,选择Insert Emmy Debugger Code,然后根据宿主程序需要选择 x86/x64即可(我这里选择x86,选完后运行如果有问题就修改插入代码的路径试试另外一个):
在这里插入图片描述

插入后代码如下:

lua">package.cpath = package.cpath .. ";c:/Users/xxxx/.vscode/extensions/tangzx.emmylua-0.8.20-win32-x64/debugger/emmy/windows/x86/?.dll"
local dbg = require("emmy_core")
dbg.tcpListen("localhost", 9966)print("hello!")

可以看到这里有个tcpListen,说明lua代码这边是Server端,IDE进行调试时lua代码的宿主程序需要处于运行状态,一般在游戏开发中没有问题,但是我们的测试代码很快就运行完成并退出了,所以我们这里 使用【Debugger connect IDE】的方式:这里的tcpListen 改成 tcpConnect

我们按照下图步骤生成launch.json文件:
F5
我们需要把这个文件里的ideConnectDebugger值改成false
在这里插入图片描述
接下来就可以调试了,我们在 print("hello!") 前打断点,按F5启动调试器,再在终端页签,输入 lua .\hello.lua 执行即可命中断点:
在这里插入图片描述

EmmyLua 还有许多其他功能,需要注意的是EmmyLua为了支持其他IDE,大部分的配置文件需要配置在项目的工作区顶层目录的.emmyrc.json中,具体的配置说明如下:

{"completion": {"autoRequire": true,"autoRequireFunction": "require","autoRequireNamingConvention": "camelCase","callSnippet": false,"postfix": "@"},"signature": {"detailSignatureHelper": false},"diagnostics": {"disable": [],"globals": [],"globalsRegex": [],"severity": {},"enables": []},"hint": {"paramHint": true,"indexHint": true,"localHint": true,"overrideHint": true},"runtime": {"version": "Lua5.4","requireLikeFunction": [],"frameworkVersions": [],"extensions": [],"requirePattern": []},"workspace": {"ignoreDir": [],"ignoreGlobs": [],"library": [],"workspaceRoots": [],"preloadFileSize": 1048576,"encoding": ""},"resource": {"paths": []},"codeLens": {"enable": true},"strict": {"requirePath": false,"typeCall": true}
}

completion

  • autoRequire: 是否自动补全 require 语句,默认为 true。
  • autoRequireFunction: 自动补全 require 语句时使用的函数名,默认为 require。
  • autoRequireNamingConvention: 自动补全 require 语句时使用的命名规范,默认为 camelCase, 可选值为 camelCase, snakeCase, pascalCase。
  • callSnippet: 是否使用代码片段补全函数调用,默认为 false。
  • postfix: 补全时的后缀,默认为 @。但是设置该选项暂时无用

signature

  • detailSignatureHelper: 是否显示详细的函数签名帮助,默认为 false。

diagnostics

  • disable: 禁用的诊断信息列表, 如果需要工作区内禁用一些诊断消息, 需要填上对应诊断的id, 例如: “undefined-global”
  • globals: 全局变量列表, 在该列表中的全局变量不会被诊断为未定义.
  • globalsRegex: 全局变量正则表达式列表, 符合正则表达式的全局变量不会被诊断为未定义.
  • severity: 诊断消息的严重程度, 例如: “undefined-global”: “warning”, 可选值为 “error”, “warning”, “information”, “hint”.
  • enables: 启用的诊断信息列表, 语言服务的诊断不是全部都启用的, 可以通过该选项启用一些诊断消息. 例如: “undefined-field”

hint

  • paramHint: 是否显示参数提示,默认为 true。
  • indexHint: 在索引表达式跨行时, 是否显示hint,默认为 true。
  • localHint: 是否显示局部变量提示,默认为 true。
  • overrideHint: 是否显示重载提示,默认为 true。

runtime

  • version: 运行时版本, 默认为 Lua5.4, 可选值为 Lua5.1, Lua5.2, Lua5.3, Lua5.4, LuaJIT.
  • requireLikeFunction: 类似 require 的函数列表, 用于识别类似 require 的函数, 例如: [“import”].
  • frameworkVersions: 框架版本列表, 用于识别框架版本, 例如: [“love2d”]. 可以和emmylua doc 的version标签配合使用.
  • extensions: 文件扩展名列表, 用于识别文件扩展名, 例如: [“.lua”, “.lua.txt”].
  • requirePattern: require 模式列表, 该参数和lua中的package.path和package.cpath有关, 例如: [“?.lua”, “?.lua.txt”]. 默认不需要填写, 将自动拥有, [“?.lua”, “?/init.lua”].

workspace

工作区配置, 大部分工作区配置本身既支持相对路径也支持绝对路径

  • ignoreDir: 忽略的目录列表, 用于忽略一些目录, 例如: [“build”, “dist”].
  • ignoreGlobs: 忽略的文件列表, 基于正则表达式的忽略一些文件, 例如: [“.log", ".tmp”].
  • library: 库文件目录列表, 用于指定一些库文件, 例如: [“/usr/local/lib”].
  • workspaceRoots: 工作区根目录列表, 用于指定工作区的根目录, 例如: [“Assets/script/Lua”]. 该功能主要是为了让require正常工作, 如果必须要打开lua主目录的上级目录, 需要在这里添加当前打开的目录相对于lua主目录的相对路径.
  • preloadFileSize: 预加载文件大小, 默认为 1048576 字节, 用于控制预加载文件的大小.
  • encoding: 文件编码, 默认为 utf-8, 用于读取文件时的编码.

resource

  • paths: 资源路径列表, 用于指定需要加载的资源的根目录, 例如: [“Assets/settings”]. 其默认值为当前打开的工作区目录, emmylua支持在任意字符串中的文件路径补全, 以及任意字符串中的文件路径跳转. 通过配置这个目录, 可以让emmylua知道哪些目录是资源目录, 从而正确的提供补全和跳转.

codeLens

  • enable: 是否启用CodeLens功能, 默认为 true.

strict

  • requirePath: 是否启用require严格模式, 默认为 true. 严格模式时, require必须从指定的根目录开始, 否则无法跳转
  • typeCall: 是否启用类型调用时严格模式, 默认为 true. 严格模式时, 类型调用必须手动写好重载, 否则返回unknown, 非严格模式时, 类型调用会返回自身

http://www.ppmy.cn/server/131385.html

相关文章

GAMES104:16 游戏引擎的玩法系统:基础AI-学习笔记

文章目录 一,寻路/导航系统Navigation1.1 Walkable Area1.1.1 Waypoint Network1.1.2 Grid1.1.3 Navigation Mesh1.1.4 Sparse Voxel Octree 1.2 Path Finding1.2.1 Dijkstra Algorithm迪杰斯特拉算法1.2.2 A Star(A*算法) 1.3 Path Smoothin…

ADS时域 连续相位观察方法

🏆本文收录于《全栈Bug调优(实战版)》专栏,主要记录项目实战过程中所遇到的Bug或因后果及提供真实有效的解决方案,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&am…

用C++编写信息管理系统(歌单信息管理)

C语言是面向过程的编程语言,而C是面向对象的编程语言,在书写代码时风格有所不同(也存在很多共性)。 程序说明 本次系统程序使用的是C语言进行编写,主要考虑怎么实现面向对象的问题。 因为本次程序属于小型系统程序&…

基于Spring Boot的医疗病历交互系统开发指南

第2章 设计技术与开发环境 2.1 相关技术介绍 2.1.1 B/S模式分析 C/S模式主要由客户应用程序(Client)、服务器管理程序(Server)和中间件(middleware)三个部件组成。客户应用程序是系统中用户与数据组件交互。服务器程序负责系统资源,如管理信息数据库的有效管理&…

大数据毕业设计选题推荐-王者荣耀战队数据分析-Python数据可视化-Hive-Hadoop-Spark

✨作者主页:IT研究室✨ 个人简介:曾从事计算机专业培训教学,擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Python…

ReactRouter快速梳理

快速开始 创建项目并安装所有依赖 npx create-react-app react-router-pro安装最新的reactrouter包 npm i react-router-dom启动项目 npm run start搭建路由(index.js) //index.js项目的入口 从这里开始运行//react必要的两个核心包 import React from react; impo…

MokeJs使用实例

文章目录 MokeJs使用实例介绍使用安装配置文件导入配置到main.js使用 axios 发送网络请求测试(如果不会axios,具体可以见上篇文章axios)启动示例 MokeJs使用实例 介绍 使用 安装 npm install mockjs --save-dev # 或者 yarn add mockj…

Base16编码解码在线工具

具体请前往:在线Base16编码/解码工具-支持utf-8,Latin1,ascii,GBK,Hex等编码