summaryrefslogtreecommitdiffhomepage
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/mruby/build.rb2
-rw-r--r--lib/mruby/build/command.rb7
-rw-r--r--lib/mruby/core_ext.rb4
-rw-r--r--lib/mruby/gem.rb15
4 files changed, 21 insertions, 7 deletions
diff --git a/lib/mruby/build.rb b/lib/mruby/build.rb
index a79732802..b9f26d49f 100644
--- a/lib/mruby/build.rb
+++ b/lib/mruby/build.rb
@@ -248,7 +248,7 @@ module MRuby
end
end
else
- cxx_src = "#{build_dir}/#{src.relative_path})".ext << "-cxx.cxx"
+ cxx_src = "#{build_dir}/#{src.relative_path.to_s.remove_leading_parents}".ext << "-cxx.cxx"
obj = cxx_src.ext(@exts.object)
end
diff --git a/lib/mruby/build/command.rb b/lib/mruby/build/command.rb
index 9d70ac086..dbe3763d9 100644
--- a/lib/mruby/build/command.rb
+++ b/lib/mruby/build/command.rb
@@ -328,13 +328,16 @@ module MRuby
@compile_options = "-B%{funcname} -o-"
end
- def run(out, infiles, funcname, cdump = true)
+ def run(out, infiles, funcname, cdump: true, static: false)
@command ||= @build.mrbcfile
infiles = [infiles].flatten
infiles.each_with_index do |f, i|
_pp i == 0 ? "MRBC" : "", f.relative_path, indent: 2
end
- cmd = %Q["#{filename @command}" #{cdump ? "-S" : ""} #{@compile_options % {:funcname => funcname}} #{filename(infiles).map{|f| %Q["#{f}"]}.join(' ')}]
+ opt = @compile_options % {funcname: funcname}
+ opt << " -S" if cdump
+ opt << " -s" if static
+ cmd = %["#{filename @command}" #{opt} #{filename(infiles).map{|f| %["#{f}"]}.join(' ')}]
puts cmd if Rake.verbose
IO.popen(cmd, 'r+') do |io|
out.puts io.read
diff --git a/lib/mruby/core_ext.rb b/lib/mruby/core_ext.rb
index 33454edad..1ad528c26 100644
--- a/lib/mruby/core_ext.rb
+++ b/lib/mruby/core_ext.rb
@@ -18,6 +18,10 @@ class String
def relative_path
relative_path_from(Dir.pwd)
end
+
+ def remove_leading_parents
+ Pathname.new(".#{Pathname.new("/#{self}").cleanpath}").cleanpath.to_s
+ end
end
def install_D(src, dst)
diff --git a/lib/mruby/gem.rb b/lib/mruby/gem.rb
index 48a14fc54..716f21286 100644
--- a/lib/mruby/gem.rb
+++ b/lib/mruby/gem.rb
@@ -119,6 +119,10 @@ module MRuby
@dir.start_with?("#{MRUBY_ROOT}/mrbgems/")
end
+ def bin?
+ @bins.size > 0
+ end
+
def add_dependency(name, *requirements)
default_gem = requirements.last.kind_of?(Hash) ? requirements.pop : nil
requirements = ['>= 0.0.0'] if requirements.empty?
@@ -194,10 +198,11 @@ module MRuby
open(fname, 'w') do |f|
print_gem_init_header f
unless rbfiles.empty?
+ opts = {cdump: cdump?, static: true}
if cdump?
- build.mrbc.run f, rbfiles, "gem_mrblib_#{funcname}_proc"
+ build.mrbc.run f, rbfiles, "gem_mrblib_#{funcname}_proc", **opts
else
- build.mrbc.run f, rbfiles, "gem_mrblib_irep_#{funcname}", false
+ build.mrbc.run f, rbfiles, "gem_mrblib_irep_#{funcname}", **opts
end
end
f.puts %Q[void mrb_#{funcname}_gem_init(mrb_state *mrb);]
@@ -496,8 +501,10 @@ module MRuby
end
end
- def linker_attrs
- map{|g| g.linker.run_attrs}.transpose
+ def linker_attrs(gem=nil)
+ gems = self.reject{|g| g.bin?} # library gems
+ gems << gem unless gem.nil?
+ gems.map{|g| g.linker.run_attrs}.transpose
end
end # List
end # Gem