--- parser3/src/targets/cgi/parser3.C 2001/03/19 21:39:35 1.26 +++ parser3/src/targets/cgi/parser3.C 2001/03/21 15:53:28 1.28 @@ -1,9 +1,11 @@ -/* - Parser +/** @file + Parser: scripting and CGI main. + Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com) + Author: Alexander Petrosyan (http://design.ru/paf) - $Id: parser3.C,v 1.26 2001/03/19 21:39:35 paf Exp $ + $Id: parser3.C,v 1.28 2001/03/21 15:53:28 paf Exp $ */ #ifdef HAVE_CONFIG_H @@ -14,7 +16,15 @@ #ifdef WIN32 # include # include +#else +# include #endif + +//\ifwin32 +#include +//#include +//\endifwin32 + #include #include #include @@ -24,8 +34,8 @@ #include "pa_globals.h" #include "pa_request.h" -Pool pool; // global pool -bool cgi; +Pool pool; ///< global pool +bool cgi; ///< we were started as CGI? #ifdef WIN32 # if _MSC_VER @@ -55,15 +65,23 @@ LONG WINAPI TopLevelExceptionFilter ( } # endif +#endif + +//\if void fix_slashes(char *s) { - for(; *s; s++) - if(*s=='\\') - *s='/'; + if(s) + for(; *s; s++) + if(*s=='\\') + *s='/'; } -#endif +//\endif // service funcs +const char *get_env(Pool& pool, const char *name) { + return getenv(name); +} + int read_post(char *buf, int max_bytes) { int read_size=0; do { @@ -93,13 +111,14 @@ void output_body(const char *buf, size_t int main(int argc, char *argv[]) { // TODO:umask(2); -#ifdef WIN32 - _setmode(fileno(stdin), _O_BINARY); - _setmode(fileno(stdout), _O_BINARY); - _setmode(fileno(stderr), _O_BINARY); -#endif +//\#ifdef WIN32 + setmode(fileno(stdin), _O_BINARY); + setmode(fileno(stdout), _O_BINARY); + setmode(fileno(stderr), _O_BINARY); +//\#endif // Service funcs + service_funcs.get_env=get_env; service_funcs.read_post=read_post; service_funcs.output_header_attribute=output_header_attribute; service_funcs.output_body=output_body; @@ -120,9 +139,9 @@ int main(int argc, char *argv[]) { } char *filespec_to_process=cgi?getenv("PATH_TRANSLATED"):argv[1]; -#ifdef WIN32 +//\#ifdef WIN32 fix_slashes(filespec_to_process); -#endif +//\#endif PTRY { // global try // must be first in PTRY{}PCATCH @@ -161,9 +180,10 @@ int main(int argc, char *argv[]) { request_info.cookie=getenv("HTTP_COOKIE"); // prepare to process request - Request request(Pool(), + Pool request_pool; + Request request(request_pool, request_info, - cgi ? String::Untaint_lang::HTML_TYPO : String::Untaint_lang::NO + cgi ? String::UL_HTML_TYPO : String::UL_NO ); // some root-controlled location