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 #include <stdio.h>
17 #include <stdarg.h>
18
19 #include "StringUtil.h"
20 #include "Log.h"
21
22 Log* Log::mInstance = NULL;
23
24 #define ASSERT_PLAIN(cond) if(!(cond)) { fprintf(stderr, \
25 "assertion failed %s %d", __FILE__, __LINE__); \
26 *(char*)0 = 0; /* this will crash */};
27
Instance(const char * dirName)28 Log* Log::Instance(const char* dirName)
29 {
30 if (!mInstance) {
31 mInstance = new Log();
32 ASSERT_PLAIN(mInstance->init(dirName));
33 }
34 return mInstance;
35 }
Finalize()36 void Log::Finalize()
37 {
38 delete mInstance;
39 mInstance = NULL;
40 }
printf(LogLevel level,const char * fmt,...)41 void Log::printf(LogLevel level, const char* fmt, ...)
42 {
43 va_list ap;
44 va_start(ap, fmt);
45 FileUtil::doVprintf(level < mLogLevel, level, fmt, ap);
46 va_end(ap);
47 }
48
setLogLevel(LogLevel level)49 void Log::setLogLevel(LogLevel level)
50 {
51 mLogLevel = level;
52 }
53
Log()54 Log::Log()
55 : mLogLevel(ELogV)
56 {
57 ::fprintf(stderr, "Log level %d\n", mLogLevel);
58 }
59
~Log()60 Log::~Log()
61 {
62
63 }
64
init(const char * dirName)65 bool Log::init(const char* dirName)
66 {
67 if (dirName == NULL) {
68 return true;
69 }
70 android::String8 logFile;
71 if (logFile.appendFormat("%s/log.txt", dirName) != 0) {
72 return false;
73 }
74 return FileUtil::init(logFile.string());
75 }
76
77
78
79