agentskills.codes
MD

Write README sections that include runnable script examples MdExplorer can execute interactively. Use whenever you document a CLI tool, build/deploy script, dev task, or any command-line invocation in a README, sprint note, or how-to doc. Each example must declare its parameters in a way MdExplorer'

Install

mkdir -p .claude/skills/mde-readme && curl -L -o skill.zip "https://agentskills.codes/api/skills/download/14880" && unzip -o skill.zip -d .claude/skills/mde-readme && rm skill.zip

Installs to .claude/skills/mde-readme

Activation

This is the description your AI agent reads to decide when to run this skill — the better it matches your request, the more reliably it fires.

Write README sections that include runnable script examples MdExplorer can execute interactively. Use whenever you document a CLI tool, build/deploy script, dev task, or any command-line invocation in a README, sprint note, or how-to doc. Each example must declare its parameters in a way MdExplorer's runner can detect, so the user can fill them in a dialog and click ▶ Run.
375 charsno explicit “when” triggerlonger than Claude Code's old 250-char listing cap (fine on current versions)

About this skill

<!-- MdExplorer-managed skill. The `mde:` block above marks this file as distributed by MdExplorer. When you open a project, MdExplorer compares the embedded version with what is on disk and will overwrite this file to keep it in sync with the current MdExplorer features. To customize the skill while keeping your edits, remove the `mde:` block (or change `origin` to something else) — MdExplorer will then leave the file alone. -->

README with runnable examples — MdExplorer convention

MdExplorer renders fenced bash, sh, powershell, pwsh, cmd blocks with a ▶ Run toolbar. When the user clicks Run, MdExplorer parses the script for parameters, pops up a dialog so the user can fill them in, and then executes the script with those values substituted.

For this to work, you must write the example following the convention below.

What every runnable example must contain

  1. A short prose intro explaining what the script does.
  2. A @param documentation header inside the fenced block, one line per parameter.
  3. Placeholder tokens of the form <param-name> wherever the user must supply a value.
  4. Optionally, a @description line summarising the block.

Do not hardcode example values directly into the call — always use placeholders. The dialog defaults to empty (or to a default: you declare); the user fills them in before running.

Parameter declaration syntax

Use comments natural to the shell:

ShellComment prefix
bash / sh#
powershell#
cmd / batREM or ::

The grammar for each parameter line is:

<comment-prefix> @param <NAME> [— description]  [default: <value>]  [secret]  [type: file|dir|out-file]

Rules:

  • <NAME> is [A-Za-z][A-Za-z0-9_-]* (letters, digits, underscore, dash).
  • The (em dash) or a simple - or : separates the name from the description. Anything after the name on the same line is the description.
  • default: <value> (anywhere on the line, in parentheses or after the description) sets the default value pre-filled in the dialog.
  • secret (or the name containing KEY/TOKEN/SECRET/PASSWORD/PWD) renders the field as a password input.
  • type: file renders a path-picker button that opens MdExplorer's file browser rooted at the project folder. The chosen path is inserted as the parameter value when Run is clicked.
  • type: dir is identical to type: file but lets the user pick a folder instead of a file.
  • type: out-file is for files the script will generate (output files that don't exist yet). The picker opens in Save-As mode: the user navigates to the destination folder, types the filename, and the full path is composed for the script. Use this whenever the parameter represents an output / destination file. The default: value (if any) pre-fills the filename suggestion in the Save-As input. Synonyms accepted: output-file, save-file.
  • Path pickers work identically in the browser and in the Electron build — they reuse the MdExplorer-managed file browser, no native OS dialog needed, so they behave consistently on Windows, macOS and Linux.

The same <NAME> is then referenced inside the script body as <name> (lower-cased and with underscores allowed) — case-insensitive match. Placeholders never quoted by you; the runner quotes them safely per shell.

This bites hardest in variable assignments, where the quoting habit is strongest. Leave the placeholder bare:

Correct (bare)Wrong (quoted)
$fuseki = <FUSEKI>$fuseki = "<FUSEKI>"
DEST=<target_dir>DEST="<target_dir>"

The runner substitutes <FUSEKI> with an already shell-quoted value (e.g. 'http://localhost:3030'). If you also quote it, the two stack up — "<FUSEKI>""'http://localhost:3030'" — and the variable ends up holding literal quote characters, producing failures like "Invalid URI: hostname could not be parsed". The only exception is the legacy export VAR="<x>" form (Example 3), where the runner rewrites the entire right-hand side, quotes included.

Working directory — every command runs from the PROJECT ROOT

Critical: when the user clicks ▶ Run, MdExplorer executes the script with the working directory set to the project root — the folder the user opened in MdExplorer — not the folder that contains the README. This is true even when the README lives several levels deep in a subfolder.

Therefore every relative path in the command must be written relative to the project root, not relative to the README's own location. This applies to:

  • the script/program being invoked (python main.py, ./build.sh, node cli.js),
  • any helper files, config files, or relative output paths the command references.

The trap: a README documenting a tool naturally describes commands as if you were standing inside the tool's folder. That instinct produces a broken block. Example — a README at ai-tools-pli/analyze-pli-programs/README.md whose main.py sits next to it:

Wrong (relative to the README)Correct (relative to the project root)
python main.py <pli_file>python ai-tools-pli/analyze-pli-programs/main.py <pli_file>
./run.sh./tools/run.sh

The wrong form fails with can't open file '...\main.py': [Errno 2] No such file or directory because Python looks for main.py in the project root, where it does not exist.

Rules:

  • Prefix the invoked script with its path from the project root. This is the simplest robust form and is unaffected by how parameter values are resolved.
  • Do not assume the README's folder is the cwd. Don't write python main.py hoping the runner will cd next to the README — it won't.
  • If you genuinely need a different working directory, cd explicitly using a root-relative path as the first line of the block (e.g. cd ai-tools-pli/analyze-pli-programs), then call the script. Prefer the path-prefix form above unless the tool truly requires its own cwd.
  • type: file / type: dir pickers are also rooted at the project root, so picked paths share the same anchor as your root-relative command — they stay consistent, no conflict.

Path separator — always /, never \

Critical for cross-platform documents. The same README is run on both Windows and Linux/macOS, so every path you write inside a runnable block must use the forward slash / as separator — never the Windows backslash \.

  • Forward slash works on all platforms: .NET / Win32 accept / for filesystem paths on Windows too, and it is the native separator on Linux/macOS.
  • Backslash works only on Windows. On Linux/macOS \ is a literal filename character, not a separator, so a path like Ontology\ABoxPL1\file.ttl is read as one big filename and the script fails with "No such file or directory".

MdExplorer cannot fix this for you at run time: since \ is a legal character in a Linux filename, the runner must pass your path through verbatim — rewriting it would corrupt paths that legitimately contain a backslash. Portability is your responsibility as the author: type /.

Wrong (Windows-only \)Correct (portable /)
$file = "Ontology\ABoxPL1\BS507.ttl"$file = "Ontology/ABoxPL1/BS507.ttl"
dotnet publish .\src\MyApp.csprojdotnet publish src/MyApp.csproj
python tools\foo\main.pypython tools/foo/main.py

This holds for every shell — bash, powershell, cmd alike. (PowerShell accepts / on Windows for file paths, so a single /-form works in pwsh on every OS.) If a PowerShell script genuinely needs the OS-native separator (e.g. to hand a path to a Windows-only external tool), build it with Join-Path instead of hardcoding \:

$file = Join-Path "Ontology" "ABoxPL1" "BS507.ttl"   # -> '\' on Windows, '/' on Linux

Also never hardcode an absolute root (C:\sviluppo\..., /home/user/...) or a drive letter: those are machine-specific and break the moment the document moves. Keep paths relative to the project root (see the previous section) and use /.

Examples to copy when authoring a README

1. Bash — deploy script

# @param ENV       — target environment (default: staging)
# @param VERSION   — git tag or branch to deploy
# @param API_KEY   — deployment API key (secret)
./deploy.sh --env <env> --version <version> --key <api_key>

2. PowerShell — local build

# @param Configuration — Debug or Release (default: Release)
# @param Runtime       — RID like win-x64, linux-x64 (default: win-x64)
dotnet publish src/MyApp.csproj -c <Configuration> -r <Runtime> --self-contained

3. Bash with env-export style (also detected, legacy)

Special case: the quotes around "<greeting>" are correct only here — the export VAR=... form makes the runner rewrite the whole right-hand side. Everywhere else (plain $var = <x> assignments, command arguments) keep placeholders bare.

# @param GREETING — message to print (default: Hello)
export GREETING="<greeting>"
echo "$GREETING, world!"

4. Cmd / batch

REM @param TARGET  — build target (default: all)
REM @param THREADS — parallel build threads (default: 4)
make <target> -j<threads>

5. Bash with path pickers

When a parameter takes a path on disk, mark it type: file (file picker), type: dir (folder picker), or `ty


Content truncated.

Search skills

Search the agent skills registry