fleshing out Config::read() more
git-svn-id: http://apu.dw.local/svnusers/JoshHoltrop/pppc/trunk@53 8131a0b2-b21c-1c47-bd6a-f003126495bd
This commit is contained in:
parent
874021f94f
commit
3c22f00c7d
89
Config.cc
89
Config.cc
@ -1,5 +1,6 @@
|
|||||||
|
|
||||||
#include "Config.h"
|
#include "Config.h"
|
||||||
|
#include "trim.h"
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <string>
|
#include <string>
|
||||||
@ -15,15 +16,76 @@ Config::Entry::Entry(const string & name)
|
|||||||
on_unlock = NONE;
|
on_unlock = NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Config::Config()
|
||||||
|
{
|
||||||
|
port = "LPT1"; /* default to first parallel port */
|
||||||
|
}
|
||||||
|
|
||||||
void Config::read(const char * file)
|
void Config::read(const char * file)
|
||||||
{
|
{
|
||||||
ifstream ifs(file);
|
ifstream ifs(file);
|
||||||
if (ifs.is_open())
|
if (ifs.is_open())
|
||||||
{
|
{
|
||||||
|
int entry_num = -1;
|
||||||
string line;
|
string line;
|
||||||
while (!ifs.eof())
|
while (!ifs.eof())
|
||||||
{
|
{
|
||||||
getline(ifs, line);
|
getline(ifs, line);
|
||||||
|
line = trim(line);
|
||||||
|
|
||||||
|
if (line == "") /* skip blank lines */
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (line[0] == ';' || line[0] == '#') /* skip comments */
|
||||||
|
continue;
|
||||||
|
|
||||||
|
/* Look for the beginning of a new entry section */
|
||||||
|
if (line[0] == '[' && line[line.size()-1] == ']')
|
||||||
|
{
|
||||||
|
entries.push_back(Entry(string(line, 1, line.size() - 2)));
|
||||||
|
entry_num++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* split the line into variable and value parts */
|
||||||
|
pair<string, string> parts = split(line);
|
||||||
|
if (entry_num == -1)
|
||||||
|
{
|
||||||
|
if (parts.first == "port")
|
||||||
|
{
|
||||||
|
if (parts.second != "")
|
||||||
|
port = parts.second;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
cerr << "Warning: Unrecognized global command: "
|
||||||
|
<< line << endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (parts.first == "on_start")
|
||||||
|
{
|
||||||
|
entries[entry_num].on_start = parseAction(parts.second);
|
||||||
|
}
|
||||||
|
else if (parts.first == "on_exit")
|
||||||
|
{
|
||||||
|
entries[entry_num].on_exit = parseAction(parts.second);
|
||||||
|
}
|
||||||
|
else if (parts.first == "on_lock")
|
||||||
|
{
|
||||||
|
entries[entry_num].on_lock = parseAction(parts.second);
|
||||||
|
}
|
||||||
|
else if (parts.first == "on_unlock")
|
||||||
|
{
|
||||||
|
entries[entry_num].on_unlock = parseAction(parts.second);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
cerr << "Warning: Unrecognized entry command: "
|
||||||
|
<< line << endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -31,3 +93,30 @@ void Config::read(const char * file)
|
|||||||
cerr << "Warning: Could not open '" << file << "'" << endl;
|
cerr << "Warning: Could not open '" << file << "'" << endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pair<string, string> Config::split(const string & line)
|
||||||
|
{
|
||||||
|
pair<string, string> res;
|
||||||
|
size_t pos = line.find('=');
|
||||||
|
if (pos != string::npos)
|
||||||
|
{
|
||||||
|
res.first = trim(string(line, 0, pos));
|
||||||
|
res.second = trim(string(line, pos + 1, line.size() - pos - 1));
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
Config::Action Config::parseAction(const string & str)
|
||||||
|
{
|
||||||
|
string s = str;
|
||||||
|
Action res = NONE;
|
||||||
|
for (int sz = s.size(), i = 0; i < sz; i++)
|
||||||
|
s[i] = tolower(s[i]);
|
||||||
|
if (s == "on")
|
||||||
|
res = ON;
|
||||||
|
else if (s == "off")
|
||||||
|
res = OFF;
|
||||||
|
else if (s == "previous")
|
||||||
|
res = PREVIOUS;
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
6
Config.h
6
Config.h
@ -4,6 +4,7 @@
|
|||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
#include <utility> /* pair */
|
||||||
|
|
||||||
class Config
|
class Config
|
||||||
{
|
{
|
||||||
@ -26,7 +27,12 @@ class Config
|
|||||||
std::string port;
|
std::string port;
|
||||||
std::vector<Entry> entries;
|
std::vector<Entry> entries;
|
||||||
|
|
||||||
|
Config();
|
||||||
void read(const char * file);
|
void read(const char * file);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
std::pair<std::string, std::string> split(const std::string & line);
|
||||||
|
Action parseAction(const std::string & str);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user