X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f9133b32002a600cb48dd05fbcce1ab3ed684dba..d566b182a54ff3bba1bfc71e235bb1f46996766c:/include/wx/protocol/http.h?ds=sidebyside diff --git a/include/wx/protocol/http.h b/include/wx/protocol/http.h index 4abcaf5951..b3ee9a5384 100644 --- a/include/wx/protocol/http.h +++ b/include/wx/protocol/http.h @@ -18,17 +18,11 @@ #include "wx/hashmap.h" #include "wx/protocol/protocol.h" -WX_DECLARE_EXPORTED_STRING_HASH_MAP( wxString, wxStringToStringHashMap ); +WX_DECLARE_STRING_HASH_MAP_WITH_DECL( wxString, wxStringToStringHashMap, + class WXDLLIMPEXP_NET ); -class WXDLLIMPEXP_BASE wxHTTP : public wxProtocol { - DECLARE_DYNAMIC_CLASS(wxHTTP) - DECLARE_PROTOCOL(wxHTTP) -protected: - wxProtocolError m_perr; - wxStringToStringHashMap m_headers; - bool m_read, m_proxy_mode; - wxSockAddress *m_addr; - wxString m_post_buf; +class WXDLLIMPEXP_NET wxHTTP : public wxProtocol +{ public: wxHTTP(); ~wxHTTP(); @@ -41,25 +35,41 @@ public: wxString GetContentType(); void SetHeader(const wxString& header, const wxString& h_data); - wxString GetHeader(const wxString& header); + wxString GetHeader(const wxString& header) const; void SetPostBuffer(const wxString& post_buf); void SetProxyMode(bool on); protected: - typedef enum { + enum wxHTTP_Req + { wxHTTP_GET, wxHTTP_POST, wxHTTP_HEAD - } wxHTTP_Req; + }; + + typedef wxStringToStringHashMap::iterator wxHeaderIterator; + bool BuildRequest(const wxString& path, wxHTTP_Req req); void SendHeaders(); bool ParseHeaders(); + // find the header in m_headers + wxHeaderIterator FindHeader(const wxString& header) const; + // deletes the header value strings void ClearHeaders(); - DECLARE_NO_COPY_CLASS(wxHTTP) + wxProtocolError m_perr; + wxStringToStringHashMap m_headers; + bool m_read, + m_proxy_mode; + wxSockAddress *m_addr; + wxString m_post_buf; + + DECLARE_DYNAMIC_CLASS(wxHTTP) + DECLARE_PROTOCOL(wxHTTP) + DECLARE_NO_COPY_CLASS(wxHTTP) }; #endif // wxUSE_PROTOCOL_HTTP