1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: FTP protocol
4 // Author: Vadim Zeitlin
5 // Modified by: Mark Johnson, wxWindows@mj10777.de
6 // 20000917 : RmDir, GetLastResult, GetList
9 // Copyright: (c) 1997, 1998 Guilhem Lavaux
10 // Licence: wxWindows license
11 /////////////////////////////////////////////////////////////////////////////
17 #pragma interface "ftp.h"
20 #include "wx/object.h"
21 #include "wx/sckaddr.h"
22 #include "wx/protocol/protocol.h"
25 class WXDLLEXPORT wxFTP
: public wxProtocol
30 NONE
, // not set by user explicitly
38 // Connecting and disconnecting
39 void SetUser(const wxString
& user
) { m_user
= user
; }
40 void SetPassword(const wxString
& passwd
) { m_passwd
= passwd
; }
42 bool Connect(wxSockAddress
& addr
, bool wait
= TRUE
);
43 bool Connect(const wxString
& host
);
50 // set transfer mode now
51 bool SetBinary() { return SetTransferMode(BINARY
); }
52 bool SetAscii() { return SetTransferMode(ASCII
); }
53 bool SetTransferMode(TransferMode mode
);
55 // Generic FTP interface
58 virtual wxProtocolError
GetError() { return m_lastError
; }
60 // the last FTP server reply
61 const wxString
& GetLastResult() { return m_lastResult
; }
63 // send any FTP command (should be full FTP command line but without
64 // trailing "\r\n") and return its return code
65 char SendCommand(const wxString
& command
);
67 // check that the command returned the given code
68 bool CheckCommand(const wxString
& command
, char expectedReturn
)
70 return SendCommand(command
) == expectedReturn
;
73 // Filesystem commands
74 bool ChDir(const wxString
& dir
);
75 bool MkDir(const wxString
& dir
);
76 bool RmDir(const wxString
& dir
);
78 bool Rename(const wxString
& src
, const wxString
& dst
);
79 bool RmFile(const wxString
& path
);
81 // Get the size of a file in the current dir.
82 // this function tries its best to deliver the size in bytes using BINARY
83 // (the SIZE command reports different sizes depending on whether
84 // type is set to ASCII or BINARY)
85 // returns -1 if file is non-existant or size could not be found
86 int GetFileSize(const wxString
& fileName
);
88 // Check to see if a file exists in the current dir
89 bool FileExists(const wxString
& fileName
);
94 virtual wxInputStream
*GetInputStream(const wxString
& path
);
95 virtual wxOutputStream
*GetOutputStream(const wxString
& path
);
99 // get the list of full filenames, the format is fixed: one file name per
101 bool GetFilesList(wxArrayString
& files
,
102 const wxString
& wildcard
= wxEmptyString
)
104 return GetList(files
, wildcard
, FALSE
);
107 // get a directory list in server dependent format - this can be shown
108 // directly to the user
109 bool GetDirList(wxArrayString
& files
,
110 const wxString
& wildcard
= wxEmptyString
)
112 return GetList(files
, wildcard
, TRUE
);
115 // equivalent to either GetFilesList() (default) or GetDirList()
116 bool GetList(wxArrayString
& files
,
117 const wxString
& wildcard
= wxEmptyString
,
118 bool details
= FALSE
);
120 #if WXWIN_COMPATIBILITY_2
122 wxList
*GetList(const wxString
& wildcard
, bool details
= FALSE
);
123 #endif // WXWIN_COMPATIBILITY_2
126 // this executes a simple ftp command with the given argument and returns
127 // TRUE if it its return code starts with '2'
128 bool DoSimpleCommand(const wxChar
*command
,
129 const wxString
& arg
= wxEmptyString
);
131 // get the server reply, return the first character of the reply code,
132 // '1'..'5' for normal FTP replies, 0 (*not* '0') if an error occured
135 // check that the result is equal to expected value
136 bool CheckResult(char ch
) { return GetResult() == ch
; }
138 wxSocketClient
*GetPort();
143 wxString m_lastResult
;
144 wxProtocolError m_lastError
;
146 // true if there is an FTP transfer going on
149 // although this should be set to ASCII by default according to STD9,
150 // we will use BINARY transfer mode by default for backwards compatibility
151 TransferMode m_currentTransfermode
;
153 friend class wxInputFTPStream
;
154 friend class wxOutputFTPStream
;
156 DECLARE_DYNAMIC_CLASS(wxFTP
)
157 DECLARE_PROTOCOL(wxFTP
)
160 // the trace mask used by assorted wxLogTrace() in ftp code, do
161 // wxLog::AddTraceMask(FTP_TRACE_MASK) to see them in output
162 #define FTP_TRACE_MASK _T("ftp")
164 #endif // __WX_FTP_H__