]>
git.saurik.com Git - apt.git/blob - apt-pkg/acquire-worker.h
   1 // -*- mode: cpp; mode: fold -*- 
   3 // $Id: acquire-worker.h,v 1.12 2001/02/20 07:03:17 jgg Exp $ 
   4 /* ###################################################################### 
   6    Acquire Worker - Worker process manager 
   8    Each worker class is associated with exaclty one subprocess. 
  10    ##################################################################### */ 
  13 /** \addtogroup acquire 
  16  *  \file acquire-worker.h 
  19 #ifndef PKGLIB_ACQUIRE_WORKER_H 
  20 #define PKGLIB_ACQUIRE_WORKER_H 
  22 #include <apt-pkg/acquire.h> 
  23 #include <apt-pkg/weakptr.h> 
  26 /** \brief A fetch subprocess. 
  28  *  A worker process is responsible for one stage of the fetch.  This 
  29  *  class encapsulates the communications protocol between the master 
  30  *  process and the worker, from the master end. 
  32  *  Each worker is intrinsically placed on two linked lists.  The 
  33  *  Queue list (maintained in the #NextQueue variable) is maintained 
  34  *  by the pkgAcquire::Queue class; it represents the set of workers 
  35  *  assigned to a particular queue.  The Acquire list (maintained in 
  36  *  the #NextAcquire variable) is maintained by the pkgAcquire class; 
  37  *  it represents the set of active workers for a particular 
  40  *  \todo Like everything else in the Acquire system, this has way too 
  41  *  many protected items. 
  43  *  \sa pkgAcqMethod, pkgAcquire::Item, pkgAcquire 
  45 class pkgAcquire::Worker 
: public WeakPointable
 
  47    /** \brief dpointer placeholder (for later in case we need it) */ 
  50    friend class pkgAcquire
; 
  55    /** \brief The next link on the Queue list. 
  57     *  \todo This is always NULL; is it just for future use? 
  61    /** \brief The next link on the Acquire list. */ 
  64    /** \brief The Queue with which this worker is associated. */ 
  67    /** \brief The download progress indicator to which progress 
  68     *  messages should be sent. 
  70    pkgAcquireStatus 
*Log
; 
  72    /** \brief The configuration of this method.  On startup, the 
  73     *  target of this pointer is filled in with basic data about the 
  74     *  method, as reported by the worker. 
  78    /** \brief The access method to be used by this worker. 
  80     *  \todo Doesn't this duplicate Config->Access? 
  84    /** \brief The PID of the subprocess. */ 
  87    /** \brief A file descriptor connected to the standard output of 
  90     *  Used to read messages and data from the subprocess. 
  94    /** \brief A file descriptor connected to the standard input of the 
  97     *  Used to send commands and configuration data to the subprocess. 
 101    /** \brief Set to \b true if the worker is in a state in which it 
 102     *  might generate data or command responses. 
 104     *  \todo Is this right?  It's a guess. 
 108    /** \brief Set to \b true if the worker is in a state in which it 
 109     *  is legal to send commands to it. 
 111     *  \todo Is this right? 
 115    /** If \b true, debugging output will be sent to std::clog. */ 
 118    /** \brief The raw text values of messages received from the 
 119     *  worker, in sequence. 
 121    std::vector
<std::string
> MessageQueue
; 
 123    /** \brief Buffers pending writes to the subprocess. 
 125     *  \todo Wouldn't a std::dequeue be more appropriate? 
 127    std::string OutQueue
; 
 129    /** \brief Common code for the constructor. 
 131     *  Initializes NextQueue and NextAcquire to NULL; Process, InFd, 
 132     *  and OutFd to -1, OutReady and InReady to \b false, and Debug 
 137    /** \brief Retrieve any available messages from the subprocess. 
 139     *  The messages are retrieved as in ::ReadMessages(), and 
 140     *  MessageFailure() is invoked if an error occurs; in particular, 
 141     *  if the pipe to the subprocess dies unexpectedly while a message 
 144     *  \return \b true if the messages were successfully read, \b 
 149    /** \brief Parse and dispatch pending messages. 
 151     *  This dispatches the message in a manner appropriate for its 
 154     *  \todo Several message types lack separate handlers. 
 156     *  \sa Capabilities(), SendConfiguration(), MediaChange() 
 160    /** \brief Read and dispatch any pending messages from the 
 163     *  \return \b false if the subprocess died unexpectedly while a 
 164     *  message was being transmitted. 
 168    /** \brief Send any pending commands to the subprocess. 
 170     *  This method will fail if there is no pending output. 
 172     *  \return \b true if all commands were succeeded, \b false if an 
 173     *  error occurred (in which case MethodFailure() will be invoked). 
 177    /** \brief Handle a 100 Capabilities response from the subprocess. 
 179     *  \param Message the raw text of the message from the subprocess. 
 181     *  The message will be parsed and its contents used to fill 
 182     *  #Config.  If #Config is NULL, this routine is a NOP. 
 186    bool Capabilities(std::string Message
); 
 188    /** \brief Send a 601 Configuration message (containing the APT 
 189     *  configuration) to the subprocess. 
 191     *  The APT configuration will be send to the subprocess in a 
 192     *  message of the following form: 
 196     *  Config-Item: Fully-Qualified-Item=Val 
 197     *  Config-Item: Fully-Qualified-Item=Val 
 201     *  \return \b true if the command was successfully sent, \b false 
 204    bool SendConfiguration(); 
 206    /** \brief Handle a 403 Media Change message. 
 208     *  \param Message the raw text of the message; the Media field 
 209     *  indicates what type of media should be changed, and the Drive 
 210     *  field indicates where the media is located. 
 212     *  Invokes pkgAcquireStatus::MediaChange(Media, Drive) to ask the 
 213     *  user to swap disks; informs the subprocess of the result (via 
 214     *  603 Media Changed, with the Failed field set to \b true if the 
 215     *  user cancelled the media change). 
 217    bool MediaChange(std::string Message
); 
 219    /** \brief Invoked when the worked process dies unexpectedly. 
 221     *  Waits for the subprocess to terminate and generates an error if 
 222     *  it terminated abnormally, then closes and blanks out all file 
 223     *  descriptors.  Discards all pending messages from the 
 228    bool MethodFailure(); 
 230    /** \brief Invoked when a fetch job is completed, either 
 231     *  successfully or unsuccessfully. 
 233     *  Resets the status information for the worker process. 
 239    /** \brief The queue entry that is currently being downloaded. */ 
 240    pkgAcquire::Queue::QItem 
*CurrentItem
; 
 242    /** \brief The most recent status string received from the 
 247    /** \brief How many bytes of the file have been downloaded.  Zero 
 248     *  if the current progress of the file cannot be determined. 
 250    unsigned long long CurrentSize
; 
 252    /** \brief The total number of bytes to be downloaded.  Zero if the 
 253     *  total size of the final is unknown. 
 255    unsigned long long TotalSize
; 
 257    /** \brief How much of the file was already downloaded prior to 
 258     *  starting this worker. 
 260    unsigned long long ResumePoint
; 
 262    /** \brief Tell the subprocess to download the given item. 
 264     *  \param Item the item to queue up. 
 265     *  \return \b true if the item was successfully enqueued. 
 267     *  Queues up a 600 URI Acquire message for the given item to be 
 268     *  sent at the next possible moment.  Does \e not flush the output 
 271    bool QueueItem(pkgAcquire::Queue::QItem 
*Item
); 
 273    /** \brief Start up the worker and fill in #Config. 
 275     *  Reads the first message from the worker, which is assumed to be 
 276     *  a 100 Capabilities message. 
 278     *  \return \b true if all operations completed successfully. 
 282    /** \brief Update the worker statistics (CurrentSize, TotalSize, 
 287    /** \return The fetch method configuration. */ 
 288    inline const MethodConfig 
*GetConf() const {return Config
;}; 
 290    /** \brief Create a new Worker to download files. 
 292     *  \param OwnerQ The queue into which this worker should be 
 295     *  \param Config A location in which to store information about 
 298     *  \param Log The download progress indicator that should be used 
 299     *  to report the progress of this worker. 
 301    Worker(Queue 
*OwnerQ
,MethodConfig 
*Config
,pkgAcquireStatus 
*Log
); 
 303    /** \brief Create a new Worker that should just retrieve 
 304     *  information about the fetch method. 
 306     *  Nothing in particular forces you to refrain from actually 
 307     *  downloading stuff, but the various status callbacks won't be 
 310     *  \param Config A location in which to store information about 
 313    Worker(MethodConfig 
*Config
); 
 315    /** \brief Clean up this worker. 
 317     *  Closes the file descriptors; if MethodConfig::NeedsCleanup is 
 318     *  \b false, also rudely interrupts the worker with a SIGINT.