Cherri (pronounced cherry) is a Shortcuts programming language that compiles directly to a valid runnable Shortcut.
The primary goal is to make it practical to create large Shortcut projects (within the limitations of Shortcuts) and maintain them long term.
- π₯οΈ Laptop/Desktop-based development (CLI, VSCode extension, macOS app)
- π Easy to learn and syntax similar to other languages
- π 1-1 translation to Shortcut actions as much as possible to make debugging easier
- π₯Ύ Half-bootstrapped: Most actions and types are written in the language
- π¦ Package manager: GitHub repo-based package manager built in, allowing for automatic inclusion and updates.
- πͺ No magic variables syntax, they're constants instead
- πͺΆ Optimized to create as small as possible Shortcuts and reduce memory usage at runtime
- #οΈβ£ Include files within others for large Shortcut projects
- π§ Define actions with type checking, enums, optionals, default values, raw identifiers, and raw keys.
- π Define functions to run within their own scope at the top of your Shortcut to reduce duplicate actions.
- π Copy-paste actions automatically
- π₯© Enter action identifier and parameters manually using Raw Actions.
- β Define import questions
- π Generate VCards for menus
- π Embed files in base64
- π Convert Shortcuts from an iCloud link with the
--import=option - π’ Type system and type inference
- π Signs using macOS, falls back on HubSign or another server that uses scaxyz/shortcut-signing-server.
- π Cherri VSCode Extension
- π Playground - Try out Cherri on any platform, preview the result, and export signed Shortcuts
- π₯οΈ macOS IDE - Defines Cherri file type, write and build Shortcuts on Mac with a GUI
- π Documentation - Learn Cherri or how to contribute
- π Glyph Search - Search glyphs you can use in Cherri!
- β FAQ
You can install Cherri by downloading the latest release or via the Homebrew package manager:
Add Tap:
brew tap electrikmilk/cherriInstall:
brew install electrikmilk/cherri/cherricherri file.cherriRun cherri without any arguments to see all options and usage. For development, use the --debug (or -d) option to print
stack traces, debug information, and output a .plist file.
Because it's fun :)
Some languages have been abandoned, don't work well, or no longer work. I don't want Shortcuts languages to die. There should be more, not less.
Plus, some stability comes with this project being on macOS and not iOS, and I'm not aware of another Shortcuts language with macOS as its platform other than Buttermilk.
- zachary7829/Shortcuts File Format Documentation
- sebj/iOS-Shortcuts-Reference
- [Tip] Reducing memory usage of repeat loops
- Go syntax
- Ruby syntax
- ScPL
- Buttermilk
- Jelly
The original Workflow app assigned a code name to each release. Cherri is named after the second-to-last update "Cherries" (also cherry is one of my favorite flavors).
This project started on October 5, 2022.