Skip to content

Latest commit

 

History

History
90 lines (47 loc) · 2.85 KB

debug-on-phone.md

File metadata and controls

90 lines (47 loc) · 2.85 KB

真机调试

[TOC]

LuaPanda已支持真机调试。我们建议真机调试使用lua库,可以热更下发调试器。

libpdebug.so库默认放置在VSCode插件中,真机调试时可能无法被找到。如果希望使用C库调试,需要把库或是C库源码编译到工程中(Release版本不建议)。

以下是真机调试的两种方法

1. 安卓反向代理调试

  1. 安装adb命令

如果没有安装过安卓SDK,可以下载Platform Tools,其中包含adb命令

https://developer.android.com/studio/releases/platform-tools.html

  1. 设置反向代理

手机通过数据线连接PC,在终端输入

adb reverse tcp:8818 tcp:8818

如果没有报错,手机的8818端口数据会转发到pc的8818端口,实现内网访问。

VSCode 端 Launch.json中的connectionPort也到要是8818(默认),以便接收消息。

  1. 开始调试

启动调试器和APP即可正常调试。

注意: 如中途拔掉手机,重连手机后需要重新输入adb reverse tcp:8818 tcp:8818

2. 局域网调试

  1. 处于同一网络

保证手机和pc连上同一局域网,相互可以ping通。

  1. 修改代码

启动调试器代码,ip改为运行 VSCode 的 pc的 ip 地址。

require("LuaPanda").start("pcIP",8818)
  1. 开始调试

启动调试器和APP即可正常调试。

关于真机调试的说明

  • 当调试lua文件时,当前正在执行的文件路径是由lua虚拟机返回给调试器(http://www.lua.org/manual/5.3/manual.html#lua_getinfo)。

    调试器获得的路径可能是文件的绝对路径,也可能是相对路径。这取决于加载文件时传给lua虚拟机的文件路径。

    如果调试器获得的是绝对路径,那么在命中断点时直接把这个路径传给VSCode。

    如果是相对路径,调试器使用cwd+getinfo拼出完整路径,再传给VSCode。可以调整cwd,以确保拼出的路径是正确的。

  • 如果调试器获得的绝对路径,或者拼接成的路径有偏差(参见 issue #18),我们提供路径映射配置 docPathReplace

    比如lua文件在pc上路径 C:/GameProcect/Assets/script/test.lua 放置在手机里,路径变成了 /data/data/com.project.test/script/test.lua

    在launch.json docPathReplace中设置

    "docPathReplace": ["/data/data/com.project.test/"," C:/GameProcect/Assets/"]

    就可以完成路径映射,把运行环境的/data/data/com.project.test/script/test.lua映射到观察环境C:/GameProcect/Assets/script/test.lua

  • 安卓手机连接windows开启反向代理后,游戏运行会因为attach连接而卡顿。建议准备进行连接时再开反向代理,不需要调试时拔线或者使用下面命令解除反向代理

    adb reverse --remove-all
    

    mac上无此现象。