]> git.tdb.fi Git - libs/core.git/blobdiff - source/stringcodec/codec.cpp
Allow error mode to be specified when creating the codec object
[libs/core.git] / source / stringcodec / codec.cpp
index b1c05c50292295e573f307497a175ac78797a08a..d1fc1dfb0730adbfc94e5c2c7d50335172596cf8 100644 (file)
@@ -63,23 +63,40 @@ ustring Codec::Decoder::decode(const string &str)
 Codec *create_codec(const string &n)
 {
        string name;
-       for(string::const_iterator i=n.begin(); i!=n.end(); ++i)
+       string::const_iterator i;
+       for(i=n.begin(); i!=n.end(); ++i)
        {
-               if(isupper(*i))
+               if(*i==':')
+                       break;
+               else if(isupper(*i))
                        name += tolower(*i);
                else if(islower(*i) || isdigit(*i))
                        name += *i;
        }
 
-       if(name=="ascii") return new Ascii;
-       if(name=="iso2022jp") return new Iso2022Jp;
-       if(name=="iso646fi") return new Iso646Fi;
-       if(name=="iso88591" || name=="latin1") return new Iso88591;
-       if(name=="iso885915" || name=="latin9") return new Iso885915;
-       if(name=="jisx0201") return new JisX0201;
-       if(name=="jisx0208") return new JisX0208;
-       if(name=="utf8") return new Utf8;
-       if(name=="windows1252" || name=="cp1252") return new Windows1252;
+       ErrorMode em = THROW_ON_ERROR;
+       if(i!=n.end() && *i==':')
+       {
+               string em_str(i+1, n.end());
+               if(em_str=="throw")
+                       em = THROW_ON_ERROR;
+               else if(em_str=="ignore")
+                       em = IGNORE_ERRORS;
+               else if(em_str=="trans" || em_str=="transliterate")
+                       em = TRANSLITERATE;
+               else
+                       throw invalid_argument("invalid error mode");
+       }
+
+       if(name=="ascii") return new Ascii(em);
+       if(name=="iso2022jp") return new Iso2022Jp(em);
+       if(name=="iso646fi") return new Iso646Fi(em);
+       if(name=="iso88591" || name=="latin1") return new Iso88591(em);
+       if(name=="iso885915" || name=="latin9") return new Iso885915(em);
+       if(name=="jisx0201") return new JisX0201(em);
+       if(name=="jisx0208") return new JisX0208(em);
+       if(name=="utf8") return new Utf8(em);
+       if(name=="windows1252" || name=="cp1252") return new Windows1252(em);
        throw invalid_argument("unknown string codec");
 }