Beispiel #1
0
        public void Restore(string configPath)
        {
            _consoleWriter.Write("Restoring packages from {0}", configPath);

            var config = _jsonLoader.Load(configPath);

            var packages = (JArray)config["packages"];

            var packagesPath = Path.Combine(Path.GetDirectoryName(configPath), _settings.PackagesFolder);

            foreach (var packageLocator in packages.OfType <JObject>())
            {
                var packageDetails = packageLocator.ToString(Newtonsoft.Json.Formatting.None);

                try
                {
                    var provider = _providerMatcher.Match(packageLocator);

                    if (provider != null)
                    {
                        _consoleWriter.Write("Pulling package identified by {0}", packageDetails);
                        provider.Pull(packageLocator, packagesPath);
                    }
                    else
                    {
                        _consoleWriter.Write("Package locator does not match any provider: {0}", packageDetails);
                    }
                }
                catch (AmbiguousPackageLocatorException)
                {
                    _consoleWriter.Write("Package locator matches multiple providers: {0}", packageDetails);
                }
            }
        }