tools/errmsg: generate the function to use when determining if a check should be done or not

This commit is contained in:
Daniel Marjamäki 2009-01-06 16:25:42 +00:00
parent 31f95aeec9
commit 59a644b4b1
1 changed files with 25 additions and 3 deletions

View File

@ -9,12 +9,16 @@ private:
std::string _funcname;
std::string _msg;
std::string _par1;
unsigned int _settings;
public:
Message(std::string funcname, std::string msg, std::string par1)
: _funcname(funcname), _msg(msg), _par1(par1)
Message(std::string funcname, unsigned int settings, std::string msg, std::string par1)
: _funcname(funcname), _settings(settings), _msg(msg), _par1(par1)
{ }
static const unsigned int ALL = 1;
static const unsigned int STYLE = 2;
std::string msg() const
{
std::string ret("\"" + _msg + "\"");
@ -34,12 +38,30 @@ public:
void generateCode() const
{
// Error message..
std::cout << " static std::string " << _funcname << "(";
if (! _par1.empty())
std::cout << "const std::string &" << _par1;
std::cout << ") const\n";
std::cout << " { return " << msg() << "; }" << std::endl;
// Settings..
std::cout << std::endl;
std::cout << " static bool " << _funcname << "(const Settings &s) const" << std::endl;
std::cout << " { return ";
if (_settings == 0)
std::cout << "true";
else
{
if (_settings & ALL)
std::cout << "s._showAll";
if (_settings & (ALL | STYLE))
std::cout << " & ";
if (_settings & STYLE)
std::cout << "s._checkCodingStyle";
}
std::cout << "; }" << std::endl;
}
};
@ -51,7 +73,7 @@ int main()
{
// Error messages..
std::list<Message> err;
err.push_back(Message("memleak", "Memory leak: %1", "varname"));
err.push_back(Message("memleak", 0, "Memory leak: %1", "varname"));
// Generate code..
for (std::list<Message>::const_iterator it = err.begin(); it != err.end(); ++it)