栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C语言libwebsockets调试

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C语言libwebsockets调试

        这两天用libwebsockets写了个demo,碰到点问题,发现应用层没有输出libwebsockets的调试信息。于是,查找以下文档找到解决方案:

libwebsockets: Notes about coding with lwshttps://libwebsockets.org/lws-api-doc-master/html/md_README.coding.html

需要做到两点:

编译开关

        编译libwebsockets时,cmake时加上这个参数-DCMAKE_BUILD_TYPE=DEBUG:

cmake .. -DCMAKE_BUILD_TYPE=DEBUG
应用层代码

        应用层调用lws_set_log_level()函数,比如:

lws_set_log_level(LLL_ERR|LLL_WARN|LLL_NOTICE|LLL_INFO|LLL_DEBUG|LLL_PARSER|LLL_HEADER|LLL_EXT|LLL_CLIENT|LLL_LATENCY|LLL_USER, 
NULL);

其原型:

LWS_VISIBLE LWS_EXTERN void 

lws_set_log_level (int level, lws_log_emit_t log_emit_function)

具体参考:libwebsockets: Logginghttps://libwebsockets.org/lws-api-doc-master/html/group__log.html

第一个参数,定义log输出的级别,具体有:

#define LLL_ERR   (1 << 0)


#define 
LLL_WARN   (1 << 1)


#define 
LLL_NOTICE   (1 << 2)


#define 
LLL_INFO   (1 << 3)


#define 
LLL_DEBUG   (1 << 4)


#define 
LLL_PARSER   (1 << 5)


#define 
LLL_HEADER   (1 << 6)


#define 
LLL_EXT   (1 << 7)


#define 
LLL_CLIENT   (1 << 8)


#define 
LLL_LATENCY   (1 << 9)


#define 
LLL_USER   (1 << 10)


#define 
LLL_THREAD   (1 << 11)


#define 
LLL_COUNT   (12)

不设置等级的话,缺省值为7,即LLL_ERR   | LLL_WARN   | LLL_NOTICE   

第二个参数为NULL,缺省输出到stderr,可以重定向到自己的log函数中去。

最后,看下控制台输出效果:

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/511646.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号