From c23857618921c622d6227ba5e0e88487031ac06c Mon Sep 17 00:00:00 2001 From: Ciaran McCreesh Date: Thu, 14 Jul 2011 20:09:37 +0100 Subject: Make CONFIG_PROTECT etc available for hooks --- paludis/repositories/e/exndbam_repository.cc | 14 ++++++++++++++ paludis/repositories/e/vdb_repository.cc | 14 ++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/paludis/repositories/e/exndbam_repository.cc b/paludis/repositories/e/exndbam_repository.cc index 71a9624ac..c4e816015 100644 --- a/paludis/repositories/e/exndbam_repository.cc +++ b/paludis/repositories/e/exndbam_repository.cc @@ -413,6 +413,20 @@ ExndbamRepository::merge(const MergeParams & m) { } } + else + { + /* nasty: make CONFIG_PROTECT etc available for hooks */ + try + { + config_protect = snoop_variable_from_environment_file(m.environment_file(), "CONFIG_PROTECT"); + config_protect_mask = snoop_variable_from_environment_file(m.environment_file(), "CONFIG_PROTECT_MASK"); + } + catch (const Exception & e) + { + Log::get_instance()->message("e.exndbam_repository.config_protect_unfetchable", ll_warning, lc_context) + << "Could not load CONFIG_PROTECT for merge checks due to exception '" + e.message() + "' (" + e.what() + ")"; + } + } bool fix_mtimes(std::static_pointer_cast( m.package_id())->eapi()->supported()->ebuild_options()->fix_mtimes()); diff --git a/paludis/repositories/e/vdb_repository.cc b/paludis/repositories/e/vdb_repository.cc index 373b7dd6c..00f734a4a 100644 --- a/paludis/repositories/e/vdb_repository.cc +++ b/paludis/repositories/e/vdb_repository.cc @@ -638,6 +638,20 @@ VDBRepository::merge(const MergeParams & m) { } } + else + { + /* nasty: make CONFIG_PROTECT etc available for hooks */ + try + { + config_protect = snoop_variable_from_environment_file(m.environment_file(), "CONFIG_PROTECT"); + config_protect_mask = snoop_variable_from_environment_file(m.environment_file(), "CONFIG_PROTECT_MASK"); + } + catch (const Exception & e) + { + Log::get_instance()->message("e.exndbam_repository.config_protect_unfetchable", ll_warning, lc_context) + << "Could not load CONFIG_PROTECT for merge checks due to exception '" + e.message() + "' (" + e.what() + ")"; + } + } FSPath vdb_dir(_imp->params.location()); vdb_dir /= stringify(m.package_id()->name().category()); -- cgit v1.2.3