Skip to content

一个可以脱离Xcode的debug,直接在app里,打印内存对象,动态改UI,动态跑oc代码的多功能控制台

Notifications You must be signed in to change notification settings

JPFEI/VKDebugConsole

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 

Repository files navigation

VKDebugConsole

App内控制台,可以在脱离Xcode debug的情况下,调试内存,打印数据,修改UI等

方便在黑盒测试+内部体验的环境下,发现Bug后,直接在Bug现场调试内存,分析问题

先大体看一下GIF动画如何使用

git

Git地址 VKDebugConsole

恩 基于JSPatch做的 ╮(╯_╰)╭

吐槽:界面好难看。。NSLog很多的时候有点乱。。

基本上初步的功能都补全了,能在自己项目里用上了,还算方便

后续优化指令,优化功能,优化界面,还需要持续进行(眼下这个看着太难看,指令也太难用了)

基本使用

  • [VKDebugConsole showBt]方法会在window上增加一个debug按钮

  • 点一下会变成select状态,触摸屏幕中任何view可以选择一个target

  • 选择target后,console控制台打开,按钮变为Hidden

  • 上部分为输入区,输入调试代码

  • 下部分为输出区,输出调试信息,NSLog信息,调试错误(未来还会扩展其他

  • 再次点击Hidden按钮会退出控制台

调试代码

因为是基于JSPatch的,所有JSPatch的语法规则这里都一模一样可以使用,可以参考一下动画中的用法,不过大部分用法还是遵从JSPatch,戳这里看如何使用 JSPatch语法

除了JSPatch支持的基本语法,还支持如下几条命令

  • target():获取刚才通过手选的界面View
  • targetVC()获取刚才通过手选的界面View所在的VC
  • getParentVC(v)输入一个View,获取所在的VC
  • print(item)输出一个对象到控制台,单独处理了Label和View的描述信息,更加方便直观(可以扩展更多单独处理的对象类型)
  • changeSelect()重新手选获取新target
  • exit()退出控制台
  • clearOutput()清空控制台输出区
  • clearInput()清空控制台输入区

支持剪贴板

很明显,在APP黑盒的情况下,写代码是非常不方便的,用手机上面的软键盘,于是支持了剪贴板

  • 打开控制台
  • 在电脑上的编辑器里写好代码
  • 无论以QQ微信等各种形式发到手机上,在手机上复制
  • 切回APP显示控制台的时候,会自动把剪贴板的内容,复制到输入区

支持NSLog

写一个这样的宏在你的pch里面,覆盖NSLog

#ifndef __OPTIMIZE__

#import "VKLogManager.h"

#define NSLog(...) NSLog(__VA_ARGS__);\
                   VKLog(__VA_ARGS__)\

#else
#define NSLog(...) {}

#endif

在执行NSLog的同时,再自动执行一次VKLog,这样所有NSLog的打印就都同时打印在LLDB上和VKDebugConsole上了

支持了 红(出错) 黄(console.log) 白(系统NSlog)三种颜色

开启控制台后,程序再次输出的NSLog也能进入控制台区域方便查看

编译控制

所有的代码在debug模式下会生效,在release模式下会自动不参与编译,直接失效,不用担心发版前忘记关掉代码,导致线上暴露的问题

TODO LIST:

  • 指令更易输入,能支持输入oc的方括号语法
  • 界面更好看点吧,至少整理下控制台输出界面,可读性太差
  • 扩展更多地方便调试的接口和指令
  • 支持网络日志,所有的网络请求接口以及返回数据,会以网络日志的方式,在console里面查询
  • ......

About

一个可以脱离Xcode的debug,直接在app里,打印内存对象,动态改UI,动态跑oc代码的多功能控制台

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Objective-C 93.0%
  • JavaScript 6.7%
  • C 0.3%