1 /*
2  * Copyright (C) 2012 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License"); you may not
5  * use this file except in compliance with the License. You may obtain a copy of
6  * the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13  * License for the specific language governing permissions and limitations under
14  * the License.
15  */
16 
17 #ifndef CTSAUDIO_LOG_H
18 #define CTSAUDIO_LOG_H
19 
20 #include <stdio.h>
21 #include <iostream>
22 #include <fstream>
23 
24 #include "FileUtil.h"
25 
26 class Log: public FileUtil {
27 public:
28     enum LogLevel {
29         ELogV = 0,
30         ELogD = 1,
31         ELogI = 2,
32         ELogW = 3,
33         ELogE = 4
34     };
35 
36     static Log* Instance(const char* dirName = NULL);
37     static void Finalize();
38 
39 
40     void printf(LogLevel level, const char* fmt, ...);
41     void setLogLevel(LogLevel level);
getLogLevel()42     LogLevel getLogLevel() {
43         return mLogLevel;
44     };
45 private:
46     Log();
47     virtual ~Log();
48     virtual bool init(const char* dirName);
49 
50 private:
51     static Log* mInstance;
52     LogLevel mLogLevel;
53 };
54 
55 #define LOGE(x...) do { Log::Instance()->printf(Log::ELogE, x); \
56     Log::Instance()->printf(Log::ELogE, "  file %s line %d", __FILE__, __LINE__); } while(0)
57 #define LOGW(x...) do { Log::Instance()->printf(Log::ELogW, x); } while(0)
58 #define LOGI(x...) do { Log::Instance()->printf(Log::ELogI, x); } while(0)
59 #define LOGD(x...) do { Log::Instance()->printf(Log::ELogD, x); } while(0)
60 #define LOGV(x...) do { Log::Instance()->printf(Log::ELogV, x); } while(0)
61 
62 #define MSG(x...) do { Log::Instance()->printf(Log::ELogE, x); } while(0)
63 
64 #define ASSERT(cond) if(!(cond)) {  Log::Instance()->printf(Log::ELogE, \
65         "assertion failed %s %d", __FILE__, __LINE__); \
66     Log::Finalize(); \
67     *(char*)0 = 0; /* this will crash */};
68 
69 #endif // CTSAUDIO_LOG_H
70