# llcom **Repository Path**: MuNet/llcom ## Basic Information - **Project Name**: llcom - **Description**: 可运行lua脚本的串口调试工具,可提前预处理要发送的数据,也可以独立运行lua脚本。支持定时器、协程、任务订阅与发送特性。 - **Primary Language**: C# - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 203 - **Created**: 2019-09-07 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # LLCOM ![icon](/llcom/llcom.ico) [![Build Status](https://chenxuuu.visualstudio.com/llcom/_apis/build/status/chenxuuu.llcom?branchName=master&jobName=Job)](https://chenxuuu.visualstudio.com/llcom/_build/latest?definitionId=1&branchName=master) [![Build status](https://ci.appveyor.com/api/projects/status/telji5j8r0v5001c?svg=true)](https://ci.appveyor.com/project/chenxuuu/llcom) [![MIT](https://img.shields.io/static/v1.svg?label=license&message=Apache+2&color=blue)](https://github.com/chenxuuu/llcom/blob/master/LICENSE) [![code-size](https://img.shields.io/github/languages/code-size/chenxuuu/llcom.svg)](https://github.com/chenxuuu/llcom/archive/master.zip) 可运行lua脚本的高自由度串口调试工具。使用交流群:`906307487` ## 下载 release页面稳定版:[GitHub](https://github.com/chenxuuu/llcom/releases/latest) CI自动构建,快照版:[Appveyor Artifacts](https://ci.appveyor.com/project/chenxuuu/llcom/build/artifacts) ## 功能列表 - 其他串口调试功能具有的功能 - 收发日志清晰明了,同时显示HEX值与实际字符串 - 自动保存串口与Lua脚本日志,并附带时间 - 串口断开后,如果再次连接,会自动重连 - 发送的数据可被用户自定义的Lua脚本提前处理 - 右侧快捷发送栏,快捷发送条目数量不限制 - 可独立运行Lua脚本,并拥有定时器与协程任务特性(移植自[合宙Luat Task架构](http://wiki.openluat.com/doc/luatFramework/)) ![screen](/screen.png) ![screen2](/screen2.jpg) ![screen3](/screen3.png) ## 特色功能示范 ### 使用Lua脚本提前处理待发送的数据 1. 结尾加上换行回车 ```lua return uartData.."\r\n" ``` 2. 发送16进制数据 ```lua return uartData:fromHex() ``` 此脚本可将形如`30313233`发送数据,处理为`0123`的结果 3. 更多玩法等你发现 ```lua 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脚本调试区域,可直接运行你写的串口测试脚本,如软件自带的: ```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") ``` 甚至你可以利用xlua框架的特性,调用C#接口完成任何你想做的事情 ```lua request = CS.System.Net.WebRequest.Create("http://example.com") request.ContentType = "text/html;charset=UTF-8"; request.Timeout = 5000;--超时时间 request.UserAgent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.98 Safari/537.36 Vivaldi/2.2.1388.37"; response = request:GetResponse():GetResponseStream() myStreamReader = CS.System.IO.StreamReader(response, CS.System.Text.Encoding.UTF8); print(myStreamReader:ReadToEnd())--打印获取的body内容 myStreamReader:Close() response:Close() ``` 使用此功能,你可以完成大部分的自动化串口调试操作。 ## 接口文档 接口文档可以在[这个页面](https://github.com/chenxuuu/llcom/blob/master/LuaApi.md)查看 ## 已知问题与待添加的功能(请大家反馈,谢谢!) - [x] ~~bug:快速大量lua任务回调会有概率性报错(主分支)~~ - [x] ~~bug:使用nlua作为框架时,会在调用协程代码时报错(nlua分支代码)~~ - [x] ~~bug:使用vJine.Lua作为框架时,会出现加载失败的情况,原因不明(主分支)~~ - [ ] bug:某些条件下(比如Air720重启),COM口消失后不会被释放,导致无法再次开启该COM口,只能重启软件 ## 常见问题 ### 升级的时候要替换哪几个文件? 点升级就行了,一键升级 ## 开源 如果各位大佬不觉得麻烦的话,欢迎对本项目进行pr或直接重构。 本项目在前期只是为了实现功能,代码相当零散,所以不太适合阅读我的源码进行学习,等我有空的时候会重构代码。 本项目采用Apache 2.0协议,如有借用,请保留指向该项目的链接。