--- parser3/src/include/pa_string.h 2008/07/17 09:44:29 1.173 +++ parser3/src/include/pa_string.h 2009/04/16 01:10:36 1.177 @@ -8,7 +8,7 @@ #ifndef PA_STRING_H #define PA_STRING_H -static const char * const IDENT_STRING_H="$Date: 2008/07/17 09:44:29 $"; +static const char * const IDENT_STRING_H="$Date: 2009/04/16 01:10:36 $"; // includes #include "pa_types.h" @@ -57,6 +57,8 @@ inline size_t get_length(T current) { - whether they are tainted or not, and the lang which should be used to detaint them */ + + class String: public PA_Object { public: @@ -97,6 +99,7 @@ public: L_HTML='H', ///< HTML code L_REGEX='R', ///< RegEx expression L_HTTP_COOKIE='C', ///< cookies encoded as %uXXXX for compartibility with js functions encode/decode + L_FILE_POST='f', ///temporary escaping zero-char // READ WARNING ABOVE BEFORE ADDING ANYTHING L_OPTIMIZE_BIT = 0x80 ///< flag, requiring cstr whitespace optimization }; @@ -107,6 +110,7 @@ public: TRIM_END }; + union Languages { struct { @@ -181,20 +185,34 @@ public: append(current, CORD_chars((char)alang, asize)); } - /// MUST be called exactly prior to modification of current [uses it's length] template - void append(C current, size_t appending_length, - const Languages src) { - assert(appending_length); + void appendHelper(C current, Language alang, C asize_helper) { + assert(alang); + + if(!opt.is_not_just_lang) + if(opt.lang) { + if(opt.lang==alang) // same length? ignoring + return; + } else { + opt.lang=alang; // to uninitialized + return; + } + + append(current, CORD_chars((char)alang, asize_helper.length())); + } + + template + void appendHelper(C current, C length_helper, const Languages src) { if(!langs) langs=src.langs; // to uninitialized else if(!src.opt.is_not_just_lang) - append(current, src.opt.lang, appending_length); // simplifying when simple source + appendHelper(current, src.opt.lang, length_helper); // simplifying when simple source else - append(current, src.make_langs(appending_length)); + append(current, src.make_langs(length_helper)); } - + + /// MUST be called exactly prior to modification of current [uses it's length] template void append(C current, @@ -519,6 +537,7 @@ public: double as_double() const { return pa_atod(cstr(), this); } int as_int() const { return pa_atoi(cstr(), this); } bool as_bool() const { return as_int()!=0; } + const String& escape(Charset& source_charset) const; private: //disabled