mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
9b383bd6cf
string (e.g. ?x). * lib/tempfile.rb (Tempfile::make_tmpname): put dot between basename and pid. [ruby-talk:196272] * parse.y (do_block): remove -> style block. * parse.y (parser_yylex): remove tLAMBDA_ARG. * eval.c (rb_call0): binding for the return event hook should have consistent scope. [ruby-core:07928] * eval.c (proc_invoke): return behavior should depend whether it is surrounded by a lambda or a mere block. * eval.c (formal_assign): handles post splat arguments. * eval.c (rb_call0): ditto. * st.c (strhash): use FNV-1a hash. * parse.y (parser_yylex): removed experimental ';;' terminator. * eval.c (rb_node_arity): should be aware of post splat arguments. * eval.c (rb_proc_arity): ditto. * parse.y (f_args): syntax rule enhanced to support arguments after the splat. * parse.y (block_param): ditto for block parameters. * parse.y (f_post_arg): mandatory formal arguments after the splat argument. * parse.y (new_args_gen): generate nodes for mandatory formal arguments after the splat argument. * eval.c (rb_eval): dispatch mandatory formal arguments after the splat argument. * parse.y (args): allow more than one splat in the argument list. * parse.y (method_call): allow aref [] to accept all kind of method argument, including assocs, splat, and block argument. * eval.c (SETUP_ARGS0): prepare block argument as well. * lib/mathn.rb (Integer): remove Integer#gcd2. [ruby-core:07931] * eval.c (error_line): print receivers true/false/nil specially. * eval.c (rb_proc_yield): handles parameters in yield semantics. * eval.c (nil_yield): gives LocalJumpError to denote no block error. * io.c (rb_io_getc): now takes one-character string. * string.c (rb_str_hash): use FNV-1a hash from Fowler/Noll/Vo hashing algorithm. * string.c (rb_str_aref): str[0] now returns 1 character string, instead of a fixnum. [Ruby2] * parse.y (parser_yylex): ?c now returns 1 character string, instead of a fixnum. [Ruby2] * string.c (rb_str_aset): no longer support fixnum insertion. * eval.c (umethod_bind): should not update original class. [ruby-dev:28636] * eval.c (ev_const_get): should support constant access from within instance_eval(). [ruby-dev:28327] * time.c (time_timeval): should round for usec floating number. [ruby-core:07896] * time.c (time_add): ditto. * dir.c (sys_warning): should not call a vararg function rb_sys_warning() indirectly. [ruby-core:07886] * numeric.c (flo_divmod): the first element of Float#divmod should be an integer. [ruby-dev:28589] * test/ruby/test_float.rb: add tests for divmod, div, modulo and remainder. * re.c (rb_reg_initialize): should not allow modifying literal regexps. frozen check moved from rb_reg_initialize_m as well. * re.c (rb_reg_initialize): should not modify untainted objects in safe levels higher than 3. * re.c (rb_memcmp): type change from char* to const void*. * dir.c (dir_close): should not close untainted dir stream. * dir.c (GetDIR): add tainted/frozen check for each dir operation. * lib/rdoc/parsers/parse_rb.rb (RDoc::RubyParser::parse_symbol_arg): typo fixed. a patch from Florian Gross <florg at florg.net>. * eval.c (EXEC_EVENT_HOOK): trace_func may remove itself from event_hooks. no guarantee for arbitrary hook deletion. [ruby-dev:28632] * util.c (ruby_strtod): differ addition to minimize error. [ruby-dev:28619] * util.c (ruby_strtod): should not raise ERANGE when the input string does not have any digits. [ruby-dev:28629] * eval.c (proc_invoke): should restore old ruby_frame->block. thanks to ts <decoux at moulon.inra.fr>. [ruby-core:07833] also fix [ruby-dev:28614] as well. * signal.c (trap): sig should be less then NSIG. Coverity found this bug. a patch from Kevin Tew <tewk at tewk.com>. [ruby-core:07823] * math.c (math_log2): add new method inspired by [ruby-talk:191237]. * math.c (math_log): add optional base argument to Math::log(). [ruby-talk:191308] * ext/syck/emitter.c (syck_scan_scalar): avoid accessing uninitialized array element. a patch from Pat Eyler <rubypate at gmail.com>. [ruby-core:07809] * array.c (rb_ary_fill): initialize local variables first. a patch from Pat Eyler <rubypate at gmail.com>. [ruby-core:07810] * ext/syck/yaml2byte.c (syck_yaml2byte_handler): need to free type_tag. a patch from Pat Eyler <rubypate at gmail.com>. [ruby-core:07808] * ext/socket/socket.c (make_hostent_internal): accept ai_family check from Sam Roberts <sroberts at uniserve.com>. [ruby-core:07691] * util.c (ruby_strtod): should not cut off 18 digits for no reason. [ruby-core:07796] * array.c (rb_ary_fill): internalize local variable "beg" to pacify Coverity. [ruby-core:07770] * pack.c (pack_unpack): now supports CRLF newlines. a patch from <tommy at tmtm.org>. [ruby-dev:28601] * applied code clean-up patch from Stefan Huehner <stefan at huehner.org>. [ruby-core:07764] * lib/jcode.rb (String::tr_s): should have translated non squeezing character sequence (i.e. a character) as well. thanks to Hiroshi Ichikawa <gimite at gimite.ddo.jp> [ruby-list:42090] * ext/socket/socket.c: document update patch from Sam Roberts <sroberts at uniserve.com>. [ruby-core:07701] * lib/mathn.rb (Integer): need not to remove gcd2. a patch from NARUSE, Yui <naruse at airemix.com>. [ruby-dev:28570] * parse.y (arg): too much NEW_LIST() * eval.c (SETUP_ARGS0): remove unnecessary access to nd_alen. * eval.c (rb_eval): use ARGSCAT for NODE_OP_ASGN1. [ruby-dev:28585] * parse.y (arg): use NODE_ARGSCAT for placeholder. * lib/getoptlong.rb (GetoptLong::get): RDoc update patch from mathew <meta at pobox.com>. [ruby-core:07738] * variable.c (rb_const_set): raise error when no target klass is supplied. [ruby-dev:28582] * prec.c (prec_prec_f): documentation patch from <gerardo.santana at gmail.com>. [ruby-core:07689] * bignum.c (rb_big_pow): second operand may be too big even if it's a Fixnum. [ruby-talk:187984] * README.EXT: update symbol description. [ruby-talk:188104] * COPYING: explicitly note GPLv2. [ruby-talk:187922] * parse.y: remove some obsolete syntax rules (unparenthesized method calls in argument list). * eval.c (rb_call0): insecure calling should be checked for non NODE_SCOPE method invocations too. * eval.c (rb_alias): should preserve the current safe level as well as method definition. * process.c (rb_f_sleep): remove RDoc description about SIGALRM which is not valid on the current implementation. [ruby-dev:28464] Thu Mar 23 21:40:47 2006 K.Kosako <sndgk393 AT ybb.ne.jp> * eval.c (method_missing): should support argument splat in super. a bug in combination of super, splat and method_missing. [ruby-talk:185438] * configure.in: Solaris SunPro compiler -rapth patch from <kuwa at labs.fujitsu.com>. [ruby-dev:28443] * configure.in: remove enable_rpath=no for Solaris. [ruby-dev:28440] * ext/win32ole/win32ole.c (ole_val2olevariantdata): change behavior of converting OLE Variant object with VT_ARRAY|VT_UI1 and Ruby String object. * ruby.1: a clarification patch from David Lutterkort <dlutter at redhat.com>. [ruby-core:7508] * lib/rdoc/ri/ri_paths.rb (RI::Paths): adding paths from rubygems directories. a patch from Eric Hodel <drbrain at segment7.net>. [ruby-core:07423] * eval.c (rb_clear_cache_by_class): clearing wrong cache. * ext/extmk.rb: use :remove_destination to install extension libraries to avoid SEGV. [ruby-dev:28417] * eval.c (rb_thread_fd_writable): should not re-schedule output from KILLED thread (must be error printing). * array.c (rb_ary_flatten_bang): allow specifying recursion level. [ruby-talk:182170] * array.c (rb_ary_flatten): ditto. * gc.c (add_heap): a heap_slots may overflow. a patch from Stefan Weil <weil at mail.berlios.de>. * eval.c (rb_call): use separate cache for fcall/vcall invocation. * eval.c (rb_eval): NODE_FCALL, NODE_VCALL can call local functions. * eval.c (rb_mod_local): a new method to specify newly added visibility "local". * eval.c (search_method): search for local methods which are visible only from the current class. * class.c (rb_class_local_methods): a method to list local methods. * object.c (Init_Object): add BasicObject class as a top level BlankSlate class. * ruby.h (SYM2ID): should not cast to signed long. [ruby-core:07414] * class.c (rb_include_module): allow module duplication. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@10235 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
494 lines
12 KiB
Ruby
494 lines
12 KiB
Ruby
#! /usr/local/bin/ruby
|
|
# -*- ruby -*-
|
|
|
|
$force_static = nil
|
|
$install = nil
|
|
$destdir = nil
|
|
$clean = nil
|
|
$nodynamic = nil
|
|
$extinit = nil
|
|
$extobjs = nil
|
|
$ignore = nil
|
|
$message = nil
|
|
|
|
$progname = $0
|
|
alias $PROGRAM_NAME $0
|
|
alias $0 $progname
|
|
|
|
$extlist = []
|
|
$compiled = {}
|
|
|
|
$:.replace([Dir.pwd])
|
|
require 'rbconfig'
|
|
|
|
srcdir = File.dirname(File.dirname(__FILE__))
|
|
|
|
$:.unshift(srcdir, File.expand_path("lib", srcdir))
|
|
|
|
$topdir = "."
|
|
$top_srcdir = srcdir
|
|
|
|
require 'mkmf'
|
|
require 'optparse/shellwords'
|
|
|
|
def sysquote(x)
|
|
@quote ||= /human|os2|macos/ =~ (CROSS_COMPILING || RUBY_PLATFORM)
|
|
@quote ? x.quote : x
|
|
end
|
|
|
|
def relative_from(path, base)
|
|
dir = File.join(path, "")
|
|
if File.expand_path(dir) == File.expand_path(dir, base)
|
|
path
|
|
else
|
|
File.join(base, path)
|
|
end
|
|
end
|
|
|
|
def extract_makefile(makefile, keep = true)
|
|
m = File.read(makefile)
|
|
if !(target = m[/^TARGET[ \t]*=[ \t]*(\S*)/, 1])
|
|
return keep
|
|
end
|
|
installrb = {}
|
|
m.scan(/^install-rb-default:[ \t]*(\S+)\n\1:[ \t]*(\S+)/) {installrb[$2] = $1}
|
|
oldrb = installrb.keys.sort
|
|
newrb = install_rb(nil, "").collect {|d, *f| f}.flatten.sort
|
|
if target_prefix = m[/^target_prefix[ \t]*=[ \t]*\/(.*)/, 1]
|
|
target = "#{target_prefix}/#{target}"
|
|
end
|
|
unless oldrb == newrb
|
|
if $extout
|
|
newrb.each {|f| installrb.delete(f)}
|
|
unless installrb.empty?
|
|
config = CONFIG.dup
|
|
install_dirs(target_prefix).each {|var, val| config[var] = val}
|
|
FileUtils.rm_f(installrb.values.collect {|f| RbConfig.expand(f, config)}, verbose: true)
|
|
end
|
|
end
|
|
return false
|
|
end
|
|
$target = target
|
|
$extconf_h = m[/^RUBY_EXTCONF_H[ \t]*=[ \t]*(\S+)/, 1]
|
|
$static ||= m[/^EXTSTATIC[ \t]*=[ \t]*(\S+)/, 1] || false
|
|
/^STATIC_LIB[ \t]*=[ \t]*\S+/ =~ m or $static = nil
|
|
$preload = Shellwords.shellwords(m[/^preload[ \t]*=[ \t]*(.*)/, 1] || "")
|
|
$DLDFLAGS += " " + (m[/^DLDFLAGS[ \t]*=[ \t]*(.*)/, 1] || "")
|
|
if s = m[/^LIBS[ \t]*=[ \t]*(.*)/, 1]
|
|
s.sub!(/^#{Regexp.quote($LIBRUBYARG)} */, "")
|
|
s.sub!(/ *#{Regexp.quote($LIBS)}$/, "")
|
|
$libs = s
|
|
end
|
|
$LOCAL_LIBS = m[/^LOCAL_LIBS[ \t]*=[ \t]*(.*)/, 1] || ""
|
|
$LIBPATH = Shellwords.shellwords(m[/^libpath[ \t]*=[ \t]*(.*)/, 1] || "") - %w[$(libdir) $(topdir)]
|
|
true
|
|
end
|
|
|
|
def extmake(target)
|
|
print "#{$message} #{target}\n"
|
|
$stdout.flush
|
|
if $force_static or $static_ext[target]
|
|
$static = target
|
|
else
|
|
$static = false
|
|
end
|
|
|
|
unless $ignore
|
|
return true if $nodynamic and not $static
|
|
end
|
|
|
|
FileUtils.mkpath target unless File.directory?(target)
|
|
begin
|
|
dir = Dir.pwd
|
|
FileUtils.mkpath target unless File.directory?(target)
|
|
Dir.chdir target
|
|
top_srcdir = $top_srcdir
|
|
topdir = $topdir
|
|
mk_srcdir = CONFIG["srcdir"]
|
|
mk_topdir = CONFIG["topdir"]
|
|
prefix = "../" * (target.count("/")+1)
|
|
$hdrdir = $top_srcdir = relative_from(top_srcdir, prefix)
|
|
$topdir = prefix + $topdir
|
|
$target = target
|
|
$mdir = target
|
|
$srcdir = File.join($top_srcdir, "ext", $mdir)
|
|
$preload = nil
|
|
$compiled[target] = false
|
|
makefile = "./Makefile"
|
|
ok = File.exist?(makefile)
|
|
unless $ignore
|
|
RbConfig::CONFIG["hdrdir"] = $hdrdir
|
|
RbConfig::CONFIG["srcdir"] = $srcdir
|
|
RbConfig::CONFIG["topdir"] = $topdir
|
|
CONFIG["hdrdir"] = ($hdrdir == top_srcdir) ? top_srcdir : "$(topdir)"+top_srcdir[2..-1]
|
|
CONFIG["srcdir"] = "$(hdrdir)/ext/#{$mdir}"
|
|
CONFIG["topdir"] = $topdir
|
|
begin
|
|
$extconf_h = nil
|
|
ok &&= extract_makefile(makefile)
|
|
if (($extconf_h && !File.exist?($extconf_h)) ||
|
|
!(t = modified?(makefile, MTIMES)) ||
|
|
%W"#{$srcdir}/makefile.rb #{$srcdir}/extconf.rb #{$srcdir}/depend".any? {|f| modified?(f, [t])})
|
|
then
|
|
ok = false
|
|
init_mkmf
|
|
Logging::logfile 'mkmf.log'
|
|
rm_f makefile
|
|
if File.exist?($0 = "#{$srcdir}/makefile.rb")
|
|
load $0
|
|
elsif File.exist?($0 = "#{$srcdir}/extconf.rb")
|
|
load $0
|
|
else
|
|
create_makefile(target)
|
|
end
|
|
$defs << "-DRUBY_EXPORT" if $static
|
|
ok = File.exist?(makefile)
|
|
end
|
|
rescue SystemExit
|
|
# ignore
|
|
ensure
|
|
rm_f "conftest*"
|
|
config = $0
|
|
$0 = $PROGRAM_NAME
|
|
end
|
|
end
|
|
ok = yield(ok) if block_given?
|
|
unless ok
|
|
open(makefile, "w") do |f|
|
|
f.print dummy_makefile(CONFIG["srcdir"])
|
|
end
|
|
return true
|
|
end
|
|
args = sysquote($mflags)
|
|
unless $destdir.to_s.empty? or $mflags.include?("DESTDIR")
|
|
args += [sysquote("DESTDIR=" + relative_from($destdir, "../"+prefix))]
|
|
end
|
|
if $static
|
|
args += ["static"] unless $clean
|
|
$extlist.push [$static, $target, File.basename($target), $preload]
|
|
end
|
|
unless system($make, *args)
|
|
$ignore or $continue or return false
|
|
end
|
|
$compiled[target] = true
|
|
if $clean and $clean != true
|
|
File.unlink(makefile) rescue nil
|
|
end
|
|
if $static
|
|
$extflags ||= ""
|
|
$extlibs ||= []
|
|
$extpath ||= []
|
|
unless $mswin
|
|
$extflags = ($extflags.split | $DLDFLAGS.split | $LDFLAGS.split).join(" ")
|
|
end
|
|
$extlibs = merge_libs($extlibs, $libs.split, $LOCAL_LIBS.split)
|
|
$extpath |= $LIBPATH
|
|
end
|
|
ensure
|
|
RbConfig::CONFIG["srcdir"] = $top_srcdir
|
|
RbConfig::CONFIG["topdir"] = topdir
|
|
CONFIG["srcdir"] = mk_srcdir
|
|
CONFIG["topdir"] = mk_topdir
|
|
CONFIG.delete("hdrdir")
|
|
$hdrdir = $top_srcdir = top_srcdir
|
|
$topdir = topdir
|
|
Dir.chdir dir
|
|
end
|
|
begin
|
|
Dir.rmdir target
|
|
target = File.dirname(target)
|
|
rescue SystemCallError
|
|
break
|
|
end while true
|
|
true
|
|
end
|
|
|
|
def compiled?(target)
|
|
$compiled[target]
|
|
end
|
|
|
|
def parse_args()
|
|
$mflags = []
|
|
|
|
opts = nil
|
|
$optparser ||= OptionParser.new do |opts|
|
|
opts.on('-n') {$dryrun = true}
|
|
opts.on('--[no-]extension [EXTS]', Array) do |v|
|
|
$extension = (v == false ? [] : v)
|
|
end
|
|
opts.on('--[no-]extstatic [STATIC]', Array) do |v|
|
|
if ($extstatic = v) == false
|
|
$extstatic = []
|
|
elsif v
|
|
$force_static = true if $extstatic.delete("static")
|
|
$extstatic = nil if $extstatic.empty?
|
|
end
|
|
end
|
|
opts.on('--dest-dir=DIR') do |v|
|
|
$destdir = v
|
|
end
|
|
opts.on('--extout=DIR') do |v|
|
|
$extout = (v unless v.empty?)
|
|
end
|
|
opts.on('--make=MAKE') do |v|
|
|
$make = v || 'make'
|
|
end
|
|
opts.on('--make-flags=FLAGS', '--mflags', Shellwords) do |*v|
|
|
v.grep(/\A([-\w]+)=(.*)/) {$configure_args["--#{$1}"] = $2}
|
|
if arg = v.first
|
|
arg.insert(0, '-') if /\A[^-][^=]*\Z/ =~ arg
|
|
end
|
|
$mflags.concat(v)
|
|
end
|
|
opts.on('--message [MESSAGE]', String) do |v|
|
|
$message = v
|
|
end
|
|
end
|
|
begin
|
|
$optparser.parse!(ARGV)
|
|
rescue OptionParser::InvalidOption => e
|
|
retry if /^--/ =~ e.args[0]
|
|
$optparser.warn(e)
|
|
abort opts.to_s
|
|
end
|
|
|
|
$destdir ||= ''
|
|
|
|
$make, *rest = Shellwords.shellwords($make)
|
|
$mflags.unshift(*rest) unless rest.empty?
|
|
|
|
def $mflags.set?(flag)
|
|
grep(/\A-(?!-).*#{'%s' % flag}/i) { return true }
|
|
false
|
|
end
|
|
def $mflags.defined?(var)
|
|
grep(/\A#{var}=(.*)/) {return $1}
|
|
false
|
|
end
|
|
|
|
if $mflags.set?(?n)
|
|
$dryrun = true
|
|
else
|
|
$mflags.unshift '-n' if $dryrun
|
|
end
|
|
|
|
$continue = $mflags.set?(?k)
|
|
if $extout
|
|
$extout = '$(topdir)/'+$extout
|
|
$extout_prefix = $extout ? "$(extout)$(target_prefix)/" : ""
|
|
$mflags << "extout=#$extout" << "extout_prefix=#$extout_prefix"
|
|
end
|
|
end
|
|
|
|
parse_args()
|
|
|
|
if target = ARGV.shift and /^[a-z-]+$/ =~ target
|
|
$mflags.push(target)
|
|
target = target.sub(/^(dist|real)(?=(?:clean)?$)/, '')
|
|
case target
|
|
when /clean/
|
|
$ignore ||= true
|
|
$clean = $1 ? $1[0] : true
|
|
when /^install\b/
|
|
$install = true
|
|
$ignore ||= true
|
|
$mflags.unshift("INSTALL_PROG=install -c -p -m 0755",
|
|
"INSTALL_DATA=install -c -p -m 0644",
|
|
"MAKEDIRS=mkdir -p") if $dryrun
|
|
end
|
|
end
|
|
unless $message
|
|
if target
|
|
$message = target.sub(/^(\w+)e?\b/, '\1ing').tr('-', ' ')
|
|
else
|
|
$message = "compiling"
|
|
end
|
|
end
|
|
|
|
EXEEXT = CONFIG['EXEEXT']
|
|
if CROSS_COMPILING
|
|
$ruby = CONFIG['MINIRUBY']
|
|
elsif sep = config_string('BUILD_FILE_SEPARATOR')
|
|
$ruby = "$(topdir:/=#{sep})#{sep}miniruby" + EXEEXT
|
|
else
|
|
$ruby = '$(topdir)/miniruby' + EXEEXT
|
|
end
|
|
$ruby << " -I'$(topdir)' -I'$(hdrdir)/lib'"
|
|
$config_h = '$(topdir)/config.h'
|
|
|
|
MTIMES = [__FILE__, 'rbconfig.rb', srcdir+'/lib/mkmf.rb'].collect {|f| File.mtime(f)}
|
|
|
|
# get static-link modules
|
|
$static_ext = {}
|
|
if $extstatic
|
|
$extstatic.each do |target|
|
|
target = target.downcase if /mswin32|bccwin32/ =~ RUBY_PLATFORM
|
|
$static_ext[target] = $static_ext.size
|
|
end
|
|
end
|
|
for dir in ["ext", File::join($top_srcdir, "ext")]
|
|
setup = File::join(dir, CONFIG['setup'])
|
|
if File.file? setup
|
|
f = open(setup)
|
|
while line = f.gets()
|
|
line.chomp!
|
|
line.sub!(/#.*$/, '')
|
|
next if /^\s*$/ =~ line
|
|
target, opt = line.split(nil, 3)
|
|
if target == 'option'
|
|
case opt
|
|
when 'nodynamic'
|
|
$nodynamic = true
|
|
end
|
|
next
|
|
end
|
|
target = target.downcase if /mswin32|bccwin32/ =~ RUBY_PLATFORM
|
|
$static_ext[target] = $static_ext.size
|
|
end
|
|
MTIMES << f.mtime
|
|
$setup = setup
|
|
f.close
|
|
break
|
|
end
|
|
end unless $extstatic
|
|
|
|
ext_prefix = "#{$top_srcdir}/ext"
|
|
exts = $static_ext.sort_by {|t, i| i}.collect {|t, i| t}
|
|
if $extension
|
|
exts |= $extension.select {|d| File.directory?("#{ext_prefix}/#{d}")}
|
|
else
|
|
withes, withouts = %w[--with --without].collect {|w|
|
|
if not (w = %w[-extensions -ext].collect {|opt|arg_config(w+opt)}).any?
|
|
proc {false}
|
|
elsif (w = w.grep(String)).empty?
|
|
proc {true}
|
|
else
|
|
w.collect {|opt| opt.split(/,/)}.flatten.method(:any?)
|
|
end
|
|
}
|
|
cond = proc {|ext|
|
|
cond1 = proc {|n| File.fnmatch(n, ext, File::FNM_PATHNAME)}
|
|
withes.call(&cond1) or !withouts.call(&cond1)
|
|
}
|
|
exts |= Dir.glob("#{ext_prefix}/*/**/extconf.rb").collect {|d|
|
|
d = File.dirname(d)
|
|
d.slice!(0, ext_prefix.length + 1)
|
|
d
|
|
}.find_all {|ext|
|
|
with_config(ext, &cond)
|
|
}.sort
|
|
end
|
|
|
|
if $extout
|
|
RbConfig.expand(extout = "#$extout", RbConfig::CONFIG.merge("topdir"=>$topdir))
|
|
if $install
|
|
RbConfig.expand(dest = "#{$destdir}#{$rubylibdir}")
|
|
FileUtils.cp_r(extout+"/.", dest, :remove_destination => true, :verbose => true, :noop => $dryrun)
|
|
exit
|
|
end
|
|
unless $ignore
|
|
FileUtils.mkpath(extout)
|
|
end
|
|
end
|
|
|
|
dir = Dir.pwd
|
|
FileUtils::makedirs('ext')
|
|
Dir::chdir('ext')
|
|
|
|
$hdrdir = $top_srcdir = relative_from(srcdir, $topdir = "..")
|
|
exts.each do |d|
|
|
extmake(d) or abort
|
|
end
|
|
$hdrdir = $top_srcdir = srcdir
|
|
$topdir = "."
|
|
|
|
extinit = Struct.new(:c, :o) {
|
|
def initialize(src)
|
|
super("#{src}.c", "#{src}.#{$OBJEXT}")
|
|
end
|
|
}.new("extinit")
|
|
if $ignore
|
|
FileUtils.rm_f(extinit.to_a) if $clean
|
|
Dir.chdir ".."
|
|
if $clean
|
|
Dir.rmdir('ext') rescue nil
|
|
FileUtils.rm_rf(extout) if $extout
|
|
end
|
|
exit
|
|
end
|
|
|
|
if $extlist.size > 0
|
|
$extinit ||= ""
|
|
$extobjs ||= ""
|
|
list = $extlist.dup
|
|
built = []
|
|
while e = list.shift
|
|
s,t,i,r = e
|
|
if r and !(r -= built).empty?
|
|
l = list.size
|
|
if (while l > 0; break true if r.include?(list[l-=1][1]) end)
|
|
list.insert(l + 1, e)
|
|
end
|
|
next
|
|
end
|
|
f = format("%s/%s.%s", s, i, $LIBEXT)
|
|
if File.exist?(f)
|
|
$extinit += "\tinit(Init_#{i}, \"#{t}.so\");\n"
|
|
$extobjs += "ext/#{f} "
|
|
built << t
|
|
end
|
|
end
|
|
|
|
src = %{\
|
|
extern char *ruby_sourcefile, *rb_source_filename();
|
|
#define init(func, name) (ruby_sourcefile = src = rb_source_filename(name), func(), rb_provide(src))
|
|
void Init_ext() {\n\tchar* src;\n#$extinit}
|
|
}
|
|
if !modified?(extinit.c, MTIMES) || IO.read(extinit.c) != src
|
|
open(extinit.c, "w") {|f| f.print src}
|
|
end
|
|
|
|
$extobjs = "ext/#{extinit.o} " + $extobjs
|
|
if RUBY_PLATFORM =~ /m68k-human|beos/
|
|
$extflags.delete("-L/usr/local/lib")
|
|
end
|
|
$extpath.delete("$(topdir)")
|
|
$extflags = libpathflag($extpath) << " " << $extflags.strip
|
|
conf = [
|
|
['SETUP', $setup],
|
|
[enable_config("shared", $enable_shared) ? 'DLDOBJS' : 'EXTOBJS', $extobjs],
|
|
['EXTLIBS', $extlibs.join(' ')], ['EXTLDFLAGS', $extflags]
|
|
].map {|n, v|
|
|
"#{n}=#{v}" if v and !(v = v.strip).empty?
|
|
}.compact
|
|
puts conf
|
|
$stdout.flush
|
|
$mflags.concat(conf)
|
|
else
|
|
FileUtils.rm_f(extinit.to_a)
|
|
end
|
|
rubies = []
|
|
%w[RUBY RUBYW STATIC_RUBY].each {|r|
|
|
n = r
|
|
if r = arg_config("--"+r.downcase) || config_string(r+"_INSTALL_NAME")
|
|
rubies << r+EXEEXT
|
|
$mflags << "#{n}=#{r}"
|
|
end
|
|
}
|
|
|
|
Dir.chdir ".."
|
|
unless $destdir.to_s.empty?
|
|
$mflags.defined?("DESTDIR") or $mflags << "DESTDIR=#{$destdir}"
|
|
end
|
|
puts "making #{rubies.join(', ')}"
|
|
$stdout.flush
|
|
$mflags.concat(rubies)
|
|
|
|
if $nmake == ?b
|
|
$mflags.collect {|flag| flag.sub!(/\A(?=\w+=)/, "-D")}
|
|
end
|
|
system($make, *sysquote($mflags)) or exit($?.exitstatus)
|
|
|
|
#Local variables:
|
|
# mode: ruby
|
|
#end:
|