mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
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. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@48913 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
cfe3357581
commit
53a7c96417
2 changed files with 28 additions and 23 deletions
|
@ -1,5 +1,4 @@
|
|||
PWD =
|
||||
LOCAL_LIBS = $(LIBFFI_A)
|
||||
|
||||
CONFIGURE_LIBFFI = \
|
||||
cd $(LIBFFI_DIR) && \
|
||||
|
@ -21,8 +20,8 @@ configure-libffi $(FFI_H):
|
|||
$(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
|
||||
|
|
|
@ -19,27 +19,32 @@ begin
|
|||
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|
|
|||
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|
|
|||
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)
|
||||
|
|
Loading…
Reference in a new issue