Upgrade single project and nuget lookup fix
This commit is contained in:
@@ -1,3 +1,3 @@
|
|||||||
{
|
{
|
||||||
"printWidth": 100
|
"printWidth": 120
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ public partial class MainWindowViewModel : ViewModelBase
|
|||||||
|
|
||||||
[ObservableProperty]
|
[ObservableProperty]
|
||||||
private ObservableCollection<string> _parityResults = new() { };
|
private ObservableCollection<string> _parityResults = new() { };
|
||||||
|
|
||||||
[ObservableProperty]
|
[ObservableProperty]
|
||||||
private string _resultsLabel = "Ready";
|
private string _resultsLabel = "Ready";
|
||||||
|
|
||||||
@@ -35,10 +35,7 @@ public partial class MainWindowViewModel : ViewModelBase
|
|||||||
ResultsLabel = string.Empty;
|
ResultsLabel = string.Empty;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var results = SolutionProjectParity.CompareSolutionAndCSharpProjects(
|
var results = SolutionProjectParity.CompareSolutionAndCSharpProjects(SolutionFolderPath, SolutionFilePath);
|
||||||
SolutionFolderPath,
|
|
||||||
SolutionFilePath
|
|
||||||
);
|
|
||||||
foreach (var result in results)
|
foreach (var result in results)
|
||||||
ParityResults.Add(result);
|
ParityResults.Add(result);
|
||||||
ResultsLabel = $"{results.Count} Projects in folder missing from solution";
|
ResultsLabel = $"{results.Count} Projects in folder missing from solution";
|
||||||
@@ -62,9 +59,7 @@ public partial class MainWindowViewModel : ViewModelBase
|
|||||||
ErrorMessages?.Clear();
|
ErrorMessages?.Clear();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var csprojList = SolutionProjectParity.RetrieveAllCSharpProjectFullPathsFromFolder(
|
var csprojList = SolutionProjectParity.RetrieveAllCSharpProjectFullPathsFromFolder(SolutionFolderPath);
|
||||||
SolutionFolderPath
|
|
||||||
);
|
|
||||||
foreach (var csproj in csprojList)
|
foreach (var csproj in csprojList)
|
||||||
{
|
{
|
||||||
FormatCsproj.FormatCsprojFile(csproj);
|
FormatCsproj.FormatCsprojFile(csproj);
|
||||||
@@ -83,9 +78,7 @@ public partial class MainWindowViewModel : ViewModelBase
|
|||||||
ErrorMessages?.Clear();
|
ErrorMessages?.Clear();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var csprojList = SolutionProjectParity.RetrieveAllCSharpProjectFullPathsFromFolder(
|
var csprojList = SolutionProjectParity.RetrieveAllCSharpProjectFullPathsFromFolder(SolutionFolderPath);
|
||||||
SolutionFolderPath
|
|
||||||
);
|
|
||||||
foreach (var csproj in csprojList)
|
foreach (var csproj in csprojList)
|
||||||
{
|
{
|
||||||
FormatCsproj.FormatCsprojFile(csproj);
|
FormatCsproj.FormatCsprojFile(csproj);
|
||||||
@@ -97,7 +90,7 @@ public partial class MainWindowViewModel : ViewModelBase
|
|||||||
ParityResults?.Add(e.Message);
|
ParityResults?.Add(e.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[RelayCommand]
|
[RelayCommand]
|
||||||
private async Task CheckForMissingImplicitUsingsInSolutionFile(CancellationToken token)
|
private async Task CheckForMissingImplicitUsingsInSolutionFile(CancellationToken token)
|
||||||
{
|
{
|
||||||
@@ -116,7 +109,7 @@ public partial class MainWindowViewModel : ViewModelBase
|
|||||||
ParityResults?.Add(e.Message);
|
ParityResults?.Add(e.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[RelayCommand]
|
[RelayCommand]
|
||||||
private async Task CheckForMissingTreatWarningsAsErrorsInSolutionFile(CancellationToken token)
|
private async Task CheckForMissingTreatWarningsAsErrorsInSolutionFile(CancellationToken token)
|
||||||
{
|
{
|
||||||
@@ -135,7 +128,7 @@ public partial class MainWindowViewModel : ViewModelBase
|
|||||||
ParityResults?.Add(e.Message);
|
ParityResults?.Add(e.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[RelayCommand]
|
[RelayCommand]
|
||||||
private async Task DeleteBinAndObjFoldersInFolder(CancellationToken token)
|
private async Task DeleteBinAndObjFoldersInFolder(CancellationToken token)
|
||||||
{
|
{
|
||||||
@@ -153,7 +146,7 @@ public partial class MainWindowViewModel : ViewModelBase
|
|||||||
ParityResults?.Add(e.Message);
|
ParityResults?.Add(e.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[RelayCommand]
|
[RelayCommand]
|
||||||
private async Task UpdateAllProjectsToNet80(CancellationToken token)
|
private async Task UpdateAllProjectsToNet80(CancellationToken token)
|
||||||
{
|
{
|
||||||
@@ -172,6 +165,24 @@ public partial class MainWindowViewModel : ViewModelBase
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[RelayCommand]
|
||||||
|
private async Task UpdateProjectToNet80(CancellationToken token)
|
||||||
|
{
|
||||||
|
ErrorMessages?.Clear();
|
||||||
|
ParityResults.Clear();
|
||||||
|
ResultsLabel = string.Empty;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
await DotNetUpgrade.UpdateProjectAtPathToNet80(CsprojFilePath);
|
||||||
|
ResultsLabel = "Successfully updated project to .NET 8";
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
ResultsLabel = "Failed to update project to .NET 8";
|
||||||
|
ParityResults?.Add(e.Message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
[RelayCommand]
|
[RelayCommand]
|
||||||
private async Task LoadSolutionFile(CancellationToken token)
|
private async Task LoadSolutionFile(CancellationToken token)
|
||||||
{
|
{
|
||||||
@@ -264,7 +275,7 @@ public partial class MainWindowViewModel : ViewModelBase
|
|||||||
var json = JsonSerializer.Serialize(dto);
|
var json = JsonSerializer.Serialize(dto);
|
||||||
await File.WriteAllTextAsync("./localState.json", json);
|
await File.WriteAllTextAsync("./localState.json", json);
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task LoadSavedState()
|
private async Task LoadSavedState()
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
@@ -284,7 +295,7 @@ public partial class MainWindowViewModel : ViewModelBase
|
|||||||
// ignored
|
// ignored
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public MainWindowViewModel()
|
public MainWindowViewModel()
|
||||||
{
|
{
|
||||||
LoadSavedState().ConfigureAwait(false);
|
LoadSavedState().ConfigureAwait(false);
|
||||||
|
|||||||
@@ -107,6 +107,15 @@
|
|||||||
Update all projects in Solution to .NET 8.0
|
Update all projects in Solution to .NET 8.0
|
||||||
</TextBlock>
|
</TextBlock>
|
||||||
</Button>
|
</Button>
|
||||||
|
<Button Grid.Row="2" Grid.Column="2" MinHeight="100" Padding="10" Margin="5"
|
||||||
|
HorizontalAlignment="Stretch" VerticalAlignment="Stretch"
|
||||||
|
VerticalContentAlignment="Center" HorizontalContentAlignment="Center"
|
||||||
|
IsEnabled="{Binding SolutionFilePath, Mode=OneWay, Converter={x:Static StringConverters.IsNotNullOrEmpty}}"
|
||||||
|
Command="{Binding UpdateProjectToNet80Command}">
|
||||||
|
<TextBlock TextWrapping="Wrap">
|
||||||
|
Update C# Project to .NET 8.0
|
||||||
|
</TextBlock>
|
||||||
|
</Button>
|
||||||
</Grid>
|
</Grid>
|
||||||
<Label HorizontalAlignment="Center" Name="ResultsLabel" Content="{Binding ResultsLabel}"></Label>
|
<Label HorizontalAlignment="Center" Name="ResultsLabel" Content="{Binding ResultsLabel}"></Label>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
|
|||||||
@@ -11,30 +11,39 @@ public static class DotNetUpgrade
|
|||||||
public static async Task UpdateProjectsInSolutionToNet80(string solutionFilePath)
|
public static async Task UpdateProjectsInSolutionToNet80(string solutionFilePath)
|
||||||
{
|
{
|
||||||
var solutionFile = SolutionFile.Parse(solutionFilePath);
|
var solutionFile = SolutionFile.Parse(solutionFilePath);
|
||||||
var csprojList = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(
|
var csprojList = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(solutionFile);
|
||||||
solutionFile
|
|
||||||
);
|
|
||||||
await UpdateProjectsToNet80(csprojList);
|
await UpdateProjectsToNet80(csprojList);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static async Task UpdateProjectAtPathToNet80(string csprojFilePath)
|
||||||
|
{
|
||||||
|
var csproj = ProjectRootElement.Open(csprojFilePath);
|
||||||
|
await UpdateProjectToNet80(csproj!);
|
||||||
|
}
|
||||||
|
|
||||||
private static async Task UpdateProjectsToNet80(List<ProjectRootElement> projects)
|
private static async Task UpdateProjectsToNet80(List<ProjectRootElement> projects)
|
||||||
{
|
{
|
||||||
foreach (var project in projects)
|
foreach (var project in projects)
|
||||||
{
|
{
|
||||||
var targetFramework = project
|
await UpdateProjectToNet80(project);
|
||||||
.PropertyGroups
|
}
|
||||||
.SelectMany(x => x.Properties)
|
}
|
||||||
.FirstOrDefault(x => x.Name == "TargetFramework");
|
|
||||||
if (targetFramework?.Value is "net8.0" or "net7.0" or "net6.0" or "net5.0")
|
private static async Task UpdateProjectToNet80(ProjectRootElement project)
|
||||||
|
{
|
||||||
|
var targetFramework = project
|
||||||
|
.PropertyGroups
|
||||||
|
.SelectMany(x => x.Properties)
|
||||||
|
.FirstOrDefault(x => x.Name == "TargetFramework");
|
||||||
|
if (targetFramework?.Value is "net8.0" or "net7.0" or "net6.0" or "net5.0")
|
||||||
|
{
|
||||||
|
if (targetFramework.Value is not "net8.0")
|
||||||
{
|
{
|
||||||
if (targetFramework.Value is not "net8.0")
|
targetFramework.Value = "net8.0";
|
||||||
{
|
project.Save();
|
||||||
targetFramework.Value = "net8.0";
|
FormatCsproj.FormatCsprojFile(project.FullPath);
|
||||||
project.Save();
|
|
||||||
FormatCsproj.FormatCsprojFile(project.FullPath);
|
|
||||||
}
|
|
||||||
await UpdatePackagesToLatest(project);
|
|
||||||
}
|
}
|
||||||
|
await UpdatePackagesToLatest(project);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -47,10 +56,16 @@ public static class DotNetUpgrade
|
|||||||
project,
|
project,
|
||||||
new ProjectOptions() { LoadSettings = ProjectLoadSettings.IgnoreMissingImports }
|
new ProjectOptions() { LoadSettings = ProjectLoadSettings.IgnoreMissingImports }
|
||||||
);
|
);
|
||||||
var packages = evalProject.Items.Where(x =>
|
var packages = evalProject
|
||||||
x.ItemType == "PackageReference" && x.HasMetadata("Version") &&
|
.Items
|
||||||
x.EvaluatedInclude.StartsWith("Microsoft.")).ToList();
|
.Where(
|
||||||
|
x =>
|
||||||
|
x.ItemType == "PackageReference"
|
||||||
|
&& x.HasMetadata("Version")
|
||||||
|
&& x.EvaluatedInclude.StartsWith("Microsoft.")
|
||||||
|
)
|
||||||
|
.ToList();
|
||||||
|
|
||||||
var packageNameAndVersion = packages
|
var packageNameAndVersion = packages
|
||||||
.Select(
|
.Select(
|
||||||
x =>
|
x =>
|
||||||
@@ -68,8 +83,11 @@ public static class DotNetUpgrade
|
|||||||
var shouldSave = false;
|
var shouldSave = false;
|
||||||
foreach (var package in packageNameAndVersion)
|
foreach (var package in packageNameAndVersion)
|
||||||
{
|
{
|
||||||
var latestNugetVersion = await NugetLookup.FetchPackageMetadataAsync(package.Name);
|
var latestNugetVersion = await NugetLookup.FetchPackageMetadataAsync(
|
||||||
|
package.Name,
|
||||||
|
package.NugetVersion.IsPrerelease
|
||||||
|
);
|
||||||
|
|
||||||
if (latestNugetVersion > package.NugetVersion)
|
if (latestNugetVersion > package.NugetVersion)
|
||||||
{
|
{
|
||||||
shouldSave = true;
|
shouldSave = true;
|
||||||
@@ -83,6 +101,11 @@ public static class DotNetUpgrade
|
|||||||
FormatCsproj.FormatCsprojFile(project.FullPath);
|
FormatCsproj.FormatCsprojFile(project.FullPath);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
Console.WriteLine(e);
|
||||||
|
throw;
|
||||||
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
if (evalProject is not null)
|
if (evalProject is not null)
|
||||||
|
|||||||
@@ -7,20 +7,58 @@ namespace DotNetSolutionTools.Core.Infrastructure;
|
|||||||
|
|
||||||
public static class NugetLookup
|
public static class NugetLookup
|
||||||
{
|
{
|
||||||
public static async Task<NuGetVersion> FetchPackageMetadataAsync(string packageId)
|
public static async Task<NuGetVersion> FetchPackageMetadataAsync(string packageId, bool isCurrentlyPrerelease)
|
||||||
{
|
{
|
||||||
var cache = new SourceCacheContext();
|
var cache = new SourceCacheContext();
|
||||||
var repositories = Repository.Factory.GetCoreV3("https://api.nuget.org/v3/index.json");
|
var repositories = Repository.Factory.GetCoreV3("https://api.nuget.org/v3/index.json");
|
||||||
var logger = NullLogger.Instance;
|
var logger = NullLogger.Instance;
|
||||||
|
|
||||||
var resource = await repositories.GetResourceAsync<FindPackageByIdResource>();
|
var resource = await repositories.GetResourceAsync<FindPackageByIdResource>();
|
||||||
var versions = await resource.GetAllVersionsAsync(
|
var versions = await resource.GetAllVersionsAsync(packageId, cache, logger, CancellationToken.None);
|
||||||
packageId,
|
|
||||||
cache,
|
|
||||||
logger,
|
|
||||||
CancellationToken.None
|
|
||||||
);
|
|
||||||
|
|
||||||
return versions.Last(s => s.IsPrerelease == false);
|
var latestPrereleaseVersion = versions.LastOrDefault(s => s.IsPrerelease == true);
|
||||||
|
var latestStableVersion = versions.LastOrDefault(s => s.IsPrerelease == false);
|
||||||
|
|
||||||
|
if (latestStableVersion is null && latestPrereleaseVersion is null)
|
||||||
|
{
|
||||||
|
Throw(packageId);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (latestStableVersion is null)
|
||||||
|
{
|
||||||
|
if (isCurrentlyPrerelease && latestPrereleaseVersion is not null)
|
||||||
|
{
|
||||||
|
return latestPrereleaseVersion;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Throw(packageId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (latestPrereleaseVersion is null)
|
||||||
|
{
|
||||||
|
return latestStableVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (latestStableVersion > latestPrereleaseVersion)
|
||||||
|
{
|
||||||
|
return latestStableVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isCurrentlyPrerelease)
|
||||||
|
{
|
||||||
|
return latestPrereleaseVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
return latestStableVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Throw(string packageId)
|
||||||
|
{
|
||||||
|
throw new ArgumentNullException(
|
||||||
|
"latestVersion",
|
||||||
|
$"No latest stable or prerelease Nuget package version found for {packageId}"
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user