mirror of
				https://github.com/spectreconsole/examples.git
				synced 2025-10-25 15:19:18 +00:00 
			
		
		
		
	Initial commits
This commit is contained in:
		
							
								
								
									
										46
									
								
								examples/Cli/Demo/Commands/Add/AddPackageCommand.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								examples/Cli/Demo/Commands/Add/AddPackageCommand.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | ||||
| using System.ComponentModel; | ||||
| using Demo.Utilities; | ||||
| using Spectre.Console.Cli; | ||||
|  | ||||
| namespace Demo.Commands.Add; | ||||
|  | ||||
| [Description("Add a NuGet package reference to the project.")] | ||||
| public sealed class AddPackageCommand : Command<AddPackageCommand.Settings> | ||||
| { | ||||
|     public sealed class Settings : AddSettings | ||||
|     { | ||||
|         [CommandArgument(0, "<PACKAGENAME>")] | ||||
|         [Description("The package reference to add.")] | ||||
|         public string PackageName { get; set; } | ||||
|  | ||||
|         [CommandOption("-v|--version <VERSION>")] | ||||
|         [Description("The version of the package to add.")] | ||||
|         public string Version { get; set; } | ||||
|  | ||||
|         [CommandOption("-f|--framework <FRAMEWORK>")] | ||||
|         [Description("Add the reference only when targeting a specific framework.")] | ||||
|         public string Framework { get; set; } | ||||
|  | ||||
|         [CommandOption("--no-restore")] | ||||
|         [Description("Add the reference without performing restore preview and compatibility check.")] | ||||
|         public bool NoRestore { get; set; } | ||||
|  | ||||
|         [CommandOption("--source <SOURCE>")] | ||||
|         [Description("The NuGet package source to use during the restore.")] | ||||
|         public string Source { get; set; } | ||||
|  | ||||
|         [CommandOption("--package-directory <PACKAGEDIR>")] | ||||
|         [Description("The directory to restore packages to.")] | ||||
|         public string PackageDirectory { get; set; } | ||||
|  | ||||
|         [CommandOption("--interactive")] | ||||
|         [Description("Allows the command to stop and wait for user input or action (for example to complete authentication).")] | ||||
|         public bool Interactive { get; set; } | ||||
|     } | ||||
|  | ||||
|     public override int Execute(CommandContext context, Settings settings) | ||||
|     { | ||||
|         SettingsDumper.Dump(settings); | ||||
|         return 0; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										29
									
								
								examples/Cli/Demo/Commands/Add/AddReferenceCommand.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								examples/Cli/Demo/Commands/Add/AddReferenceCommand.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| using System.ComponentModel; | ||||
| using Demo.Utilities; | ||||
| using Spectre.Console.Cli; | ||||
|  | ||||
| namespace Demo.Commands.Add; | ||||
|  | ||||
| public sealed class AddReferenceCommand : Command<AddReferenceCommand.Settings> | ||||
| { | ||||
|     public sealed class Settings : AddSettings | ||||
|     { | ||||
|         [CommandArgument(0, "<PROJECTPATH>")] | ||||
|         [Description("The package reference to add.")] | ||||
|         public string ProjectPath { get; set; } | ||||
|  | ||||
|         [CommandOption("-f|--framework <FRAMEWORK>")] | ||||
|         [Description("Add the reference only when targeting a specific framework.")] | ||||
|         public string Framework { get; set; } | ||||
|  | ||||
|         [CommandOption("--interactive")] | ||||
|         [Description("Allows the command to stop and wait for user input or action (for example to complete authentication).")] | ||||
|         public bool Interactive { get; set; } | ||||
|     } | ||||
|  | ||||
|     public override int Execute(CommandContext context, Settings settings) | ||||
|     { | ||||
|         SettingsDumper.Dump(settings); | ||||
|         return 0; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										11
									
								
								examples/Cli/Demo/Commands/Add/AddSettings.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								examples/Cli/Demo/Commands/Add/AddSettings.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| using System.ComponentModel; | ||||
| using Spectre.Console.Cli; | ||||
|  | ||||
| namespace Demo.Commands.Add; | ||||
|  | ||||
| public abstract class AddSettings : CommandSettings | ||||
| { | ||||
|     [CommandArgument(0, "<PROJECT>")] | ||||
|     [Description("The project file to operate on. If a file is not specified, the command will search the current directory for one.")] | ||||
|     public string Project { get; set; } | ||||
| } | ||||
							
								
								
									
										69
									
								
								examples/Cli/Demo/Commands/Run/RunCommand.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								examples/Cli/Demo/Commands/Run/RunCommand.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | ||||
| using System.ComponentModel; | ||||
| using Demo.Utilities; | ||||
| using Spectre.Console.Cli; | ||||
|  | ||||
| namespace Demo.Commands.Run; | ||||
|  | ||||
| [Description("Build and run a .NET project output.")] | ||||
| public sealed class RunCommand : Command<RunCommand.Settings> | ||||
| { | ||||
|     public sealed class Settings : CommandSettings | ||||
|     { | ||||
|         [CommandOption("-c|--configuration <CONFIGURATION>")] | ||||
|         [Description("The configuration to run for. The default for most projects is '[grey]Debug[/]'.")] | ||||
|         [DefaultValue("Debug")] | ||||
|         public string Configuration { get; set; } | ||||
|  | ||||
|         [CommandOption("-f|--framework <FRAMEWORK>")] | ||||
|         [Description("The target framework to run for. The target framework must also be specified in the project file.")] | ||||
|         public string Framework { get; set; } | ||||
|  | ||||
|         [CommandOption("-r|--runtime <RUNTIMEIDENTIFIER>")] | ||||
|         [Description("The target runtime to run for.")] | ||||
|         public string RuntimeIdentifier { get; set; } | ||||
|  | ||||
|         [CommandOption("-p|--project <PROJECTPATH>")] | ||||
|         [Description("The path to the project file to run (defaults to the current directory if there is only one project).")] | ||||
|         public string ProjectPath { get; set; } | ||||
|  | ||||
|         [CommandOption("--launch-profile <LAUNCHPROFILE>")] | ||||
|         [Description("The name of the launch profile (if any) to use when launching the application.")] | ||||
|         public string LaunchProfile { get; set; } | ||||
|  | ||||
|         [CommandOption("--no-launch-profile")] | ||||
|         [Description("Do not attempt to use [grey]launchSettings.json[/] to configure the application.")] | ||||
|         public bool NoLaunchProfile { get; set; } | ||||
|  | ||||
|         [CommandOption("--no-build")] | ||||
|         [Description("Do not build the project before running. Implies [grey]--no-restore[/].")] | ||||
|         public bool NoBuild { get; set; } | ||||
|  | ||||
|         [CommandOption("--interactive")] | ||||
|         [Description("Allows the command to stop and wait for user input or action (for example to complete authentication).")] | ||||
|         public string Interactive { get; set; } | ||||
|  | ||||
|         [CommandOption("--no-restore")] | ||||
|         [Description("Do not restore the project before building.")] | ||||
|         public bool NoRestore { get; set; } | ||||
|  | ||||
|         [CommandOption("--verbosity <VERBOSITY>")] | ||||
|         [Description("Set the MSBuild verbosity level. Allowed values are q[grey]uiet[/], m[grey]inimal[/], n[grey]ormal[/], d[grey]etailed[/], and diag[grey]nostic[/].")] | ||||
|         [TypeConverter(typeof(VerbosityConverter))] | ||||
|         [DefaultValue(Verbosity.Normal)] | ||||
|         public Verbosity Verbosity { get; set; } | ||||
|  | ||||
|         [CommandOption("--no-dependencies")] | ||||
|         [Description("Do not restore project-to-project references and only restore the specified project.")] | ||||
|         public bool NoDependencies { get; set; } | ||||
|  | ||||
|         [CommandOption("--force")] | ||||
|         [Description("Force all dependencies to be resolved even if the last restore was successful. This is equivalent to deleting [grey]project.assets.json[/].")] | ||||
|         public bool Force { get; set; } | ||||
|     } | ||||
|  | ||||
|     public override int Execute(CommandContext context, Settings settings) | ||||
|     { | ||||
|         SettingsDumper.Dump(settings); | ||||
|         return 0; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										40
									
								
								examples/Cli/Demo/Commands/Serve/ServeCommand.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								examples/Cli/Demo/Commands/Serve/ServeCommand.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,40 @@ | ||||
| using System; | ||||
| using System.ComponentModel; | ||||
| using Demo.Utilities; | ||||
| using Spectre.Console.Cli; | ||||
|  | ||||
| namespace Demo.Commands.Serve; | ||||
|  | ||||
| [Description("Launches a web server in the current working directory and serves all files in it.")] | ||||
| public sealed class ServeCommand : Command<ServeCommand.Settings> | ||||
| { | ||||
|     public sealed class Settings : CommandSettings | ||||
|     { | ||||
|         [CommandOption("-p|--port <PORT>")] | ||||
|         [Description("Port to use. Defaults to [grey]8080[/]. Use [grey]0[/] for a dynamic port.")] | ||||
|         public int Port { get; set; } | ||||
|  | ||||
|         [CommandOption("-o|--open-browser [BROWSER]")] | ||||
|         [Description("Open a web browser when the server starts. You can also specify which browser to use. If none is specified, the default one will be used.")] | ||||
|         public FlagValue<string> OpenBrowser { get; set; } | ||||
|     } | ||||
|  | ||||
|     public override int Execute(CommandContext context, Settings settings) | ||||
|     { | ||||
|         if (settings.OpenBrowser.IsSet) | ||||
|         { | ||||
|             var browser = settings.OpenBrowser.Value; | ||||
|             if (browser != null) | ||||
|             { | ||||
|                 Console.WriteLine($"Open in {browser}"); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 Console.WriteLine($"Open in default browser."); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         SettingsDumper.Dump(settings); | ||||
|         return 0; | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user