X-Git-Url: https://git.saurik.com/apt.git/blobdiff_plain/afd7b358f94efddb83a2911ec1a21e7280074b1e..f13b413a3bb1f03886ba7d8c43b08bd13836a663:/methods/rsh.h diff --git a/methods/rsh.h b/methods/rsh.h index c81396b5f..64a5cf661 100644 --- a/methods/rsh.h +++ b/methods/rsh.h @@ -11,10 +11,12 @@ #define APT_RSH_H #include +#include + #include -#include -#include -#include + +class Hashes; +class FileFd; class RSHConn { @@ -23,17 +25,19 @@ class RSHConn int WriteFd; int ReadFd; URI ServerName; + std::string const Prog; // Private helper functions - bool ReadLine(string &Text); + bool ReadLine(std::string &Text); public: pid_t Process; // Raw connection IO - bool WriteMsg(string &Text,bool Sync,const char *Fmt,...); - bool Connect(string Host, string User); + bool WriteMsg(std::string &Text,bool Sync,const char *Fmt,...); + bool Connect(std::string Host, std::string User); + bool Connect(std::string Host, unsigned int Port, std::string User); bool Comp(URI Other) const {return Other.Host == ServerName.Host && Other.Port == ServerName.Port;}; // Connection control @@ -46,25 +50,29 @@ class RSHConn bool Get(const char *Path,FileFd &To,unsigned long long Resume, Hashes &Hash,bool &Missing, unsigned long long Size); - RSHConn(URI Srv); + RSHConn(std::string const &Prog, URI Srv); ~RSHConn(); }; -class RSHMethod : public pkgAcqMethod +#include +#include "aptmethod.h" + +class RSHMethod : public aptMethod { - virtual bool Fetch(FetchItem *Itm); - virtual bool Configuration(string Message); + std::string const Prog; + virtual bool Fetch(FetchItem *Itm) APT_OVERRIDE; + virtual bool Configuration(std::string Message) APT_OVERRIDE; RSHConn *Server; - static string FailFile; + static std::string FailFile; static int FailFd; static time_t FailTime; - static void SigTerm(int); + static APT_NORETURN void SigTerm(int); public: - RSHMethod(); + explicit RSHMethod(std::string const &Prog); }; #endif