cherri

command module
v0.0.0-...-fd4876a Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 16, 2023 License: GPL-2.0 Imports: 17 Imported by: 0

README ΒΆ

Cherri

Cherri

macOS Build Releases Go License Platform GoDoc Go Report Card

Cherri (pronounced cherry) is a iOS Siri Shortcuts programming language, that compiles directly to a valid runnable Shortcut.

Hello World Example

🌟 Top Features
  • πŸŽ“ Easy to learn and syntax similar to other languages
  • 🐞 1-1 translation to Shortcut actions as much as possible to make debugging easier
  • πŸͺ„ No magic variables syntax, they're constants instead
  • πŸͺΆ Optimized to create small as possible Shortcuts and reduces memory usage at runtime
  • #️⃣ Include files within each other for large Shortcut projects
  • πŸ”§ Define your own custom actions to paste actions
  • πŸ₯© Enter actions raw with custom identifier and parameters
  • ❓ Define import questions
  • πŸ“‡ Generate VCards for menus
  • πŸ”’ Strongly statically typed with type inference
Learn more
πŸ“£ WIP πŸ“£

This project has not yet reached a stable version. It is under heavy development and backward incompatible changes may be made.

Usage

cherri file.cherri

Run 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.

Why macOS only?

Generating valid Shortcuts is only possible on macOS. However, I am hoping to add a signing server to the web editor that will turn out valid Shortcuts on any platform with a web browser.

Development on other platforms

As it stands, I don't want someone to get confused and think Shortcuts compiled using Cherri on other platforms will run on their Mac or iOS device. However, you can build the compiler for your platform, it will just skip signing the compiled Shortcut, so it will not run on iOS 15+ or macOS 12+. Also, note that the compiler is primarily developed and tested on Unix-like systems.

Read my full thoughts on this

Why another Shortcuts language?

Because it's fun :)

Some languages have been abandoned, don't work very well, or no longer work. I don't want Shortcuts languages to die. There should be more, not less.

Some stability comes with the project being on macOS and not iOS.

Community

Credits

Reference
Inspiration

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 Oct 5, 2022.

Documentation ΒΆ

The Go Gopher

There is no documentation for this package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL