Find executable scripts in a directory and allow to select which one to execute
Find a file
2024-11-10 10:53:23 +01:00
.github Github Actions(deps): Bump github/codeql-action from 2 to 3 (#11) 2023-12-18 09:27:43 +01:00
src make lambdas static where possible 2024-11-10 10:53:23 +01:00
.gitignore Add publish script 2022-03-14 12:18:16 +01:00
Directory.Build.props add Directory.Build.Props to use simplified build output 2023-11-14 19:29:36 +01:00
install-as-dotnet-tool.ps1 feat: rename executable to scrl 2023-05-19 19:44:12 +02:00
install-as-dotnet-tool.sh feat: rename executable to scrl 2023-05-19 19:44:12 +02:00
LICENSE Initail Commit 2022-03-09 22:42:40 +01:00
README.md fix missing default values 2024-10-25 11:14:10 +02:00
ScriptLauncher.sln add .sln file 2023-11-14 19:29:36 +01:00

Script Launcher

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 which is included in the .NET SDK

Install manually using the following commands or by using the provided installation scripts.

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.

# 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

USAGE:
    scrl [path] [OPTIONS]

ARGUMENTS:
    [path]    Starting directory (Default: .)

OPTIONS:
                                     DEFAULT
    -h, --help                                  Prints help information
    -x, --extensions <EXTENSIONS>               List of script extensions to search for
    -d, --depth                      3          Search depth
    -e, --elevated                              Run with elevated privileges
    -g, --group                                 Group scripts by folder
    -b, --brief                                 Show brief information