#cargo-subcommand #skyline #switch #install #build #ip #directory

app cargo-skyline

A cargo subcommand for working with Skyline plugins written in Rust

39 stable releases

3.3.0 Jan 4, 2025
3.2.0 Sep 1, 2022
3.1.0 Aug 31, 2022
3.0.0 Jul 1, 2022
1.15.0 Jul 17, 2020

#150 in Cargo plugins

Download history 25/week @ 2024-09-25 29/week @ 2024-10-02 42/week @ 2024-10-09 20/week @ 2024-10-16 11/week @ 2024-10-23 15/week @ 2024-10-30 11/week @ 2024-11-06 2/week @ 2024-11-13 4/week @ 2024-11-20 5/week @ 2024-11-27 3/week @ 2024-12-04 15/week @ 2024-12-11 7/week @ 2024-12-18 185/week @ 2025-01-01 25/week @ 2025-01-08

218 downloads per month

MIT license

74KB
2K SLoC

cargo-skyline

A cargo subcommand for making it easier to work with (and make) Skyline plugins.

cargo-skyline 3.2.0

USAGE:
    cargo skyline <SUBCOMMAND>

FLAGS:
    -h, --help       Prints help information
    -V, --version    Prints version information

SUBCOMMANDS:
    build            Build the current plugin as an NRO
    check            Check if the current plugin builds and emit any errors found
    clean-project    Clean a pre-existing project files no longer needed for the latest version
    clippy           Emit beginner-helpful lints and warnings
    cp               Copy a file over FTP
    doc              Document the current plugin and its dependencies
    help             Prints this message or the help of the given subcommand(s)
    install          Build the current plugin and install to a switch over FTP
    list             List the files in the plugin directory for the given game
    listen           Listen for logs being output from a switch running skyline at the given ip
    new              Create a new plugin from a template
    package          Package plugin and latest Skyline into a zip file to prepare it for release
    restart          Install the current plugin and listen for skyline logging
    restart-game     Restart the given game using restart-plugin
    rm               Delete a file in the plugin directory for the given game
    run              Install the current plugin and listen for skyline logging
    self-update      Update cargo-skyline command
    set-ip           Set the IP address of the switch to install to
    show-ip          Show the currently configured IP address
    update           Update libraries for current plugin folder
    update-std       Download the latest stdlib for aarch64-skyline-switch

Prerequisites

Installation

cargo install cargo-skyline

Example usage

Create a new plugin called fps_counter (in a folder of the same name) in the current directory:

cargo skyline new fps_counter

Build the current plugin as an nro:

cargo skyline build

Set the ip of the Switch to install to as 192.168.0.0:

cargo skyline set-ip 192.168.0.0

Install the current plugin on a switch at ip 192.168.0.0 for an application with title of 01006A800016E000:

cargo skyline install --ip 192.168.0.0 --title-id 01006A800016E000

Note: if the IP has been set, it can be omitted from the arguments (or overriden using the arguments).

To set a default title id for a plugin use the following format in Cargo.toml:

[package.metadata.skyline]
titleid = "01006A800016E000"

Install the current plugin to the default IP and title ID, then listen for output from the console:

cargo skyline run

Alternative Installation via Docker

docker build -t cargo-skyline .
docker run it cargo-skyline cargo skyline --help

Dependencies

~30–47MB
~862K SLoC