*
*/
-#include <zypp/base/Logger.h>
#include "zypp/ResObject.h"
#include "zypp/sat/SolvAttr.h"
#include "zypp/sat/Solvable.h"
#include "zypp/Repository.h"
#include "zypp/RepoInfo.h"
+#include "zypp/IdString.h"
+
+#include "zypp/ui/Selectable.h"
using namespace zypp;
using namespace std;
}
///////////////////////////////////////////////////////////////////
- //
- // ResObject interface forwarded to implementation
- //
- ///////////////////////////////////////////////////////////////////
- Text ResObject::summary() const
- { return lookupStrAttribute( sat::SolvAttr::summary ); }
+ std::string ResObject::summary( const Locale & lang_r ) const
+ { return lookupStrAttribute( sat::SolvAttr::summary, lang_r ); }
- Text ResObject::description() const
- { return lookupStrAttribute( sat::SolvAttr::description ); }
+ std::string ResObject::description( const Locale & lang_r ) const
+ { return lookupStrAttribute( sat::SolvAttr::description, lang_r ); }
+
+ std::string ResObject::insnotify( const Locale & lang_r ) const
+ { return lookupStrAttribute( sat::SolvAttr::insnotify, lang_r ); }
+
+ std::string ResObject::delnotify( const Locale & lang_r ) const
+ { return lookupStrAttribute( sat::SolvAttr::delnotify, lang_r ); }
+
+ std::string ResObject::licenseToConfirm( const Locale & lang_r ) const
+ {
+ std::string ret = lookupStrAttribute( sat::SolvAttr::eula, lang_r );
+ if ( ret.empty() && isKind<Product>() )
+ {
+ const RepoInfo & ri( repoInfo() );
+ if ( ri.needToAcceptLicense() || ! ui::Selectable::get( *this )->hasInstalledObj() )
+ ret = ri.getLicense( lang_r ); // bnc#908976: suppress informal license upon update
+ }
+ return ret;
+ }
- Text ResObject::insnotify() const
- { return lookupStrAttribute( sat::SolvAttr::insnotify ); }
+ bool ResObject::needToAcceptLicense() const
+ {
+ if ( isKind<Product>() )
+ return repoInfo().needToAcceptLicense( );
+ return true;
+ }
- Text ResObject::delnotify() const
- { return lookupStrAttribute( sat::SolvAttr::delnotify ); }
+ std::string ResObject::distribution() const
+ { return lookupStrAttribute( sat::SolvAttr::distribution ); }
- License ResObject::licenseToConfirm() const
- { return lookupStrAttribute( sat::SolvAttr::eula ); }
+ CpeId ResObject::cpeId() const
+ { return CpeId( lookupStrAttribute( sat::SolvAttr::cpeid ), CpeId::noThrow ); }
- ByteCount ResObject::size() const
- { return ByteCount( lookupNumAttribute( sat::SolvAttr::size ), ByteCount::K ); }
+ ByteCount ResObject::installSize() const
+ { return ByteCount( lookupNumAttribute( sat::SolvAttr::installsize ) ); }
ByteCount ResObject::downloadSize() const
- { return ByteCount( lookupNumAttribute( sat::SolvAttr::downloadsize ), ByteCount::K ); }
+ { return ByteCount( lookupNumAttribute( sat::SolvAttr::downloadsize ) ); }
unsigned ResObject::mediaNr() const
{ return lookupNumAttribute( sat::SolvAttr::medianr ); }
-#warning DUMMY installOnly
- bool ResObject::installOnly() const
- { return false; }
-
-#warning DUMMY
Date ResObject::buildtime() const
- { return Date(); }
+ { return Date( lookupNumAttribute( sat::SolvAttr::buildtime ) ); }
-#warning DUMMY installtime
Date ResObject::installtime() const
- { return Date(); }
-
-#warning DUMMY diskusage
- const DiskUsage & ResObject::diskusage() const
- {
- static DiskUsage _du;
- return _du;
- }
+ { return Date( lookupNumAttribute( sat::SolvAttr::installtime ) ); }
/////////////////////////////////////////////////////////////////
} // namespace zypp
ResObject::Ptr makeResObject( const sat::Solvable & solvable_r )
{
+ if ( ! solvable_r )
+ return 0;
+
ResKind kind( solvable_r.kind() );
#define OUTS(X) if ( kind == ResTraits<X>::kind ) return make<X>( solvable_r );
- OUTS( Atom );
- OUTS( Message );
OUTS( Package );
OUTS( Patch );
OUTS( Pattern );
OUTS( Product );
- OUTS( Script );
OUTS( SrcPackage );
+ OUTS( Application );
#undef OUTS
- return 0;
+ // unknow => return a plain ResObject
+ return new ResObject( solvable_r );
}
/////////////////////////////////////////////////////////////////