From 24d0fa95bc589eec753890e9bec10f59394dfc67 Mon Sep 17 00:00:00 2001 From: Rob Reynolds Date: Sun, 25 Jan 2015 17:16:15 -0600 Subject: [PATCH] (GH-10) Allow .config items in package names Split config file names off of the package names list for further processing. Continue processing normal package names. --- .../services/ChocolateyPackageService.cs | 40 ++++++++++++++++--- 1 file changed, 34 insertions(+), 6 deletions(-) diff --git a/src/chocolatey/infrastructure.app/services/ChocolateyPackageService.cs b/src/chocolatey/infrastructure.app/services/ChocolateyPackageService.cs index d4197e6514..c5d392ba9a 100644 --- a/src/chocolatey/infrastructure.app/services/ChocolateyPackageService.cs +++ b/src/chocolatey/infrastructure.app/services/ChocolateyPackageService.cs @@ -141,7 +141,11 @@ public void push_run(ChocolateyConfiguration config) public void install_noop(ChocolateyConfiguration config) { - _nugetService.install_noop(config, (pkg) => _powershellService.install_noop(pkg)); + // each package can specify its own configuration values + foreach (var packageConfig in set_config_from_package_names_and_packages_config(config, new ConcurrentDictionary()).or_empty_list_if_null()) + { + _nugetService.install_noop(packageConfig, (pkg) => _powershellService.install_noop(pkg)); + } } public void handle_package_result(PackageResult packageResult, ChocolateyConfiguration config, CommandNameType commandName) @@ -211,10 +215,22 @@ public ConcurrentDictionary install_run(ChocolateyConfigu this.Log().Info(ChocolateyLoggers.Important, @"{0}".format_with(config.PackageNames)); this.Log().Info(@"By installing you accept licenses for the packages."); - var packageInstalls = _nugetService.install_run( - config, - (packageResult) => handle_package_result(packageResult, config, CommandNameType.install) - ); + + var packageInstalls = new ConcurrentDictionary(); + var originalConfig = config.deep_copy(); + + //each package can specify its own configuration values + foreach (var packageConfig in set_config_from_package_names_and_packages_config(config, packageInstalls).or_empty_list_if_null()) + { + var results = _nugetService.install_run( + config, + (packageResult) => handle_package_result(packageResult, packageConfig, CommandNameType.install) + ); + foreach (var result in results) + { + packageInstalls.GetOrAdd(result.Key, result.Value); + } + } var installFailures = packageInstalls.Count(p => !p.Value.Success); this.Log().Warn(() => @"{0}{1} installed {2}/{3} packages. {4} packages failed.{0}See the log for details.".format_with( @@ -241,6 +257,18 @@ public ConcurrentDictionary install_run(ChocolateyConfigu return packageInstalls; } + private IEnumerable set_config_from_package_names_and_packages_config(ChocolateyConfiguration config, ConcurrentDictionary packageInstalls) + { + // if there are any .config files, split those off of the config. Then return the config without those package names. + foreach (var packageConfigFile in config.PackageNames.Split(new[] {ApplicationParameters.PackageNamesSeparator}, StringSplitOptions.RemoveEmptyEntries).or_empty_list_if_null().Where(p => p.Contains(".config")).ToList()) + { + config.PackageNames = config.PackageNames.Replace(packageConfigFile, string.Empty); + + } + + yield return config; + } + public void upgrade_noop(ChocolateyConfiguration config) { _nugetService.upgrade_noop(config, (pkg) => _powershellService.install_noop(pkg)); @@ -307,7 +335,7 @@ public ConcurrentDictionary uninstall_run(ChocolateyConfi if (!config.SkipPackageInstallProvider) { - _powershellService.uninstall(config, packageResult); + _powershellService.uninstall(config, packageResult); } _autoUninstallerService.run(packageResult, config);