4c51a665c6
Applied patch by snowleopard2 fixing a bunch of typos such as misspellings and double words in the documentation. Combined the patch with some local queued typos waiting to be committed as well as adding new typo fixes inspired by the patch. Function names with American spelling were not changed nor was third-party code touched. The only code changes involve some changes in strings that are translated ("Can not" -> "Cannot"). Closes #13063 (again). git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@67280 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
178 lines
5.6 KiB
C++
178 lines
5.6 KiB
C++
/////////////////////////////////////////////////////////////////////////////
|
|
// Name: wx/protocol/ftp.h
|
|
// Purpose: FTP protocol
|
|
// Author: Vadim Zeitlin
|
|
// Modified by: Mark Johnson, wxWindows@mj10777.de
|
|
// 20000917 : RmDir, GetLastResult, GetList
|
|
// Created: 07/07/1997
|
|
// RCS-ID: $Id$
|
|
// Copyright: (c) 1997, 1998 Guilhem Lavaux
|
|
// Licence: wxWindows licence
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
#ifndef __WX_FTP_H__
|
|
#define __WX_FTP_H__
|
|
|
|
#include "wx/defs.h"
|
|
|
|
#if wxUSE_PROTOCOL_FTP
|
|
|
|
#include "wx/sckaddr.h"
|
|
#include "wx/protocol/protocol.h"
|
|
#include "wx/url.h"
|
|
|
|
class WXDLLIMPEXP_NET wxFTP : public wxProtocol
|
|
{
|
|
public:
|
|
enum TransferMode
|
|
{
|
|
NONE, // not set by user explicitly
|
|
ASCII,
|
|
BINARY
|
|
};
|
|
|
|
wxFTP();
|
|
virtual ~wxFTP();
|
|
|
|
// Connecting and disconnecting
|
|
virtual bool Connect(const wxSockAddress& addr, bool wait = true);
|
|
virtual bool Connect(const wxString& host) { return Connect(host, 0); }
|
|
virtual bool Connect(const wxString& host, unsigned short port);
|
|
|
|
// disconnect
|
|
virtual bool Close();
|
|
|
|
// Parameters set up
|
|
|
|
// set transfer mode now
|
|
void SetPassive(bool pasv) { m_bPassive = pasv; }
|
|
bool SetBinary() { return SetTransferMode(BINARY); }
|
|
bool SetAscii() { return SetTransferMode(ASCII); }
|
|
bool SetTransferMode(TransferMode mode);
|
|
|
|
// Generic FTP interface
|
|
|
|
// FTP doesn't know the MIME type of the last downloaded/uploaded file
|
|
virtual wxString GetContentType() const { return wxEmptyString; }
|
|
|
|
// the last FTP server reply
|
|
const wxString& GetLastResult() const { return m_lastResult; }
|
|
|
|
// send any FTP command (should be full FTP command line but without
|
|
// trailing "\r\n") and return its return code
|
|
char SendCommand(const wxString& command);
|
|
|
|
// check that the command returned the given code
|
|
bool CheckCommand(const wxString& command, char expectedReturn)
|
|
{
|
|
// SendCommand() does updates m_lastError
|
|
return SendCommand(command) == expectedReturn;
|
|
}
|
|
|
|
// Filesystem commands
|
|
bool ChDir(const wxString& dir);
|
|
bool MkDir(const wxString& dir);
|
|
bool RmDir(const wxString& dir);
|
|
wxString Pwd();
|
|
bool Rename(const wxString& src, const wxString& dst);
|
|
bool RmFile(const wxString& path);
|
|
|
|
// Get the size of a file in the current dir.
|
|
// this function tries its best to deliver the size in bytes using BINARY
|
|
// (the SIZE command reports different sizes depending on whether
|
|
// type is set to ASCII or BINARY)
|
|
// returns -1 if file is non-existent or size could not be found
|
|
int GetFileSize(const wxString& fileName);
|
|
|
|
// Check to see if a file exists in the current dir
|
|
bool FileExists(const wxString& fileName);
|
|
|
|
// Download methods
|
|
bool Abort();
|
|
|
|
virtual wxInputStream *GetInputStream(const wxString& path);
|
|
virtual wxOutputStream *GetOutputStream(const wxString& path);
|
|
|
|
// Directory listing
|
|
|
|
// get the list of full filenames, the format is fixed: one file name per
|
|
// line
|
|
bool GetFilesList(wxArrayString& files,
|
|
const wxString& wildcard = wxEmptyString)
|
|
{
|
|
return GetList(files, wildcard, false);
|
|
}
|
|
|
|
// get a directory list in server dependent format - this can be shown
|
|
// directly to the user
|
|
bool GetDirList(wxArrayString& files,
|
|
const wxString& wildcard = wxEmptyString)
|
|
{
|
|
return GetList(files, wildcard, true);
|
|
}
|
|
|
|
// equivalent to either GetFilesList() (default) or GetDirList()
|
|
bool GetList(wxArrayString& files,
|
|
const wxString& wildcard = wxEmptyString,
|
|
bool details = false);
|
|
|
|
protected:
|
|
// this executes a simple ftp command with the given argument and returns
|
|
// true if it its return code starts with '2'
|
|
bool DoSimpleCommand(const wxChar *command,
|
|
const wxString& arg = wxEmptyString);
|
|
|
|
// get the server reply, return the first character of the reply code,
|
|
// '1'..'5' for normal FTP replies, 0 (*not* '0') if an error occurred
|
|
char GetResult();
|
|
|
|
// check that the result is equal to expected value
|
|
bool CheckResult(char ch) { return GetResult() == ch; }
|
|
|
|
// return the socket to be used, Passive/Active versions are used only by
|
|
// GetPort()
|
|
wxSocketBase *GetPort();
|
|
wxSocketBase *GetPassivePort();
|
|
wxSocketBase *GetActivePort();
|
|
|
|
// helper for GetPort()
|
|
wxString GetPortCmdArgument(const wxIPV4address& Local, const wxIPV4address& New);
|
|
|
|
// accept connection from server in active mode, returns the same socket as
|
|
// passed in in passive mode
|
|
wxSocketBase *AcceptIfActive(wxSocketBase *sock);
|
|
|
|
|
|
// internal variables:
|
|
|
|
wxString m_lastResult;
|
|
|
|
// true if there is an FTP transfer going on
|
|
bool m_streaming;
|
|
|
|
// although this should be set to ASCII by default according to STD9,
|
|
// we will use BINARY transfer mode by default for backwards compatibility
|
|
TransferMode m_currentTransfermode;
|
|
|
|
bool m_bPassive;
|
|
|
|
// following is true when a read or write times out, we then assume
|
|
// the connection is dead and abort. we avoid additional delays this way
|
|
bool m_bEncounteredError;
|
|
|
|
|
|
friend class wxInputFTPStream;
|
|
friend class wxOutputFTPStream;
|
|
|
|
DECLARE_DYNAMIC_CLASS_NO_COPY(wxFTP)
|
|
DECLARE_PROTOCOL(wxFTP)
|
|
};
|
|
|
|
// the trace mask used by assorted wxLogTrace() in ftp code, do
|
|
// wxLog::AddTraceMask(FTP_TRACE_MASK) to see them in output
|
|
#define FTP_TRACE_MASK wxT("ftp")
|
|
|
|
#endif // wxUSE_PROTOCOL_FTP
|
|
|
|
#endif // __WX_FTP_H__
|