这一讲是整体的设计思路。由于需要高度定制显示内容,我选择了Scintilla作为核心编辑器。关于Scintilla,是一款开源的支持很多平台的编辑器引擎,有些著名的编辑器就是建立在Scintilla之上的。下载Scintilla源代码(http://www.scintilla.org/ScintillaDownload.html)。当然Scintilla有其局限性,并不能满足我们的需求。本专题会讲解如何扩展其功能。
本文以Mac OSX上QT编程为例,详细讨论如何定制一款适合你的log阅读分析器。由于QT和Scintilla的可移植性很好,你在Linux或者Windows上可以依葫芦画瓢。这里面会以作者供职的声网(agora)的产品输出log为例讲解如何使用这个log阅读分析器。
日志分析器的需求分析
1. 支持高亮显示感兴趣的信息
2. 支持使用不同的颜色区分不同的信息
3. 在右侧滚动条区域显示这些信息的分布情况
4. 在右侧滚动条区域标记session的开始和结束位置
5. 方便的跳转功能
6. 插入对于log的分析
因此需要对Scintilla做功能扩展,然后主程序实现各种搜索功能。主程序和Scintilla的通讯通过message的方式进行(API文档见http://www.scintilla.org/ScintillaDoc.html#Notifications)。