This commit is contained in:
parent
8070c536d5
commit
09d6f4f0a4
|
@ -481,7 +481,7 @@ bool CmdLineParser::ParseFromArgs(int argc, const char* const argv[])
|
||||||
}
|
}
|
||||||
// experimental --project
|
// experimental --project
|
||||||
else if (std::strncmp(argv[i], "--project=", 10) == 0) {
|
else if (std::strncmp(argv[i], "--project=", 10) == 0) {
|
||||||
_settings.project(argv[i]+10);
|
_settings->importProject(argv[i]+10);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Report progress
|
// Report progress
|
||||||
|
@ -765,7 +765,7 @@ bool CmdLineParser::ParseFromArgs(int argc, const char* const argv[])
|
||||||
}
|
}
|
||||||
|
|
||||||
// Print error only if we have "real" command and expect files
|
// Print error only if we have "real" command and expect files
|
||||||
if (!_exitAfterPrint && _pathnames.empty()) {
|
if (!_exitAfterPrint && _pathnames.empty() && _settings->fileSettings.empty()) {
|
||||||
PrintMessage("cppcheck: No C or C++ source files found.");
|
PrintMessage("cppcheck: No C or C++ source files found.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -154,7 +154,7 @@ bool CppCheckExecutor::parseFromArgs(CppCheck *cppcheck, int argc, const char* c
|
||||||
FileLister::recursiveAddFiles(_files, Path::toNativeSeparators(*iter), _settings->library.markupExtensions(), matcher);
|
FileLister::recursiveAddFiles(_files, Path::toNativeSeparators(*iter), _settings->library.markupExtensions(), matcher);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_files.empty()) {
|
if (_files.empty() && settings.fileSettings.empty()) {
|
||||||
std::cout << "cppcheck: error: could not find or open any of the paths given." << std::endl;
|
std::cout << "cppcheck: error: could not find or open any of the paths given." << std::endl;
|
||||||
if (!ignored.empty())
|
if (!ignored.empty())
|
||||||
std::cout << "cppcheck: Maybe all paths were ignored?" << std::endl;
|
std::cout << "cppcheck: Maybe all paths were ignored?" << std::endl;
|
||||||
|
|
|
@ -20,6 +20,8 @@
|
||||||
#include "preprocessor.h" // Preprocessor
|
#include "preprocessor.h" // Preprocessor
|
||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
#include "tinyxml2.h"
|
#include "tinyxml2.h"
|
||||||
|
#include "path.h"
|
||||||
|
#include "tokenlist.h"
|
||||||
|
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <set>
|
#include <set>
|
||||||
|
@ -321,3 +323,58 @@ bool Settings::platformFile(const std::string &filename)
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Settings::importProject(const std::string &filename) {
|
||||||
|
std::ifstream fin(filename);
|
||||||
|
if (!fin.is_open())
|
||||||
|
return;
|
||||||
|
if (filename == "compile_commands.json") {
|
||||||
|
importCompileCommands(fin);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Settings::importCompileCommands(std::istream &istr) {
|
||||||
|
std::map<std::string, std::string> values;
|
||||||
|
|
||||||
|
TokenList tokenList(this);
|
||||||
|
tokenList.createTokens(istr);
|
||||||
|
for (const Token *tok = tokenList.front(); tok; tok = tok->next()) {
|
||||||
|
if (Token::Match(tok, "%str% : %str% [,}]")) {
|
||||||
|
std::string key = tok->str();
|
||||||
|
std::string value = tok->strAt(2);
|
||||||
|
values[key.substr(1, key.size() - 2U)] = value.substr(1, value.size() - 2U);
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (tok->str() == "}") {
|
||||||
|
if (!values["file"].empty() && !values["command"].empty()) {
|
||||||
|
struct FileSettings fs;
|
||||||
|
fs.filename = Path::fromNativeSeparators(values["file"]);
|
||||||
|
std::string command = values["command"];
|
||||||
|
std::string::size_type pos = 0;
|
||||||
|
while (std::string::npos != (pos = command.find(" ",pos))) {
|
||||||
|
pos++;
|
||||||
|
if (pos >= command.size())
|
||||||
|
break;
|
||||||
|
if (command[pos] != '/' && command[pos] != '-')
|
||||||
|
continue;
|
||||||
|
pos++;
|
||||||
|
if (pos >= command.size())
|
||||||
|
break;
|
||||||
|
char F = command[pos++];
|
||||||
|
std::string fval;
|
||||||
|
while (pos < command.size() && command[pos] != ' ')
|
||||||
|
fval += command[pos++];
|
||||||
|
if (F=='D')
|
||||||
|
fs.defines += fval + ";";
|
||||||
|
else if (F=='U')
|
||||||
|
fs.undefs += fval + ";";
|
||||||
|
else if (F=='I')
|
||||||
|
fs.includes += fval + ";";
|
||||||
|
}
|
||||||
|
fileSettings.push_back(fs);
|
||||||
|
}
|
||||||
|
values.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -322,6 +322,19 @@ public:
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** File settings */
|
||||||
|
struct FileSettings {
|
||||||
|
std::string filename;
|
||||||
|
std::string defines;
|
||||||
|
std::string undefs;
|
||||||
|
std::string includes;
|
||||||
|
};
|
||||||
|
std::list<FileSettings> fileSettings;
|
||||||
|
|
||||||
|
void importProject(const std::string &filename);
|
||||||
|
private:
|
||||||
|
void importCompileCommands(std::istream &istr);
|
||||||
};
|
};
|
||||||
|
|
||||||
/// @}
|
/// @}
|
||||||
|
|
Loading…
Reference in New Issue