
Allow XCode without the Command Line Tools to work with homebrew, so it's not necessary to register an Apple Dev ID and/or go to the XCode prefs and download the CLT. Yay! Further, this commit allows to use the CLT solely (without the need for XCode). Saves quite some megs. (Some furmulae require xcodebuild) Of course XCode together with the CLT is still fine and has been tested on 10.7 and 10.6 with Xcode 4 and Xcode 3. Only on Lion or above, tell the user about the options, which are - Xcode without CLT - CLT without Xcode - both (ok, it's not directly stated, but implicit) So if no Xcode is found and we are on Lion or above, we don't fail but check for the CLTs now. For older Macs, the old message that Xcode is needed and the installer should be run is still displayed. If the CLT are not found but Xcode is, then we print out about the experimental status of this setup. Closes Homebrew/homebrew#10510. Signed-off-by: Adam Vandenberg <flangy@gmail.com>
88 lines
2.4 KiB
Ruby
88 lines
2.4 KiB
Ruby
class Cleaner
|
|
def initialize f
|
|
@f = Formula.factory f
|
|
[f.bin, f.sbin, f.lib].select{ |d| d.exist? }.each{ |d| clean_dir d }
|
|
|
|
if ENV['HOMEBREW_KEEP_INFO']
|
|
# Get rid of the directory file, so it no longer bother us at link stage.
|
|
info_dir_file = f.info + 'dir'
|
|
if info_dir_file.file? and not f.skip_clean? info_dir_file
|
|
puts "rm #{info_dir_file}" if ARGV.verbose?
|
|
info_dir_file.unlink
|
|
end
|
|
else
|
|
f.info.rmtree if f.info.directory? and not f.skip_clean? f.info
|
|
end
|
|
|
|
# Hunt for empty folders and nuke them unless they are protected by
|
|
# f.skip_clean? We want post-order traversal, so put the dirs in a stack
|
|
# and then pop them off later.
|
|
paths = []
|
|
f.prefix.find do |path|
|
|
paths << path if path.directory?
|
|
end
|
|
|
|
paths.each do |d|
|
|
if d.children.empty? and not f.skip_clean? d
|
|
puts "rmdir: #{d} (empty)" if ARGV.verbose?
|
|
d.rmdir
|
|
end
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def strip path, args=''
|
|
return if @f.skip_clean? path
|
|
puts "strip #{path}" if ARGV.verbose?
|
|
path.chmod 0644 # so we can strip
|
|
unless path.stat.nlink > 1
|
|
system "#{MacOS.locate('strip')}", *(args+path)
|
|
else
|
|
path = path.to_s.gsub ' ', '\\ '
|
|
|
|
# strip unlinks the file and recreates it, thus breaking hard links!
|
|
# is this expected behaviour? patch does it too… still, this fixes it
|
|
tmp = `/usr/bin/mktemp -t homebrew_strip`.chomp
|
|
begin
|
|
`#{MacOS.locate('strip')} #{args} -o #{tmp} #{path}`
|
|
`/bin/cat #{tmp} > #{path}`
|
|
ensure
|
|
FileUtils.rm tmp
|
|
end
|
|
end
|
|
end
|
|
|
|
def clean_file path
|
|
perms = 0444
|
|
if path.dylib?
|
|
# Stripping libraries is causing no end of trouble. Lets just give up,
|
|
# and try to do it manually in instances where it makes sense.
|
|
#strip path, '-SxX'
|
|
elsif path.mach_o_executable?
|
|
strip path
|
|
perms = 0555
|
|
elsif path.text_executable?
|
|
perms = 0555
|
|
end
|
|
path.chmod perms
|
|
end
|
|
|
|
def clean_dir d
|
|
d.find do |path|
|
|
if path.directory?
|
|
Find.prune if @f.skip_clean? path
|
|
elsif not path.file?
|
|
next
|
|
elsif path.extname == '.la'
|
|
# *.la files are stupid
|
|
path.unlink unless @f.skip_clean? path
|
|
elsif path == @f.lib+'charset.alias'
|
|
path.unlink unless @f.skip_clean? path
|
|
elsif not path.symlink?
|
|
clean_file path
|
|
end
|
|
end
|
|
end
|
|
end
|