重定义NSLog

#ifdef TEST_MODE
#define NSLog(...) iydLog(__FILE__, __FUNCTION__, __LINE__, __VA_ARGS__)
#endif


//
//  iydLogWithFile.m
//  ebook
//
//  Created by xiejinniu on 12-7-3.
//  Copyright (c) 2012年 __MyCompanyName__. All rights reserved.
//


#import "iydLogWithFile.h"
#include <sys/stat.h>
#import "systemhelper.h"
#import "ebookAppDelegate.h"


#define KLOG_FILE_MAX_SIZE (5*1024*1024)


static void checkLogFileSizeAndDelete()
{
    struct stat fileStatus = {0};
    const char* logPath = [[SystemHelper GetIYDFileLogPath_str] cStringUsingEncoding:NSUTF8StringEncoding];
    if(stat(logPath, &fileStatus) == -1)
    {
        return;
    }
    
    if (fileStatus.st_size > KLOG_FILE_MAX_SIZE) 
    {
        [[NSFileManager defaultManager] removeItemAtPath:[SystemHelper GetIYDFileLogPath_str] error:nil];
    }
}


void iydLog(const char* file, const char* function, int line, NSString* format, ...)
{
    [[ebookAppDelegate getInstance].logLock lock];


    {
        checkLogFileSizeAndDelete();
        
        va_list args;
        va_start(args, format);
        
        NSMutableString* strContent = [[NSMutableString alloc] initWithFormat:format
                                                                    arguments:args];
        [strContent appendFormat:@"\r\n[file:%s], [function:%s], [line:%d]\r\n\r\n", file, function, line];
        
        NSLogv(format, args);


        const char* cLog = [strContent cStringUsingEncoding:NSUTF8StringEncoding];


        const char* logPath = [[SystemHelper GetIYDFileLogPath_str] cStringUsingEncoding:NSUTF8StringEncoding];


        FILE* filehandle = fopen(logPath, "ab+");
        if (filehandle != NULL) 
        {
            int realsize = fwrite(cLog, 1, strlen(cLog), filehandle);
            if (realsize != strlen(cLog)) 
            {
                NSLogv(@"write log file error!", nil);
            }
        }
        fclose(filehandle);
        
        [strContent release];
        va_end(args);
    }
    
    [[ebookAppDelegate getInstance].logLock unlock];
}

 

转载于:https://www.cnblogs.com/ference/p/3990901.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值