mirror of
				https://github.com/Tyrrrz/CliFx.git
				synced 2025-10-25 15:19:17 +00:00 
			
		
		
		
	Compare commits
	
		
			17 Commits
		
	
	
		
			357426c536
			...
			aot
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | ca8368e1d9 | ||
|  | d4b6a2b7a9 | ||
|  | 63f57025e8 | ||
|  | 25083eff44 | ||
|  | 7f2c00fe3a | ||
|  | 7638b997ff | ||
|  | d80d012938 | ||
|  | 2a02d39dba | ||
|  | c40b4f3501 | ||
|  | 3fb2a2319b | ||
|  | 1a5a0374c7 | ||
|  | 432c8a66af | ||
|  | 078ddeaf07 | ||
|  | 0fa2ebc636 | ||
|  | c79a8c6502 | ||
|  | cfbd8f9e76 | ||
|  | e329f0fc78 | 
| @@ -1,4 +1,4 @@ | ||||
| <Project Sdk="Microsoft.NET.Sdk"> | ||||
| <Project Sdk="Microsoft.NET.Sdk"> | ||||
|  | ||||
|   <PropertyGroup> | ||||
|     <OutputType>Exe</OutputType> | ||||
| @@ -7,14 +7,14 @@ | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|     <PackageReference Include="BenchmarkDotNet" Version="0.14.0" /> | ||||
|     <PackageReference Include="BenchmarkDotNet" Version="0.15.2" /> | ||||
|     <PackageReference Include="clipr" Version="1.6.1" /> | ||||
|     <PackageReference Include="Cocona" Version="2.2.0" /> | ||||
|     <PackageReference Include="CommandLineParser" Version="2.9.1" /> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="0.29.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="1.1.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="McMaster.Extensions.CommandLineUtils" Version="4.1.1" /> | ||||
|     <PackageReference Include="PowerArgs" Version="4.0.3" /> | ||||
|     <PackageReference Include="System.CommandLine" Version="2.0.0-beta4.22272.1" /> | ||||
|     <PackageReference Include="System.CommandLine" Version="2.0.0-beta6.25358.103" /> | ||||
|   </ItemGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| <Project Sdk="Microsoft.NET.Sdk"> | ||||
| <Project Sdk="Microsoft.NET.Sdk"> | ||||
|  | ||||
|   <PropertyGroup> | ||||
|     <OutputType>Exe</OutputType> | ||||
| @@ -8,8 +8,8 @@ | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="0.29.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="8.0.1" /> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="1.1.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="9.0.9" /> | ||||
|   </ItemGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|   | ||||
| @@ -1,5 +1,4 @@ | ||||
| <Project Sdk="Microsoft.NET.Sdk"> | ||||
|  | ||||
|   <PropertyGroup> | ||||
|     <TargetFramework>netstandard2.0</TargetFramework> | ||||
|     <CopyLocalLockFileAssemblies>true</CopyLocalLockFileAssemblies> | ||||
| @@ -7,7 +6,6 @@ | ||||
|     <EnforceExtendedAnalyzerRules>true</EnforceExtendedAnalyzerRules> | ||||
|     <NoWarn>$(NoWarn);RS1035</NoWarn> | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <PropertyGroup> | ||||
|     <!-- | ||||
|       Because this project only has a single target framework, the condition in | ||||
| @@ -15,13 +13,15 @@ | ||||
|     --> | ||||
|     <Nullable>annotations</Nullable> | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="0.28.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="1.1.2" PrivateAssets="all" /> | ||||
|     <!-- Make sure to target the lowest possible version of the compiler for wider support --> | ||||
|     <PackageReference Include="Microsoft.CodeAnalysis" Version="4.11.0" PrivateAssets="all" /> | ||||
|     <PackageReference Include="Microsoft.CodeAnalysis.CSharp" Version="4.11.0" PrivateAssets="all" /> | ||||
|     <PackageReference Include="PolyShim" Version="1.12.0" PrivateAssets="all" /> | ||||
|     <PackageReference | ||||
|       Include="Microsoft.CodeAnalysis.CSharp" | ||||
|       Version="4.11.0" | ||||
|       PrivateAssets="all" | ||||
|     /> | ||||
|     <PackageReference Include="PolyShim" Version="1.15.0" PrivateAssets="all" /> | ||||
|   </ItemGroup> | ||||
|  | ||||
| </Project> | ||||
| </Project> | ||||
|   | ||||
| @@ -41,10 +41,9 @@ internal partial class CommandSymbol( | ||||
|     private string GenerateSchemaInitializationCode(CommandInputSymbol input) => | ||||
|         input switch | ||||
|         { | ||||
|             CommandParameterSymbol parameter | ||||
|                 => | ||||
|                 // lang=csharp | ||||
|                 $$""" | ||||
|             CommandParameterSymbol parameter => | ||||
|             // lang=csharp | ||||
|             $$""" | ||||
|                     new CliFx.Schema.CommandParameterSchema<{{Type.FullyQualifiedName}}, {{parameter | ||||
|                         .Property | ||||
|                         .Type | ||||
| @@ -59,10 +58,9 @@ internal partial class CommandSymbol( | ||||
|                         // TODO | ||||
|                     ); | ||||
|                     """, | ||||
|             CommandOptionSymbol option | ||||
|                 => | ||||
|                 // lang=csharp | ||||
|                 $$""" | ||||
|             CommandOptionSymbol option => | ||||
|             // lang=csharp | ||||
|             $$""" | ||||
|                     new CliFx.Schema.CommandOptionSchema<{{Type.FullyQualifiedName}}, {{option | ||||
|                         .Property | ||||
|                         .Type | ||||
| @@ -78,7 +76,7 @@ internal partial class CommandSymbol( | ||||
|                         // TODO | ||||
|                     ); | ||||
|                     """, | ||||
|             _ => throw new ArgumentOutOfRangeException(nameof(input), input, null) | ||||
|             _ => throw new ArgumentOutOfRangeException(nameof(input), input, null), | ||||
|         }; | ||||
|  | ||||
|     public string GenerateSchemaInitializationCode() => | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="0.29.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="1.1.2" PrivateAssets="all" /> | ||||
|   </ItemGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| <Project Sdk="Microsoft.NET.Sdk"> | ||||
| <Project Sdk="Microsoft.NET.Sdk"> | ||||
|  | ||||
|   <PropertyGroup> | ||||
|     <TargetFramework>net9.0</TargetFramework> | ||||
| @@ -9,18 +9,18 @@ | ||||
|   </ItemGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|     <PackageReference Include="Basic.Reference.Assemblies.Net80" Version="1.7.9" /> | ||||
|     <PackageReference Include="CliWrap" Version="3.6.7" /> | ||||
|     <PackageReference Include="coverlet.collector" Version="6.0.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="0.29.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="FluentAssertions" Version="6.12.1" /> | ||||
|     <PackageReference Include="Basic.Reference.Assemblies.Net80" Version="1.8.3" /> | ||||
|     <PackageReference Include="CliWrap" Version="3.9.0" /> | ||||
|     <PackageReference Include="coverlet.collector" Version="6.0.4" PrivateAssets="all" /> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="1.1.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="FluentAssertions" Version="8.6.0" /> | ||||
|     <PackageReference Include="GitHubActionsTestLogger" Version="2.4.1" PrivateAssets="all" /> | ||||
|     <PackageReference Include="Microsoft.CodeAnalysis.CSharp" Version="4.11.0" /> | ||||
|     <PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="8.0.1" /> | ||||
|     <PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.11.1" /> | ||||
|     <PackageReference Include="PolyShim" Version="1.14.0" PrivateAssets="all" /> | ||||
|     <PackageReference Include="xunit" Version="2.9.2" /> | ||||
|     <PackageReference Include="xunit.runner.visualstudio" Version="2.8.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="Microsoft.CodeAnalysis.CSharp" Version="4.14.0" /> | ||||
|     <PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="9.0.9" /> | ||||
|     <PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.14.1" /> | ||||
|     <PackageReference Include="PolyShim" Version="1.15.0" PrivateAssets="all" /> | ||||
|     <PackageReference Include="xunit" Version="2.9.3" /> | ||||
|     <PackageReference Include="xunit.runner.visualstudio" Version="3.1.4" PrivateAssets="all" /> | ||||
|   </ItemGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|   | ||||
| @@ -33,7 +33,7 @@ public class HelpTextSpecs(ITestOutputHelper testOutput) : SpecsBase(testOutput) | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_can_request_the_help_text_by_running_the_application_with_the_help_option() | ||||
|     public async Task I_can_request_the_help_text_by_running_the_application_with_the_implicit_help_option() | ||||
|     { | ||||
|         // Arrange | ||||
|         var commandType = DynamicCommandBuilder.Compile( | ||||
| @@ -64,7 +64,7 @@ public class HelpTextSpecs(ITestOutputHelper testOutput) : SpecsBase(testOutput) | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_can_request_the_help_text_by_running_the_application_with_the_help_option_even_if_the_default_command_is_not_defined() | ||||
|     public async Task I_can_request_the_help_text_by_running_the_application_with_the_implicit_help_option_even_if_the_default_command_is_not_defined() | ||||
|     { | ||||
|         // Arrange | ||||
|         var commandTypes = DynamicCommandBuilder.CompileMany( | ||||
| @@ -101,7 +101,7 @@ public class HelpTextSpecs(ITestOutputHelper testOutput) : SpecsBase(testOutput) | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_can_request_the_help_text_for_a_specific_command_by_running_the_application_and_specifying_its_name_with_the_help_option() | ||||
|     public async Task I_can_request_the_help_text_for_a_specific_command_by_running_the_application_and_specifying_its_name_with_the_implicit_help_option() | ||||
|     { | ||||
|         // Arrange | ||||
|         var commandTypes = DynamicCommandBuilder.CompileMany( | ||||
| @@ -146,7 +146,7 @@ public class HelpTextSpecs(ITestOutputHelper testOutput) : SpecsBase(testOutput) | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_can_request_the_help_text_for_a_specific_nested_command_by_running_the_application_and_specifying_its_name_with_the_help_option() | ||||
|     public async Task I_can_request_the_help_text_for_a_specific_nested_command_by_running_the_application_and_specifying_its_name_with_the_implicit_help_option() | ||||
|     { | ||||
|         // Arrange | ||||
|         var commandTypes = DynamicCommandBuilder.CompileMany( | ||||
| @@ -475,7 +475,7 @@ public class HelpTextSpecs(ITestOutputHelper testOutput) : SpecsBase(testOutput) | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_can_request_the_help_text_to_see_the_help_and_version_options() | ||||
|     public async Task I_can_request_the_help_text_to_see_the_help_and_implicit_version_options() | ||||
|     { | ||||
|         // Arrange | ||||
|         var commandType = DynamicCommandBuilder.Compile( | ||||
| @@ -514,7 +514,7 @@ public class HelpTextSpecs(ITestOutputHelper testOutput) : SpecsBase(testOutput) | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_can_request_the_help_text_on_a_named_command_to_see_the_help_option() | ||||
|     public async Task I_can_request_the_help_text_on_a_named_command_to_see_the_implicit_help_option() | ||||
|     { | ||||
|         // Arrange | ||||
|         var commandType = DynamicCommandBuilder.Compile( | ||||
| @@ -973,7 +973,7 @@ public class HelpTextSpecs(ITestOutputHelper testOutput) : SpecsBase(testOutput) | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_can_request_the_version_text_by_running_the_application_with_the_version_option() | ||||
|     public async Task I_can_request_the_version_text_by_running_the_application_with_the_implicit_version_option() | ||||
|     { | ||||
|         // Arrange | ||||
|         var application = new CliApplicationBuilder() | ||||
| @@ -991,4 +991,72 @@ public class HelpTextSpecs(ITestOutputHelper testOutput) : SpecsBase(testOutput) | ||||
|         var stdOut = FakeConsole.ReadOutputString(); | ||||
|         stdOut.Trim().Should().Be("v6.9"); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_cannot_request_the_help_text_by_running_the_application_with_the_implicit_help_option_if_there_is_an_option_with_the_same_identifier() | ||||
|     { | ||||
|         // Arrange | ||||
|         var commandType = DynamicCommandBuilder.Compile( | ||||
|             // lang=csharp | ||||
|             """ | ||||
|             [Command] | ||||
|             public class DefaultCommand : ICommand | ||||
|             { | ||||
|                 [CommandOption("help", 'h')] | ||||
|                 public string? Foo { get; init; } | ||||
|  | ||||
|                 public ValueTask ExecuteAsync(IConsole console) => default; | ||||
|             } | ||||
|             """ | ||||
|         ); | ||||
|  | ||||
|         var application = new CliApplicationBuilder() | ||||
|             .AddCommand(commandType) | ||||
|             .UseConsole(FakeConsole) | ||||
|             .SetDescription("This will be in help text") | ||||
|             .Build(); | ||||
|  | ||||
|         // Act | ||||
|         var exitCode = await application.RunAsync(["--help"], new Dictionary<string, string>()); | ||||
|  | ||||
|         // Assert | ||||
|         exitCode.Should().Be(0); | ||||
|  | ||||
|         var stdOut = FakeConsole.ReadOutputString(); | ||||
|         stdOut.Should().NotContain("This will be in help text"); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_cannot_request_the_version_text_by_running_the_application_with_the_implicit_version_option_if_there_is_an_option_with_the_same_identifier() | ||||
|     { | ||||
|         // Arrange | ||||
|         var commandType = DynamicCommandBuilder.Compile( | ||||
|             // lang=csharp | ||||
|             """ | ||||
|             [Command] | ||||
|             public class DefaultCommand : ICommand | ||||
|             { | ||||
|                 [CommandOption("version")] | ||||
|                 public string? Foo { get; init; } | ||||
|  | ||||
|                 public ValueTask ExecuteAsync(IConsole console) => default; | ||||
|             } | ||||
|             """ | ||||
|         ); | ||||
|  | ||||
|         var application = new CliApplicationBuilder() | ||||
|             .AddCommand(commandType) | ||||
|             .SetVersion("v6.9") | ||||
|             .UseConsole(FakeConsole) | ||||
|             .Build(); | ||||
|  | ||||
|         // Act | ||||
|         var exitCode = await application.RunAsync(["--version"], new Dictionary<string, string>()); | ||||
|  | ||||
|         // Assert | ||||
|         exitCode.Should().Be(0); | ||||
|  | ||||
|         var stdOut = FakeConsole.ReadOutputString(); | ||||
|         stdOut.Trim().Should().NotBe("v6.9"); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -586,6 +586,86 @@ public class OptionBindingSpecs(ITestOutputHelper testOutput) : SpecsBase(testOu | ||||
|         stdOut.Trim().Should().Be("-13"); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_can_bind_an_option_to_a_property_with_the_same_identifier_as_the_implicit_help_option_and_get_the_correct_value() | ||||
|     { | ||||
|         // Arrange | ||||
|         var commandType = DynamicCommandBuilder.Compile( | ||||
|             // lang=csharp | ||||
|             """ | ||||
|             [Command] | ||||
|             public class Command : ICommand | ||||
|             { | ||||
|                 [CommandOption("help", 'h')] | ||||
|                 public string? Foo { get; init; } | ||||
|  | ||||
|                 public ValueTask ExecuteAsync(IConsole console) | ||||
|                 { | ||||
|                     console.WriteLine(Foo); | ||||
|                     return default; | ||||
|                 } | ||||
|             } | ||||
|             """ | ||||
|         ); | ||||
|  | ||||
|         var application = new CliApplicationBuilder() | ||||
|             .AddCommand(commandType) | ||||
|             .UseConsole(FakeConsole) | ||||
|             .Build(); | ||||
|  | ||||
|         // Act | ||||
|         var exitCode = await application.RunAsync( | ||||
|             ["--help", "me"], | ||||
|             new Dictionary<string, string>() | ||||
|         ); | ||||
|  | ||||
|         // Assert | ||||
|         exitCode.Should().Be(0); | ||||
|  | ||||
|         var stdOut = FakeConsole.ReadOutputString(); | ||||
|         stdOut.Trim().Should().Be("me"); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_can_bind_an_option_to_a_property_with_the_same_identifier_as_the_implicit_version_option_and_get_the_correct_value() | ||||
|     { | ||||
|         // Arrange | ||||
|         var commandType = DynamicCommandBuilder.Compile( | ||||
|             // lang=csharp | ||||
|             """ | ||||
|             [Command] | ||||
|             public class Command : ICommand | ||||
|             { | ||||
|                 [CommandOption("version")] | ||||
|                 public string? Foo { get; init; } | ||||
|  | ||||
|                 public ValueTask ExecuteAsync(IConsole console) | ||||
|                 { | ||||
|                     console.WriteLine(Foo); | ||||
|                     return default; | ||||
|                 } | ||||
|             } | ||||
|             """ | ||||
|         ); | ||||
|  | ||||
|         var application = new CliApplicationBuilder() | ||||
|             .AddCommand(commandType) | ||||
|             .UseConsole(FakeConsole) | ||||
|             .Build(); | ||||
|  | ||||
|         // Act | ||||
|         var exitCode = await application.RunAsync( | ||||
|             ["--version", "1.2.0"], | ||||
|             new Dictionary<string, string>() | ||||
|         ); | ||||
|  | ||||
|         // Assert | ||||
|         exitCode.Should().Be(0); | ||||
|  | ||||
|         var stdOut = FakeConsole.ReadOutputString(); | ||||
|         stdOut.Trim().Should().Be("1.2.0"); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task I_can_try_to_bind_a_required_option_to_a_property_and_get_an_error_if_the_user_does_not_provide_the_corresponding_argument() | ||||
|     { | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using FluentAssertions; | ||||
| using FluentAssertions.Execution; | ||||
| using FluentAssertions.Primitives; | ||||
|  | ||||
| namespace CliFx.Tests.Utils.Extensions; | ||||
| @@ -13,7 +12,7 @@ internal static class AssertionExtensions | ||||
|         params IEnumerable<string> lines | ||||
|     ) => | ||||
|         assertions | ||||
|             .Subject.Split(new[] { '\n', '\r' }, StringSplitOptions.RemoveEmptyEntries) | ||||
|             .Subject.Split(['\n', '\r'], StringSplitOptions.RemoveEmptyEntries) | ||||
|             .Should() | ||||
|             .Equal(lines); | ||||
|  | ||||
| @@ -30,7 +29,7 @@ internal static class AssertionExtensions | ||||
|  | ||||
|             if (index < 0) | ||||
|             { | ||||
|                 Execute.Assertion.FailWith( | ||||
|                 assertions.CurrentAssertionChain.FailWith( | ||||
|                     $"Expected string '{assertions.Subject}' to contain '{value}' after position {lastIndex}." | ||||
|                 ); | ||||
|             } | ||||
|   | ||||
| @@ -7,7 +7,7 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "CliFx", "CliFx\CliFx.csproj | ||||
| EndProject | ||||
| Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "CliFx.Tests", "CliFx.Tests\CliFx.Tests.csproj", "{268CF863-65A5-49BB-93CF-08972B7756DC}" | ||||
| EndProject | ||||
| Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{3AAE8166-BB8E-49DA-844C-3A0EE6BD40A0}" | ||||
| Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Misc", "Misc", "{3AAE8166-BB8E-49DA-844C-3A0EE6BD40A0}" | ||||
| 	ProjectSection(SolutionItems) = preProject | ||||
| 		Directory.Build.props = Directory.Build.props | ||||
| 		License.txt = License.txt | ||||
|   | ||||
| @@ -1,12 +1,16 @@ | ||||
| <Project Sdk="Microsoft.NET.Sdk"> | ||||
|  | ||||
|   <PropertyGroup> | ||||
|     <TargetFrameworks>netstandard2.0;netstandard2.1;net7.0;net8.0</TargetFrameworks> | ||||
|     <TargetFrameworks>netstandard2.0;netstandard2.1;net8.0;net9.0</TargetFrameworks> | ||||
|     <IsPackable>true</IsPackable> | ||||
|     <IsTrimmable Condition="$([MSBuild]::IsTargetFrameworkCompatible('$(TargetFramework)', 'net6.0'))">true</IsTrimmable> | ||||
|     <IsAotCompatible Condition="$([MSBuild]::IsTargetFrameworkCompatible('$(TargetFramework)', 'net7.0'))">true</IsAotCompatible> | ||||
|     <IsTrimmable | ||||
|       Condition="$([MSBuild]::IsTargetFrameworkCompatible('$(TargetFramework)', 'net6.0'))" | ||||
|       >true</IsTrimmable | ||||
|     > | ||||
|     <IsAotCompatible | ||||
|       Condition="$([MSBuild]::IsTargetFrameworkCompatible('$(TargetFramework)', 'net7.0'))" | ||||
|       >true</IsAotCompatible | ||||
|     > | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <PropertyGroup> | ||||
|     <Authors>$(Company)</Authors> | ||||
|     <Description>Class-first framework for building command-line interfaces</Description> | ||||
| @@ -17,21 +21,25 @@ | ||||
|     <PackageLicenseExpression>MIT</PackageLicenseExpression> | ||||
|     <GenerateDocumentationFile>true</GenerateDocumentationFile> | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|     <None Include="../favicon.png" Pack="true" PackagePath="" Visible="false" /> | ||||
|   </ItemGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="0.29.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="CSharpier.MsBuild" Version="1.1.2" PrivateAssets="all" /> | ||||
|     <PackageReference Include="Microsoft.SourceLink.GitHub" Version="8.0.0" PrivateAssets="all" /> | ||||
|     <PackageReference Include="PolyShim" Version="1.13.0" PrivateAssets="all" /> | ||||
|     <PackageReference Include="System.Threading.Tasks.Extensions" Version="4.5.4" Condition="'$(TargetFramework)' == 'netstandard2.0'" /> | ||||
|     <PackageReference Include="PolyShim" Version="1.15.0" PrivateAssets="all" /> | ||||
|     <PackageReference | ||||
|       Include="System.Threading.Tasks.Extensions" | ||||
|       Version="4.6.3" | ||||
|       Condition="!$([MSBuild]::IsTargetFrameworkCompatible('$(TargetFramework)', 'netstandard2.1'))" | ||||
|     /> | ||||
|   </ItemGroup> | ||||
|  | ||||
|   <!-- Embed the analyzer inside the package --> | ||||
|   <ItemGroup> | ||||
|     <ProjectReference Include="..\CliFx.SourceGeneration\CliFx.SourceGeneration.csproj" ReferenceOutputAssembly="false" OutputItemType="analyzer" /> | ||||
|     <ProjectReference | ||||
|       Include="..\CliFx.SourceGeneration\CliFx.SourceGeneration.csproj" | ||||
|       ReferenceOutputAssembly="false" | ||||
|       OutputItemType="analyzer" | ||||
|     /> | ||||
|   </ItemGroup> | ||||
|  | ||||
| </Project> | ||||
| </Project> | ||||
|   | ||||
| @@ -6,12 +6,11 @@ namespace CliFx.Utils; | ||||
|  | ||||
| internal static class EnvironmentEx | ||||
| { | ||||
|     private static readonly Lazy<string?> ProcessPathLazy = | ||||
|         new(() => | ||||
|         { | ||||
|             using var process = Process.GetCurrentProcess(); | ||||
|             return process.MainModule?.FileName; | ||||
|         }); | ||||
|     private static readonly Lazy<string?> ProcessPathLazy = new(() => | ||||
|     { | ||||
|         using var process = Process.GetCurrentProcess(); | ||||
|         return process.MainModule?.FileName; | ||||
|     }); | ||||
|  | ||||
|     public static string? ProcessPath => ProcessPathLazy.Value; | ||||
|  | ||||
|   | ||||
| @@ -38,43 +38,42 @@ internal partial class StackFrame | ||||
|     private const string NotSpace = @"[^\x20\t]"; | ||||
|  | ||||
|     // Taken from https://github.com/atifaziz/StackTraceParser | ||||
|     private static readonly Regex Pattern = | ||||
|         new( | ||||
|             $$""" | ||||
|             ^ | ||||
|             {{Space}}* | ||||
|             \w+ {{Space}}+ | ||||
|             (?<frame> | ||||
|                 (?<type> {{NotSpace}}+ ) \. | ||||
|                 (?<method> {{NotSpace}}+? ) {{Space}}* | ||||
|                 (?<params>  \( ( {{Space}}* \) | ||||
|                                |                    (?<pt> .+?) {{Space}}+ (?<pn> .+?) | ||||
|                                  (, {{Space}}* (?<pt> .+?) {{Space}}+ (?<pn> .+?) )* \) ) ) | ||||
|                 ( {{Space}}+ | ||||
|                     ( # Microsoft .NET stack traces | ||||
|                     \w+ {{Space}}+ | ||||
|                     (?<file> ( [a-z] \: # Windows rooted path starting with a drive letter | ||||
|                              | / )      # Unix rooted path starting with a forward-slash | ||||
|                              .+? ) | ||||
|                     \: \w+ {{Space}}+ | ||||
|                     (?<line> [0-9]+ ) \p{P}? | ||||
|                     | # Mono stack traces | ||||
|                     \[0x[0-9a-f]+\] {{Space}}+ \w+ {{Space}}+ | ||||
|                     <(?<file> [^>]+ )> | ||||
|                     :(?<line> [0-9]+ ) | ||||
|                     ) | ||||
|                 )? | ||||
|             ) | ||||
|             \s* | ||||
|             $ | ||||
|             """, | ||||
|             RegexOptions.IgnoreCase | ||||
|                 | RegexOptions.Multiline | ||||
|                 | RegexOptions.ExplicitCapture | ||||
|                 | RegexOptions.CultureInvariant | ||||
|                 | RegexOptions.IgnorePatternWhitespace, | ||||
|             TimeSpan.FromSeconds(5) | ||||
|         ); | ||||
|     private static readonly Regex Pattern = new( | ||||
|         $$""" | ||||
|         ^ | ||||
|         {{Space}}* | ||||
|         \w+ {{Space}}+ | ||||
|         (?<frame> | ||||
|             (?<type> {{NotSpace}}+ ) \. | ||||
|             (?<method> {{NotSpace}}+? ) {{Space}}* | ||||
|             (?<params>  \( ( {{Space}}* \) | ||||
|                            |                    (?<pt> .+?) {{Space}}+ (?<pn> .+?) | ||||
|                              (, {{Space}}* (?<pt> .+?) {{Space}}+ (?<pn> .+?) )* \) ) ) | ||||
|             ( {{Space}}+ | ||||
|                 ( # Microsoft .NET stack traces | ||||
|                 \w+ {{Space}}+ | ||||
|                 (?<file> ( [a-z] \: # Windows rooted path starting with a drive letter | ||||
|                          | / )      # Unix rooted path starting with a forward-slash | ||||
|                          .+? ) | ||||
|                 \: \w+ {{Space}}+ | ||||
|                 (?<line> [0-9]+ ) \p{P}? | ||||
|                 | # Mono stack traces | ||||
|                 \[0x[0-9a-f]+\] {{Space}}+ \w+ {{Space}}+ | ||||
|                 <(?<file> [^>]+ )> | ||||
|                 :(?<line> [0-9]+ ) | ||||
|                 ) | ||||
|             )? | ||||
|         ) | ||||
|         \s* | ||||
|         $ | ||||
|         """, | ||||
|         RegexOptions.IgnoreCase | ||||
|             | RegexOptions.Multiline | ||||
|             | RegexOptions.ExplicitCapture | ||||
|             | RegexOptions.CultureInvariant | ||||
|             | RegexOptions.IgnorePatternWhitespace, | ||||
|         TimeSpan.FromSeconds(5) | ||||
|     ); | ||||
|  | ||||
|     public static IEnumerable<StackFrame> ParseTrace(string stackTrace) | ||||
|     { | ||||
|   | ||||
| @@ -12,7 +12,7 @@ | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <!-- Disable nullability warnings on older frameworks because there is no nullability info for BCL --> | ||||
|   <PropertyGroup Condition="'$(TargetFramework)' == 'netstandard2.0'"> | ||||
|   <PropertyGroup Condition="!$([MSBuild]::IsTargetFrameworkCompatible('$(TargetFramework)', 'netstandard2.1'))"> | ||||
|     <Nullable>annotations</Nullable> | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user