aboutsummaryrefslogtreecommitdiffstats
path: root/Library
diff options
context:
space:
mode:
authorAlex Dunn2015-05-08 14:37:15 +0800
committerXu Cheng2015-05-08 14:37:15 +0800
commitdba9675ed37c98efebada330c562bc0410fb20aa (patch)
treef6da96ebe6defdeaa14fb8ae56dd332b539ffd41 /Library
parent8297810e3c4d5a15cb9b176f5a02a6023a6db7be (diff)
downloadbrew-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.rb1
-rw-r--r--Library/Homebrew/requirements.rb1
-rw-r--r--Library/Homebrew/requirements/emacs_requirement.rb30
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