我一直致力于在我的 Mac OSX Lion 上安装 Ruby。我已经安装了 XCode、GCC、Readline、Homebrew 和 JewleryBox,但我不知道发生了什么。有什么指点吗?
这是我的终端显示的内容?
hugo-pc:ruby-1.9.3-p125 squantowalks$ rvm install 1.9.3
Fetching yaml-0.1.4.tar.gz to /Users/squantowalks/.rvm/archives
Extracting yaml-0.1.4.tar.gz to /Users/squantowalks/.rvm/src
Error running 'tar xmzf /Users/squantowalks/.rvm/archives/yaml-0.1.4.tar.gz -C /Users/squantowalks/.rvm/src ', please read /Users/squantowalks/.rvm/log/ruby-1.9.3-p125/yaml/extract.log
Configuring yaml in /Users/squantowalks/.rvm/src/yaml-0.1.4.
Error running ' ./configure --prefix="/Users/squantowalks/.rvm/usr" ', please read /Users/squantowalks/.rvm/log/ruby-1.9.3-p125/yaml/configure.log
Compiling yaml in /Users/squantowalks/.rvm/src/yaml-0.1.4.
Error running 'make ', please read /Users/squantowalks/.rvm/log/ruby-1.9.3-p125/yaml/make.log
Installing Ruby from source to: /Users/squantowalks/.rvm/rubies/ruby-1.9.3-p125, this may take a while depending on your cpu(s)...
ruby-1.9.3-p125 - #fetching
ruby-1.9.3-p125 - #extracted to /Users/squantowalks/.rvm/src/ruby-1.9.3-p125 (already extracted)
ruby-1.9.3-p125 - #configuring
ruby-1.9.3-p125 - #compiling
Error running 'make ', please read /Users/squantowalks/.rvm/log/ruby-1.9.3-p125/make.log
There has been an error while running make. Halting the installation.
这是控制台日志:
[2012-03-08 18:20:17] make
CC = clang
LD = ld
LDSHARED = clang -dynamiclib -O3 -ggdb -Wextra -Wno-unused-parameter -Wno-parentheses -Wno-long-long -Wno-missing-field-initializers -Werror=pointer-arith -Werror=write-strings -Werror=declaration-after-statement -Werror=shorten-64-to-32 -Werror=implicit-function-declaration -fno-common -pipe -L. -L/usr/local/lib
CFLAGS = -O3 -ggdb -Wextra -Wno-unused-parameter -Wno-parentheses -Wno-long-long -Wno-missing-field-initializers -Werror=pointer-arith -Werror=write-strings -Werror=declaration-after-statement -Werror=shorten-64-to-32 -Werror=implicit-function-declaration -fno-common -pipe
XCFLAGS = -include ruby/config.h -include ruby/missing.h -fvisibility=hidden -DRUBY_EXPORT
CPPFLAGS = -D_XOPEN_SOURCE -D_DARWIN_C_SOURCE -I. -I.ext/include/x86_64-darwin11.3.0 -I./include -I.
DLDFLAGS = -Wl,-undefined,dynamic_lookup -Wl,-multiply_defined,suppress -Wl,-flat_namespace -install_name /Users/squantowalks/.rvm/rubies/ruby-1.9.3-p125/lib/libruby.1.9.1.dylib -current_version 1.9.1 -compatibility_version 1.9.1 -Wl,-unexported_symbol,_Init_* -Wl,-unexported_symbol,*_threadptr_* -Wl,-u,_objc_msgSend
SOLIBS =
linking miniruby
<internal:prelude>:1: [BUG] Bus Error
ruby 1.9.3p125 (2012-02-16 revision 34643) [universal.x86_64-darwin11.3.0]
-- Control frame information -----------------------------------------------
c:0003 p:0002 s:0006 b:0006 l:000005 d:000005 TOP <internal:prelude>:1
c:0002 p:---- s:0004 b:0004 l:000003 d:000003 FINISH
c:0001 p:0000 s:0002 b:0002 l:0025e8 d:0025e8 TOP
-- Ruby level backtrace information ----------------------------------------
<internal:prelude>:1:in `<compiled>'
-- C level backtrace information -------------------------------------------
See Crash Report log file under ~/Library/Logs/CrashReporter or
/Library/Logs/CrashReporter, for the more detail of.
-- Other runtime information -----------------------------------------------
* Loaded script: ./miniruby
* Loaded features:
0 enumerator.so
[NOTE]
You may have encountered a bug in the Ruby interpreter or extension libraries.
Bug reports are welcome.
For details: http://www.ruby-lang.org/bugreport.html
make: *** [.rbconfig.time] Abort trap: 6
谢谢:)
编辑:安装 macports 和 apple 的 4.2 gcc(谢谢大家)后,我得到了这个:
hugo-pc:bin squantowalks$ CC=/opt/local/bin/gcc-apple-4.2 rvm install 1.9.3Fetching yaml-0.1.4.tar.gz to /Users/squantowalks/.rvm/archives
Extracting yaml-0.1.4.tar.gz to /Users/squantowalks/.rvm/src
Error running 'tar xmzf /Users/squantowalks/.rvm/archives/yaml-0.1.4.tar.gz -C /Users/squantowalks/.rvm/src ', please read /Users/squantowalks/.rvm/log/ruby-1.9.3-p125/yaml/extract.log
Configuring yaml in /Users/squantowalks/.rvm/src/yaml-0.1.4.
Error running ' ./configure --prefix="/Users/squantowalks/.rvm/usr" ', please read /Users/squantowalks/.rvm/log/ruby-1.9.3-p125/yaml/configure.log
Compiling yaml in /Users/squantowalks/.rvm/src/yaml-0.1.4.
Error running 'make ', please read /Users/squantowalks/.rvm/log/ruby-1.9.3-p125/yaml/make.log
Installing Ruby from source to: /Users/squantowalks/.rvm/rubies/ruby-1.9.3-p125, this may take a while depending on your cpu(s)...
ruby-1.9.3-p125 - #fetching
ruby-1.9.3-p125 - #extracted to /Users/squantowalks/.rvm/src/ruby-1.9.3-p125 (already extracted)
ruby-1.9.3-p125 - #configuring
ruby-1.9.3-p125 - #compiling
Error running 'make ', please read /Users/squantowalks/.rvm/log/ruby-1.9.3-p125/make.log
There has been an error while running make. Halting the installation.
这是控制台日志:
[2012-03-08 20:05:01] make
CC = /opt/local/bin/i686-apple-darwin11-gcc-apple-4.2.1
LD = ld
LDSHARED = /opt/local/bin/i686-apple-darwin11-gcc-apple-4.2.1 -dynamiclib -O3 -ggdb -Wextra -Wno-unused-parameter -Wno-parentheses -Wno-long-long -Wno-missing-field-initializers -Werror=pointer-arith -Werror=write-strings -Werror=declaration-after-statement -Werror=shorten-64-to-32 -Werror=implicit-function-declaration -fno-common -pipe -L. -L/usr/local/lib
CFLAGS = -O3 -ggdb -Wextra -Wno-unused-parameter -Wno-parentheses -Wno-long-long -Wno-missing-field-initializers -Werror=pointer-arith -Werror=write-strings -Werror=declaration-after-statement -Werror=shorten-64-to-32 -Werror=implicit-function-declaration -fno-common -pipe
XCFLAGS = -include ruby/config.h -include ruby/missing.h -fvisibility=hidden -DRUBY_EXPORT
CPPFLAGS = -D_XOPEN_SOURCE -D_DARWIN_C_SOURCE -I. -I.ext/include/i386-darwin11.3.0 -I./include -I.
DLDFLAGS = -Wl,-undefined,dynamic_lookup -Wl,-multiply_defined,suppress -Wl,-flat_namespace -install_name /Users/squantowalks/.rvm/rubies/ruby-1.9.3-p125/lib/libruby.1.9.1.dylib -current_version 1.9.1 -compatibility_version 1.9.1 -Wl,-unexported_symbol,_Init_* -Wl,-unexported_symbol,*_threadptr_* -Wl,-u,_objc_msgSend
SOLIBS =
linking miniruby
ld: warning: ignoring file dmyext.o, file was built for unsupported file format which is not the architecture being linked (i386)
Undefined symbols for architecture i386:
"_Init_ext", referenced from:
_require_libraries in ruby.o
ld: symbol(s) not found for architecture i386
collect2: ld returned 1 exit status
make: *** [miniruby] Error 1
make: *** [miniruby] Error 1
he architecture being linked (x86_64)
ld: warning: ignoring file miniprelude.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file array.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file bignum.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file class.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file compar.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file complex.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file dir.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file dln_find.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file enum.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file enumerator.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file error.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file eval.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file load.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file proc.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file file.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file gc.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file hash.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file inits.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file io.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file marshal.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file math.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file node.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file numeric.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file object.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file pack.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file parse.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file process.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file random.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file range.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file rational.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file re.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file regcomp.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file regenc.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file regerror.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file regexec.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file regparse.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file regsyntax.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file ruby.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file safe.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file signal.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file sprintf.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file st.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file strftime.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file string.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file struct.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file time.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file transcode.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file util.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file variable.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file compile.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file debug.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file iseq.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file vm.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file vm_dump.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file thread.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file cont.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file ascii.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file us_ascii.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file unicode.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file utf_8.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file newline.o, file was built for i386 which is not the architecture being linked (x86_64)
ld: warning: ignoring file setproctitle.o, file was built for i386 which is not the architecture being linked (x86_64)
Undefined symbols for architecture x86_64:
"_main", referenced from:
start in crt1.10.6.o
ld: symbol(s) not found for architecture x86_64
collect2: ld returned 1 exit status
make: *** [miniruby] Error 1
想法?
编辑:Jared。当我添加 --with-gcc=clang 时,日志看起来像
[2012-03-08 21:20:12] make
CC = clang
LD = ld
LDSHARED = clang -dynamiclib
CFLAGS = -O3 -ggdb -Wextra -Wno-unused-parameter -Wno-parentheses -Wno-long-long -Wno-missing-field-initializers -Werror=pointer-arith -Werror=write-strings -Werror=declaration-after-statement -Werror=shorten-64-to-32 -Werror=implicit-function-declaration -fno-common -pipe
XCFLAGS = -include ruby/config.h -include ruby/missing.h -fvisibility=hidden -DRUBY_EXPORT
CPPFLAGS = -D_XOPEN_SOURCE -D_DARWIN_C_SOURCE -I. -I.ext/include/x86_64-darwin11.3.0 -I./include -I.
DLDFLAGS = -Wl,-undefined,dynamic_lookup -Wl,-multiply_defined,suppress -Wl,-flat_namespace -install_name /Users/squantowalks/.rvm/rubies/ruby-1.9.3-p125/lib/libruby.1.9.1.dylib -current_version 1.9.1 -compatibility_version 1.9.1 -Wl,-unexported_symbol,_Init_* -Wl,-unexported_symbol,*_threadptr_* -Wl,-u,_objc_msgSend
SOLIBS =
compiling main.c
compiling dmydln.c
compiling dmyencoding.c
compiling version.c
compiling dmyversion.c
compiling miniprelude.c
compiling array.c
compiling bignum.c
compiling class.c
compiling compar.c
compiling complex.c
compiling dir.c
compiling dln_find.c
compiling enum.c
compiling enumerator.c
compiling error.c
compiling eval.c
compiling load.c
compiling proc.c
compiling file.c
compiling gc.c
compiling hash.c
compiling inits.c
compiling io.c
io.c:997:2: warning: expression result unused [-Wunused-value]
SET_BINARY_MODE(fptr);
^~~~~~~~~~~~~~~~~~~~~
io.c:330:31: note: instantiated from:
#define SET_BINARY_MODE(fptr) 0
^
io.c:1953:2: warning: expression result unused [-Wunused-value]
SET_BINARY_MODE(fptr);
^~~~~~~~~~~~~~~~~~~~~
io.c:330:31: note: instantiated from:
#define SET_BINARY_MODE(fptr) 0
^
io.c:1975:5: warning: expression result unused [-Wunused-value]
NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:331:52: note: instantiated from:
#define NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr) 0
^
io.c:2409:2: warning: expression result unused [-Wunused-value]
SET_BINARY_MODE(fptr);
^~~~~~~~~~~~~~~~~~~~~
io.c:330:31: note: instantiated from:
#define SET_BINARY_MODE(fptr) 0
^
io.c:2452:5: warning: expression result unused [-Wunused-value]
NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:331:52: note: instantiated from:
#define NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr) 0
^
io.c:2491:2: warning: expression result unused [-Wunused-value]
SET_BINARY_MODE(fptr);
^~~~~~~~~~~~~~~~~~~~~
io.c:330:31: note: instantiated from:
#define SET_BINARY_MODE(fptr) 0
^
io.c:2515:5: warning: expression result unused [-Wunused-value]
NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:331:52: note: instantiated from:
#define NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr) 0
^
io.c:2652:2: warning: expression result unused [-Wunused-value]
NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:331:52: note: instantiated from:
#define NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr) 0
^
io.c:2662:2: warning: expression result unused [-Wunused-value]
SET_BINARY_MODE(fptr);
^~~~~~~~~~~~~~~~~~~~~
io.c:330:31: note: instantiated from:
#define SET_BINARY_MODE(fptr) 0
^
io.c:3012:2: warning: expression result unused [-Wunused-value]
SET_BINARY_MODE(fptr);
^~~~~~~~~~~~~~~~~~~~~
io.c:330:31: note: instantiated from:
#define SET_BINARY_MODE(fptr) 0
^
io.c:3057:5: warning: expression result unused [-Wunused-value]
NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:331:52: note: instantiated from:
#define NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr) 0
^
io.c:3172:2: warning: expression result unused [-Wunused-value]
SET_BINARY_MODE(fptr);
^~~~~~~~~~~~~~~~~~~~~
io.c:330:31: note: instantiated from:
#define SET_BINARY_MODE(fptr) 0
^
io.c:3213:5: warning: expression result unused [-Wunused-value]
NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:331:52: note: instantiated from:
#define NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr) 0
^
io.c:3417:2: warning: expression result unused [-Wunused-value]
SET_BINARY_MODE(fptr);
^~~~~~~~~~~~~~~~~~~~~
io.c:330:31: note: instantiated from:
#define SET_BINARY_MODE(fptr) 0
^
io.c:3437:2: warning: expression result unused [-Wunused-value]
NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:331:52: note: instantiated from:
#define NEED_NEWLINE_DECORATOR_ON_READ_CHECK(fptr) 0
^
io.c:4173:5: warning: expression result unused [-Wunused-value]
SET_BINARY_MODE_WITH_SEEK_CUR(fptr);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:333:45: note: instantiated from:
#define SET_BINARY_MODE_WITH_SEEK_CUR(fptr) 0
^
io.c:4696:2: warning: expression result unused [-Wunused-value]
SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:332:64: note: instantiated from:
#define SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags) 0
^
io.c:4743:2: warning: expression result unused [-Wunused-value]
SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:332:64: note: instantiated from:
#define SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags) 0
^
io.c:8236:2: warning: expression result unused [-Wunused-value]
SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:332:64: note: instantiated from:
#define SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags) 0
^
io.c:8243:6: warning: expression result unused [-Wunused-value]
SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:332:64: note: instantiated from:
#define SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags) 0
^
io.c:8250:3: warning: expression result unused [-Wunused-value]
SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:332:64: note: instantiated from:
#define SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags) 0
^
io.c:8255:3: warning: expression result unused [-Wunused-value]
SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags);
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
io.c:332:64: note: instantiated from:
#define SET_UNIVERSAL_NEWLINE_DECORATOR_IF_ENC2(enc2, ecflags) 0
^
22 warnings generated.
compiling marshal.c
compiling math.c
compiling node.c
compiling numeric.c
compiling object.c
compiling pack.c
compiling parse.c
compiling process.c
compiling random.c
compiling range.c
compiling rational.c
compiling re.c
compiling regcomp.c
compiling regenc.c
compiling regerror.c
compiling regexec.c
compiling regparse.c
compiling regsyntax.c
compiling ruby.c
compiling safe.c
compiling signal.c
compiling sprintf.c
compiling st.c
compiling strftime.c
compiling string.c
compiling struct.c
compiling time.c
compiling transcode.c
compiling util.c
compiling variable.c
compiling compile.c
compiling debug.c
compiling iseq.c
compiling vm.c
compiling vm_dump.c
compiling thread.c
compiling cont.c
compiling ./enc/ascii.c
compiling ./enc/us_ascii.c
compiling ./enc/unicode.c
compiling ./enc/utf_8.c
compiling newline.c
compiling ./missing/setproctitle.c
linking miniruby
<internal:prelude>:1: [BUG] Bus Error
ruby 1.9.3p125 (2012-02-16 revision 34643) [x86_64-darwin11.3.0]
-- Control frame information -----------------------------------------------
c:0003 p:0002 s:0006 b:0006 l:000005 d:000005 TOP <internal:prelude>:1
c:0002 p:---- s:0004 b:0004 l:000003 d:000003 FINISH
c:0001 p:0000 s:0002 b:0002 l:000e28 d:000e28 TOP
-- Ruby level backtrace information ----------------------------------------
<internal:prelude>:1:in `<compiled>'
-- C level backtrace information -------------------------------------------
See Crash Report log file under ~/Library/Logs/CrashReporter or
/Library/Logs/CrashReporter, for the more detail of.
-- Other runtime information -----------------------------------------------
* Loaded script: ./miniruby
* Loaded features:
0 enumerator.so
[NOTE]
You may have encountered a bug in the Ruby interpreter or extension libraries.
Bug reports are welcome.
For details: http://www.ruby-lang.org/bugreport.html
make: *** [.rbconfig.time] Abort trap: 6
编辑:感谢大家的帮助 :),终于弄明白了。这是我所做的 sparknotes 版本:
(如果您不熟悉命令行,http://jewelrybox.unfiniti.com/ 真是天赐之物)。
获取 XCode (https://developer.apple.com/xcode/) 需要一起编译代码。但是,您还需要 gcc,它没有随最新版本的 XCode 一起打包。苏....
访问此处 (https://developer.apple.com/downloads/index.action) 并下载“XCode 命令行工具”,运行简单直接。
安装了 Macports (http://www.macports.org/install.php ) 这样我就可以...
通过终端安装 make(port install make)。不知道它做了什么,但终端在安装前给出了错误,之后没有错误。
现在我们准备好摇滚了:)
运行(rvm 安装 1.9.3) 出去玩一会儿。这需要一段时间。
然后(rvm 1.9.3 --default)
然后(gem 安装导轨) 安装 Ruby on Rails。这也需要一段时间。
设置好 Rails 3 后,我制作了一个测试应用程序。 (rails new tester) - 构建目录 (cd tester)- 移动到新目录
(rails server) - 设置服务器
然后,上网访问 (http://localhost:3000)。如果一切顺利,您应该会在浏览器中看到 welcome to rails。
最佳答案
我自己刚遇到这个问题,这似乎是 ruby-1.9.3-125 如何与 clang 一起工作的问题。一旦我针对 gcc 运行它,它就像一个魅力。
检查以确保您已使用 which gcc-4.2 安装了实际的 gcc。如果不是,则需要安装 Xcode 或类似于 os x gcc installer 的东西.如果安装运行 rvm install 1.9.3 --with-gcc=gcc-4.2 就是我的诀窍。
关于ruby - 如何在 OSX Lion 上安装(构建)Ruby 1.9.3?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9626729/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
这似乎应该有一个直截了当的答案,但在Google上花了很多时间,所以我找不到它。这可能是缺少正确关键字的情况。在我的RoR应用程序中,我有几个模型共享一种特定类型的字符串属性,该属性具有特殊验证和其他功能。我能想到的最接近的类似示例是表示URL的字符串。这会导致模型中出现大量重复(甚至单元测试中会出现更多重复),但我不确定如何让它更DRY。我能想到几个可能的方向...按照“validates_url_format_of”插件,但这只会让验证干给这个特殊的字符串它自己的模型,但这看起来很像重溶液为这个特殊的字符串创建一个ruby类,但是我如何得到ActiveRecord关联这个类模型
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits