Moka Ihm Qt
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros
HtmlEntities.hh
Go to the documentation of this file.
1 /*
2  * Moka : Un modeleur de 3-G-cartes.
3  * Copyright (C) 2004, Moka Team, Université de Poitiers, Laboratoire SIC
4  * http://www.sic.sp2mi.univ-poitiers.fr/
5  * Copyright (C) 2009, Guillaume Damiand, CNRS, LIRIS,
6  * guillaume.damiand@liris.cnrs.fr, http://liris.cnrs.fr/
7  *
8  * This file is part of Moka
9  *
10  * This program is free software: you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation, either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with this program. If not, see <http://www.gnu.org/licenses/>.
22  */
23 
24 #ifndef HTMLENTITIES_H
25 #define HTMLENTITIES_H
26 
27 #include <QtCore/QString>
28 #include <string>
29 
30 using namespace std;
31 
32 
33 struct HtmlEntity
34 {
35  const char *name;
36  quint16 code;
37 };
38 
39 
40 class HTML
41 {
42  public :
43 
44  // Decode une chaine de caractere utilisant des
45  // caracteres speciaux d'HTML.
46 
47  static void decodeStr(QString* str);
48  static QString* decode(const QString* src);
49  static QString* decode(const QString& src);
50  static QString* decode(const char* src);
51  static QString* decode(const string* src);
52  static QString* decode(const string& src);
53 
54 
55  // Encode une chaine de caractere utilisant des
56  // caracteres speciaux d'HTML.
57 
58  static void encodeStr(QString* str);
59  static QString* encode(const QString* src);
60  static QString* encode(const QString& src);
61  static QString* encode(const char* src);
62  static QString* encode(const string* src);
63  static QString* encode(const string& src);
64 
65 
66 
67  // Retourne le caractere associe a un caractere special HTML.
68 
69  static QChar resolveEntity(const QString &entity);
70 
71 
72  // Retourne la chaine HTML representant le caractere "entityCode".
73 
74  static QString resolveEntity(quint16 entityCode);
75 
76 
77  private :
78 
79  static const int MaxEntities;
80  static const int FirstEntities;
81  static const HtmlEntity first[];
82  static const HtmlEntity entities[];
83 
84  static const HtmlEntity* end_ent;
85  static const HtmlEntity* start_ent;
86  static const HtmlEntity* end_first;
87  static const HtmlEntity* start_first;
88 
89 };
90 
91 #endif