Skip to content

Commit

Permalink
Revert "Add option to enable floating versions in CPM (#5440)" (#5513)
Browse files Browse the repository at this point in the history
This reverts commit 8bc8c9a.
  • Loading branch information
jeffkl authored and Nigusu-Allehu committed Nov 21, 2023
1 parent c410c2c commit f68fcd0
Show file tree
Hide file tree
Showing 24 changed files with 75 additions and 543 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -459,7 +459,6 @@ private async Task<PackageSpec> GetPackageSpecAsync(ISettings settings)
MSBuildStringUtility.IsTrue(GetPropertySafe(_vsProjectAdapter.BuildProperties, ProjectBuildProperties.RestoreLockedMode))),
CentralPackageVersionsEnabled = isCpvmEnabled,
CentralPackageVersionOverrideDisabled = GetPropertySafe(_vsProjectAdapter.BuildProperties, ProjectBuildProperties.CentralPackageVersionOverrideEnabled).EqualsFalse(),
CentralPackageFloatingVersionsEnabled = MSBuildStringUtility.IsTrue(GetPropertySafe(_vsProjectAdapter.BuildProperties, ProjectBuildProperties.CentralPackageFloatingVersionsEnabled)),
CentralPackageTransitivePinningEnabled = MSBuildStringUtility.IsTrue(GetPropertySafe(_vsProjectAdapter.BuildProperties, ProjectBuildProperties.CentralPackageTransitivePinningEnabled)),
RestoreAuditProperties = auditProperties,
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -297,11 +297,6 @@ internal static bool IsCentralPackageVersionOverrideDisabled(IEnumerable tfms)
return GetSingleNonEvaluatedPropertyOrNull(tfms, ProjectBuildProperties.CentralPackageVersionOverrideEnabled, (value) => value.EqualsFalse());
}

internal static bool IsCentralPackageFloatingVersionsEnabled(IEnumerable tfms)
{
return GetSingleNonEvaluatedPropertyOrNull(tfms, ProjectBuildProperties.CentralPackageFloatingVersionsEnabled, MSBuildStringUtility.IsTrue);
}

internal static bool IsCentralPackageTransitivePinningEnabled(IEnumerable tfms)
{
return GetSingleNonEvaluatedPropertyOrNull(tfms, ProjectBuildProperties.CentralPackageTransitivePinningEnabled, MSBuildStringUtility.IsTrue);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -348,7 +348,6 @@ internal static PackageSpec ToPackageSpec(ProjectNames projectNames, IEnumerable
CacheFilePath = NoOpRestoreUtilities.GetProjectCacheFilePath(cacheRoot: outputPath),
RestoreLockProperties = VSNominationUtilities.GetRestoreLockProperties(TargetFrameworks),
CentralPackageVersionsEnabled = cpvmEnabled,
CentralPackageFloatingVersionsEnabled = VSNominationUtilities.IsCentralPackageFloatingVersionsEnabled(TargetFrameworks),
CentralPackageVersionOverrideDisabled = VSNominationUtilities.IsCentralPackageVersionOverrideDisabled(TargetFrameworks),
CentralPackageTransitivePinningEnabled = VSNominationUtilities.IsCentralPackageTransitivePinningEnabled(TargetFrameworks),
RestoreAuditProperties = VSNominationUtilities.GetRestoreAuditProperties(TargetFrameworks),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -808,7 +808,7 @@ private PackageSpec GetPackageSpec(IMSBuildProject project, IReadOnlyDictionary<

ProjectStyle? projectStyleOrNull = BuildTasksUtility.GetProjectRestoreStyleFromProjectProperty(project.GetProperty("RestoreProjectStyle"));

(bool isCentralPackageManagementEnabled, bool isCentralPackageVersionOverrideDisabled, bool isCentralPackageTransitivePinningEnabled, bool isCentralPackageFloatingVersionsEnabled) = MSBuildRestoreUtility.GetCentralPackageManagementSettings(project, projectStyleOrNull);
(bool isCentralPackageManagementEnabled, bool isCentralPackageVersionOverrideDisabled, bool isCentralPackageTransitivePinningEnabled) = GetCentralPackageManagementSettings(project, projectStyleOrNull);

RestoreAuditProperties auditProperties = MSBuildRestoreUtility.GetRestoreAuditProperties(project);

Expand Down Expand Up @@ -854,7 +854,6 @@ private PackageSpec GetPackageSpec(IMSBuildProject project, IReadOnlyDictionary<
SkipContentFileWrite = IsLegacyProject(project),
ValidateRuntimeAssets = project.IsPropertyTrue("ValidateRuntimeIdentifierCompatibility"),
CentralPackageVersionsEnabled = isCentralPackageManagementEnabled && projectStyle == ProjectStyle.PackageReference,
CentralPackageFloatingVersionsEnabled = isCentralPackageFloatingVersionsEnabled,
CentralPackageVersionOverrideDisabled = isCentralPackageVersionOverrideDisabled,
CentralPackageTransitivePinningEnabled = isCentralPackageTransitivePinningEnabled,
RestoreAuditProperties = auditProperties
Expand Down Expand Up @@ -1026,6 +1025,22 @@ private ICollection<ProjectWithInnerNodes> LoadProjects(IEnumerable<ProjectGraph
}
}

/// <summary>
/// Determines the current settings for central package management for the specified project.
/// </summary>
/// <param name="project">The <see cref="IMSBuildProject" /> to get the central package management settings for.</param>
/// <param name="projectStyle">The <see cref="ProjectStyle?" /> of the specified project. Specify <see langword="null" /> when the project does not define a restore style.</param>
/// <returns>A <see cref="Tuple{T1, T2}" /> containing values indicating whether or not central package management is enabled and if the ability to override a package version is disabled.</returns>
internal static (bool IsEnabled, bool IsVersionOverrideDisabled, bool IsCentralPackageTransitivePinningEnabled) GetCentralPackageManagementSettings(IMSBuildProject project, ProjectStyle? projectStyle)
{
if (!projectStyle.HasValue || (projectStyle.Value == ProjectStyle.PackageReference))
{
return (project.IsPropertyTrue("_CentralPackageVersionsEnabled"), project.IsPropertyFalse("CentralPackageVersionOverrideEnabled"), project.IsPropertyTrue("CentralPackageTransitivePinningEnabled"));
}

return (false, false, false);
}

/// <summary>
/// Returns the list of distinct items with the <paramref name="itemName"/> name.
/// Two items are equal if they have the same <see cref="IMSBuildItem.Identity"/>.
Expand Down
1 change: 0 additions & 1 deletion src/NuGet.Core/NuGet.Build.Tasks/NuGet.targets
Original file line number Diff line number Diff line change
Expand Up @@ -862,7 +862,6 @@ Copyright (c) .NET Foundation. All rights reserved.
<NuGetLockFilePath>$(NuGetLockFilePath)</NuGetLockFilePath>
<RestoreLockedMode>$(RestoreLockedMode)</RestoreLockedMode>
<_CentralPackageVersionsEnabled>$(_CentralPackageVersionsEnabled)</_CentralPackageVersionsEnabled>
<CentralPackageFloatingVersionsEnabled>$(CentralPackageFloatingVersionsEnabled)</CentralPackageFloatingVersionsEnabled>
<CentralPackageVersionOverrideEnabled>$(CentralPackageVersionOverrideEnabled)</CentralPackageVersionOverrideEnabled>
<CentralPackageTransitivePinningEnabled>$(CentralPackageTransitivePinningEnabled)</CentralPackageTransitivePinningEnabled>
<NuGetAudit>$(NuGetAudit)</NuGetAudit>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -164,15 +164,11 @@ public bool AreCentralVersionRequirementsSatisfied(PackageReferenceArgs packageR
packageReferenceArgs.Logger.LogError(string.Format(CultureInfo.CurrentCulture, Strings.Error_CentralPackageVersions_MissingPackageVersion, string.Join(";", packageReferencedDependenciesWithoutCentralVersionDefined.Select(d => d.Name))));
return false;
}

if (!packageSpec.RestoreMetadata.CentralPackageFloatingVersionsEnabled)
var floatingVersionDependencies = packageSpec.TargetFrameworks.SelectMany(tfm => tfm.CentralPackageVersions.Values).Where(cpv => cpv.VersionRange.IsFloating);
if (floatingVersionDependencies.Any())
{
var floatingVersionDependencies = packageSpec.TargetFrameworks.SelectMany(tfm => tfm.CentralPackageVersions.Values).Where(cpv => cpv.VersionRange.IsFloating);
if (floatingVersionDependencies.Any())
{
packageReferenceArgs.Logger.LogError(string.Format(CultureInfo.CurrentCulture, Strings.Error_CentralPackageVersions_FloatingVersionsAreNotAllowed));
return false;
}
packageReferenceArgs.Logger.LogError(string.Format(CultureInfo.CurrentCulture, Strings.Error_CentralPackageVersions_FloatingVersionsAreNotAllowed));
return false;
}

// PackageVersion should not be defined outside the project file.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,2 +1 @@
#nullable enable
~static NuGet.Commands.MSBuildRestoreUtility.GetCentralPackageManagementSettings(NuGet.Commands.IMSBuildItem projectSpecItem, NuGet.ProjectModel.ProjectStyle? projectStyle) -> (bool IsEnabled, bool IsVersionOverrideDisabled, bool IsCentralPackageTransitivePinningEnabled, bool isCentralPackageFloatingVersionsEnabled)
Original file line number Diff line number Diff line change
@@ -1,2 +1 @@
#nullable enable
~static NuGet.Commands.MSBuildRestoreUtility.GetCentralPackageManagementSettings(NuGet.Commands.IMSBuildItem projectSpecItem, NuGet.ProjectModel.ProjectStyle? projectStyle) -> (bool IsEnabled, bool IsVersionOverrideDisabled, bool IsCentralPackageTransitivePinningEnabled, bool isCentralPackageFloatingVersionsEnabled)
Original file line number Diff line number Diff line change
@@ -1,2 +1 @@
#nullable enable
~static NuGet.Commands.MSBuildRestoreUtility.GetCentralPackageManagementSettings(NuGet.Commands.IMSBuildItem projectSpecItem, NuGet.ProjectModel.ProjectStyle? projectStyle) -> (bool IsEnabled, bool IsVersionOverrideDisabled, bool IsCentralPackageTransitivePinningEnabled, bool isCentralPackageFloatingVersionsEnabled)
13 changes: 4 additions & 9 deletions src/NuGet.Core/NuGet.Commands/RestoreCommand/RestoreCommand.cs
Original file line number Diff line number Diff line change
Expand Up @@ -598,17 +598,12 @@ private async Task<bool> AreCentralVersionRequirementsSatisfiedAsync(RestoreRequ
await _logger.LogAsync(RestoreLogMessage.CreateError(NuGetLogCode.NU1010, string.Format(CultureInfo.CurrentCulture, Strings.Error_CentralPackageVersions_MissingPackageVersion, string.Join(";", packageReferencedDependenciesWithoutCentralVersionDefined.Select(d => d.Name)))));
return false;
}

if (!restoreRequest.Project.RestoreMetadata.CentralPackageFloatingVersionsEnabled)
var floatingVersionDependencies = _request.Project.TargetFrameworks.SelectMany(tfm => tfm.CentralPackageVersions.Values).Where(cpv => cpv.VersionRange.IsFloating);
if (floatingVersionDependencies.Any())
{
var floatingVersionDependencies = _request.Project.TargetFrameworks.SelectMany(tfm => tfm.CentralPackageVersions.Values).Where(cpv => cpv.VersionRange.IsFloating);
if (floatingVersionDependencies.Any())
{
await _logger.LogAsync(RestoreLogMessage.CreateError(NuGetLogCode.NU1011, Strings.Error_CentralPackageVersions_FloatingVersionsAreNotAllowed));
return false;
}
await _logger.LogAsync(RestoreLogMessage.CreateError(NuGetLogCode.NU1011, Strings.Error_CentralPackageVersions_FloatingVersionsAreNotAllowed));
return false;
}

return true;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -161,7 +161,7 @@ public static PackageSpec GetPackageSpec(IEnumerable<IMSBuildItem> items)
{
ProjectStyle restoreType = GetProjectStyle(specItem);

(bool isCentralPackageManagementEnabled, bool isCentralPackageVersionOverrideDisabled, bool isCentralPackageTransitivePinningEnabled, bool isCentralPackageFloatingVersionsEnabled) = GetCentralPackageManagementSettings(specItem, restoreType);
(bool isCentralPackageManagementEnabled, bool isCentralPackageVersionOverrideDisabled, bool isCentralPackageTransitivePinningEnabled) = GetCentralPackageManagementSettings(specItem, restoreType);

// Get base spec
if (restoreType == ProjectStyle.ProjectJson)
Expand Down Expand Up @@ -296,7 +296,6 @@ public static PackageSpec GetPackageSpec(IEnumerable<IMSBuildItem> items)

result.RestoreMetadata.CentralPackageVersionsEnabled = isCentralPackageManagementEnabled;
result.RestoreMetadata.CentralPackageVersionOverrideDisabled = isCentralPackageVersionOverrideDisabled;
result.RestoreMetadata.CentralPackageFloatingVersionsEnabled = isCentralPackageFloatingVersionsEnabled;
result.RestoreMetadata.CentralPackageTransitivePinningEnabled = isCentralPackageTransitivePinningEnabled;
}

Expand Down Expand Up @@ -958,7 +957,7 @@ private static string FixSourcePath(string s, string prefixWithoutSlashes, strin
return s;
}

internal static bool IsPropertyFalse(IMSBuildItem item, string propertyName, bool defaultValue = false)
private static bool IsPropertyFalse(IMSBuildItem item, string propertyName, bool defaultValue = false)
{
string value = item.GetProperty(propertyName);

Expand All @@ -970,7 +969,7 @@ internal static bool IsPropertyFalse(IMSBuildItem item, string propertyName, boo
return string.Equals(value, bool.FalseString, StringComparison.OrdinalIgnoreCase);
}

internal static bool IsPropertyTrue(IMSBuildItem item, string propertyName, bool defaultValue = false)
private static bool IsPropertyTrue(IMSBuildItem item, string propertyName, bool defaultValue = false)
{
string value = item.GetProperty(propertyName);

Expand Down Expand Up @@ -1056,23 +1055,11 @@ private static ProjectStyle GetProjectStyle(IMSBuildItem projectSpecItem)
return restoreType;
}

/// <summary>
/// Determines the current settings for central package management for the specified project.
/// </summary>
/// <param name="projectSpecItem">The <see cref="IMSBuildItem" /> to get the central package management settings from.</param>
/// <param name="projectStyle">The <see cref="ProjectStyle?" /> of the specified project. Specify <see langword="null" /> when the project does not define a restore style.</param>
/// <returns>A <see cref="Tuple{T1, T2, T3, T4}" /> containing values indicating whether or not central package management is enabled, if the ability to override a package version
public static (bool IsEnabled, bool IsVersionOverrideDisabled, bool IsCentralPackageTransitivePinningEnabled, bool isCentralPackageFloatingVersionsEnabled) GetCentralPackageManagementSettings(IMSBuildItem projectSpecItem, ProjectStyle? projectStyle)
internal static (bool IsEnabled, bool IsVersionOverrideDisabled, bool IsCentralPackageTransitivePinningEnabled) GetCentralPackageManagementSettings(IMSBuildItem projectSpecItem, ProjectStyle projectStyle)
{
if (!projectStyle.HasValue || (projectStyle.Value == ProjectStyle.PackageReference))
{
return (IsPropertyTrue(projectSpecItem, "_CentralPackageVersionsEnabled") && projectStyle == ProjectStyle.PackageReference,
return (IsPropertyTrue(projectSpecItem, "_CentralPackageVersionsEnabled") && projectStyle == ProjectStyle.PackageReference,
IsPropertyFalse(projectSpecItem, "CentralPackageVersionOverrideEnabled"),
IsPropertyTrue(projectSpecItem, "CentralPackageTransitivePinningEnabled"),
IsPropertyTrue(projectSpecItem, "CentralPackageFloatingVersionsEnabled"));
}

return (false, false, false, false);
IsPropertyTrue(projectSpecItem, "CentralPackageTransitivePinningEnabled"));
}

private static void AddCentralPackageVersions(PackageSpec spec, IEnumerable<IMSBuildItem> items)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,5 @@ public static class ProjectBuildProperties
public const string NuGetAudit = nameof(NuGetAudit);
public const string NuGetAuditLevel = nameof(NuGetAuditLevel);
public const string NuGetAuditMode = nameof(NuGetAuditMode);
public const string CentralPackageFloatingVersionsEnabled = nameof(CentralPackageFloatingVersionsEnabled);
}
}
Original file line number Diff line number Diff line change
@@ -1,2 +1 @@
#nullable enable
~const NuGet.ProjectManagement.ProjectBuildProperties.CentralPackageFloatingVersionsEnabled = "CentralPackageFloatingVersionsEnabled" -> string
6 changes: 0 additions & 6 deletions src/NuGet.Core/NuGet.ProjectModel/JsonPackageSpecReader.cs
Original file line number Diff line number Diff line change
Expand Up @@ -902,7 +902,6 @@ private static void ReadMappings(JsonTextReader jsonReader, string mappingKey, I
private static void ReadMSBuildMetadata(JsonTextReader jsonReader, PackageSpec packageSpec)
{
var centralPackageVersionsManagementEnabled = false;
var centralPackageFloatingVersionsEnabled = false;
var centralPackageVersionOverrideDisabled = false;
var CentralPackageTransitivePinningEnabled = false;
List<string> configFilePaths = null;
Expand Down Expand Up @@ -936,10 +935,6 @@ private static void ReadMSBuildMetadata(JsonTextReader jsonReader, PackageSpec p
centralPackageVersionsManagementEnabled = ReadNextTokenAsBoolOrFalse(jsonReader, packageSpec.FilePath);
break;

case "centralPackageFloatingVersionsEnabled":
centralPackageFloatingVersionsEnabled = ReadNextTokenAsBoolOrFalse(jsonReader, packageSpec.FilePath);
break;

case "centralPackageVersionOverrideDisabled":
centralPackageVersionOverrideDisabled = ReadNextTokenAsBoolOrFalse(jsonReader, packageSpec.FilePath);
break;
Expand Down Expand Up @@ -1136,7 +1131,6 @@ private static void ReadMSBuildMetadata(JsonTextReader jsonReader, PackageSpec p
}

msbuildMetadata.CentralPackageVersionsEnabled = centralPackageVersionsManagementEnabled;
msbuildMetadata.CentralPackageFloatingVersionsEnabled = centralPackageFloatingVersionsEnabled;
msbuildMetadata.CentralPackageVersionOverrideDisabled = centralPackageVersionOverrideDisabled;
msbuildMetadata.CentralPackageTransitivePinningEnabled = CentralPackageTransitivePinningEnabled;
msbuildMetadata.RestoreAuditProperties = auditProperties;
Expand Down
1 change: 0 additions & 1 deletion src/NuGet.Core/NuGet.ProjectModel/PackageSpecWriter.cs
Original file line number Diff line number Diff line change
Expand Up @@ -176,7 +176,6 @@ private static void WriteMetadataBooleans(IObjectWriter writer, ProjectRestoreMe
SetValueIfTrue(writer, "validateRuntimeAssets", msbuildMetadata.ValidateRuntimeAssets);
SetValueIfTrue(writer, "skipContentFileWrite", msbuildMetadata.SkipContentFileWrite);
SetValueIfTrue(writer, "centralPackageVersionsManagementEnabled", msbuildMetadata.CentralPackageVersionsEnabled);
SetValueIfTrue(writer, "centralPackageFloatingVersionsEnabled", msbuildMetadata.CentralPackageFloatingVersionsEnabled);
SetValueIfTrue(writer, "centralPackageVersionOverrideDisabled", msbuildMetadata.CentralPackageVersionOverrideDisabled);
SetValueIfTrue(writer, "CentralPackageTransitivePinningEnabled", msbuildMetadata.CentralPackageTransitivePinningEnabled);
}
Expand Down
Loading

0 comments on commit f68fcd0

Please sign in to comment.