diff options
| author | Alex Dunn | 2015-05-08 14:37:15 +0800 |
|---|---|---|
| committer | Xu Cheng | 2015-05-08 14:37:15 +0800 |
| commit | dba9675ed37c98efebada330c562bc0410fb20aa (patch) | |
| tree | f6da96ebe6defdeaa14fb8ae56dd332b539ffd41 /Library | |
| parent | 8297810e3c4d5a15cb9b176f5a02a6023a6db7be (diff) | |
| download | brew-dba9675ed37c98efebada330c562bc0410fb20aa.tar.bz2 | |
add EmacsRequirement
Closes Homebrew/homebrew#39326.
Signed-off-by: Xu Cheng <xucheng@me.com>
Diffstat (limited to 'Library')
| -rw-r--r-- | Library/Homebrew/dependency_collector.rb | 1 | ||||
| -rw-r--r-- | Library/Homebrew/requirements.rb | 1 | ||||
| -rw-r--r-- | Library/Homebrew/requirements/emacs_requirement.rb | 30 |
3 files changed, 32 insertions, 0 deletions
diff --git a/Library/Homebrew/dependency_collector.rb b/Library/Homebrew/dependency_collector.rb index 5bd96cfff..0211015f7 100644 --- a/Library/Homebrew/dependency_collector.rb +++ b/Library/Homebrew/dependency_collector.rb @@ -121,6 +121,7 @@ class DependencyCollector when :tuntap then TuntapDependency.new(tags) when :ant then ant_dep(spec, tags) when :apr then AprDependency.new(tags) + when :emacs then EmacsRequirement.new(tags) # Tiger's ld is too old to properly link some software when :ld64 then LD64Dependency.new if MacOS.version < :leopard when :clt # deprecated diff --git a/Library/Homebrew/requirements.rb b/Library/Homebrew/requirements.rb index c53250fbc..269657e2e 100644 --- a/Library/Homebrew/requirements.rb +++ b/Library/Homebrew/requirements.rb @@ -12,6 +12,7 @@ require 'requirements/ruby_requirement' require 'requirements/tuntap_dependency' require 'requirements/unsigned_kext_requirement' require 'requirements/x11_dependency' +require 'requirements/emacs_requirement' class XcodeDependency < Requirement fatal true diff --git a/Library/Homebrew/requirements/emacs_requirement.rb b/Library/Homebrew/requirements/emacs_requirement.rb new file mode 100644 index 000000000..1da3ecd04 --- /dev/null +++ b/Library/Homebrew/requirements/emacs_requirement.rb @@ -0,0 +1,30 @@ +class EmacsRequirement < Requirement + fatal true + default_formula "emacs" + + def initialize(tags) + @version = tags.shift if /\d+\.*\d*/ === tags.first + raise "Specify a version for EmacsRequirement" unless @version + super + end + + satisfy :build_env => false do + next unless which "emacs" + emacs_version = Utils.popen_read("emacs", "--batch", "--eval", "(princ emacs-version)") + Version.new(emacs_version) >= Version.new(@version) + end + + env do + ENV.prepend_path "PATH", which("emacs").dirname + end + + def message + s = "Emacs #{@version} or later is required." + s += super + s + end + + def inspect + "#<#{self.class.name}: #{name.inspect} #{tags.inspect} version=#{@version.inspect}>" + end +end |
