• Stars
    star
    337
  • Rank 125,272 (Top 3 %)
  • Language
    Go
  • License
    MIT License
  • Created almost 10 years ago
  • Updated about 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Mack — Golang wrapper for AppleScript

Mack

Mack is a Golang wrapper for AppleScript. With Mack, you can easily trigger OS X desktop notifications and system sounds from within your Go application.

Installation

Mack requires OS X.

go get github.com/andybrewer/mack

Usage

Mack is ideal for local workflow optimization, OS X binary applications, or just spicing things up. For example:

Workflow: Process notification

When executing a long-running process, trigger a notification so you can get back to development without having to check the execution status.

package main

import "github.com/andybrewer/mack"

func main() {
  mack.Say("Starting process")
  // do stuff
  mack.Notify("Complete")
}

Workflow: Open applications

Interact with any Mac application from your code, like opening a URL to a HowTo video.

package main

import (
  "github.com/andybrewer/mack"
)

func main() {
  browsers := []string{"Some new browser", "Google Chrome", "Firefox", "Safari"}
  opened := false

  for _, browser := range browsers {
    _, err := mack.Tell(browser, `open location "http://youtube.com/my-howto-video"`)
    if err != nil {
      // handle error
    } else {
      // exit when we found a browser that works
      opened = true
      break
    }
  }

  if !opened {
    // alert user that a common browser could not be found
  }
}

App: ToDo list

Add a cheap GUI to your applications

package main

import "github.com/andybrewer/mack"

func main() {
  response, err := mack.Dialog("Enter a ToDo", "ToDo Wizard", "My new ToDo")
  if err != nil {
    panic(err)
  }

  if response.Clicked == "Cancel" {
    // handle the Cancel event
  } else {
    newToDo := response.Text
    // add ToDo to the database
    mack.Notify("Added " + newToDo + " to your calendar")
  }
}

Workflow: clipboard

Manipulate the clipboard

package main

import (
  "fmt"
  "github.com/andybrewer/mack"
)

func main() {
  // Output the content of the clipboard
  content, _ := mack.Clipboard()
  fmt.Println(content)

  // Change the content of the clipboard
  mack.SetClipboard("Hello World!")
  content, _ = mack.Clipboard()
  fmt.Println(content)
}

Documentation

Currently, Mack supports the following AppleScript commands:

  • Beep
  • Clipboard
  • Display Alert
  • Display Dialog
  • Display Notification
  • Say
  • Tell

Full documentation is available at: godoc.org/github.com/andybrewer/mack

Links

Contributors

License

MIT