GithubHelp home page GithubHelp logo

mruby-require's Introduction

mruby-require

Build Status

mruby-require adds require support to mruby. This is based on iij's fork of mruby: https://github.com/iij/mruby

install by mrbgems

MRuby::Build.new do |conf|
  if ENV['OS'] != 'Windows_NT' then
    conf.cc.flags << %w|-fPIC| # needed for using bundled gems
  end
    # ... (snip) ...
  conf.gem :github => 'mattn/mruby-require'
end

To work properly, mruby-require must be the last mrbgem specified in the build configuration. Any mrbgem specified after mruby-require is compiled as a shared object (.so) and put in build/host/lib (full path available in $:). For loading them at runtime, see the next section.

Requiring additional mrbgems

When mruby-require is being used, additional mrbgems that appear after mruby-require in build_config.rb must be required to be used.

For example, if using mruby-onig-regexp, you should add the following to your code:

require 'mruby-onig-regexp'

Requiring mrbgems in defaults

Set MRUBY_REQUIRE environment variable as comma separated values like following

MRUBY_REQUIRE=mruby-onig-regexp,mruby-xquote

License

MIT

mruby-require's People

Contributors

code0100fun avatar dearblue avatar ksss avatar masahino avatar mattn avatar monaka avatar ongaeshi avatar pbosetti avatar pichurriaj avatar ppibburr avatar rjst avatar sdottaka avatar yyamano avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

mruby-require's Issues

Crash on requiring bundled gems

On requiring a bundled gem, I get the following crash, whichever is the gem I require:

> require 'mruby-complex'
mirb(13889,0x7fff7df1f300) malloc: *** error for object 0x10066cc30: pointer being realloc'd was not allocated
*** set a breakpoint in malloc_error_break to debug
Abort trap: 6

This happens for both C-compiled gems as well as pure ruby gems. Conversely, requiring plain ruby files and bytecode compiled files (.mrb) works as expected.

Issues with mruby 3.2.0

Hi,

I've found an issue with mruby 3.2.0.

Given these two files:

entry.rb

$:.unshift '.'

require 'zip'

and zip.rb

a = [1,2,3]
b = [:a, :b, :c]

p a.zip(b)

I am getting the error:

trace (most recent call last):
        [10] (unknown):0
        [9] (unknown):0:in require
        [8] /home/sean/Syncthing/code/c++/taylor/zip.rb:4
        [7] /home/sean/Syncthing/code/c++/taylor/zip.rb:4:in zip
        [6] /home/sean/Syncthing/code/c++/taylor/zip.rb:4:in each
        [5] /home/sean/Syncthing/code/c++/taylor/zip.rb:4:in zip
        [4] /home/sean/Syncthing/code/c++/taylor/zip.rb:4:in each
        [3] /home/sean/Syncthing/code/c++/taylor/zip.rb:4:in zip
        [2] /home/sean/Syncthing/code/c++/taylor/zip.rb:4:in next
        [1] /home/sean/Syncthing/code/c++/taylor/zip.rb:4:in next_values
/home/sean/Syncthing/code/c++/taylor/zip.rb:4:in resume: can't cross C function boundary (FiberError)

It works as expected with mruby 3.1.0

Please let me know if you require any more information

Strange behaviour on Windows

Hi,
on my fork, I notice a trance behaviour on Windows. When I compile a .mrb file and then require (or load it), if the original source .rb file contains a function, whose name has exactly 10 characters (regardless the actual string), then loading the file has no effect, and no error is raised.

Note that this only happens on Windows. Mac and Linux do not present this issue. Additionally, if I run the same compiled .mrb compiled script with the standard mruby interpreter I get the correct behaviour. Can you replicate this?

Steps to replicate:

  1. create a test.rb script which defines the function def abcdefghij(); end
  2. compile it with mrbc
  3. launch the mirb interactive interpreter and load "./test.mrb"
  4. test for existence of abcdefghij(): you should get an undefined method error.

More or less character in the function name do work. Exactly 10 characters and it doesn't.

`Kernel` prefix are attached to the namespace

preparing foo.rb

class Foo end

and doing the following:

require './foo.rb'
p Foo

outputs Kernel::Foo, while CRuby outputs Foo. Is this behavior what you intended?

Thank you in advance.

Support mruby 3.0

CPP   build/repos/host/mruby-require/src/mrb_require.c -> build/host/mrbgems/mruby-require/src/mrb_require.pi
GEN   build/host/mrbgems/mruby-require/gem_init.c 
CPP   build/host/mrbgems/mruby-require/gem_init.c -> build/host/mrbgems/mruby-require/gem_init.pi
CPP   mrbgems/mruby-string-ext/src/string.c -> build/host/mrbgems/mruby-string-ext/src/string.pi
GEN   build/host/mrbgems/mruby-string-ext/gem_init.c 
      MRBC mrbgems/mruby-string-ext/mrblib/string.rb 
CPP   build/host/mrbgems/mruby-string-ext/gem_init.c -> build/host/mrbgems/mruby-string-ext/gem_init.pi
CPP   build/host/mrbgems/gem_init.c -> build/host/mrbgems/gem_init.pi
CPP   mrbgems/mruby-bin-mrbc/tools/mrbc/mrbc.c -> build/host/mrbgems/mruby-bin-mrbc/tools/mrbc/mrbc.pi
GEN   build/host/presym 
GEN   build/host/include/mruby/presym/id.h 
GEN   build/host/include/mruby/presym/table.h 
rake aborted!
Don't know how to build task '/Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/bin/mruby.dylib' (See the list of available tasks with `rake --tasks`)
Did you mean?  /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/bin/mrbc
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrblib/mrblib.c
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrblib/mrblib.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrblib/mrblib.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/symbol.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/init.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/bin/mruby.dylib
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/load.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/vm.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/bin/mrbc
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/print.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/init.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/kernel.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/string.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/mrbgems/gem_init.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/mrbgems/gem_init.c
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/gc.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/array.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/range.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/print.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/variable.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/pool.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/init.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/version.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbgems/gem_init.c
               /Users/Kanbaru/GitWorkspace/mruby/build/host/include/mruby/presym/id.h
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/etc.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/object.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/bin
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/string.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/symbol.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/lib/libmruby_core.a
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/class.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/hash.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/proc.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/array.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/variable.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/libmruby.a
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/load.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/print.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/version.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/load.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/compar.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/fmt_fp.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/libmruby_core.a
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-random.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/state.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/error.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/string.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/array.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/range.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/symbol.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/range.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/pool.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/backtrace.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/proc.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/LEGAL
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/variable.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/version.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/gc.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/vm.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/gc.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/class.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-fiber.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-print.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/vm.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/numeric.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/error.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbgems/gem_init.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/proc.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-time.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/etc.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/pool.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-struct.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/etc.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbgems/gem_init.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/compar.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/error.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/enum.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/dump.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-io.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/hash.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/class.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-sprintf.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/numeric.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/hash.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-method.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/bin/mruby-config
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/debug.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/kernel.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/compar.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/state.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/state.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/dump.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-pack.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-math.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/libmruby.flags.mak
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/numeric.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/fmt_fp.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/object.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/object.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/fmt_fp.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/debug.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-complex.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/enum.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/mruby_sharp.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/enum.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/dump.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-socket.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/mrbc/src/codedump.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/kernel.o
               /Users/Kanbaru/GitWorkspace/mruby/bin/mruby.dylib
               /Users/Kanbaru/GitWorkspace/mruby/build/host/lib/mruby-eval.so
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/debug.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/mruby_sharp.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/mruby_sharp.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/codedump.pi
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/backtrace.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/codedump.o
               /Users/Kanbaru/GitWorkspace/mruby/build/host/src/backtrace.pi
/Users/Kanbaru/GitWorkspace/mruby/Rakefile:43:in `block in <top (required)>'
Tasks: TOP => build
(See full trace by running task with --trace)

Unable to bundle gem

I have a very minimalist build_config.rb to test that:

MRuby::Build.new do |conf|
  if ENV['VisualStudioVersion'] || ENV['VSINSTALLDIR']
    toolchain :visualcpp
  else
    toolchain :gcc
  end

  enable_debug
  
  conf.gembox 'default'

  conf.gem 'path/to/mruby-gem_a'
  
  conf.gem :github => 'mattn/mruby-require'
  
  conf.gem 'path/to/mruby-gem_b'

Here mruby-gem_a and mruby-gem_b are just dummy names.
I tried using minirake and rake, the same problem arise:

Build summary:

================================================
      Config Name: host
 Output Directory: build/x86/host
         Binaries: mrbc
    Included Gems:
             mruby-dir
             mruby-io - IO and File class
             mruby-random - Random class
             mruby-sprintf - standard Kernel#sprintf method
             mruby-time - standard Time class
             mruby-tempfile
             mruby-pack - Array#pack and String#unpack method
             mruby-print - standard print/puts/p
             mruby-math - standard Math module
             mruby-struct - standard Struct class
             mruby-compar-ext - Enumerable module extension
             mruby-enum-ext - Enumerable module extension
             mruby-string-ext - String class extension
             mruby-numeric-ext - Numeric class extension
             mruby-array-ext - Array class extension
             mruby-hash-ext - Hash class extension
             mruby-range-ext - Range class extension
             mruby-proc-ext - Proc class extension
             mruby-symbol-ext - Symbol class extension
             mruby-object-ext - Object class extension
             mruby-objectspace - ObjectSpace class
             mruby-fiber - Fiber class
             mruby-enumerator - Enumerator class
             mruby-enum-lazy - Enumerator::Lazy class
             mruby-toplevel-ext - toplevel object (main) methods extension
             mruby-compiler - mruby compiler library
             mruby-bin-mirb - mirb command
               - Binaries: mirb
             mruby-error - extensional error handling
             mruby-bin-mruby - mruby command
               - Binaries: mruby
             mruby-bin-strip - irep dump debug section remover command
               - Binaries: mruby-strip
             mruby-kernel-ext - Kernel module extension
             mruby-class-ext - class/module extension
             mruby-gem_a
             mruby-bin-mrbc - mruby compiler executable
             mruby-require
================================================

** Invoke C:/Workspace/MRuby/build/x86/host/lib/mruby-gem_b.so (first_time)
rake aborted!
Don't know how to build task 'C:/Workspace/MRuby/build/x86/host/mrbgems/mruby-gem_b/src/mruby-gem_b.obj  (see --tasks)

@pbosetti you made the change about that feature, right ? What am I missing here ?

Cann't build in early mruby

mruby: mruby/mruby@ddb1aae
mruby-require: ff56b56

MRuby::Build.new do |conf|
  toolchain :clang
  
  enable_debug
  conf.gembox 'default'
  conf.gem github: "mattn/mruby-require"
end
$ rake
CC    src/array.c -> build/host/src/array.o
CC    src/backtrace.c -> build/host/src/backtrace.o
CC    src/class.c -> build/host/src/class.o
CC    src/codedump.c -> build/host/src/codedump.o
CC    src/compar.c -> build/host/src/compar.o
CC    src/crc.c -> build/host/src/crc.o
CC    src/debug.c -> build/host/src/debug.o
CC    src/dump.c -> build/host/src/dump.o
CC    src/enum.c -> build/host/src/enum.o
CC    src/error.c -> build/host/src/error.o
CC    src/etc.c -> build/host/src/etc.o
CC    src/fmt_fp.c -> build/host/src/fmt_fp.o
CC    src/gc.c -> build/host/src/gc.o
CC    src/hash.c -> build/host/src/hash.o
CC    src/init.c -> build/host/src/init.o
CC    src/kernel.c -> build/host/src/kernel.o
CC    src/load.c -> build/host/src/load.o
CC    src/numeric.c -> build/host/src/numeric.o
CC    src/object.c -> build/host/src/object.o
CC    src/pool.c -> build/host/src/pool.o
CC    src/print.c -> build/host/src/print.o
CC    src/proc.c -> build/host/src/proc.o
CC    src/range.c -> build/host/src/range.o
CC    src/state.c -> build/host/src/state.o
CC    src/string.c -> build/host/src/string.o
CC    src/symbol.c -> build/host/src/symbol.o
CC    src/variable.c -> build/host/src/variable.o
CC    src/version.c -> build/host/src/version.o
CC    src/vm.c -> build/host/src/vm.o
rake aborted!
Don't know how to build task '/Users/ksss/src/github.com/ksss/mruby/build/host/mrbgems/mruby-bin-mrbc/tools/mrbc/mrbc.o' (see --tasks)

mruby-require causing issues with other mrbgems

Hi,

I'm using mruby-require, and although it appears to work fine, when using it, other mrbgems such as mruby-onig-regexp or mruby-eval stop working, just as if they weren't being included.

Am I doing something wrong or could this be a bug ?

regards,
Ricardo

undefined method `uniq' for #<MRuby::Gem::List:0x00000001fee358>

From mruby/mruby#1386

MRuby::Build.new do |conf|
  toolchain :gcc

  # include the default GEMs
  conf.gembox 'default'

  conf.gem :github => 'mattn/mruby-require'
end

Output:

(in /home/speed/ruby/moon/vendor/mruby)
GIT   https://github.com/mattn/mruby-require.git -> build/mrbgems/mruby-require
Cloning into 'build/mrbgems/mruby-require'...
remote: Counting objects: 231, done.
remote: Compressing objects: 100% (132/132), done.
remote: Total 231 (delta 65), reused 227 (delta 63)
Receiving objects: 100% (231/231), 29.55 KiB | 0 bytes/s, done.
Resolving deltas: 100% (65/65), done.
Checking connectivity... done
rake aborted!
undefined method `uniq' for #<MRuby::Gem::List:0x00000001fee358>
Rakefile:26:in `load'

Attempting require on .mrb file causes crash

Tested on Windows, and built with mingw-w64 5.1

Using require from either mirb or a script ran with mruby will work fine for a standard .rb script, but attempting to load .mrb bytecode compiled from that same script causes an immediate crash.

build failed with latest mruby

MKOP_* seem to be gone with mruby/mruby@891839b

/path/to/mruby/build/mrbgems/mruby-require/src/mrb_require.c: 関数 ‘replace_stop_with_return’ 内:
/path/to/mruby/build/mrbgems/mruby-require/src/mrb_require.c:234:3: エラー: 関数 ‘MKOP_A’ の暗黙的な宣言です [-Werror=implicit-function-declaration]
   if (irep->iseq[irep->ilen - 1] == MKOP_A(OP_STOP, 0)) {
   ^
/path/to/mruby/build/mrbgems/mruby-require/src/mrb_require.c:244:5: エラー: 関数 ‘MKOP_AB’ の暗黙的な宣言です [-Werror=implicit-function-declaration]
     irep->iseq[irep->ilen] = MKOP_AB(OP_RETURN, 0, OP_R_NORMAL);
     ^
cc1: some warnings being treated as errors
/path/to/mruby/build/mrbgems/mruby-require/src/mrb_require.c: 関数 ‘replace_stop_with_return’ 内:
/path/to/mruby/build/mrbgems/mruby-require/src/mrb_require.c:234:3: エラー: 関数 ‘MKOP_A’ の暗黙的な宣言です [-Werror=implicit-function-declaration]
   if (irep->iseq[irep->ilen - 1] == MKOP_A(OP_STOP, 0)) {
   ^
/path/to/mruby/build/mrbgems/mruby-require/src/mrb_require.c:244:5: エラー: 関数 ‘MKOP_AB’ の暗黙的な宣言です [-Werror=implicit-function-declaration]
     irep->iseq[irep->ilen] = MKOP_AB(OP_RETURN, 0, OP_R_NORMAL);

Error: 'rake aborted!'

mruby version 1.3
ruby 2.3.3p222 (2016-11-21) [arm-linux-gnueabihf]
device: Raspiberry
system: Raspbian

Add this line in build_config.rb: conf.gem :github => 'mattn/mruby-require'

Error info:

root@tskpi2num01:/home/tokai-soft/mruby-1.3.0# ruby minirake
(in /home/tokai-soft/mruby-1.3.0)
GIT   https://github.com/mattn/mruby-require.git -> build/mrbgems/mruby-require
Cloning into '/home/tokai-soft/mruby-1.3.0/build/mrbgems/mruby-require'...
remote: Counting objects: 9, done.
remote: Compressing objects: 100% (8/8), done.
remote: Total 9 (delta 0), reused 5 (delta 0), pack-reused 0
Unpacking objects: 100% (9/9), done.
CC    src/load.c -> build/host/src/load.o
CC    src/init.c -> build/host/src/init.o
CC    src/dump.c -> build/host/src/dump.o
CC    src/range.c -> build/host/src/range.o
CC    src/gc.c -> build/host/src/gc.o
CC    src/object.c -> build/host/src/object.o
CC    src/state.c -> build/host/src/state.o
CC    src/codedump.c -> build/host/src/codedump.o
CC    src/hash.c -> build/host/src/hash.o
CC    src/debug.c -> build/host/src/debug.o
CC    src/vm.c -> build/host/src/vm.o
CC    src/string.c -> build/host/src/string.o
CC    src/crc.c -> build/host/src/crc.o
CC    src/kernel.c -> build/host/src/kernel.o
CC    src/proc.c -> build/host/src/proc.o
CC    src/error.c -> build/host/src/error.o
CC    src/enum.c -> build/host/src/enum.o
CC    src/fmt_fp.c -> build/host/src/fmt_fp.o
CC    src/numeric.c -> build/host/src/numeric.o
CC    src/compar.c -> build/host/src/compar.o
CC    src/print.c -> build/host/src/print.o
CC    src/pool.c -> build/host/src/pool.o
CC    src/array.c -> build/host/src/array.o
CC    src/variable.c -> build/host/src/variable.o
CC    src/backtrace.c -> build/host/src/backtrace.o
CC    src/version.c -> build/host/src/version.o
CC    src/symbol.c -> build/host/src/symbol.o
CC    src/class.c -> build/host/src/class.o
CC    src/etc.c -> build/host/src/etc.o
rake aborted!
Don't know how to rake /home/tokai-soft/mruby-1.3.0/build/host/mrbgems/mruby-bin-mrbc/tools/mrbc/mrbc.o

implicit declaration of function ‘mrb_load_fail’

using standard build_config.rb of master head (commit c3188cac431225fda48718f309ad3d9318a6e44f) I add conf.gem :github => 'mattn/mruby-require' and get the following error:

make

...
CC    build/host/mrbgems/gem_init.c -> build/host/mrbgems/gem_init.o
CC    build/mrbgems/mruby-require/src/mrb_require.c -> build/host/mrbgems/mruby-require/src/mrb_require.o
/opt/mruby/build/mrbgems/mruby-require/src/mrb_require.c: In function ‘find_file’:
/opt/mruby/build/mrbgems/mruby-require/src/mrb_require.c:234:3: error: implicit declaration of function ‘mrb_load_fail’; did you mean ‘mrb_load_file’? [-Werror=implicit-function-declaration]
   mrb_load_fail(mrb, filename, "cannot load such file");
   ^~~~~~~~~~~~~
   mrb_load_file
/opt/mruby/build/mrbgems/mruby-require/src/mrb_require.c: In function ‘mrb_load_irep_data’:
/opt/mruby/build/mrbgems/mruby-require/src/mrb_require.c:318:5: error: implicit declaration of function ‘replace_stop_with_return’ [-Werror=implicit-function-declaration]
     replace_stop_with_return(mrb, irep);
     ^~~~~~~~~~~~~~~~~~~~~~~~
cc1: some warnings being treated as errors
/opt/mruby/build/mrbgems/mruby-require/src/mrb_require.c: In function ‘find_file’:
/opt/mruby/build/mrbgems/mruby-require/src/mrb_require.c:234:3: error: implicit declaration of function ‘mrb_load_fail’; did you mean ‘mrb_load_file’? [-Werror=implicit-function-declaration]
   mrb_load_fail(mrb, filename, "cannot load such file");
   ^~~~~~~~~~~~~
   mrb_load_file
/opt/mruby/build/mrbgems/mruby-require/src/mrb_require.c: In function ‘mrb_load_irep_data’:
/opt/mruby/build/mrbgems/mruby-require/src/mrb_require.c:318:5: error: implicit declaration of function ‘replace_stop_with_return’ [-Werror=implicit-function-declaration]
     replace_stop_with_return(mrb, irep);
     ^~~~~~~~~~~~~~~~~~~~~~~~
cc1: some warnings being treated as errors
rake aborted!
Command Failed: [gcc -g -std=gnu99 -O3 -Wall -Werror-implicit-function-declaration -Wdeclaration-after-statement -Wwrite-strings -DMRBGEMS_ROOT=\"/opt/mruby/build/test/lib\" -DMRBGEM_MRUBY_REQUIRE_VERSION=0.0.0 -I"/opt/mruby/include" -I"/opt/mruby/src" -MMD -o "/opt/mruby/build/host/mrbgems/mruby-require/src/mrb_require.o" -c "/opt/mruby/build/mrbgems/mruby-require/src/mrb_require.c"]

Makefile:8: recipe for target 'all' failed
make: *** [all] Error 1

Does not compile due to rake problems

I get the following error below problems with rake when I try to use mruby-require as a gem in a gembox. This is with mruby v1.2.0. Any suggestions on how to resolve this?

bjorn@ancelot~/work/src/swita/build/src/mruby/build/mrbgems/mruby-require$ rake
(in /home/bjorn/work/src/swita/build/src/mruby)
rake aborted!
NoMethodError: undefined method `each' for nil:NilClass
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgem_spec.rake:310:in `block in generate_gem_table'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgem_spec.rake:290:in `each'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgem_spec.rake:290:in `each'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgem_spec.rake:309:in `generate_gem_table'
/home/bjorn/work/src/swita/build/src/mruby/mrbgems/mruby-test/mrbgem.rake:35:in `block in <top (required)>'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgem_spec.rake:80:in `instance_eval'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgem_spec.rake:80:in `setup'
/home/bjorn/work/src/swita/build/src/mruby/build/mrbgems/mruby-require/mrbgem.rake:63:in `block (3 levels) in <top (required)>'
/home/bjorn/work/src/swita/build/src/mruby/build/mrbgems/mruby-require/mrbgem.rake:61:in `each'
/home/bjorn/work/src/swita/build/src/mruby/build/mrbgems/mruby-require/mrbgem.rake:61:in `block (2 levels) in <top (required)>'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mruby_build.rake:13:in `instance_eval'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mruby_build.rake:13:in `block in each_target'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mruby_build.rake:12:in `each'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mruby_build.rake:12:in `each_target'
/home/bjorn/work/src/swita/build/src/mruby/build/mrbgems/mruby-require/mrbgem.rake:46:in `block in <top (required)>'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgem_spec.rake:80:in `instance_eval'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgem_spec.rake:80:in `setup'
/home/bjorn/work/src/swita/build/src/mruby/tasks/ruby_ext.rake:41:in `block in to_proc'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgem_spec.rake:290:in `each'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgem_spec.rake:290:in `each'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgems.rake:4:in `block in <top (required)>'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mruby_build.rake:13:in `instance_eval'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mruby_build.rake:13:in `block in each_target'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mruby_build.rake:12:in `each'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mruby_build.rake:12:in `each_target'
/home/bjorn/work/src/swita/build/src/mruby/tasks/mrbgems.rake:1:in `<top (required)>'
/home/bjorn/work/src/swita/build/src/mruby/Rakefile:26:in `load'
/home/bjorn/work/src/swita/build/src/mruby/Rakefile:26:in `<top (required)>'
/home/bjorn/.rvm/gems/ruby-2.3.0/gems/rake-11.2.2/exe/rake:27:in `<top (required)>'
/home/bjorn/.rvm/gems/ruby-2.3.0/bin/ruby_executable_hooks:15:in `eval'
/home/bjorn/.rvm/gems/ruby-2.3.0/bin/ruby_executable_hooks:15:in `<main>'
(See full trace by running task with --trace)

require not working with mruby

I try to create an executable from a simple Ruby program. If the file contains a simple puts with a string and I use the following commands
mrbc -Btest load.rb
gcc -std=c99 -I/root/mruby/include -I. test_stub.c -o load /root/mruby/build/host/lib/libmruby.a -lm -ldl
everything runs well calling ./load display my string.
But if I add
require 'yaml' or require 'ostruct' or require 'json' before, execution simply display nothig, no crash either...
I have added the following line in mrbgems/default.gembox file
conf.gem :core => "mruby-yaml"

and
conf.gem :github => 'ksss/mruby-ostruct', :branch => 'master'
conf.gem :github => 'mattn/mruby-json'
conf.gem :github => 'mattn/mruby-require'
in build_config.rb after conf.gembox 'default'
After make clean a call to objdump on libmruby.a show that the modules are in the lib...
But it doesn't work!
What am I doing wrong ?

Implement `require_relative`

Working with Ruby I found Kernel#require_relative function quite useful. It might be a good idea implement it for mruby as well.

Error when compiling: "Don't know how to build task 'some/path/mruby-2.1.1/build/host/mrbgems/mruby-array-ext/src/array.o'" and "relocation R_X86_64_PC32 against symbol `mrb_ary_push' can not be used when making a shared object"

mruby 2.1.1

Summary

I ran into this when trying to add the mruby-require gem. The error I get depends on the order I do stuff in.

To reproduce the first, I run rake clean, add the mruby-require gem to the build config (if not there), and try to compile.

Relevant-looking output:

      MRBC test/t/literals.rb                                                                                                                                                                                     
      MRBC test/t/object.rb                                                                                                                                                                                       
      MRBC test/t/iterations.rb                                                                                                                                                                                   
CC    build/test/mrbgems/mruby-test/gem_test.c -> build/test/mrbgems/mruby-test/gem_test.o                                                                                                                        
CC    mrbgems/mruby-error/test/exception.c -> build/test/mrbgems/mruby-error/test/exception.o                                                                                                                     
      MRBC mrbgems/mruby-error/test/exception.rb                                                                                                                                                                  
CC    build/test/mrbgems/mruby-error/gem_test.c -> build/test/mrbgems/mruby-error/gem_test.o                                                                                                                      
AR    build/test/mrbgems/mruby-test/mrbtest.a                                                                                                                                                                     
ar: creating some/path/mruby-2.1.1/build/test/mrbgems/mruby-test/mrbtest.a                                                                                                                        
LD    build/test/bin/mrbtest                                                                                                                                                                                      
                                                                                                                                                                                                                  
Build summary:                                                                                                                                                                                                    
                                                                                                                                                                                                                  
================================================                                                                                                                                                                  
      Config Name: host                                                                                                                                                                                           
 Output Directory: build/host                                                                                                                                                                                     
         Binaries: mrbc                                                                                                                                                                                           
    Included Gems:                                                                                                                                                                                                
             mruby-require                                                                                                                                                                                        
             mruby-compiler - mruby compiler library                                                                                                                                                              
             mruby-bin-mrbc - mruby compiler executable                                                                                                                                                           
================================================                                                                                                                                                                  
                                                                                                                                                                                                                  
rake aborted!                                                                                                                                                                                                     
Don't know how to build task 'some/path/mruby-2.1.1/build/host/mrbgems/mruby-array-ext/src/array.o' (See the list of available tasks with `rake --tasks`)                                         

To reproduce the latter, I run rake clean, compile with no gems, add the mruby-require gem to my build config, and try to compile again.

<...>
      MRBC test/t/literals.rb 
      MRBC test/t/object.rb 
      MRBC test/t/iterations.rb 
CC    build/test/mrbgems/mruby-test/gem_test.c -> build/test/mrbgems/mruby-test/gem_test.o
CC    mrbgems/mruby-error/test/exception.c -> build/test/mrbgems/mruby-error/test/exception.o
      MRBC mrbgems/mruby-error/test/exception.rb 
CC    build/test/mrbgems/mruby-error/gem_test.c -> build/test/mrbgems/mruby-error/gem_test.o
AR    build/test/mrbgems/mruby-test/mrbtest.a 
LD    build/test/bin/mrbtest 

Build summary:

================================================
      Config Name: host
 Output Directory: build/host
         Binaries: mrbc
    Included Gems:
             mruby-require
             mruby-compiler - mruby compiler library
             mruby-bin-mrbc - mruby compiler executable
================================================

LD    some/path/mruby-2.1.1/build/host/lib/mruby-array-ext.so 
/usr/bin/ld: some/path/mruby-2.1.1/build/host/lib/libmruby.a(array.o): relocation R_X86_64_PC32 against symbol `mrb_ary_push' can not be used when making a shared object; recompile with -fPIC
/usr/bin/ld: final link failed: Bad value
collect2: error: ld returned 1 exit status
rake aborted!
Command failed with status (1): [gcc -shared -fPIC -o "some/path...]

Fix

The relevant bits are that "To work properly, mruby-require must be the last mrbgem specified in the build configuration. Any mrbgem specified after mruby-require is compiled as a shared object" (as per the README, which explains the errors above) and that the default build config includes this line conf.gembox 'default' which adds a bunch of default gems (these would be the gems that the above errors are complaining about)

Make sure that your conf.gem github: 'mattn/mruby-require' line is below the conf.gembox 'default' line.

It's easy to make this mistake because the default build_config.rb has the "Use mrbgems" section above the "include the default GEMs" section.

After I made that fix, it compiled without issue. Will close since this is really just here to hopefully save some other people some time in the future.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.