public LibraryDescription GetDescription(LibraryRange libraryRange, FrameworkName targetFramework) { if (libraryRange.IsGacOrFrameworkReference) { return(null); } var package = FindCandidate(libraryRange.Name, libraryRange.VersionRange); if (package != null) { LockFileFrameworkGroup group = null; IEnumerable <LibraryDependency> dependencies; bool resolved = true; if (package.LockFileLibrary != null) { // If we have a lock file, it MUST have an exact match for this target // framework group = package.LockFileLibrary.FrameworkGroups.FirstOrDefault(f => f.TargetFramework == targetFramework); if (group == null) { resolved = false; dependencies = Enumerable.Empty <LibraryDependency>(); } else { dependencies = GetDependencies(package, targetFramework, group); } } else { dependencies = GetDependencies(package, targetFramework, lockFileGroup: null); } return(new LibraryDescription { LibraryRange = libraryRange, Identity = new Library { Name = package.Id, Version = package.Version }, Type = "Package", Dependencies = dependencies, Resolved = resolved }); } return(null); }
public static LockFileLibrary CreateLockFileLibraryForProject( Runtime.Project project, IPackage package, SHA512 sha512, IEnumerable <FrameworkName> frameworks, IPackagePathResolver resolver, string correctedPackageName = null) { var lockFileLib = new LockFileLibrary(); // package.Id is read from nuspec and it might be in wrong casing. // correctedPackageName should be the package name used by dependency graph and // it has the correct casing that runtime needs during dependency resolution. lockFileLib.Name = correctedPackageName ?? package.Id; lockFileLib.Version = package.Version; using (var nupkgStream = package.GetStream()) { lockFileLib.Sha = Convert.ToBase64String(sha512.ComputeHash(nupkgStream)); } lockFileLib.Files = package.GetFiles().Select(p => p.Path).ToList(); foreach (var framework in frameworks) { var group = new LockFileFrameworkGroup(); group.TargetFramework = framework; IEnumerable <PackageDependencySet> dependencySet; if (VersionUtility.TryGetCompatibleItems(framework, package.DependencySets, out dependencySet)) { var set = dependencySet.FirstOrDefault()?.Dependencies?.ToList(); if (set != null) { group.Dependencies = set; } } // TODO: Remove this when we do #596 // ASP.NET Core isn't compatible with generic PCL profiles if (!string.Equals(framework.Identifier, VersionUtility.AspNetCoreFrameworkIdentifier, StringComparison.OrdinalIgnoreCase) && !string.Equals(framework.Identifier, VersionUtility.DnxCoreFrameworkIdentifier, StringComparison.OrdinalIgnoreCase)) { IEnumerable <FrameworkAssemblyReference> frameworkAssemblies; if (VersionUtility.TryGetCompatibleItems(framework, package.FrameworkAssemblies, out frameworkAssemblies)) { foreach (var assemblyReference in frameworkAssemblies) { if (!assemblyReference.SupportedFrameworks.Any() && !VersionUtility.IsDesktop(framework)) { // REVIEW: This isn't 100% correct since none *can* mean // any in theory, but in practice it means .NET full reference assembly // If there's no supported target frameworks and we're not targeting // the desktop framework then skip it. // To do this properly we'll need all reference assemblies supported // by each supported target framework which isn't always available. continue; } group.FrameworkAssemblies.Add(assemblyReference); } } } group.RuntimeAssemblies = GetPackageAssemblies(package, framework); string contractPath = Path.Combine("lib", "contract", package.Id + ".dll"); var hasContract = lockFileLib.Files.Any(path => path == contractPath); var hasLib = group.RuntimeAssemblies.Any(); if (hasContract && hasLib && !VersionUtility.IsDesktop(framework)) { group.CompileTimeAssemblies.Add(contractPath); } else if (hasLib) { group.CompileTimeAssemblies.AddRange(group.RuntimeAssemblies); } lockFileLib.FrameworkGroups.Add(group); } var installPath = resolver.GetInstallPath(package.Id, package.Version); foreach (var assembly in lockFileLib.FrameworkGroups.SelectMany(f => f.RuntimeAssemblies)) { var assemblyPath = Path.Combine(installPath, assembly); if (IsAssemblyServiceable(assemblyPath)) { lockFileLib.IsServiceable = true; break; } } return(lockFileLib); }
private IEnumerable <LibraryDependency> GetDependencies(PackageInfo packageInfo, FrameworkName targetFramework, LockFileFrameworkGroup lockFileGroup) { if (lockFileGroup != null) { foreach (var d in lockFileGroup.Dependencies) { yield return(new LibraryDependency { LibraryRange = new LibraryRange { Name = d.Id, VersionRange = d.VersionSpec == null ? null : new SemanticVersionRange(d.VersionSpec) } }); } foreach (var fa in lockFileGroup.FrameworkAssemblies) { yield return(new LibraryDependency { LibraryRange = new LibraryRange { Name = fa.AssemblyName, IsGacOrFrameworkReference = true } }); } yield break; } // If we weren't given a lockFileGroup, there isn't a lock file, so resolve the NuGet way. var package = packageInfo.Package; IEnumerable <PackageDependencySet> dependencySet; if (VersionUtility.TryGetCompatibleItems(targetFramework, package.DependencySets, out dependencySet)) { foreach (var set in dependencySet) { foreach (var d in set.Dependencies) { yield return(new LibraryDependency { LibraryRange = new LibraryRange { Name = d.Id, VersionRange = d.VersionSpec == null ? null : new SemanticVersionRange(d.VersionSpec) } }); } } } // TODO: Remove this when we do #596 // ASP.NET Core isn't compatible with generic PCL profiles if (string.Equals(targetFramework.Identifier, VersionUtility.AspNetCoreFrameworkIdentifier, StringComparison.OrdinalIgnoreCase) || string.Equals(targetFramework.Identifier, VersionUtility.DnxCoreFrameworkIdentifier, StringComparison.OrdinalIgnoreCase)) { yield break; } IEnumerable <FrameworkAssemblyReference> frameworkAssemblies; if (VersionUtility.TryGetCompatibleItems(targetFramework, package.FrameworkAssemblies, out frameworkAssemblies)) { foreach (var assemblyReference in frameworkAssemblies) { if (!assemblyReference.SupportedFrameworks.Any() && !VersionUtility.IsDesktop(targetFramework)) { // REVIEW: This isn't 100% correct since none *can* mean // any in theory, but in practice it means .NET full reference assembly // If there's no supported target frameworks and we're not targeting // the desktop framework then skip it. // To do this properly we'll need all reference assemblies supported // by each supported target framework which isn't always available. continue; } yield return(new LibraryDependency { LibraryRange = new LibraryRange { Name = assemblyReference.AssemblyName, IsGacOrFrameworkReference = true } }); } } }