]> git.saurik.com Git - wxWidgets.git/blame - interface/url.h
other misc fixes
[wxWidgets.git] / interface / url.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: url.h
e54c96f1 3// Purpose: interface of wxURL
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxURL
11 @wxheader{url.h}
7c913512 12
23324ae1
FM
13 wxURL is a specialization of wxURI for parsing URLs.
14 Please look at wxURI documentation for more info about the functions
15 you can use to retrieve the various parts of the URL (scheme, server, port,
16 etc).
7c913512 17
23324ae1
FM
18 Supports standard assignment operators, copy constructors,
19 and comparison operators.
7c913512 20
23324ae1
FM
21 @library{wxnet}
22 @category{net}
7c913512 23
e54c96f1 24 @see wxSocketBase, wxProtocol
23324ae1
FM
25*/
26class wxURL : public wxURI
27{
28public:
29 /**
30 Constructs a URL object from the string. The URL must be valid according
31 to RFC 1738. In particular, file URLs must be of the format
32 @c file://hostname/path/to/file otherwise GetError()
33 will return a value different from @c wxURL_NOERR.
7c913512
FM
34 It is valid to leave out the hostname but slashes must remain in place -
35 i.e. a file URL without a hostname must contain three consecutive slashes
23324ae1 36 (e.g. @c file:///somepath/myfile).
3c4f71cc 37
7c913512 38 @param url
4cc4bfaf 39 Url string to parse.
23324ae1 40 */
4cc4bfaf 41 wxURL(const wxString& url = wxEmptyString);
23324ae1
FM
42
43 /**
44 Destroys the URL object.
45 */
4cc4bfaf 46 ~wxURL();
23324ae1
FM
47
48 /**
49 Returns the last error. This error refers to the URL parsing or to the protocol.
50 It can be one of these errors:
3c4f71cc 51
23324ae1 52 @b wxURL_NOERR
3c4f71cc 53
23324ae1 54 No error.
3c4f71cc 55
23324ae1 56 @b wxURL_SNTXERR
3c4f71cc 57
23324ae1 58 Syntax error in the URL string.
3c4f71cc 59
23324ae1 60 @b wxURL_NOPROTO
3c4f71cc 61
23324ae1 62 Found no protocol which can get this URL.
3c4f71cc 63
23324ae1 64 @b wxURL_NOHOST
3c4f71cc 65
23324ae1 66 A host name is required for this protocol.
3c4f71cc 67
23324ae1 68 @b wxURL_NOPATH
3c4f71cc 69
23324ae1 70 A path is required for this protocol.
3c4f71cc 71
23324ae1 72 @b wxURL_CONNERR
3c4f71cc 73
23324ae1 74 Connection error.
3c4f71cc 75
23324ae1 76 @b wxURL_PROTOERR
3c4f71cc 77
23324ae1
FM
78 An error occurred during negotiation.
79 */
328f5751 80 wxURLError GetError() const;
23324ae1
FM
81
82 /**
83 Creates a new input stream on the specified URL. You can use all but seek
84 functionality of wxStream. Seek isn't available on all streams. For example,
85 HTTP or FTP streams don't deal with it.
23324ae1
FM
86 Note that this method is somewhat deprecated, all future wxWidgets applications
87 should really use wxFileSystem instead.
23324ae1 88 Example:
3c4f71cc 89
23324ae1 90 @returns Returns the initialized stream. You will have to delete it
4cc4bfaf 91 yourself.
3c4f71cc 92
4cc4bfaf 93 @see wxInputStream
23324ae1 94 */
4cc4bfaf 95 wxInputStream* GetInputStream();
23324ae1
FM
96
97 /**
98 Returns a reference to the protocol which will be used to get the URL.
99 */
100 wxProtocol GetProtocol();
101
102 /**
7c913512 103 Returns @true if this object is correctly initialized, i.e. if
23324ae1
FM
104 GetError() returns @c wxURL_NOERR.
105 */
328f5751 106 bool IsOk() const;
23324ae1
FM
107
108 /**
109 Sets the default proxy server to use to get the URL. The string specifies
110 the proxy like this: hostname:port number.
3c4f71cc 111
7c913512 112 @param url_proxy
4cc4bfaf 113 Specifies the proxy to use
3c4f71cc 114
4cc4bfaf 115 @see SetProxy()
23324ae1
FM
116 */
117 static void SetDefaultProxy(const wxString& url_proxy);
118
119 /**
120 Sets the proxy to use for this URL.
3c4f71cc 121
4cc4bfaf 122 @see SetDefaultProxy()
23324ae1
FM
123 */
124 void SetProxy(const wxString& url_proxy);
125
126 /**
127 Initializes this object with the given URL and returns @c wxURL_NOERR
128 if it's valid (see GetError() for more info).
129 */
4cc4bfaf 130 wxURLError SetURL(const wxString& url);
23324ae1 131};
e54c96f1 132