本文最后更新于 2022 天前,其中的信息可能已经有所发展或是发生改变。
经过一周多的苦肝,这个工具终于基本完工了。
实在是懒得写文章了,我把GitHub上面readme的内容复制到这里吧(懒死了)
LLCOM
可运行lua脚本的高自由度串口调试工具。
下载
release页面稳定版:GitHub Release Page
CI自动构建,快照版:Appveyor Artifacts
功能列表
- 其他串口调试功能具有的功能
- 收发日志清晰明了
- 自动保存串口与Lua脚本日志
- 串口断开后,如果再次连接,会自动重连
- 发送的数据可被用户自定义的Lua脚本提前处理
- 右侧快捷发送栏,快捷发送条目数量不限制
- 可独立运行Lua脚本,并拥有定时器与协程任务特性
特色功能示范
使用Lua脚本提前处理待发送的数据
- 结尾加上换行回车
return uartData.."\r\n"
- 发送16进制数据
return uartData:fromHex()
此脚本可将形如30313233
发送数据,处理为0123
的结果
- 更多玩法等你发现
json = require("JSON")
t = uartData:split(",")
return JSON:encode({
key1 = t[1],
key2 = t[2],
key3 = t[3],
})
此脚本可将形如a,b,c
发送数据,处理为{"key1":"a","key2":"b","key3":"c"}
的结果
此处理脚本,同样对右侧快捷发送区域有效。
独立的Lua脚本自动处理串口收发
右侧的Lua脚本调试区域,可直接运行你写的串口测试脚本,如软件自带的:
--注册串口接收函数
uartReceive = function (data)
log.info("uartReceive",data)
sys.publish("UART",data)--发布消息
end
--新建任务,等待接收到消息再继续运行
sys.taskInit(function()
while true do
local _,udata = sys.waitUntil("UART")--等待消息
log.info("task waitUntil",udata)
local sendResult = apiSendUartData("ok!")--发送串口消息
log.info("uart send",sendResult)
end
end)
--新建任务,每休眠1000ms继续一次
sys.taskInit(function()
while true do
sys.wait(1000)--等待1000ms
log.info("task wait",os.time())
end
end)
--1000ms循环定时器
sys.timerLoopStart(log.info,1000,"timer test")
使用此功能,你可以完成大部分的自动化串口调试操作。
接口文档
接口文档可以在这个页面查看
开源
代码逻辑相当难看,如果各位大佬不觉得麻烦的话,欢迎对本项目进行pr或直接重构。
本项目采用Apache 2.0协议,如有借用,请保留指向该项目的链接。