1 /* 2 * Copyright (C) 2003-2005 Tommi Maekitalo 3 * 4 * This library is free software; you can redistribute it and/or 5 * modify it under the terms of the GNU Lesser General Public 6 * License as published by the Free Software Foundation; either 7 * version 2.1 of the License, or (at your option) any later version. 8 * 9 * As a special exception, you may use this file as part of a free 10 * software library without restriction. Specifically, if other files 11 * instantiate templates or use macros or inline functions from this 12 * file, or you compile this file and link it with other files to 13 * produce an executable, this file does not by itself cause the 14 * resulting executable to be covered by the GNU General Public 15 * License. This exception does not however invalidate any other 16 * reasons why the executable file might be covered by the GNU Library 17 * General Public License. 18 * 19 * This library is distributed in the hope that it will be useful, 20 * but WITHOUT ANY WARRANTY; without even the implied warranty of 21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 22 * Lesser General Public License for more details. 23 * 24 * You should have received a copy of the GNU Lesser General Public 25 * License along with this library; if not, write to the Free Software 26 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 27 */ 28 29 30 #ifndef TNT_ENCODING_H 31 #define TNT_ENCODING_H 32 33 #include <string> 34 #include <map> 35 36 namespace tnt 37 { 38 class Encoding 39 { 40 typedef std::map<std::string, unsigned> encodingMapType; 41 encodingMapType encodingMap; 42 43 public: Encoding()44 Encoding() { } Encoding(const char * header)45 explicit Encoding(const char* header) 46 { parse(header); } 47 48 void parse(const char* header); clear()49 void clear() 50 { encodingMap.clear(); } 51 52 /** 53 * returns the quality-value in the range 0..10 54 */ 55 unsigned accept(const std::string& encoding) const; 56 }; 57 } 58 59 #endif // TNT_ENCODING_H 60