Commit be0fa4c4fabc542b911b4e4047cd1c8569596879
1 parent
47feef3a
Exists in
master
QLogger alterado para criar diretório caso seja passado um diretório não existen…
…te em addDestination.
Showing
2 changed files
with
23 additions
and
6 deletions
Show diff stats
cacic-teste/testcacic.cpp
... | ... | @@ -266,16 +266,16 @@ void CTestCacic::testColeta() |
266 | 266 | void CTestCacic::testLogger() |
267 | 267 | { |
268 | 268 | QLogger::QLoggerManager *logManager = QLogger::QLoggerManager::getInstance(); |
269 | - logManager->addDestination("./log.txt","teste",QLogger::DebugLevel); | |
269 | + logManager->addDestination("log.txt","teste",QLogger::DebugLevel); | |
270 | 270 | |
271 | - QLogger::QLog_Debug("teste", "Teste do módulo logger."); | |
271 | + QLogger::QLog_Debug("teste", "Teste do modulo logger."); | |
272 | 272 | |
273 | - QFile logFile("./log.txt"); | |
273 | + QFile logFile("log.txt"); | |
274 | 274 | if(logFile.exists()) logFile.open(QIODevice::ReadOnly); |
275 | 275 | |
276 | 276 | QVERIFY(logManager && |
277 | 277 | logFile.exists() && |
278 | - logFile.readLine().contains("Teste do módulo logger.") | |
278 | + logFile.readLine().contains("Teste do modulo logger.") | |
279 | 279 | ); |
280 | 280 | |
281 | 281 | logManager->closeLogger(); | ... | ... |
src/QLogger.cpp
... | ... | @@ -113,6 +113,7 @@ namespace QLogger |
113 | 113 | bool QLoggerManager::addDestination(const QString &fileDest, const QStringList &modules, LogLevel level) |
114 | 114 | { |
115 | 115 | QLoggerWriter *log; |
116 | + | |
116 | 117 | foreach (QString module, modules) |
117 | 118 | { |
118 | 119 | if (!moduleDest.contains(module)) |
... | ... | @@ -139,13 +140,29 @@ namespace QLogger |
139 | 140 | |
140 | 141 | void QLoggerWriter::write(const QString &module, const QString &message) |
141 | 142 | { |
143 | + QString originalDir = QDir::currentPath(); | |
142 | 144 | QString _fileName = m_fileDestination; |
143 | 145 | |
144 | 146 | int MAX_SIZE = 1024 * 1024; |
145 | 147 | |
148 | + | |
149 | + QStringList fileDestSplit = _fileName.split("/"); | |
150 | + QString dirDest; | |
151 | + | |
152 | + for(int i = 0 ; i < fileDestSplit.size() ; ++i ) | |
153 | + { | |
154 | + if( !(i == fileDestSplit.size() - 1) ) // last fileDestSplit element | |
155 | + { | |
156 | + dirDest.append(fileDestSplit[i] + "/"); | |
157 | + } | |
158 | + } | |
159 | + | |
146 | 160 | QDir dir(QDir::currentPath()); |
147 | - if (!dir.exists("logs")) | |
148 | - dir.mkdir("logs"); | |
161 | + | |
162 | + if (!dir.exists(dirDest)) | |
163 | + dir.mkdir(dirDest); | |
164 | + | |
165 | +// dir.cd(dirDest); | |
149 | 166 | |
150 | 167 | QFile file(_fileName); |
151 | 168 | QString toRemove = _fileName.section('.',-1); | ... | ... |