pkgman: auto-refresh repositories only for update/install
This commit is contained in:
parent
8b26ef6779
commit
ce4f367692
@ -42,7 +42,7 @@ PackageManager::Repository::Repository()
|
|||||||
|
|
||||||
status_t
|
status_t
|
||||||
PackageManager::Repository::Init(BPackageRoster& roster, BContext& context,
|
PackageManager::Repository::Init(BPackageRoster& roster, BContext& context,
|
||||||
const char* name)
|
const char* name, bool refresh)
|
||||||
{
|
{
|
||||||
// get the repository config
|
// get the repository config
|
||||||
status_t error = roster.GetRepositoryConfig(name, &fConfig);
|
status_t error = roster.GetRepositoryConfig(name, &fConfig);
|
||||||
@ -50,6 +50,9 @@ PackageManager::Repository::Init(BPackageRoster& roster, BContext& context,
|
|||||||
return error;
|
return error;
|
||||||
|
|
||||||
// refresh
|
// refresh
|
||||||
|
if (!refresh)
|
||||||
|
return B_OK;
|
||||||
|
|
||||||
BRefreshRepositoryRequest refreshRequest(context, fConfig);
|
BRefreshRepositoryRequest refreshRequest(context, fConfig);
|
||||||
error = refreshRequest.Process();
|
error = refreshRequest.Process();
|
||||||
if (error != B_OK) {
|
if (error != B_OK) {
|
||||||
@ -143,7 +146,8 @@ PackageManager::PackageManager(BPackageInstallationLocation location,
|
|||||||
DIE(B_NO_MEMORY, "failed to create/add repository object");
|
DIE(B_NO_MEMORY, "failed to create/add repository object");
|
||||||
|
|
||||||
const BString& name = repositoryNames.StringAt(i);
|
const BString& name = repositoryNames.StringAt(i);
|
||||||
error = repository->Init(roster, fContext, name);
|
error = repository->Init(roster, fContext, name,
|
||||||
|
(flags & REFRESH_REPOSITORIES) != 0);
|
||||||
if (error != B_OK) {
|
if (error != B_OK) {
|
||||||
WARN(error,
|
WARN(error,
|
||||||
"failed to get config for repository \"%s\". Skipping.",
|
"failed to get config for repository \"%s\". Skipping.",
|
||||||
|
@ -32,6 +32,7 @@ public:
|
|||||||
enum {
|
enum {
|
||||||
ADD_INSTALLED_REPOSITORIES = 0x01,
|
ADD_INSTALLED_REPOSITORIES = 0x01,
|
||||||
ADD_REMOTE_REPOSITORIES = 0x02,
|
ADD_REMOTE_REPOSITORIES = 0x02,
|
||||||
|
REFRESH_REPOSITORIES = 0x04,
|
||||||
};
|
};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
@ -90,7 +91,7 @@ struct PackageManager::Repository : public BSolverRepository {
|
|||||||
Repository();
|
Repository();
|
||||||
|
|
||||||
status_t Init(BPackageRoster& roster, BContext& context,
|
status_t Init(BPackageRoster& roster, BContext& context,
|
||||||
const char* name);
|
const char* name, bool refresh);
|
||||||
|
|
||||||
const BRepositoryConfig& Config() const;
|
const BRepositoryConfig& Config() const;
|
||||||
|
|
||||||
|
@ -87,7 +87,8 @@ InstallCommand::Execute(int argc, const char* const* argv)
|
|||||||
: B_PACKAGE_INSTALLATION_LOCATION_COMMON;
|
: B_PACKAGE_INSTALLATION_LOCATION_COMMON;
|
||||||
PackageManager packageManager(location,
|
PackageManager packageManager(location,
|
||||||
PackageManager::ADD_INSTALLED_REPOSITORIES
|
PackageManager::ADD_INSTALLED_REPOSITORIES
|
||||||
| PackageManager::ADD_REMOTE_REPOSITORIES);
|
| PackageManager::ADD_REMOTE_REPOSITORIES
|
||||||
|
| PackageManager::REFRESH_REPOSITORIES);
|
||||||
packageManager.Install(packages, packageCount);
|
packageManager.Install(packages, packageCount);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -85,7 +85,8 @@ UpdateCommand::Execute(int argc, const char* const* argv)
|
|||||||
: B_PACKAGE_INSTALLATION_LOCATION_COMMON;
|
: B_PACKAGE_INSTALLATION_LOCATION_COMMON;
|
||||||
PackageManager packageManager(location,
|
PackageManager packageManager(location,
|
||||||
PackageManager::ADD_INSTALLED_REPOSITORIES
|
PackageManager::ADD_INSTALLED_REPOSITORIES
|
||||||
| PackageManager::ADD_REMOTE_REPOSITORIES);
|
| PackageManager::ADD_REMOTE_REPOSITORIES
|
||||||
|
| PackageManager::REFRESH_REPOSITORIES);
|
||||||
packageManager.Update(packages, packageCount);
|
packageManager.Update(packages, packageCount);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user