diff options
Diffstat (limited to 'conf.cpp')
| -rwxr-xr-x | conf.cpp | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/conf.cpp b/conf.cpp new file mode 100755 index 0000000..e4fcc0b --- /dev/null +++ b/conf.cpp @@ -0,0 +1,87 @@ +// class conf implementation. + +#ifndef s_conf_CXX +#define s_conf_CXX + +#include <fstream> +#include "s_ncur.h" +#include "conf.h" + +using namespace std; + +conf::conf( string s_conf = CONFILE ) : name( s_conf ) +{ + parse( ); // parse the config file. +} + +conf::~conf() +{} + +void +conf::parse() +{ +#ifdef VERBOSE + cout << CFILEOK << get_name() << endl; +#endif + + string s_configfile=get_name(); + + string homeconfig=string(getenv("HOME"))+string("/.ychat/")+get_name(); + ifstream homecheck( homeconfig.c_str() ); + if( homecheck ) + { + homecheck.close(); + s_configfile=homeconfig; + } + + ifstream fs_conf( s_configfile.c_str() ); + + if ( ! fs_conf ) + { +#ifdef VERBOSE + cout << CFILENO << get_name() << endl; +#endif + + return; + } + + char c_buf[READBUF]; + + while( fs_conf.getline( c_buf, READBUF ) ) + { + string s_token( c_buf ); + unsigned int ui_pos = s_token.find( "#", 0 ); + + // if line is commented out: + if ( ui_pos == 0 ) + continue; + + ui_pos = s_token.find( ";", 0 ); + + // if token has not been found. + if ( ui_pos == string::npos ) + continue; + + s_token = s_token.substr( 0 , --ui_pos ); + ui_pos = s_token.find ( "\"", 0 ); + + if ( ui_pos == string::npos ) + continue; + + string s_val = s_token.substr( ui_pos+1, s_token.length() ); + string s_key = s_token.substr( 0 , --ui_pos ); + +#ifdef VERBOSE2 + + cout << s_key << "=" << s_val << endl; +#endif + + // fill the map. + map_vals[s_key] = s_val; + } + + fs_conf.close(); + fs_conf.~ifstream(); +} + +#endif |
