require "guard/notifiers/base" module Guard module Notifier # Send a notification to Emacs with emacsclient # (http://www.emacswiki.org/emacs/EmacsClient). # # @example Add the `:emacs` notifier to your `Guardfile` # notification :emacs # class Emacs < Base DEFAULTS = { client: "emacsclient", success: "ForestGreen", failed: "Firebrick", default: "Black", fontcolor: "White", } def self.available?(opts = {}) return false unless super client_name = opts.fetch(:client, DEFAULTS[:client]) cmd = "#{client_name} --eval '1' 2> #{DEV_NULL} || echo 'N/A'" stdout = Sheller.stdout(cmd) return false if stdout.nil? !%w(N/A 'N/A').include?(stdout.chomp) end # Shows a system notification. # # @param [String] type the notification type. Either 'success', # 'pending', 'failed' or 'notify' # @param [String] title the notification title # @param [String] message the notification message body # @param [String] image the path to the notification image # @param [Hash] opts additional notification library options # @option opts [String] success the color to use for success # notifications (default is 'ForestGreen') # @option opts [String] failed the color to use for failure # notifications (default is 'Firebrick') # @option opts [String] pending the color to use for pending # notifications # @option opts [String] default the default color to use (default is # 'Black') # @option opts [String] client the client to use for notification # (default is 'emacsclient') # @option opts [String, Integer] priority specify an int or named key # (default is 0) # def notify(message, opts = {}) super opts = DEFAULTS.merge(opts) color = emacs_color(opts[:type], opts) fontcolor = emacs_color(:fontcolor, opts) elisp = <<-EOF.gsub(/\s+/, " ").strip (set-face-attribute 'mode-line nil :background "#{color}" :foreground "#{fontcolor}") EOF _run_cmd(opts[:client], "--eval", elisp) end # Get the Emacs color for the notification type. # You can configure your own color by overwrite the defaults. # # @param [String] type the notification type # @param [Hash] options aditional notification options # # @option options [String] success the color to use for success # notifications (default is 'ForestGreen') # # @option options [String] failed the color to use for failure # notifications (default is 'Firebrick') # # @option options [String] pending the color to use for pending # notifications # # @option options [String] default the default color to use (default is # 'Black') # # @return [String] the name of the emacs color # def emacs_color(type, options = {}) default = options.fetch(:default, DEFAULTS[:default]) options.fetch(type.to_sym, default) end private def _run_cmd(cmd, *args) Sheller.run(cmd, *args) end end end end