Sign Up
Log In
Log In
or
Sign Up
Places
All Projects
Status Monitor
Collapse sidebar
home:yfjiang:test:gnome45
PackageKit
PackageKit-zypp-add-repo-in-packageid.patch
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File PackageKit-zypp-add-repo-in-packageid.patch of Package PackageKit
Index: PackageKit-1.2.5/backends/zypp/pk-backend-zypp.cpp =================================================================== --- PackageKit-1.2.5.orig/backends/zypp/pk-backend-zypp.cpp +++ PackageKit-1.2.5/backends/zypp/pk-backend-zypp.cpp @@ -169,18 +169,30 @@ zypp_build_package_id_from_resolvable (c { gchar *package_id; const char *arch; + g_autofree gchar *repo = NULL; if (isKind<SrcPackage>(resolvable)) arch = "source"; else arch = resolvable.arch ().asString ().c_str (); - string repo = resolvable.repository ().alias(); - if (resolvable.isSystem()) - repo = "installed"; + if (resolvable.isSystem ()) { + PoolItem pi; + PoolItem installedPI { resolvable }; + ui::Selectable::Ptr selectable { ui::Selectable::get (resolvable) }; + + if (selectable->identicalAvailableObj (installedPI) != NULL) + pi = selectable->identicalAvailableObj (installedPI); + else + pi = selectable->updateCandidateObj (); + + repo = g_strconcat ("installed:", pi.repository ().alias ().c_str (), NULL); + } else + repo = g_strdup (resolvable.repository ().alias ().c_str ()); + package_id = pk_package_id_build (resolvable.name ().c_str (), resolvable.edition ().asString ().c_str (), - arch, repo.c_str ()); + arch, repo); return package_id; }
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Code of Conduct
Contact
Support
@OBShq
Terms
openSUSE Build Service is sponsored by
The Open Build Service is an
openSUSE project
.
Sign Up
Log In
Places
Places
All Projects
Status Monitor