1 // -*- mode: cpp; mode: fold -*-
3 /* ######################################################################
5 SourceList - Manage a list of sources
7 The Source List class provides access to a list of sources. It
8 can read them from a file and generate a list of all the distinct
11 All sources have a type associated with them that defines the layout
12 of the archive. The exact format of the file is documented in
15 The types are mapped through a list of type definitions which handle
16 the actual construction of the back end type. After loading a source
17 list all you have is a list of package index files that have the ability
20 ##################################################################### */
22 #ifndef PKGLIB_SOURCELIST_H
23 #define PKGLIB_SOURCELIST_H
25 #include <apt-pkg/pkgcache.h>
26 #include <apt-pkg/cacheiterators.h>
27 #include <apt-pkg/macros.h>
35 #ifndef APT_8_CLEANER_HEADERS
36 #include <apt-pkg/tagfile.h>
38 #ifndef APT_8_CLEANER_HEADERS
39 #include <apt-pkg/metaindex.h>
54 std::vector
<pkgIndexFile
*> VolatileFiles
;
57 // List of supported source list types
62 // Global list of Items supported
63 static Type
**GlobalList
;
64 static unsigned long GlobalListLen
;
65 static Type
*GetType(const char *Type
) APT_PURE
;
67 char const * const Name
;
68 char const * const Label
;
70 bool FixupURI(std::string
&URI
) const;
71 virtual bool ParseStanza(std::vector
<metaIndex
*> &List
,
73 unsigned int const stanza_n
,
75 virtual bool ParseLine(std::vector
<metaIndex
*> &List
,
77 unsigned int const CurLine
,std::string
const &File
) const;
78 virtual bool CreateItem(std::vector
<metaIndex
*> &List
,std::string
const &URI
,
79 std::string
const &Dist
,std::string
const &Section
,
80 std::map
<std::string
, std::string
> const &Options
) const = 0;
81 Type(char const * const Name
, char const * const Label
);
85 typedef std::vector
<metaIndex
*>::const_iterator const_iterator
;
89 std::vector
<metaIndex
*> SrcList
;
92 APT_HIDDEN
bool ParseFileDeb822(std::string
const &File
);
93 APT_HIDDEN
bool ParseFileOldStyle(std::string
const &File
);
98 bool Read(std::string
const &File
);
102 bool ReadAppend(std::string
const &File
);
103 bool ReadSourceDir(std::string
const &Dir
);
106 inline const_iterator
begin() const {return SrcList
.begin();};
107 inline const_iterator
end() const {return SrcList
.end();};
108 inline unsigned int size() const {return SrcList
.size();};
109 inline bool empty() const {return SrcList
.empty();};
111 bool FindIndex(pkgCache::PkgFileIterator File
,
112 pkgIndexFile
*&Found
) const;
113 bool GetIndexes(pkgAcquire
*Owner
, bool GetAll
=false) const;
115 // query last-modified time
116 time_t GetLastModifiedTime();
118 /** \brief add file for parsing, but not to the cache
120 * pkgIndexFiles origining from pkgSourcesList are included in
121 * srcpkgcache, the status files added via #AddStatusFiles are
122 * included in pkgcache, but these files here are not included in
123 * any cache to have the possibility of having a file included just
124 * for a single run like a local .deb/.dsc file.
126 * The volatile files do not count as "normal" sourceslist entries,
127 * can't be iterated over with #begin and #end and can't be
128 * downloaded, but they can be found via #FindIndex.
130 * @param File is an index file; pointer-ownership is transferred
132 void AddVolatileFile(pkgIndexFile
* const File
);
133 bool AddVolatileFile(std::string
const &File
);
134 bool AddVolatileFile(std::string
const &File
, std::vector
<std::string
> * const VolatileCmdL
);
135 APT_DEPRECATED_MSG("Use the overload with string-vector") void AddVolatileFiles(CommandLine
&CmdL
, std::vector
<const char*> * const VolatileCmdL
);
136 void AddVolatileFiles(CommandLine
&CmdL
, std::vector
<std::string
> * const VolatileCmdL
);
138 /** @return list of files registered with #AddVolatileFile */
139 std::vector
<pkgIndexFile
*> GetVolatileFiles() const;
142 virtual ~pkgSourceList();