文档列表见:Rust 移动端跨平台复杂图形渲染项目开发系列总结(目录)
(上次更新:2018-12-20 新增【日志颜色】)基于log、env_logger、fern等的使用总结,详细配置建议参考官方说明。
给工程添加第三方日志库依赖
给Cargo.toml文件加上如下配置,log基本为Rust项目日志需求的标配库,env_logger提供了具体实现,类似策略模式:log定义操作,env_logger实现具体行为,很方便切换另一个实现了log所定义接口的库,比如daboross/fern。
[dependencies]
log = "0.4.0"
env_logger = "0.6.0"
复制代码
env_log配置
下面描述我们项目对env_log所作的配置。问题:修改format导致终端执行时日志无颜色。
配置输出时间为本地时间
env_logger默认用0时区,而北京是东8区,每次日志输出都少8小时,时间没对上不方便分析日志。0时区举个例子:
INFO 2018-11-18T02:00:08Z: webgpu-native::registry: env_logger initialized.
复制代码
下面给出env_logger输出本地时间的示例代码,参考了DCjanus/nabu,他用flexi_logger,略调整即可用于env_logger。加上更多自定义信息的关键是修改writeln!
宏。
#[macro_use]
extern crate log;
extern crate chrono;
extern crate env_logger;
fn init_log() {
use chrono::Local;
use std::io::Write;
let env = env_logger::