Add more checks for Intel compiler.
[wxWidgets.git] / include / wx / uri.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/uri.h
3 // Purpose: wxURI - Class for parsing URIs
4 // Author: Ryan Norton
5 // Vadim Zeitlin (UTF-8 URI support, many other changes)
6 // Created: 07/01/2004
7 // Copyright: (c) 2004 Ryan Norton
8 // 2008 Vadim Zeitlin
9 // Licence: wxWindows Licence
10 /////////////////////////////////////////////////////////////////////////////
11
12 #ifndef _WX_URI_H_
13 #define _WX_URI_H_
14
15 #include "wx/defs.h"
16 #include "wx/object.h"
17 #include "wx/string.h"
18 #include "wx/arrstr.h"
19
20 // Host Type that the server component can be
21 enum wxURIHostType
22 {
23 wxURI_REGNAME, // Host is a normal register name (www.mysite.com etc.)
24 wxURI_IPV4ADDRESS, // Host is a version 4 ip address (192.168.1.100)
25 wxURI_IPV6ADDRESS, // Host is a version 6 ip address [aa:aa:aa:aa::aa:aa]:5050
26 wxURI_IPVFUTURE // Host is a future ip address (wxURI is unsure what kind)
27 };
28
29 // Component Flags
30 enum wxURIFieldType
31 {
32 wxURI_SCHEME = 1,
33 wxURI_USERINFO = 2,
34 wxURI_SERVER = 4,
35 wxURI_PORT = 8,
36 wxURI_PATH = 16,
37 wxURI_QUERY = 32,
38 wxURI_FRAGMENT = 64
39 };
40
41 // Miscellaneous other flags
42 enum wxURIFlags
43 {
44 wxURI_STRICT = 1
45 };
46
47
48 // Generic class for parsing URIs.
49 //
50 // See RFC 3986
51 class WXDLLIMPEXP_BASE wxURI : public wxObject
52 {
53 public:
54 wxURI();
55 wxURI(const wxString& uri);
56
57 // default copy ctor, assignment operator and dtor are ok
58
59 bool Create(const wxString& uri);
60
61 wxURI& operator=(const wxString& string)
62 {
63 Create(string);
64 return *this;
65 }
66
67 bool operator==(const wxURI& uri) const;
68
69 // various accessors
70
71 bool HasScheme() const { return (m_fields & wxURI_SCHEME) != 0; }
72 bool HasUserInfo() const { return (m_fields & wxURI_USERINFO) != 0; }
73 bool HasServer() const { return (m_fields & wxURI_SERVER) != 0; }
74 bool HasPort() const { return (m_fields & wxURI_PORT) != 0; }
75 bool HasPath() const { return (m_fields & wxURI_PATH) != 0; }
76 bool HasQuery() const { return (m_fields & wxURI_QUERY) != 0; }
77 bool HasFragment() const { return (m_fields & wxURI_FRAGMENT) != 0; }
78
79 const wxString& GetScheme() const { return m_scheme; }
80 const wxString& GetPath() const { return m_path; }
81 const wxString& GetQuery() const { return m_query; }
82 const wxString& GetFragment() const { return m_fragment; }
83 const wxString& GetPort() const { return m_port; }
84 const wxString& GetUserInfo() const { return m_userinfo; }
85 const wxString& GetServer() const { return m_server; }
86 wxURIHostType GetHostType() const { return m_hostType; }
87
88 // these functions only work if the user information part of the URI is in
89 // the usual (but insecure and hence explicitly recommended against by the
90 // RFC) "user:password" form
91 wxString GetUser() const;
92 wxString GetPassword() const;
93
94
95 // combine all URI components into a single string
96 //
97 // BuildURI() returns the real URI suitable for use with network libraries,
98 // for example, while BuildUnescapedURI() returns a string suitable to be
99 // shown to the user.
100 wxString BuildURI() const { return DoBuildURI(&wxURI::Nothing); }
101 wxString BuildUnescapedURI() const { return DoBuildURI(&wxURI::Unescape); }
102
103 // the escaped URI should contain only ASCII characters, including possible
104 // escape sequences
105 static wxString Unescape(const wxString& escapedURI);
106
107
108 void Resolve(const wxURI& base, int flags = wxURI_STRICT);
109 bool IsReference() const;
110
111 protected:
112 void Clear();
113
114 // common part of BuildURI() and BuildUnescapedURI()
115 wxString DoBuildURI(wxString (*funcDecode)(const wxString&)) const;
116
117 // function which returns its argument unmodified, this is used by
118 // BuildURI() to tell DoBuildURI() that nothing needs to be done with the
119 // URI components
120 static wxString Nothing(const wxString& value) { return value; }
121
122 bool Parse(const char* uri);
123
124 const char* ParseAuthority (const char* uri);
125 const char* ParseScheme (const char* uri);
126 const char* ParseUserInfo (const char* uri);
127 const char* ParseServer (const char* uri);
128 const char* ParsePort (const char* uri);
129 const char* ParsePath (const char* uri);
130 const char* ParseQuery (const char* uri);
131 const char* ParseFragment (const char* uri);
132
133
134 static bool ParseH16(const char*& uri);
135 static bool ParseIPv4address(const char*& uri);
136 static bool ParseIPv6address(const char*& uri);
137 static bool ParseIPvFuture(const char*& uri);
138
139 // should be called with i pointing to '%', returns the encoded character
140 // following it or -1 if invalid and advances i past it (so that it points
141 // to the last character consumed on return)
142 static int DecodeEscape(wxString::const_iterator& i);
143
144 // append next character pointer to by p to the string in an escaped form
145 // and advance p past it
146 //
147 // if the next character is '%' and it's followed by 2 hex digits, they are
148 // not escaped (again) by this function, this allows to keep (backwards-
149 // compatible) ambiguity about the input format to wxURI::Create(): it can
150 // be either already escaped or not
151 void AppendNextEscaped(wxString& s, const char *& p);
152
153 // convert hexadecimal digit to its value; return -1 if c isn't valid
154 static int CharToHex(char c);
155
156 // split an URI path string in its component segments (including empty and
157 // "." ones, no post-processing is done)
158 static wxArrayString SplitInSegments(const wxString& path);
159
160 // various URI grammar helpers
161 static bool IsUnreserved(char c);
162 static bool IsReserved(char c);
163 static bool IsGenDelim(char c);
164 static bool IsSubDelim(char c);
165 static bool IsHex(char c);
166 static bool IsAlpha(char c);
167 static bool IsDigit(char c);
168 static bool IsEndPath(char c);
169
170 wxString m_scheme;
171 wxString m_path;
172 wxString m_query;
173 wxString m_fragment;
174
175 wxString m_userinfo;
176 wxString m_server;
177 wxString m_port;
178
179 wxURIHostType m_hostType;
180
181 size_t m_fields;
182
183 DECLARE_DYNAMIC_CLASS(wxURI)
184 };
185
186 #endif // _WX_URI_H_
187