⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ftp.h

📁 wxGTK 是 wxWidgets 的 linux GTK+ (>2.2.3)版本。wxWidgets 是一个跨平台的 GUI 框架
💻 H
字号:
/////////////////////////////////////////////////////////////////////////////// Name:        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: ftp.h,v 1.23 2005/09/24 21:42:27 VZ Exp $// 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    void SetUser(const wxString& user) { m_user = user; }    void SetPassword(const wxString& passwd) { m_passwd = passwd; }    bool Connect(wxSockAddress& addr, bool wait = true);    bool Connect(const wxString& host);    // disconnect    virtual bool Close();    // Parameters set up    // set transfer mode now    void SetPassive(bool pasv) { m_bPassive = pasv; };    void SetDefaultTimeout(wxUint32 Value);    bool SetBinary() { return SetTransferMode(BINARY); }    bool SetAscii() { return SetTransferMode(ASCII); }    bool SetTransferMode(TransferMode mode);    // Generic FTP interface    // the error code    virtual wxProtocolError GetError() { return m_lastError; }    // the last FTP server reply    const wxString& GetLastResult() { 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)    {        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-existant 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);    wxString m_user,             m_passwd;    wxString m_lastResult;    wxProtocolError m_lastError;    // 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;    friend class wxInputFTPStream;    friend class wxOutputFTPStream;    bool            m_bPassive;    wxUint32        m_uiDefaultTimeout;    // 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;    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 _T("ftp")#endif // wxUSE_PROTOCOL_FTP#endif // __WX_FTP_H__

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -