make CD ordering function available
[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
17 #include "zypp/base/ReferenceCounted.h"
18 #include "zypp/base/NonCopyable.h"
19 #include "zypp/base/PtrTypes.h"
20 #include "zypp/ResStore.h"
21
22 #include "zypp/Pathname.h"
23 #include "zypp/media/MediaAccess.h"
24 #include "zypp/Target.h"
25 #include "zypp/target/rpm/RpmDb.h"
26 #include "zypp/target/store/PersistentStorage.h"
27 #include "zypp/solver/detail/Types.h"
28
29 ///////////////////////////////////////////////////////////////////
30 namespace zypp
31 { /////////////////////////////////////////////////////////////////
32   ///////////////////////////////////////////////////////////////////
33   namespace target
34   { /////////////////////////////////////////////////////////////////
35
36     DEFINE_PTR_TYPE(TargetImpl);
37
38     ///////////////////////////////////////////////////////////////////
39     //
40     //  CLASS NAME : TargetImpl
41     //
42     /** Base class for concrete Target implementations.
43      *
44      * Constructed by \ref TargetFactory. Public access via \ref Target
45      * interface.
46     */
47     class TargetImpl : public base::ReferenceCounted, private base::NonCopyable
48     {
49       friend std::ostream & operator<<( std::ostream & str, const TargetImpl & obj );
50
51     public:
52       /** JUST FOR TESTSUITE */
53       /** Sort according to prereqs and media numbers */
54       void getResolvablesToInsDel ( const ResPool pool_r,
55                                     PoolItemList & dellist_r,
56                                     PoolItemList & instlist_r,
57                                     PoolItemList & srclist_r ) const;
58
59
60     public:
61       /** Ctor. */
62       TargetImpl(const Pathname & root_r = "/");
63       /** Dtor. */
64       virtual ~TargetImpl();
65
66       /** Null implementation */
67       static TargetImpl_Ptr nullimpl();
68
69     public:
70
71       /** All resolvables in the target. */
72       const ResStore & resolvables();
73
74       /** Commit changes in the pool
75           media = 0 means any/all medias
76           media > 0 means limit commits to this media */
77       int commit( ResPool pool_r, unsigned int medianr, PoolItemList & errors_r, PoolItemList & remaining_r, PoolItemList & srcremaining_r );
78
79       /** enables the storage target */
80       bool isStorageEnabled() const;
81       void enableStorage(const Pathname &root_r);
82
83       /** Commit ordered changes
84           return uncommitted ones (due to error) */
85       PoolItemList commit( const PoolItemList & items_r );
86
87       /** Overload to realize stream output. */
88       virtual std::ostream & dumpOn( std::ostream & str ) const
89       { return str << "TargetImpl"; }
90
91       /** The RPM database */
92       rpm::RpmDb & rpm();
93
94       /** If the package is installed and provides the file
95           Needed to evaluate split provides during Resolver::Upgrade() */
96       bool providesFile (const std::string & path_str, const std::string & name_str) const;
97
98       /** Return the resolvable which provides path_str (rpm -qf)
99           return NULL if no resolvable provides this file  */
100       ResObject::constPtr whoOwnsFile (const std::string & path_str) const;
101
102     protected:
103       /** All resolvables provided by the target. */
104       ResStore _store;
105       /** Path to the target */
106       Pathname _root;
107       /** RPM database */
108       rpm::RpmDb _rpm;
109 #ifndef STORAGE_DISABLED
110       zypp::storage::PersistentStorage _storage;
111 #endif
112     private:
113       /** Null implementation */
114       static TargetImpl_Ptr _nullimpl;
115       
116       /** wrapper with callback around getPlainRpm */
117       Pathname getRpmFile(Package::constPtr package);
118     };
119     ///////////////////////////////////////////////////////////////////
120
121     /** \relates TargetImpl Stream output */
122     inline std::ostream & operator<<( std::ostream & str, const TargetImpl & obj )
123     { return obj.dumpOn( str ); }
124
125     /////////////////////////////////////////////////////////////////
126   } // namespace target
127   ///////////////////////////////////////////////////////////////////
128   /////////////////////////////////////////////////////////////////
129 } // namespace zypp
130 ///////////////////////////////////////////////////////////////////
131 #endif // ZYPP_TARGET_TARGETIMPL_H