annotate mcabber/libjabber/xmltok_ns_c.h @ 1509:189ffdd944b4

Add a small Coding Style document
author Mikael Berthe <mikael@lilotux.net>
date Sun, 31 Aug 2008 15:21:49 +0200
parents bf3d6e241714
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
25
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
1 /*
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
2 * This program is free software; you can redistribute it and/or modify
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
3 * it under the terms of the GNU General Public License as published by
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
4 * the Free Software Foundation; either version 2 of the License, or
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
5 * (at your option) any later version.
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
6 *
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
7 * This program is distributed in the hope that it will be useful,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
10 * GNU General Public License for more details.
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
11 *
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
12 * You should have received a copy of the GNU General Public License
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
13 * along with this program; if not, write to the Free Software
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
14 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
15 *
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
16 * Jabber
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
17 * Copyright (C) 1998-1999 The Jabber Team http://jabber.org/
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
18 */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
19
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
20 const ENCODING *NS(XmlGetUtf8InternalEncoding)()
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
21 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
22 return &ns(internal_utf8_encoding).enc;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
23 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
24
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
25 const ENCODING *NS(XmlGetUtf16InternalEncoding)()
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
26 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
27 #if XML_BYTE_ORDER == 12
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
28 return &ns(internal_little2_encoding).enc;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
29 #elif XML_BYTE_ORDER == 21
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
30 return &ns(internal_big2_encoding).enc;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
31 #else
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
32 const short n = 1;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
33 return *(const char *)&n ? &ns(internal_little2_encoding).enc : &ns(internal_big2_encoding).enc;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
34 #endif
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
35 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
36
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
37 static
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
38 const ENCODING *NS(encodings)[] = {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
39 &ns(latin1_encoding).enc,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
40 &ns(ascii_encoding).enc,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
41 &ns(utf8_encoding).enc,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
42 &ns(big2_encoding).enc,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
43 &ns(big2_encoding).enc,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
44 &ns(little2_encoding).enc,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
45 &ns(utf8_encoding).enc /* NO_ENC */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
46 };
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
47
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
48 static
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
49 int NS(initScanProlog)(const ENCODING *enc, const char *ptr, const char *end,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
50 const char **nextTokPtr)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
51 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
52 return initScan(NS(encodings), (const INIT_ENCODING *)enc, XML_PROLOG_STATE, ptr, end, nextTokPtr);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
53 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
54
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
55 static
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
56 int NS(initScanContent)(const ENCODING *enc, const char *ptr, const char *end,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
57 const char **nextTokPtr)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
58 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
59 return initScan(NS(encodings), (const INIT_ENCODING *)enc, XML_CONTENT_STATE, ptr, end, nextTokPtr);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
60 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
61
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
62 int NS(XmlInitEncoding)(INIT_ENCODING *p, const ENCODING **encPtr, const char *name)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
63 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
64 int i = getEncodingIndex(name);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
65 if (i == UNKNOWN_ENC)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
66 return 0;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
67 INIT_ENC_INDEX(p) = (char)i;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
68 p->initEnc.scanners[XML_PROLOG_STATE] = NS(initScanProlog);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
69 p->initEnc.scanners[XML_CONTENT_STATE] = NS(initScanContent);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
70 p->initEnc.updatePosition = initUpdatePosition;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
71 p->encPtr = encPtr;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
72 *encPtr = &(p->initEnc);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
73 return 1;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
74 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
75
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
76 static
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
77 const ENCODING *NS(findEncoding)(const ENCODING *enc, const char *ptr, const char *end)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
78 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
79 #define ENCODING_MAX 128
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
80 char buf[ENCODING_MAX];
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
81 char *p = buf;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
82 int i;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
83 XmlUtf8Convert(enc, &ptr, end, &p, p + ENCODING_MAX - 1);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
84 if (ptr != end)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
85 return 0;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
86 *p = 0;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
87 if (streqci(buf, "UTF-16") && enc->minBytesPerChar == 2)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
88 return enc;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
89 i = getEncodingIndex(buf);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
90 if (i == UNKNOWN_ENC)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
91 return 0;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
92 return NS(encodings)[i];
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
93 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
94
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
95 int NS(XmlParseXmlDecl)(int isGeneralTextEntity,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
96 const ENCODING *enc,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
97 const char *ptr,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
98 const char *end,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
99 const char **badPtr,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
100 const char **versionPtr,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
101 const char **encodingName,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
102 const ENCODING **encoding,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
103 int *standalone)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
104 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
105 return doParseXmlDecl(NS(findEncoding),
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
106 isGeneralTextEntity,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
107 enc,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
108 ptr,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
109 end,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
110 badPtr,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
111 versionPtr,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
112 encodingName,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
113 encoding,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
114 standalone);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
115 }