ruby-changes:36832
From: nobu <ko1@a...>
Date: Sun, 21 Dec 2014 14:45:15 +0900 (JST)
Subject: [ruby-changes:36832] nobu:r48913 (trunk): fiddle: fix build failures
nobu 2014-12-21 14:45:01 +0900 (Sun, 21 Dec 2014) New Revision: 48913 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=48913 Log: fiddle: fix build failures * ext/fiddle/depend (build-libffi): get rid of eventually empty target for nmake. * ext/fiddle/extconf.rb: omit stuffs for libffi unless bundled libffi is found and used. Modified files: trunk/ext/fiddle/depend trunk/ext/fiddle/extconf.rb Index: ext/fiddle/depend =================================================================== --- ext/fiddle/depend (revision 48912) +++ ext/fiddle/depend (revision 48913) @@ -1,5 +1,4 @@ https://github.com/ruby/ruby/blob/trunk/ext/fiddle/depend#L1 PWD = -LOCAL_LIBS = $(LIBFFI_A) CONFIGURE_LIBFFI = \ cd $(LIBFFI_DIR) && \ @@ -21,8 +20,8 @@ configure-libffi $(FFI_H): https://github.com/ruby/ruby/blob/trunk/ext/fiddle/depend#L20 $(Q) $(MAKEDIRS) $(LIBFFI_DIR) $(Q) $(CONFIGURE_LIBFFI) -lib: $(LIBFFI_A) -$(LIBFFI_A): +build-libffi: $(LIBFFI_A) +build-libffi $(LIBFFI_A): $(Q) $(SUBMAKE_LIBFFI) configure: configure-libffi Index: ext/fiddle/extconf.rb =================================================================== --- ext/fiddle/extconf.rb (revision 48912) +++ ext/fiddle/extconf.rb (revision 48913) @@ -19,27 +19,32 @@ begin https://github.com/ruby/ruby/blob/trunk/ext/fiddle/extconf.rb#L19 ver = Dir.glob("#{$srcdir}/libffi-*/") .map {|n| File.basename(n)} .max_by {|n| n.scan(/\d+/).map(&:to_i)} - bundled = ver - if $srcdir == "." - builddir = "#{ver}/#{RUBY_PLATFORM}" - libffi_srcdir = "." - else - builddir = bundled - libffi_srcdir = relative_from("#{$srcdir}/#{bundled}", "..") + if ver + libffi = Struct.new(:dir, :srcdir, :builddir, :include, :lib, :a, :cflags).new + libffi.dir = ver + if $srcdir == "." + libffi.builddir = "#{ver}/#{RUBY_PLATFORM}" + libffi.srcdir = "." + else + libffi.builddir = libffi.dir + libffi.srcdir = relative_from("#{$srcdir}/#{ver}", "..") + end + libffi.include = "#{libffi.builddir}/include" + libffi.lib = "#{libffi.builddir}/.libs" + libffi.a = "#{libffi.lib}/libffi.#{$LIBEXT}" + libffi.cflags = RbConfig.expand("$(CFLAGS)", CONFIG.merge("warnflags"=>"")) + $LIBPATH.unshift libffi.lib + $INCFLAGS << " -I" << libffi.include + ver = ver[/libffi-(.*)/, 1] end - libffi_include = "#{builddir}/include" - libffi_lib = "#{builddir}/.libs" - libffi_a = "#{libffi_lib}/libffi.#{$LIBEXT}" - libffi_cflags = RbConfig.expand("$(CFLAGS)", CONFIG.merge("warnflags"=>"")) - $LIBPATH.unshift libffi_lib - $INCFLAGS << " -I" << libffi_include - ver = ver[/libffi-(.*)/, 1] end if ver ver = ver.gsub(/-rc\d+/, '') # If ver contains rc version, just ignored. ver = (ver.split('.') + [0,0])[0,3] $defs.push(%{-DRUBY_LIBFFI_MODVERSION=#{ '%d%03d%03d' % ver }}) +else + raise "missing libffi. Please install libffi." end have_header 'sys/mman.h' @@ -75,6 +80,7 @@ types.each do |type, signed| https://github.com/ruby/ruby/blob/trunk/ext/fiddle/extconf.rb#L80 end create_makefile 'fiddle' do |conf| + next conf unless libffi if $gnumake submake = "$(MAKE) -C $(LIBFFI_DIR)\n" else @@ -86,16 +92,16 @@ create_makefile 'fiddle' do |conf| https://github.com/ruby/ruby/blob/trunk/ext/fiddle/extconf.rb#L92 PWD = LIBFFI_CONFIGURE = $(LIBFFI_SRCDIR#{seprpl})#{sep}configure#{/'-C'/ =~ CONFIG['configure_args'] ? ' -C' : ''} LIBFFI_ARCH = #{RbConfig::CONFIG['arch'].sub(/\Ax64-(?=mingw|mswin)/, 'x86_64-')} - LIBFFI_SRCDIR = #{libffi_srcdir} - LIBFFI_DIR = #{bundled} - LIBFFI_A = #{libffi_a} - LIBFFI_CFLAGS = #{libffi_cflags} - FFI_H = #{bundled && '$(LIBFFI_DIR)/include/ffi.h'} + LIBFFI_SRCDIR = #{libffi.srcdir} + LIBFFI_DIR = #{libffi.dir} + LIBFFI_A = #{libffi.a} + LIBFFI_CFLAGS = #{libffi.cflags} + FFI_H = $(LIBFFI_DIR)/include/ffi.h SUBMAKE_LIBFFI = #{submake} MK end -if bundled +if libffi args = [$make, *sysquote($mflags)] Logging::open do Logging.message("%p\n", args) -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/