Some subdirs and renames to aid homebrew n00bs
The classes better reflect their contents. I'm sure this change may be contentious, but I am a sucker for trying to create source bases that are easy to get to grips with and easy to navigate. brewkit.rb is now a deprecated file.
This commit is contained in:
parent
6ad2907000
commit
543a113712
@ -1,224 +1,4 @@
|
|||||||
# Copyright 2009 Max Howell and other contributors.
|
require 'utils'
|
||||||
#
|
opoo "brewkit.rb is deprecated please require 'formula' instead"
|
||||||
# Redistribution and use in source and binary forms, with or without
|
puts "This file will be removed at version 0.7"
|
||||||
# modification, are permitted provided that the following conditions
|
require 'formula'
|
||||||
# are met:
|
|
||||||
#
|
|
||||||
# 1. Redistributions of source code must retain the above copyright
|
|
||||||
# notice, this list of conditions and the following disclaimer.
|
|
||||||
# 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
# notice, this list of conditions and the following disclaimer in the
|
|
||||||
# documentation and/or other materials provided with the distribution.
|
|
||||||
#
|
|
||||||
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
||||||
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
||||||
# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
||||||
# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
||||||
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
||||||
# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
||||||
# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
#
|
|
||||||
|
|
||||||
# TODO
|
|
||||||
# 1. Indeed, there should be an option to build 32 or 64 bit binaries
|
|
||||||
# 2. Homebrew will not support building 32 and 64 bit lipo'd binaries, I
|
|
||||||
# want to, but the simple fact is it is difficult to force most of the
|
|
||||||
# build systems we support to do it.
|
|
||||||
|
|
||||||
|
|
||||||
ENV['MACOSX_DEPLOYMENT_TARGET']=MACOS_VERSION.to_s
|
|
||||||
|
|
||||||
unless HOMEBREW_PREFIX.to_s == '/usr/local'
|
|
||||||
# /usr/local is always in the build system path so only add other paths
|
|
||||||
ENV['CPPFLAGS'] = "-I#{HOMEBREW_PREFIX}/include"
|
|
||||||
ENV['LDFLAGS'] = "-L#{HOMEBREW_PREFIX}/lib"
|
|
||||||
else
|
|
||||||
# ignore existing build vars, thus we should have less bugs to deal with
|
|
||||||
ENV['CPPFLAGS'] = ''
|
|
||||||
ENV['LDFLAGS'] = ''
|
|
||||||
end
|
|
||||||
|
|
||||||
if MACOS_VERSION >= 10.6 or ENV['HOMEBREW_USE_LLVM']
|
|
||||||
# you can install Xcode wherever you like you know.
|
|
||||||
prefix = `/usr/bin/xcode-select -print-path`.chomp
|
|
||||||
prefix = "/Developer" if prefix.to_s.empty?
|
|
||||||
|
|
||||||
ENV['CC'] = "#{prefix}/usr/llvm-gcc-4.2/bin/llvm-gcc-4.2"
|
|
||||||
ENV['CXX'] = "#{prefix}/usr/llvm-gcc-4.2/bin/llvm-g++-4.2"
|
|
||||||
cflags = ['-O4'] # O4 baby!
|
|
||||||
else
|
|
||||||
ENV['CC']="gcc-4.2"
|
|
||||||
ENV['CXX']="g++-4.2"
|
|
||||||
cflags = ['-O3']
|
|
||||||
end
|
|
||||||
# in rare cases this may break your builds, as the tool for some reason wants
|
|
||||||
# to use a specific linker, however doing this in general causes formula to
|
|
||||||
# build more successfully because we are changing CC and many build systems
|
|
||||||
# don't react properly to that
|
|
||||||
ENV['LD']=ENV['CC']
|
|
||||||
|
|
||||||
# optimise all the way to eleven, references:
|
|
||||||
# http://en.gentoo-wiki.com/wiki/Safe_Cflags/Intel
|
|
||||||
# http://forums.mozillazine.org/viewtopic.php?f=12&t=577299
|
|
||||||
# http://gcc.gnu.org/onlinedocs/gcc-4.2.1/gcc/i386-and-x86_002d64-Options.html
|
|
||||||
if MACOS_VERSION >= 10.6
|
|
||||||
case Hardware.intel_family
|
|
||||||
when :penryn, :core2
|
|
||||||
# no need to add -mfpmath it happens automatically with 64 bit compiles
|
|
||||||
cflags << "-march=core2"
|
|
||||||
when :core
|
|
||||||
cflags<<"-march=prescott"<<"-mfpmath=sse"
|
|
||||||
end
|
|
||||||
else
|
|
||||||
case Hardware.intel_family
|
|
||||||
when :penryn, :core2
|
|
||||||
cflags<<"-march=nocona"
|
|
||||||
when :core
|
|
||||||
cflags<<"-march=prescott"
|
|
||||||
end
|
|
||||||
cflags<<"-mfpmath=sse"
|
|
||||||
end
|
|
||||||
cflags<<"-mmmx"
|
|
||||||
case Hardware.intel_family
|
|
||||||
when :nehalem
|
|
||||||
cflags<<"-msse4.2"
|
|
||||||
when :penryn
|
|
||||||
cflags<<"-msse4.1"
|
|
||||||
when :core2, :core
|
|
||||||
cflags<<"-msse3"
|
|
||||||
end
|
|
||||||
|
|
||||||
# -w: keep signal to noise high
|
|
||||||
# -fomit-frame-pointer: we are not debugging this software, we are using it
|
|
||||||
BREWKIT_SAFE_FLAGS="-w -pipe -fomit-frame-pointer -mmacosx-version-min=#{MACOS_VERSION}"
|
|
||||||
ENV['CFLAGS']=ENV['CXXFLAGS']="#{cflags*' '} #{BREWKIT_SAFE_FLAGS}"
|
|
||||||
|
|
||||||
# compile faster
|
|
||||||
ENV['MAKEFLAGS']="-j#{Hardware.processor_count}"
|
|
||||||
|
|
||||||
|
|
||||||
# you can use these functions for packages that have build issues
|
|
||||||
module HomebrewEnvExtension
|
|
||||||
def deparallelize
|
|
||||||
remove 'MAKEFLAGS', /-j\d+/
|
|
||||||
end
|
|
||||||
alias_method :j1, :deparallelize
|
|
||||||
def gcc_4_0_1
|
|
||||||
case MACOS_VERSION
|
|
||||||
when 10.5
|
|
||||||
self['CC']=nil
|
|
||||||
self['CXX']=nil
|
|
||||||
self['LD']=nil
|
|
||||||
when 10.6..11.0
|
|
||||||
self['CC']='gcc-4.0'
|
|
||||||
self['CXX']='g++-4.0'
|
|
||||||
self['LD']=self['CC']
|
|
||||||
remove_from_cflags '-march=core2'
|
|
||||||
self.O3
|
|
||||||
end
|
|
||||||
remove_from_cflags '-msse4.1'
|
|
||||||
remove_from_cflags '-msse4.2'
|
|
||||||
end
|
|
||||||
def O3
|
|
||||||
# Sometimes O4 just takes fucking forever
|
|
||||||
remove_from_cflags '-O4'
|
|
||||||
append_to_cflags '-O3'
|
|
||||||
end
|
|
||||||
def O2
|
|
||||||
# Sometimes O3 doesn't work or produces bad binaries
|
|
||||||
remove_from_cflags '-O4'
|
|
||||||
remove_from_cflags '-O3'
|
|
||||||
append_to_cflags '-O2'
|
|
||||||
end
|
|
||||||
def gcc_4_2
|
|
||||||
# Sometimes you want to downgrade from LLVM to GCC 4.2
|
|
||||||
self['CC']="gcc-4.2"
|
|
||||||
self['CXX']="g++-4.2"
|
|
||||||
self['LD']=self['CC']
|
|
||||||
self.O3
|
|
||||||
end
|
|
||||||
def osx_10_4
|
|
||||||
self['MACOSX_DEPLOYMENT_TARGET']=nil
|
|
||||||
remove_from_cflags(/ ?-mmacosx-version-min=10\.\d/)
|
|
||||||
end
|
|
||||||
def minimal_optimization
|
|
||||||
self['CFLAGS']=self['CXXFLAGS']="-Os #{BREWKIT_SAFE_FLAGS}"
|
|
||||||
end
|
|
||||||
def no_optimization
|
|
||||||
self['CFLAGS']=self['CXXFLAGS']=BREWKIT_SAFE_FLAGS
|
|
||||||
end
|
|
||||||
def libxml2
|
|
||||||
append_to_cflags ' -I/usr/include/libxml2'
|
|
||||||
end
|
|
||||||
def x11
|
|
||||||
# CPPFLAGS are the C-PreProcessor flags, *not* C++!
|
|
||||||
append 'CPPFLAGS', '-I/usr/X11R6/include'
|
|
||||||
append 'LDFLAGS', '-L/usr/X11R6/lib'
|
|
||||||
end
|
|
||||||
alias_method :libpng, :x11
|
|
||||||
# we've seen some packages fail to build when warnings are disabled!
|
|
||||||
def enable_warnings
|
|
||||||
remove_from_cflags '-w'
|
|
||||||
end
|
|
||||||
# Snow Leopard defines an NCURSES value the opposite of most distros
|
|
||||||
# See: http://bugs.python.org/issue6848
|
|
||||||
def ncurses_define
|
|
||||||
append 'CPPFLAGS', "-DNCURSES_OPAQUE=0"
|
|
||||||
end
|
|
||||||
# returns the compiler we're using
|
|
||||||
def cc
|
|
||||||
ENV['CC'] or "gcc"
|
|
||||||
end
|
|
||||||
def cxx
|
|
||||||
ENV['cxx'] or "g++"
|
|
||||||
end
|
|
||||||
# in case you need it
|
|
||||||
def m64
|
|
||||||
append_to_cflags '-m64'
|
|
||||||
ENV['LDFLAGS'] += '-arch x86_64'
|
|
||||||
end
|
|
||||||
|
|
||||||
private
|
|
||||||
def append key, value
|
|
||||||
ref=self[key]
|
|
||||||
if ref.nil? or ref.empty?
|
|
||||||
self[key]=value
|
|
||||||
else
|
|
||||||
self[key]=ref+' '+value
|
|
||||||
end
|
|
||||||
end
|
|
||||||
def append_to_cflags f
|
|
||||||
append 'CFLAGS', f
|
|
||||||
append 'CXXFLAGS', f
|
|
||||||
end
|
|
||||||
def remove key, value
|
|
||||||
return if self[key].nil?
|
|
||||||
self[key]=self[key].sub value, '' # can't use sub! on ENV
|
|
||||||
self[key]=nil if self[key].empty? # keep things clean
|
|
||||||
end
|
|
||||||
def remove_from_cflags f
|
|
||||||
remove 'CFLAGS', f
|
|
||||||
remove 'CXXFLAGS', f
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
ENV.extend HomebrewEnvExtension
|
|
||||||
|
|
||||||
|
|
||||||
# Clear CDPATH to avoid make issues that depend on changing directories
|
|
||||||
ENV.delete('CDPATH')
|
|
||||||
|
|
||||||
def inreplace(path, before, after)
|
|
||||||
before=Regexp.escape before.to_s
|
|
||||||
before.gsub! "/", "\\/" # I guess not escaped as delimiter varies
|
|
||||||
after=after.to_s
|
|
||||||
after.gsub! "\\", "\\\\"
|
|
||||||
after.gsub! "/", "\\/"
|
|
||||||
after.gsub! "$", "\\$"
|
|
||||||
|
|
||||||
# FIXME use proper Ruby for teh exceptions!
|
|
||||||
safe_system "/usr/bin/perl", "-pi", "-e", "s/#{before}/#{after}/g", path
|
|
||||||
end
|
|
||||||
|
@ -114,5 +114,3 @@ private
|
|||||||
end
|
end
|
||||||
|
|
||||||
class UsageError <RuntimeError; end
|
class UsageError <RuntimeError; end
|
||||||
|
|
||||||
ARGV.extend HomebrewArgvExtension
|
|
207
Library/Homebrew/extend/ENV.rb
Normal file
207
Library/Homebrew/extend/ENV.rb
Normal file
@ -0,0 +1,207 @@
|
|||||||
|
# Copyright 2009 Max Howell and other contributors.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions
|
||||||
|
# are met:
|
||||||
|
#
|
||||||
|
# 1. Redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer.
|
||||||
|
# 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
||||||
|
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||||
|
# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||||
|
# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
|
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||||||
|
# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
||||||
|
# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
#
|
||||||
|
|
||||||
|
module HomebrewEnvExtension
|
||||||
|
# -w: keep signal to noise high
|
||||||
|
# -fomit-frame-pointer: we are not debugging this software, we are using it
|
||||||
|
SAFE_CFLAGS_FLAGS = "-w -pipe -fomit-frame-pointer -mmacosx-version-min=#{MACOS_VERSION}"
|
||||||
|
|
||||||
|
def setup_build_environment
|
||||||
|
# Clear CDPATH to avoid make issues that depend on changing directories
|
||||||
|
ENV.delete('CDPATH')
|
||||||
|
|
||||||
|
ENV['MACOSX_DEPLOYMENT_TARGET']=MACOS_VERSION.to_s
|
||||||
|
ENV['MAKEFLAGS']="-j#{Hardware.processor_count}"
|
||||||
|
|
||||||
|
unless HOMEBREW_PREFIX.to_s == '/usr/local'
|
||||||
|
# /usr/local is always in the build system path so only add other paths
|
||||||
|
ENV['CPPFLAGS'] = "-I#{HOMEBREW_PREFIX}/include"
|
||||||
|
ENV['LDFLAGS'] = "-L#{HOMEBREW_PREFIX}/lib"
|
||||||
|
else
|
||||||
|
# ignore existing build vars, thus we should have less bugs to deal with
|
||||||
|
ENV['CPPFLAGS'] = ''
|
||||||
|
ENV['LDFLAGS'] = ''
|
||||||
|
end
|
||||||
|
|
||||||
|
if MACOS_VERSION >= 10.6 or ENV['HOMEBREW_USE_LLVM']
|
||||||
|
# you can install Xcode wherever you like you know.
|
||||||
|
prefix = `/usr/bin/xcode-select -print-path`.chomp
|
||||||
|
prefix = "/Developer" if prefix.to_s.empty?
|
||||||
|
|
||||||
|
ENV['CC'] = "#{prefix}/usr/llvm-gcc-4.2/bin/llvm-gcc-4.2"
|
||||||
|
ENV['CXX'] = "#{prefix}/usr/llvm-gcc-4.2/bin/llvm-g++-4.2"
|
||||||
|
cflags = ['-O4'] # O4 baby!
|
||||||
|
else
|
||||||
|
ENV['CC']="gcc-4.2"
|
||||||
|
ENV['CXX']="g++-4.2"
|
||||||
|
cflags = ['-O3']
|
||||||
|
end
|
||||||
|
# in rare cases this may break your builds, as the tool for some reason wants
|
||||||
|
# to use a specific linker, however doing this in general causes formula to
|
||||||
|
# build more successfully because we are changing CC and many build systems
|
||||||
|
# don't react properly to that
|
||||||
|
ENV['LD']=ENV['CC']
|
||||||
|
|
||||||
|
# optimise all the way to eleven, references:
|
||||||
|
# http://en.gentoo-wiki.com/wiki/Safe_Cflags/Intel
|
||||||
|
# http://forums.mozillazine.org/viewtopic.php?f=12&t=577299
|
||||||
|
# http://gcc.gnu.org/onlinedocs/gcc-4.2.1/gcc/i386-and-x86_002d64-Options.html
|
||||||
|
if MACOS_VERSION >= 10.6
|
||||||
|
case Hardware.intel_family
|
||||||
|
when :penryn, :core2
|
||||||
|
# no need to add -mfpmath it happens automatically with 64 bit compiles
|
||||||
|
cflags << "-march=core2"
|
||||||
|
when :core
|
||||||
|
cflags<<"-march=prescott"<<"-mfpmath=sse"
|
||||||
|
end
|
||||||
|
else
|
||||||
|
case Hardware.intel_family
|
||||||
|
when :penryn, :core2
|
||||||
|
cflags<<"-march=nocona"
|
||||||
|
when :core
|
||||||
|
cflags<<"-march=prescott"
|
||||||
|
end
|
||||||
|
cflags<<"-mfpmath=sse"
|
||||||
|
end
|
||||||
|
cflags<<"-mmmx"
|
||||||
|
case Hardware.intel_family
|
||||||
|
when :nehalem
|
||||||
|
cflags<<"-msse4.2"
|
||||||
|
when :penryn
|
||||||
|
cflags<<"-msse4.1"
|
||||||
|
when :core2, :core
|
||||||
|
cflags<<"-msse3"
|
||||||
|
end
|
||||||
|
|
||||||
|
ENV['CFLAGS']=ENV['CXXFLAGS']="#{cflags*' '} #{SAFE_CFLAGS_FLAGS}"
|
||||||
|
end
|
||||||
|
|
||||||
|
def deparallelize
|
||||||
|
remove 'MAKEFLAGS', /-j\d+/
|
||||||
|
end
|
||||||
|
alias_method :j1, :deparallelize
|
||||||
|
def gcc_4_0_1
|
||||||
|
case MACOS_VERSION
|
||||||
|
when 10.5
|
||||||
|
self['CC']=nil
|
||||||
|
self['CXX']=nil
|
||||||
|
self['LD']=nil
|
||||||
|
when 10.6..11.0
|
||||||
|
self['CC']='gcc-4.0'
|
||||||
|
self['CXX']='g++-4.0'
|
||||||
|
self['LD']=self['CC']
|
||||||
|
remove_from_cflags '-march=core2'
|
||||||
|
self.O3
|
||||||
|
end
|
||||||
|
remove_from_cflags '-msse4.1'
|
||||||
|
remove_from_cflags '-msse4.2'
|
||||||
|
end
|
||||||
|
def O3
|
||||||
|
# Sometimes O4 just takes fucking forever
|
||||||
|
remove_from_cflags '-O4'
|
||||||
|
append_to_cflags '-O3'
|
||||||
|
end
|
||||||
|
def O2
|
||||||
|
# Sometimes O3 doesn't work or produces bad binaries
|
||||||
|
remove_from_cflags '-O4'
|
||||||
|
remove_from_cflags '-O3'
|
||||||
|
append_to_cflags '-O2'
|
||||||
|
end
|
||||||
|
def gcc_4_2
|
||||||
|
# Sometimes you want to downgrade from LLVM to GCC 4.2
|
||||||
|
self['CC']="gcc-4.2"
|
||||||
|
self['CXX']="g++-4.2"
|
||||||
|
self['LD']=self['CC']
|
||||||
|
self.O3
|
||||||
|
end
|
||||||
|
def osx_10_4
|
||||||
|
self['MACOSX_DEPLOYMENT_TARGET']=nil
|
||||||
|
remove_from_cflags(/ ?-mmacosx-version-min=10\.\d/)
|
||||||
|
end
|
||||||
|
def minimal_optimization
|
||||||
|
self['CFLAGS']=self['CXXFLAGS']="-Os #{SAFE_CFLAGS_FLAGS}"
|
||||||
|
end
|
||||||
|
def no_optimization
|
||||||
|
self['CFLAGS']=self['CXXFLAGS'] = SAFE_CFLAGS_FLAGS
|
||||||
|
end
|
||||||
|
def libxml2
|
||||||
|
append_to_cflags ' -I/usr/include/libxml2'
|
||||||
|
end
|
||||||
|
def x11
|
||||||
|
# CPPFLAGS are the C-PreProcessor flags, *not* C++!
|
||||||
|
append 'CPPFLAGS', '-I/usr/X11R6/include'
|
||||||
|
append 'LDFLAGS', '-L/usr/X11R6/lib'
|
||||||
|
end
|
||||||
|
alias_method :libpng, :x11
|
||||||
|
# we've seen some packages fail to build when warnings are disabled!
|
||||||
|
def enable_warnings
|
||||||
|
remove_from_cflags '-w'
|
||||||
|
end
|
||||||
|
# Snow Leopard defines an NCURSES value the opposite of most distros
|
||||||
|
# See: http://bugs.python.org/issue6848
|
||||||
|
def ncurses_define
|
||||||
|
append 'CPPFLAGS', "-DNCURSES_OPAQUE=0"
|
||||||
|
end
|
||||||
|
# returns the compiler we're using
|
||||||
|
def cc
|
||||||
|
ENV['CC'] or "gcc"
|
||||||
|
end
|
||||||
|
def cxx
|
||||||
|
ENV['cxx'] or "g++"
|
||||||
|
end
|
||||||
|
# in case you need it
|
||||||
|
def m64
|
||||||
|
append_to_cflags '-m64'
|
||||||
|
ENV['LDFLAGS'] += '-arch x86_64'
|
||||||
|
end
|
||||||
|
|
||||||
|
def prepend key, value, separator = ' '
|
||||||
|
unless self[key].to_s.empty?
|
||||||
|
self[key] = value + separator + self[key]
|
||||||
|
else
|
||||||
|
self[key] = value
|
||||||
|
end
|
||||||
|
end
|
||||||
|
def append key, value
|
||||||
|
ref=self[key]
|
||||||
|
if ref.nil? or ref.empty?
|
||||||
|
self[key]=value
|
||||||
|
else
|
||||||
|
self[key]=ref+' '+value
|
||||||
|
end
|
||||||
|
end
|
||||||
|
def append_to_cflags f
|
||||||
|
append 'CFLAGS', f
|
||||||
|
append 'CXXFLAGS', f
|
||||||
|
end
|
||||||
|
def remove key, value
|
||||||
|
return if self[key].nil?
|
||||||
|
self[key]=self[key].sub value, '' # can't use sub! on ENV
|
||||||
|
self[key]=nil if self[key].empty? # keep things clean
|
||||||
|
end
|
||||||
|
def remove_from_cflags f
|
||||||
|
remove 'CFLAGS', f
|
||||||
|
remove 'CXXFLAGS', f
|
||||||
|
end
|
||||||
|
end
|
@ -21,11 +21,14 @@
|
|||||||
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
||||||
# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
#
|
#
|
||||||
require 'pathname+yeast'
|
require 'extend/pathname'
|
||||||
require 'ARGV+yeast'
|
require 'extend/ARGV'
|
||||||
require 'utils'
|
require 'utils'
|
||||||
require 'hardware'
|
require 'hardware'
|
||||||
|
|
||||||
|
ARGV.extend(HomebrewArgvExtension)
|
||||||
|
|
||||||
|
|
||||||
if Process.uid == 0
|
if Process.uid == 0
|
||||||
# technically this is not the correct place, this cache is for *all users*
|
# technically this is not the correct place, this cache is for *all users*
|
||||||
# so in that case, maybe we should always use it, root or not?
|
# so in that case, maybe we should always use it, root or not?
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
require 'global'
|
require 'global'
|
||||||
|
|
||||||
require 'brew.h'
|
require 'brew.h'
|
||||||
require 'brewkit'
|
require 'extend/ENV'
|
||||||
require 'fileutils'
|
require 'fileutils'
|
||||||
require 'formula'
|
require 'formula'
|
||||||
require 'hardware'
|
require 'hardware'
|
||||||
@ -31,30 +31,25 @@ EOS
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
def ENV_prepend key, value, separator = ' '
|
|
||||||
if ENV[key] and not ENV[key].empty?
|
|
||||||
ENV[key] = value+separator+ENV[key]
|
|
||||||
else
|
|
||||||
ENV[key] = value
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
def install f
|
def install f
|
||||||
|
# we deliberately only do this when install is run, although it may be the wrong decision…
|
||||||
|
ENV.extend(HomebrewEnvExtension)
|
||||||
|
ENV.setup_build_environment
|
||||||
|
|
||||||
f.deps.each do |dep|
|
f.deps.each do |dep|
|
||||||
dep = Formula.factory dep
|
dep = Formula.factory dep
|
||||||
if dep.keg_only?
|
if dep.keg_only?
|
||||||
ENV_prepend 'LDFLAGS', "-L#{dep.lib}"
|
ENV.prepend 'LDFLAGS', "-L#{dep.lib}"
|
||||||
ENV_prepend 'CPPFLAGS', "-I#{dep.include}"
|
ENV.prepend 'CPPFLAGS', "-I#{dep.include}"
|
||||||
ENV_prepend 'PATH', "#{dep.bin}", ':'
|
ENV.prepend 'PATH', "#{dep.bin}", ':'
|
||||||
ENV_prepend 'PKG_CONFIG_PATH', dep.lib+'pkgconfig', ':'
|
ENV.prepend 'PKG_CONFIG_PATH', dep.lib+'pkgconfig', ':'
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if ARGV.verbose?
|
if ARGV.verbose?
|
||||||
ohai "Build Environment"
|
ohai "Build Environment"
|
||||||
%w[PATH CFLAGS LDFLAGS CPPFLAGS MAKEFLAGS CC CXX MACOSX_DEPLOYMENT_TARGET].each do |f|
|
%w[PATH CFLAGS LDFLAGS CPPFLAGS MAKEFLAGS CC CXX MACOSX_DEPLOYMENT_TARGET].each do |env|
|
||||||
puts "#{f}: #{ENV[f]}" unless ENV[f].to_s.empty?
|
puts "#{env}: #{ENV[env]}" unless ENV[env].to_s.empty?
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -3,15 +3,12 @@
|
|||||||
# support, and with no warranty, express or implied, as to its usefulness for
|
# support, and with no warranty, express or implied, as to its usefulness for
|
||||||
# any purpose.
|
# any purpose.
|
||||||
|
|
||||||
$:.unshift File.dirname(__FILE__)
|
$:.unshift File.dirname(__FILE__)+'/..'
|
||||||
require 'test/unit'
|
require 'test/unit'
|
||||||
require 'global'
|
require 'global'
|
||||||
require 'pathname+yeast'
|
|
||||||
require 'formula'
|
require 'formula'
|
||||||
require 'utils'
|
require 'utils'
|
||||||
|
|
||||||
require 'ARGV+yeast' # needs to be after test/unit to avoid conflict with OptionsParser
|
|
||||||
|
|
||||||
|
|
||||||
# NOTE duplicated in unittest.rb (we need to refactor the tests anyway)
|
# NOTE duplicated in unittest.rb (we need to refactor the tests anyway)
|
||||||
def nostdout
|
def nostdout
|
@ -5,8 +5,10 @@
|
|||||||
|
|
||||||
ABS__FILE__=File.expand_path(__FILE__)
|
ABS__FILE__=File.expand_path(__FILE__)
|
||||||
|
|
||||||
$:.unshift File.dirname(ABS__FILE__)
|
$:.unshift File.dirname(ABS__FILE__)+'/..'
|
||||||
require 'pathname+yeast'
|
require 'extend/pathname'
|
||||||
|
require 'utils'
|
||||||
|
require 'hardware'
|
||||||
require 'formula'
|
require 'formula'
|
||||||
require 'download_strategy'
|
require 'download_strategy'
|
||||||
require 'keg'
|
require 'keg'
|
||||||
@ -29,7 +31,8 @@ Dir.chdir HOMEBREW_PREFIX
|
|||||||
at_exit { HOMEBREW_PREFIX.parent.rmtree }
|
at_exit { HOMEBREW_PREFIX.parent.rmtree }
|
||||||
|
|
||||||
require 'test/unit' # must be after at_exit
|
require 'test/unit' # must be after at_exit
|
||||||
require 'ARGV+yeast' # needs to be after test/unit to avoid conflict with OptionsParser
|
require 'extend/ARGV' # needs to be after test/unit to avoid conflict with OptionsParser
|
||||||
|
ARGV.extend(HomebrewArgvExtension)
|
||||||
|
|
||||||
|
|
||||||
class MockFormula <Formula
|
class MockFormula <Formula
|
@ -122,3 +122,17 @@ def arch_for_command cmd
|
|||||||
|
|
||||||
return archs
|
return archs
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
# replaces before with after for the file path
|
||||||
|
def inreplace path, before, after
|
||||||
|
before=Regexp.escape before.to_s
|
||||||
|
before.gsub! "/", "\\/" # I guess not escaped as delimiter varies
|
||||||
|
after=after.to_s
|
||||||
|
after.gsub! "\\", "\\\\"
|
||||||
|
after.gsub! "/", "\\/"
|
||||||
|
after.gsub! "$", "\\$"
|
||||||
|
|
||||||
|
# FIXME use proper Ruby for teh exceptions!
|
||||||
|
safe_system "/usr/bin/perl", "-pi", "-e", "s/#{before}/#{after}/g", path
|
||||||
|
end
|
||||||
|
3
bin/brew
3
bin/brew
@ -104,9 +104,6 @@ begin
|
|||||||
warn_about_macports_or_fink # keep warning before dependency resolution
|
warn_about_macports_or_fink # keep warning before dependency resolution
|
||||||
|
|
||||||
unless ARGV.force?
|
unless ARGV.force?
|
||||||
unless system "/usr/bin/which -s #{ENV.cc}"
|
|
||||||
raise "We cannot find a c compiler, have you installed the latest Xcode?"
|
|
||||||
end
|
|
||||||
formulae = ARGV.formulae.reject do |f|
|
formulae = ARGV.formulae.reject do |f|
|
||||||
if f.installed?
|
if f.installed?
|
||||||
message = "Formula already installed: #{f.prefix}"
|
message = "Formula already installed: #{f.prefix}"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user