You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1.7 KiB


scpt is an applescript-inspired scripting language written for fun and to see if I could.

Go Reference


scpt is to be used as a library imported into Go. A basic interpreter with no extra functionality would look like this:

package main

import (

func main() {
	filename := os.Args[1]
	file, err := os.Open(filepath.Clean(filename))
	if err != nil {
	ast, err := scpt.Parse(file)
	if err != nil {
	err = ast.Execute()
	if err != nil {

Basic Syntax

The basic syntax of scpt can be learned from the test.scpt file.

Default Functions

scpt comes with the following default functions:

  • str: Convert value to string
  • num: Parse string to number (float64)
  • bool: Parse string to boolean
  • break: Break out of loop (Errors if not in loop)
  • append: Return an array with given items appended
  • exit: Exit with given exit code
  • return: Return value in function (Errors if not within function)
  • print: Print using fmt.Println()

Adding functionality:

Adding functionality is simple and requires a call to scpt.AddFuncs() or scpt.AddVars(). Here are some examples:

	"my-function": myFunction

Where myFunction is:

func myFunction(args map[string]interface{}) (interface{}, error) {
	return nil, nil

After the call to scpt.AddFuncs(), my-function can be used to run the function from within an scpt script. Variables work similarly.