Agent skill

unityctl-plugins

Create unityctl plugins. Use when the user wants to create, scaffold, or write a unityctl plugin (script or executable).

Stars 10
Forks 2

Install this agent skill to your Project

npx add-skill https://github.com/DirtybitGames/unityctl/tree/main/.claude/skills/unityctl-plugins

SKILL.md

Creating unityctl Plugins

There are two plugin types: script (C# running inside Unity) and executable (any program on disk).

Script Plugins

Run C# inside the Unity Editor via the script.execute RPC. Best for commands that need Unity APIs.

Quick start

bash
unityctl plugin create my-tool   # scaffolds .unityctl/plugins/my-tool/

Structure

.unityctl/plugins/my-tool/
  plugin.json    # manifest
  hello.cs       # handler script

plugin.json

json
{
  "name": "my-tool",
  "version": "1.0.0",
  "description": "My custom tool",
  "commands": [
    {
      "name": "stats",
      "description": "Show scene stats",
      "arguments": [
        { "name": "scene", "description": "Scene name", "required": false }
      ],
      "options": [
        { "name": "verbose", "type": "bool", "description": "Show details" },
        { "name": "format", "type": "string", "description": "Output format" }
      ],
      "handler": { "type": "script", "file": "stats.cs" }
    }
  ],
  "skill": { "file": "SKILL.md" }
}

Handler script

Must define public class Script with public static object Main(string[] args). Arguments and options are passed as the args array.

csharp
using UnityEngine;
using UnityEditor;

public class Script
{
    public static object Main(string[] args)
    {
        var count = Object.FindObjectsByType<GameObject>(FindObjectsSortMode.None).Length;
        return $"Scene has {count} GameObjects";
    }
}

The return value is sent back as the command output. The script runs on Unity's main thread and has access to all Unity and UnityEditor APIs.

Custom skill documentation

Add a "skill": { "file": "SKILL.md" } entry to plugin.json and create the markdown file. It will be included in the composed SKILL.md when running unityctl skill rebuild. Without it, documentation is auto-generated from the manifest.

Location

Level Directory Precedence
Project .unityctl/plugins/ Higher
User ~/.unityctl/plugins/ Lower

Use --global / -g with plugin create to scaffold at user level.

Plugin names must be lowercase alphanumeric with hyphens (e.g. my-tool, scene-stats). Must start and end with a letter or digit.

Executable Plugins

Any executable named unityctl-<name> becomes available as unityctl <name>. Best for workflows outside Unity: build pipelines, CI scripts, multi-step orchestration.

How it works

Place an executable (shell script, Python, Go binary, .bat/.cmd/.ps1 on Windows) named unityctl-<name> in .unityctl/plugins/ or on PATH. All arguments after the command name are passed through.

Executables in plugin directories are registered at startup (appear in --help). Executables on PATH are resolved lazily when invoked — like git resolving git foogit-foo.

bash
unityctl smoke 30          # finds and runs unityctl-smoke with arg "30"
unityctl deploy --staging  # finds and runs unityctl-deploy with arg "--staging"

Environment variables

The CLI sets these before launching the executable:

Variable Description
UNITYCTL_PROJECT_PATH Resolved Unity project root
UNITYCTL_BRIDGE_PORT Bridge HTTP port
UNITYCTL_BRIDGE_URL Full bridge URL (e.g. http://localhost:62908)
UNITYCTL_AGENT_ID Agent ID if --agent-id was passed
UNITYCTL_JSON "1" if --json was passed

Example

bash
#!/usr/bin/env bash
# Save as: unityctl-smoke (chmod +x)
unityctl logs clear
unityctl play enter
sleep "${1:-10}"
unityctl screenshot capture --json > /tmp/smoke.json
ERRORS=$(unityctl logs -n 1000 --json | jq '[.entries[] | select(.level == "Error")] | length')
unityctl play exit
[ "$ERRORS" -eq 0 ] && echo "PASS" || { echo "FAIL: $ERRORS error(s)"; exit 1; }

Companion skill file

Place unityctl-<name>.skill.md next to the executable to provide custom documentation for SKILL.md composition. Without it, a minimal section is auto-generated.

Platform notes

  • Windows: matches .exe, .cmd, .bat, .ps1 extensions
  • Unix: matches any file with execute permission; extensions are stripped from the command name (unityctl-foo.sh becomes unityctl foo)

Precedence

built-in command > script plugin > executable plugin. A plugin cannot shadow a built-in command.

After changes

Run unityctl skill rebuild to update the composed SKILL.md with plugin documentation.

Management commands

bash
unityctl plugin list              # list all plugins (script + executable)
unityctl plugin create <name>     # scaffold a script plugin
unityctl plugin create <name> -g  # scaffold at user level (~/.unityctl/plugins/)
unityctl plugin remove <name>     # remove a script plugin

Expand your agent's capabilities with these related and highly-rated skills.

DirtybitGames/unityctl

unity-editor

Remote control Unity Editor via CLI using unityctl. Activate when user mentions Unity Editor, play mode, asset compilation, Unity console logs, C# script debugging, Unity tests, scene loading, screenshots, or video recording. Use for launching/stopping editor, entering/exiting play mode, compiling scripts, viewing logs, loading scenes, running tests, capturing screenshots, recording video, or executing arbitrary C# in Unity context.

10 2
Explore
DirtybitGames/unityctl

release

Create a new release of unityctl. Analyzes changes since last tag, determines version bump type (major/minor/patch), updates version, builds, commits, tags, and creates a draft GitHub release with changelog.

10 2
Explore
DirtybitGames/unityctl

demo-page

Rebuild and publish the unityctl demo page hosted at https://dirtybitgames.github.io/unityctl/. Use when asked to update the demo, rebuild the demo page, update gh-pages, or refresh the demo screenshots/video.

10 2
Explore
DirtybitGames/unityctl

unity-editor

Remote control Unity Editor via CLI using unityctl. Activate when user mentions Unity Editor, play mode, asset compilation, Unity console logs, C# script debugging, Unity tests, scene loading, screenshots, or video recording. Use for launching/stopping editor, entering/exiting play mode, compiling scripts, viewing logs, loading scenes, running tests, capturing screenshots, recording video, or executing arbitrary C# in Unity context.

10 2
Explore
petekp/claude-code-setup

ubiquitous-language

Extract a DDD-style ubiquitous language glossary from the current conversation, flagging ambiguities and proposing canonical terms. Saves to UBIQUITOUS_LANGUAGE.md. Use when user wants to define domain terms, build a glossary, harden terminology, create a ubiquitous language, or mentions "domain model" or "DDD".

20 6
Explore
petekp/claude-code-setup

every-style-editor

This skill should be used when reviewing or editing copy to ensure adherence to Every's style guide. It provides a systematic line-by-line review process for grammar, punctuation, mechanics, and style guide compliance.

20 6
Explore

Didn't find tool you were looking for?

Be as detailed as possible for better results