2022-03-09 22:42:40 +01:00
|
|
|
# Script Launcher
|
|
|
|
|
2022-06-10 17:45:24 +02:00
|
|
|
Find executable scripts in a directory and allow to select which one to execute.
|
|
|
|
|
|
|
|
## Installation
|
|
|
|
|
|
|
|
### As .NET CLI Tool
|
|
|
|
|
|
|
|
To be installed as a tool, you need the [.NET CLI][CLI] which is included in the [.NET SDK][SDK]
|
|
|
|
|
|
|
|
Install manually using the following commands or by using the provided installation scripts.
|
|
|
|
|
|
|
|
```sh
|
|
|
|
dotnet pack ./src -o ./nupkg
|
|
|
|
dotnet tool install -g ScriptLauncher --add-source ./nupkg --ignore-failed-sources
|
|
|
|
```
|
|
|
|
|
|
|
|
### As a Standalone Executable
|
|
|
|
|
|
|
|
You will need the identifier of the .NET Runtime ([RID]) and the Target Framework Moniker ([TFM]) for your OS and Runtime.
|
|
|
|
|
|
|
|
```sh
|
|
|
|
# self contained: will not need the .NET runtime to function, bigger resulting size
|
|
|
|
dotnet publish -c Release --self-contained -p:PublishSingleFile=true -p:PublishTrimmed=true -f <TFM> -r <RID> -o <output-directory> ./src
|
|
|
|
|
|
|
|
# no self contained: will need the .NET runtime to be installed to function, smallest size
|
|
|
|
dotnet publish -c Release --no-self-contained -p:PublishSingleFile=true -r <RID> -o <output-directory> ./src
|
|
|
|
```
|
|
|
|
|
|
|
|
_**NOTE**_: The option `-p:PublishTrimmed=true` may produce some *warnings*. If so simply skip that option and the resulting executable will be larger
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
```sh
|
2022-10-15 13:06:19 +02:00
|
|
|
USAGE:
|
2023-01-27 16:27:08 +01:00
|
|
|
scrl <path> [OPTIONS]
|
2022-10-15 13:06:19 +02:00
|
|
|
|
|
|
|
ARGUMENTS:
|
|
|
|
<path> Starting directory (Default: .)
|
|
|
|
|
|
|
|
OPTIONS:
|
|
|
|
-h, --help Prints help information
|
|
|
|
-x, --extensions Comma separated list of script extensions
|
|
|
|
-d, --depth Search depth
|
|
|
|
-e, --elevated Run with elevated privileges
|
|
|
|
-g, --group Group scripts by folder
|
|
|
|
-b, --brief Show brief information
|
2022-06-10 17:45:24 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
[CLI]: https://docs.microsoft.com/en-us/dotnet/core/tools/ ".NET CLI Docs"
|
|
|
|
[SDK]: https://dotnet.microsoft.com/en-us/download ".NET SDK Downloads"
|
|
|
|
[RID]: https://docs.microsoft.com/en-us/dotnet/core/rid-catalog "Runtime IDs Catalog"
|
|
|
|
[TFM]: https://docs.microsoft.com/en-us/dotnet/standard/frameworks "Target Framework Moniker Docs"
|