CocoaLumberjack 和 XcodeColors 的使用

CocoaLumberjack的安裝應(yīng)該沒什么問題蚪拦,具體使用如下:

先初始化一下状原,添加輸出到控制臺(tái)和系統(tǒng)控制臺(tái)的 logger挚赊。


[DDLog addLogger:[DDTTYLogger sharedInstance]]; //  Xcode控制臺(tái)

// 輸出到控制臺(tái)的可以有顏色藻三,但是依賴于XcodeColors(裝了就行)洪橘,后面講XcodeColors

[[DDTTYLogger sharedInstance] setColorsEnabled:YES]; 

[DDLog addLogger:[DDASLLogger sharedInstance]]; // 系統(tǒng)控制臺(tái)

輸出到文件的


NSString*path = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES) lastObject];

DDLogFileManagerDefault *fileManager = [[DDLogFileManager Defaultalloc] initWithLogsDirectory:path]; 

// 如果不指定路徑,直接 new 一個(gè)fileLogger棵帽,會(huì)把日志存到電腦資源庫的一個(gè)文件夾里(忘了具體哪 兒)熄求,日志名稱是項(xiàng)目的 BundleId + 日期,

DDFileLogger *fileLogger = [[DDFileLogger alloc] initWithLogFileManager:fileManager];

fileLogger.rollingFrequency = 3600*24; // 日志滾動(dòng)頻率逗概,單位是秒弟晚。這里每天會(huì)創(chuàng)建一個(gè)新的日志

// 日志文件的最大大小。如果在設(shè)置的刷新時(shí)間之前大小已經(jīng)滿了,就會(huì)重新創(chuàng)建一個(gè)日志卿城,時(shí)間重新計(jì)算枚钓。

fileLog.maximumFileSize=1024*1024; 

[[fileLogger logFileManager] setMaximumNumberOfLogFiles:7]; // 最大日志文件數(shù)。

[DDLog addLogger:fileLogger];

輸出的調(diào)試信息格式是可以改的瑟押,比如改成這樣:

image

新建一個(gè)類繼承自NSObject搀捷,遵守<DDLogFormatter>協(xié)議,實(shí)現(xiàn)協(xié)議的- (NSString)formatLogMessage:(DDLogMessage)logMessage;方法多望。


- (NSString *)formatLogMessage:(DDLogMessage *)logMessage {

// 時(shí)間

NSDateFormatter *dateF = [[NSDateFormatter alloc]init];

dateF.dateFormat = @"yyyy-MM-dd HH:mm:ss.SSS";

NSString *time = [dateF stringFromDate:logMessage.timestamp];

// 文件名

NSArray *pathComponents = [logMessage.file componentsSeparatedByString:@"/"];

NSString *file = @"^No File^";

if (pathComponents.count > 0) {

file = [pathComponents lastObject];

}

NSString *newLogMessage = [NSString stringWithFormat:@"\n%@ %@ %@:%ld\n%@",time,file,logMessage.function,logMessage.line,logMessage.message];

return newLogMessage;

}

然后在添加 Logger 的時(shí)候:


PrivateLogFormatter *logFormatter = [[PrivateLogFormatter alloc] init];

[DDTTYLogger sharedInstance].logFormatter = logFormatter;

fileLogger.logFormatter = logFormatter;

這樣控制臺(tái)和文件日志的輸出格式就改了嫩舟。

XcodeColors是專門針對(duì) Xcode 控制臺(tái)輸出變顏色用的,如果不是通過插件安裝怀偷,那么需要先編譯一下家厌。具體:打開XcodeColors,command + B 編譯椎工,關(guān)掉饭于,退出 Xcode。打開終端维蒙,cd 到XcodeColors的目錄镰绎,輸入 ./update_compat.sh 執(zhí)行腳本文件。重新打開Xcode木西,會(huì)提示是否使用插件畴栖。安裝完后,需要設(shè)置環(huán)境變量

image
image

從 XcodeColors 的 TestXcodeColors 文件夾的 AppDelegate.m 中把宏定義和輸出示例代碼都復(fù)制過來八千。如果是通過插件下的吗讶,那么宏定義如下:


#define XCODE_COLORS_ESCAPE_MAC @"\033["

#define XCODE_COLORS_ESCAPE_IOS @"\xC2\xA0["

#if TARGET_OS_IPHONE

#define XCODE_COLORS_ESCAPEXCODE_COLORS_ESCAPE_IOS

#else

#define XCODE_COLORS_ESCAPEXCODE_COLORS_ESCAPE_MAC

#endif

#define XCODE_COLORS_RESET_FGXCODE_COLORS_ESCAPE @"fg;"http:// Clear any foreground color

#define XCODE_COLORS_RESET_BGXCODE_COLORS_ESCAPE @"bg;"http:// Clear any background color

#define XCODE_COLORS_RESETXCODE_COLORS_ESCAPE @";"http:// Clear any foreground or background color

#define LogBlue(frmt, ...) NSLog((XCODE_COLORS_ESCAPE @"fg0,0,255;" frmt  XCODE_COLORS_RESET), ##__VA_ARGS__)

輸出示例代碼:


NSLog(@"After building the XcodeColors plugin for the first time, you MUST RESTART XCODE.");

NSLog(@"If you still don't see colors below, please consult the README.");

NSLog(XCODE_COLORS_ESCAPE @"fg0,0,255;" @"Blue text" XCODE_COLORS_RESET);

NSLog(XCODE_COLORS_ESCAPE @"bg220,0,0;" @"Red background" XCODE_COLORS_RESET);

NSLog(XCODE_COLORS_ESCAPE @"fg0,0,255;"

XCODE_COLORS_ESCAPE @"bg220,0,0;"

@"Blue text on red background"

XCODE_COLORS_RESET);

NSLog(XCODE_COLORS_ESCAPE @"fg209,57,168;" @"You can supply your own RGB values!" XCODE_COLORS_RESET);

LogBlue(@"Blue text via macro");

然后就可以輸出看效果了。

image

如果控制臺(tái)的輸出還是沒看到顏色恋捆,那改一下宏定義的一個(gè)地方:

image

這是因?yàn)?¥@照皆,算了不重要,能看到效果就行了沸停。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末膜毁,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子愤钾,更是在濱河造成了極大的恐慌瘟滨,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件能颁,死亡現(xiàn)場(chǎng)離奇詭異杂瘸,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)伙菊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門败玉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來敌土,“玉大人,你說我怎么就攤上這事运翼》蹈桑” “怎么了?”我有些...
    開封第一講書人閱讀 152,702評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵血淌,是天一觀的道長(zhǎng)矩欠。 經(jīng)常有香客問我,道長(zhǎng)六剥,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,259評(píng)論 1 279
  • 正文 為了忘掉前任峰伙,我火速辦了婚禮疗疟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘瞳氓。我一直安慰自己策彤,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,263評(píng)論 5 371
  • 文/花漫 我一把揭開白布匣摘。 她就那樣靜靜地躺著店诗,像睡著了一般。 火紅的嫁衣襯著肌膚如雪音榜。 梳的紋絲不亂的頭發(fā)上庞瘸,一...
    開封第一講書人閱讀 49,036評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音赠叼,去河邊找鬼擦囊。 笑死,一個(gè)胖子當(dāng)著我的面吹牛嘴办,可吹牛的內(nèi)容都是我干的瞬场。 我是一名探鬼主播,決...
    沈念sama閱讀 38,349評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼涧郊,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼贯被!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起妆艘,我...
    開封第一講書人閱讀 36,979評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤彤灶,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后批旺,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體枢希,經(jīng)...
    沈念sama閱讀 43,469評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,938評(píng)論 2 323
  • 正文 我和宋清朗相戀三年朱沃,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了苞轿。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片茅诱。...
    茶點(diǎn)故事閱讀 38,059評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖搬卒,靈堂內(nèi)的尸體忽然破棺而出瑟俭,到底是詐尸還是另有隱情,我是刑警寧澤契邀,帶...
    沈念sama閱讀 33,703評(píng)論 4 323
  • 正文 年R本政府宣布摆寄,位于F島的核電站,受9級(jí)特大地震影響坯门,放射性物質(zhì)發(fā)生泄漏微饥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,257評(píng)論 3 307
  • 文/蒙蒙 一古戴、第九天 我趴在偏房一處隱蔽的房頂上張望欠橘。 院中可真熱鬧,春花似錦现恼、人聲如沸肃续。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽始锚。三九已至,卻和暖如春喳逛,著一層夾襖步出監(jiān)牢的瞬間瞧捌,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工润文, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留察郁,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,501評(píng)論 2 354
  • 正文 我出身青樓转唉,卻偏偏與公主長(zhǎng)得像皮钠,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子赠法,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,792評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容