Remove unneeded DefaultFalseBool.
[platform/upstream/libzypp.git] / zypp / target / TargetImpl.h
1 /*---------------------------------------------------------------------\
2 |                          ____ _   __ __ ___                          |
3 |                         |__  / \ / / . \ . \                         |
4 |                           / / \ V /|  _/  _/                         |
5 |                          / /__ | | | | | |                           |
6 |                         /_____||_| |_| |_|                           |
7 |                                                                      |
8 \---------------------------------------------------------------------*/
9 /** \file       zypp/target/TargetImpl.h
10  *
11 */
12 #ifndef ZYPP_TARGET_TARGETIMPL_H
13 #define ZYPP_TARGET_TARGETIMPL_H
14
15 #include <iosfwd>
16 #include <list>
17 #include <set>
18
19 #include "zypp/base/ReferenceCounted.h"
20 #include "zypp/base/NonCopyable.h"
21 #include "zypp/base/PtrTypes.h"
22 #include "zypp/PoolItem.h"
23 #include "zypp/ZYppCommit.h"
24
25 #include "zypp/Pathname.h"
26 #include "zypp/media/MediaAccess.h"
27 #include "zypp/Target.h"
28 #include "zypp/target/rpm/RpmDb.h"
29 #include "zypp/target/TargetException.h"
30 #include "zypp/target/RequestedLocalesFile.h"
31 #include "zypp/target/SoftLocksFile.h"
32 #include "zypp/target/HardLocksFile.h"
33
34 ///////////////////////////////////////////////////////////////////
35 namespace zypp
36 { /////////////////////////////////////////////////////////////////
37   ///////////////////////////////////////////////////////////////////
38   namespace target
39   { /////////////////////////////////////////////////////////////////
40
41     DEFINE_PTR_TYPE(TargetImpl);
42     class CommitPackageCache;
43
44     ///////////////////////////////////////////////////////////////////
45     //
46     //  CLASS NAME : TargetImpl
47     //
48     /** Base class for concrete Target implementations.
49      *
50      * Constructed by \ref TargetFactory. Public access via \ref Target
51      * interface.
52     */
53     class TargetImpl : public base::ReferenceCounted, private base::NonCopyable
54     {
55       friend std::ostream & operator<<( std::ostream & str, const TargetImpl & obj );
56
57     public:
58       /** list of pool items  */
59       typedef std::list<PoolItem> PoolItemList;
60
61       /** set of pool items  */
62       typedef std::set<PoolItem> PoolItemSet;
63
64     public:
65       /** Ctor. */
66       TargetImpl(const Pathname & root_r = "/", bool doRebuild_r = false );
67       /** Dtor. */
68       virtual ~TargetImpl();
69
70       /** Null implementation */
71       static TargetImpl_Ptr nullimpl();
72
73       /**
74        * generates the unique anonymous id which is called
75        * when creating the target
76        */
77       void createAnonymousId() const;
78
79       /**
80        * generates a cache of the last product flavor
81        */
82       void createLastDistributionFlavorCache() const;
83
84       /** \name Solv file handling.
85        * If target solv file is outdated, but (non-root-)user has
86        * no permission to  create it at the default location, we
87        * use a temporary one.
88        */
89       //@{
90     private:
91       /** The systems default solv file location. */
92       Pathname defaultSolvfilesPath() const;
93
94       /** The solv file location actually in use (default or temp). */
95       Pathname solvfilesPath() const
96       { return solvfilesPathIsTemp() ? _tmpSolvfilesPath : defaultSolvfilesPath(); }
97
98       /** Whether we're using a temp. solvfile. */
99       bool solvfilesPathIsTemp() const
100       { return ! _tmpSolvfilesPath.empty(); }
101
102       Pathname _tmpSolvfilesPath;
103
104     public:
105       void load();
106
107       void unload();
108
109       void clearCache();
110
111       void buildCache();
112       //@}
113
114       std::string anonymousUniqueId() const;
115
116     public:
117
118       /** The root set for this target */
119       Pathname root() const
120       { return _root; }
121
122       /** The directory to store things. */
123       Pathname home() const
124       { return _root / "/var/lib/zypp"; }
125
126       /** Commit changes in the pool */
127       ZYppCommitResult commit( ResPool pool_r, const ZYppCommitPolicy & policy_r );
128
129       ZYPP_DEPRECATED int commit( ResPool pool_r, unsigned int medianr,
130                                   PoolItemList & errors_r,
131                                   PoolItemList & remaining_r,
132                                   PoolItemList & srcremaining_r,
133                                   bool dry_run = false )
134       {
135         ZYppCommitPolicy policy;
136         policy.restrictToMedia( medianr ).dryRun( dry_run );
137         ZYppCommitResult res = commit( pool_r, policy );
138         errors_r.swap( res._errors );
139         remaining_r.swap( res._remaining );
140         srcremaining_r.swap( res._srcremaining );
141         return res._result;
142       }
143
144       /** Commit ordered changes
145        *  @param packageCache_r Access to the package provider
146        *  @return uncommitted ones (due to error)
147        */
148       PoolItemList commit( const PoolItemList & items_r, const ZYppCommitPolicy & policy_r,
149                            CommitPackageCache & packageCache_r );
150
151       /** Install a source package on the Target. */
152       void installSrcPackage( const SrcPackage_constPtr & srcPackage_r );
153
154       /** Overload to realize stream output. */
155       virtual std::ostream & dumpOn( std::ostream & str ) const
156       {
157         return str << "TargetImpl";
158       }
159
160       /** The RPM database */
161       rpm::RpmDb & rpm();
162
163       /** If the package is installed and provides the file
164       Needed to evaluate split provides during Resolver::Upgrade() */
165       bool providesFile (const std::string & path_str, const std::string & name_str) const;
166
167       /** Return name of package owning \a path_str
168        * or empty string if no installed package owns \a path_str. */
169       std::string whoOwnsFile (const std::string & path_str) const
170       { return _rpm.whoOwnsFile (path_str); }
171
172       /** return the last modification date of the target */
173       Date timestamp() const;
174
175       /** \copydoc Target::baseProduct() */
176       Product::constPtr baseProduct() const;
177
178       /** \copydoc Target::release() */
179       std::string release() const;
180
181       /** \copydoc Target::targetDistribution() */
182       std::string targetDistribution() const;
183
184       /** \copydoc Target::targetDistributionRelease()*/
185       std::string targetDistributionRelease() const;
186
187       /** \copydoc Target::distributionVersion()*/
188       std::string distributionVersion() const;
189
190       /** \copydoc Target::distributionFlavor() */
191       std::string distributionFlavor() const;
192
193     protected:
194       /** Path to the target */
195       Pathname _root;
196       /** RPM database */
197       rpm::RpmDb _rpm;
198       /** Requested Locales database */
199       RequestedLocalesFile _requestedLocalesFile;
200       /** Soft-locks database */
201       SoftLocksFile _softLocksFile;
202       /** Hard-Locks database */
203       HardLocksFile _hardLocksFile;
204       /** Cache distributionVersion */
205       mutable std::string _distributionVersion;
206     private:
207       /** Null implementation */
208       static TargetImpl_Ptr _nullimpl;
209     };
210     ///////////////////////////////////////////////////////////////////
211
212     /** \relates TargetImpl Stream output */
213     inline std::ostream & operator<<( std::ostream & str, const TargetImpl & obj )
214     {
215       return obj.dumpOn( str );
216     }
217
218     /////////////////////////////////////////////////////////////////
219   } // namespace target
220   ///////////////////////////////////////////////////////////////////
221   /////////////////////////////////////////////////////////////////
222 } // namespace zypp
223 ///////////////////////////////////////////////////////////////////
224 #endif // ZYPP_TARGET_TARGETIMPL_H