Annotation of parser3/src/include/pa_sapi.h, revision 1.22.2.7
1.1 paf 1: /** @file
2: Parser: web server api interface object decl.
3:
1.22.2.4 paf 4: Copyright (c) 2001-2003 ArtLebedev Group (http://www.artlebedev.com)
1.18 paf 5: Author: Alexandr Petrosian <paf@design.ru> (http://paf.design.ru)
1.1 paf 6: */
7:
8: #ifndef PA_SAPI_H
9: #define PA_SAPI_H
1.20 paf 10:
1.22.2.7! paf 11: static const char* IDENT_SAPI_H="$Date: 2003/02/14 17:28:19 $";
1.22.2.2 paf 12:
13: // includes
1.1 paf 14:
15: #include "pa_pool.h"
16: #include "pa_types.h"
1.22.2.6 paf 17: #include "pa_array.h"
1.22.2.2 paf 18:
19: // forwards
1.22.2.1 paf 20: class SAPI_Info;
1.22.2.7! paf 21: class Pool;
1.5 paf 22:
1.4 paf 23: /// target web-Server API
1.1 paf 24: struct SAPI {
1.5 paf 25: /// log error message
1.22.2.4 paf 26: static void log(SAPI_Info& info, const char* fmt, ...);
1.14 parser 27: /// log error message & die
1.22.2.4 paf 28: static void die(const char* fmt, ...);
1.19 paf 29: /// environment strings
1.22.2.6 paf 30: static const char* const *environment(SAPI_Info& info, Pool& pool);
1.12 parser 31: /// get environment string
1.22.2.7! paf 32: static char* get_env(Pool& pool, SAPI_Info& info, const char* name);
1.1 paf 33: /// read POST request bytes
1.22.2.1 paf 34: static size_t read_post(SAPI_Info& info, char *buf, size_t max_bytes);
1.12 parser 35: /// add response header attribute [but do not send it to client]
1.22.2.5 paf 36: static void add_header_attribute(SAPI_Info& info,
37: const char* dont_store_key, const char* dont_store_value);
1.12 parser 38: /// send collected header attributes to client
1.22.2.1 paf 39: static void send_header(SAPI_Info& info);
1.1 paf 40: /// output body bytes
1.22.2.1 paf 41: static void send_body(SAPI_Info& info, const void *buf, size_t size);
1.1 paf 42: };
43:
44: #endif
E-mail: