diff options
Diffstat (limited to 'src/html.cpp')
| -rwxr-xr-x[-rw-r--r--] | src/html.cpp | 187 |
1 files changed, 93 insertions, 94 deletions
diff --git a/src/html.cpp b/src/html.cpp index f4278ca..3b5f6b0 100644..100755 --- a/src/html.cpp +++ b/src/html.cpp @@ -1,27 +1,3 @@ -/*:* - *: File: ./src/html.cpp - *: - *: yChat; Homepage: www.yChat.org; Version 0.8.3-CURRENT - *: - *: Copyright (C) 2003 Paul C. Buetow, Volker Richter - *: Copyright (C) 2004 Paul C. Buetow - *: Copyright (C) 2005 EXA Digital Solutions GbR - *: - *: This program is free software; you can redistribute it and/or - *: modify it under the terms of the GNU General Public License - *: as published by the Free Software Foundation; either version 2 - *: of the License, or (at your option) any later version. - *: - *: This program is distributed in the hope that it will be useful, - *: but WITHOUT ANY WARRANTY; without even the implied warranty of - *: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - *: GNU General Public License for more details. - *: - *: You should have received a copy of the GNU General Public License - *: along with this program; if not, write to the Free Software - *: Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. - *:*/ - #ifndef HTML_CPP #define HTML_CPP @@ -30,121 +6,144 @@ using namespace std; -html::html( ) +html::html( ) : smap<string,string>::smap(HMAPOCC) { - set_name( wrap::CONF->get_elem( "httpd.templatedir" ) ); + set_name( wrap::CONF->get_elem( "httpd.templatedir" ) ); } html::~html( ) -{} +{ +} void html::clear_cache( ) { - clear(); - wrap::system_message( CLRHTML ); + make_empty(); + wrap::system_message( CLRHTML ); + +#ifdef NCURSES + print_cached( 0 ); +#endif } string html::parse( map<string,string> &map_params ) { - string s_file = map_params["request"]; - - // check if s_file is in the container. - string s_templ; + string s_file = map_params["request"]; - // if not, read file. - if ( ! shashmap<string>::exists( s_file ) ) - { - string s_path = get_name(); - ifstream if_templ( s_path.append( s_file ).c_str(), ios::binary ); + // check if s_file is in the container. + string s_templ; - if ( ! if_templ ) + // if not, read file. + if ( ! smap<string,string>::is_avail( s_file ) ) { - wrap::system_message( OFFFOUND + s_path ); - if(map_params["request"] == wrap::CONF->get_elem( "httpd.html.notfound" )) - return ""; + string s_path = get_name(); + ifstream if_templ( s_path.append( s_file ).c_str(), ios::binary ); - map_params["request"] = wrap::CONF->get_elem( "httpd.html.notfound" ); - return parse( map_params ); - } + if ( ! if_templ ) + { + wrap::system_message( OFFFOUND + s_path ); + if(map_params["request"]== wrap::CONF->get_elem( "httpd.html.notfound" )) + return ""; - char c_buf; - while( !if_templ.eof() ) - { - if_templ.get( c_buf ); - s_templ += c_buf; - } + map_params["request"] = wrap::CONF->get_elem( "httpd.html.notfound" ); + return parse( map_params ); - if ( map_params["content-type"].compare(0,5,"text/") == 0 ) - s_templ.erase(s_templ.end()-1); + } - if_templ.close(); + char c_buf; + while( !if_templ.eof() ) + { + if_templ.get( c_buf ); + s_templ += c_buf; + } - wrap::system_message( TECACHE + s_path ); + if ( map_params["content-type"].compare(0,5,"text/") == 0 ) + s_templ.erase(s_templ.end()-1); - // cache file. - shashmap<string>::add_elem(s_templ, s_file); - } - else - { - s_templ = shashmap<string>::get_elem( s_file ); - } + if_templ.close(); - // find %%KEY%% token and substituate those. - unsigned pos[2]; - pos[0] = pos[1] = 0; + wrap::system_message( TECACHE + s_path ); - for(;;) - { - pos[0] = s_templ.find( "%%", pos[1] ); + // cache file. + smap<string,string>::add_elem( s_templ, s_file ); +#ifdef NCURSES + print_cached( smap<string,string>::get_size() ); +#endif + } - if ( pos[0] == string::npos ) - break; + else + { + s_templ = smap<string,string>::get_elem( s_file ); + } + + // find %%KEY%% token and substituate those. + unsigned pos[2]; + pos[0] = pos[1] = 0; + + for(;;) + { + pos[0] = s_templ.find( "%%", pos[1] ); - pos[0] += 2; - pos[1] = s_templ.find( "%%", pos[0] ); + if ( pos[0] == string::npos ) + break; - if ( pos[0] == string::npos ) - break; + pos[0] += 2; + pos[1] = s_templ.find( "%%", pos[0] ); - // get key and val. - string s_key = s_templ.substr( pos[0], pos[1]-pos[0] ); - string s_val = wrap::CONF->get_elem( s_key ); + if ( pos[0] == string::npos ) + break; - // if s_val is empty use map_params. - if ( s_val.empty() ) - s_val = map_params[ s_key ]; + // get key and val. + string s_key = s_templ.substr( pos[0], pos[1]-pos[0] ); + string s_val = wrap::CONF->get_elem( s_key ); - // substituate key with val. - s_templ.replace( pos[0]-2, pos[1]-pos[0]+4, s_val ); + // if s_val is empty use map_params. + if ( s_val.empty() ) + s_val = map_params[ s_key ]; + + // substituate key with val. + s_templ.replace( pos[0]-2, pos[1]-pos[0]+4, s_val ); - // calculate the string displacement. - int i_diff = s_val.length() - ( pos[1] - pos[0] + 4); + // calculate the string displacement. + int i_diff = s_val.length() - ( pos[1] - pos[0] + 4); - pos[1] += 2 + i_diff; + pos[1] += 2 + i_diff; - }; + }; - return s_templ; + return s_templ; } //<<* void html::online_list( user *p_user, map<string,string> &map_params ) { - // prepare user_list. - string s_list; + // prepare user_list. + string s_list; - room* p_room = p_user->get_room(); + room* p_room = p_user->get_room(); - p_room->get_user_list( s_list ); + p_room->get_user_list( s_list ); - map_params["room"] = p_room->get_name(); - map_params["topic"] = p_room->get_topic(); - map_params["userlist"] = s_list; + map_params["ROOMNAME"] = p_room->get_name(); + map_params["ROOMTOPIC"] = p_room->get_topic(); + map_params["USERLIST"] = s_list; } //*>> +#ifdef NCURSES +void +html::print_cached( int i_docs ) +{ + if ( !wrap::NCUR->is_ready() ) + return; + + mvprintw( NCUR_CACHED_DOCS_X, NCUR_CACHED_DOCS_Y, "Docs: %d ", i_docs); + refresh(); +} + +#endif + #endif |
