Imported Upstream version 14.45.0
[platform/upstream/libzypp.git] / zypp / sat / detail / PoolImpl.h
index 6d75452..8b4035a 100644 (file)
@@ -21,10 +21,9 @@ extern "C"
 }
 #include <iosfwd>
 
-#include "zypp/base/Hash.h"
+#include "zypp/base/Tr1hash.h"
 #include "zypp/base/NonCopyable.h"
 #include "zypp/base/SerialNumber.h"
-#include "zypp/base/SetTracker.h"
 #include "zypp/sat/detail/PoolMember.h"
 #include "zypp/sat/Queue.h"
 #include "zypp/RepoInfo.h"
@@ -38,7 +37,6 @@ namespace zypp
   ///////////////////////////////////////////////////////////////////
   namespace sat
   { /////////////////////////////////////////////////////////////////
-    class SolvableSet;
     ///////////////////////////////////////////////////////////////////
     namespace detail
     { /////////////////////////////////////////////////////////////////
@@ -58,7 +56,7 @@ namespace zypp
           ~PoolImpl();
 
           /** Pointer style access forwarded to sat-pool. */
-          CPool * operator->()
+          ::_Pool * operator->()
           { return _pool; }
 
         public:
@@ -79,25 +77,21 @@ namespace zypp
            */
           void setDirty( const char * a1 = 0, const char * a2 = 0, const char * a3 = 0 );
 
-          /** Invalidate locale related housekeeping data.
-           */
-          void localeSetDirty( const char * a1 = 0, const char * a2 = 0, const char * a3 = 0 );
-
           /** Invalidate housekeeping data (e.g. whatprovides) if dependencies changed.
            */
           void depSetDirty( const char * a1 = 0, const char * a2 = 0, const char * a3 = 0 );
 
           /** Callback to resolve namespace dependencies (language, modalias, filesystem, etc.). */
-          static detail::IdType nsCallback( CPool *, void * data, detail::IdType lhs, detail::IdType rhs );
+          static detail::IdType nsCallback( ::_Pool *, void * data, detail::IdType lhs, detail::IdType rhs );
 
         public:
           /** Reserved system repository alias \c @System. */
           static const std::string & systemRepoAlias();
 
-          bool isSystemRepo( CRepo * repo_r ) const
+          bool isSystemRepo( ::_Repo * repo_r ) const
           { return repo_r && _pool->installed == repo_r; }
 
-          CRepo * systemRepo() const
+          ::_Repo * systemRepo() const
           { return _pool->installed; }
 
           /** Get rootdir (for file conflicts check) */
@@ -123,53 +117,53 @@ namespace zypp
            */
           //@{
           /** Creating a new repo named \a name_r. */
-          CRepo * _createRepo( const std::string & name_r );
+          ::_Repo * _createRepo( const std::string & name_r );
 
           /** Creating a new repo named \a name_r. */
-          void _deleteRepo( CRepo * repo_r );
+          void _deleteRepo( ::_Repo * repo_r );
 
           /** Adding solv file to a repo.
            * Except for \c isSystemRepo_r, solvables of incompatible architecture
            * are filtered out.
           */
-          int _addSolv( CRepo * repo_r, FILE * file_r );
+          int _addSolv( ::_Repo * repo_r, FILE * file_r );
 
           /** Adding helix file to a repo.
            * Except for \c isSystemRepo_r, solvables of incompatible architecture
            * are filtered out.
           */
-          int _addHelix( CRepo * repo_r, FILE * file_r );
+          int _addHelix( ::_Repo * repo_r, FILE * file_r );
 
           /** Adding Solvables to a repo. */
-          detail::SolvableIdType _addSolvables( CRepo * repo_r, unsigned count_r );
+          detail::SolvableIdType _addSolvables( ::_Repo * repo_r, unsigned count_r );
           //@}
 
           /** Helper postprocessing the repo after adding solv or helix files. */
-          void _postRepoAdd( CRepo * repo_r );
+          void _postRepoAdd( ::_Repo * repo_r );
 
         public:
           /** a \c valid \ref Solvable has a non NULL repo pointer. */
-          bool validSolvable( const CSolvable & slv_r ) const
+          bool validSolvable( const ::_Solvable & slv_r ) const
           { return slv_r.repo; }
           /** \overload Check also for id_r being in range of _pool->solvables. */
           bool validSolvable( SolvableIdType id_r ) const
           { return id_r < unsigned(_pool->nsolvables) && validSolvable( _pool->solvables[id_r] ); }
           /** \overload Check also for slv_r being in range of _pool->solvables. */
-          bool validSolvable( const CSolvable * slv_r ) const
+          bool validSolvable( const ::_Solvable * slv_r ) const
           { return _pool->solvables <= slv_r && slv_r <= _pool->solvables+_pool->nsolvables && validSolvable( *slv_r ); }
 
         public:
-          CPool * getPool() const
+          ::_Pool * getPool() const
           { return _pool; }
 
           /** \todo a quick check whether the repo was meanwhile deleted. */
-          CRepo * getRepo( RepoIdType id_r ) const
+          ::_Repo * getRepo( RepoIdType id_r ) const
           { return id_r; }
 
           /** Return pointer to the sat-solvable or NULL if it is not valid.
            * \see \ref validSolvable.
            */
-          CSolvable * getSolvable( SolvableIdType id_r ) const
+          ::_Solvable * getSolvable( SolvableIdType id_r ) const
           {
             if ( validSolvable( id_r ) )
               return &_pool->solvables[id_r];
@@ -222,45 +216,22 @@ namespace zypp
           { prepare(); return ::pool_whatprovides( _pool, cap_r.id() ); }
 
         public:
-          /// \name Requested locales.
-         /// The requested LocaleSets managed in _requestedLocalesTracker
-         /// are unexpanded; i.e. they contain just the pure user selection.
-         /// The resolver however uses expanded sets ('de_DE' will also
-         /// include its fallback locales 'de', (en); here in the namespace:
-         /// callback and in the Resolver itself).
+          /** \name Requested locales. */
           //@{
-         /** */
          void setTextLocale( const Locale & locale_r );
+          void setRequestedLocales( const LocaleSet & locales_r );
+          bool addRequestedLocale( const Locale & locale_r );
+          bool eraseRequestedLocale( const Locale & locale_r );
 
-
-         /** Start tracking changes based on this \a locales_r.
-          * Usually called on TargetInit.
-          */
-         void initRequestedLocales( const LocaleSet & locales_r );
-
-          /** Added since last initRequestedLocales. */
-          const LocaleSet & getAddedRequestedLocales() const
-          { return _requestedLocalesTracker.added(); }
-
-          /** Removed since last initRequestedLocales. */
-          const LocaleSet & getRemovedRequestedLocales() const
-          { return _requestedLocalesTracker.removed(); }
-
-          /** Current set of requested Locales. */
           const LocaleSet & getRequestedLocales() const
-          { return _requestedLocalesTracker.current(); }
+          { return _requestedLocales; }
 
           bool isRequestedLocale( const Locale & locale_r ) const
-          { return _requestedLocalesTracker.contains( locale_r ); }
-
-          /** User change (tracked). */
-          void setRequestedLocales( const LocaleSet & locales_r );
-          /** User change (tracked). */
-          bool addRequestedLocale( const Locale & locale_r );
-          /** User change (tracked). */
-          bool eraseRequestedLocale( const Locale & locale_r );
+          {
+            LocaleSet::const_iterator it( _requestedLocales.find( locale_r ) );
+            return it != _requestedLocales.end();
+          }
 
-         /** All Locales occurring in any repo. */
           const LocaleSet & getAvailableLocales() const;
 
           bool isAvailableLocale( const Locale & locale_r ) const
@@ -269,23 +240,25 @@ namespace zypp
             LocaleSet::const_iterator it( avl.find( locale_r ) );
             return it != avl.end();
           }
-
-          typedef base::SetTracker<IdStringSet> TrackedLocaleIds;
-
-          /** Expanded _requestedLocalesTracker for solver.*/
-          const TrackedLocaleIds & trackedLocaleIds() const;
           //@}
 
         public:
           /** \name Multiversion install. */
           //@{
-          typedef SolvableSet MultiversionList;
-
-          const MultiversionList & multiversionList() const;
+          typedef IdStringSet MultiversionList;
 
-          bool isMultiversion( const Solvable & solv_r ) const;
+          const MultiversionList & multiversionList() const
+          {
+            if ( ! _multiversionListPtr )
+              multiversionListInit();
+            return *_multiversionListPtr;
+          }
 
-         void multiversionSpecChanged();
+          bool isMultiversion( IdString ident_r ) const
+          {
+            const MultiversionList & l( multiversionList() );
+            return l.find( ident_r ) != l.end();
+          }
           //@}
 
         public:
@@ -309,7 +282,7 @@ namespace zypp
 
         private:
           /** sat-pool. */
-          CPool * _pool;
+          ::_Pool * _pool;
           /** Serial number. */
           SerialNumber _serial;
           /** Watch serial number. */
@@ -318,10 +291,9 @@ namespace zypp
           std::map<RepoIdType,RepoInfo> _repoinfos;
 
           /**  */
-         base::SetTracker<LocaleSet> _requestedLocalesTracker;
-         mutable scoped_ptr<TrackedLocaleIds> _trackedLocaleIdsPtr;
-
+          LocaleSet _requestedLocales;
           mutable scoped_ptr<LocaleSet> _availableLocalesPtr;
+          mutable std::tr1::unordered_set<IdString> _locale2Solver;
 
           /**  */
           void multiversionListInit() const;