The Ruby Programming Language [mirror]
Go to file
duerst 448e86d796 add clarification about details of update to Unicode 11.0.0 [ci skip]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@66322 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2018-12-11 00:44:24 +00:00
basictest
benchmark Add benchmark for hash small literals 2018-12-06 18:20:11 +00:00
bin Regenerated binstubs of bundler, rdoc and irb. 2018-11-28 03:10:09 +00:00
bootstraptest Simply treat IO::WaitReadable just like Errno::EAGAIN 2018-11-20 05:18:28 +00:00
ccan
coroutine Native coroutine implementation for ppc64le Linux 2018-12-10 23:22:56 +00:00
coverage
cygwin
defs Add separator for test/-ext- 2018-12-06 05:29:04 +00:00
doc [DOC] rational and imaginary literals [ci skip] 2018-11-17 01:21:18 +00:00
enc implement special behavior for Georgian for String#capitalize 2018-12-09 23:14:29 +00:00
ext zlib (gzfile_write_raw): do not resize string after .write call 2018-12-07 07:09:31 +00:00
gems Bump rake-12.3.2 on bundled gems. 2018-12-07 10:00:21 +00:00
include Define HAVE_STMT_AND_DECL_IN_EXPR and use it [Bug #15293] 2018-12-10 13:58:36 +00:00
lib ReFix r663197 2018-12-11 00:36:46 +00:00
libexec Revert "Remove `libexec/bundle_ruby`" 2018-12-05 11:29:56 +00:00
man Updated dates in man pages 2018-12-10 01:57:48 +00:00
misc ruby-style.el: ruby-style-c-mode by VCS [ci skip] 2018-11-27 13:47:49 +00:00
missing
sample Fix typo in trick2018/README [ci skip] 2018-12-03 10:35:13 +00:00
spec Array#any? just returns true/false 2018-12-07 14:37:28 +00:00
template Let sub-directory exts depend on their parent ext 2018-12-01 09:29:14 +00:00
test Preserve HTTP header key as string [Bug #15394] 2018-12-10 23:54:14 +00:00
tool Limit uplevel travarsing 2018-12-10 01:58:28 +00:00
win32 win32/Makefile.sub: missing dependency of mjit_config.h 2018-12-10 02:58:01 +00:00
.document Include LEGAL in .document [ci skip] 2018-12-01 12:05:37 +00:00
.editorconfig
.gdbinit support theap for T_HASH. [Feature #14989] 2018-10-30 22:11:51 +00:00
.gitattributes
.gitignore Use BUILDDIR in ruby-runner.h from config.status 2018-12-08 01:49:02 +00:00
.indent.pro
.travis.yml .travis.yml: config_2nd may not exist in ~/ 2018-12-04 13:15:24 +00:00
BSDL
CONTRIBUTING.md
COPYING
COPYING.ja
GPL
KNOWNBUGS.rb
LEGAL LEGAL: gathered util.c [ci skip] 2018-12-10 12:43:16 +00:00
Makefile.in Honor configured ruby header locations as the MJIT header path 2018-12-08 02:20:14 +00:00
NEWS add clarification about details of update to Unicode 11.0.0 [ci skip] 2018-12-11 00:44:24 +00:00
README.EXT
README.EXT.ja
README.ja.md
README.md README.md: add wercker status badge [ci skip] 2018-11-02 12:21:59 +00:00
aclocal.m4
addr2line.c Show function name based on dladdr 2018-11-20 22:40:21 +00:00
addr2line.h Support Mach-O on backtrace with DWARF 2018-10-20 06:35:25 +00:00
appveyor.yml Try with TZInfo and Timezone gems 2018-11-28 14:08:34 +00:00
array.c implement Array-specific #all?, #none?, #one? 2018-12-05 04:25:44 +00:00
ast.c Refine RubyVM::AbstractSyntaxTree::Node#type 2018-12-03 01:06:34 +00:00
bignum.c bignum.c: fix bug in big2dbl() 2018-11-16 03:34:53 +00:00
class.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-05 01:09:44 +00:00
common.mk Use BUILDDIR in ruby-runner.h from config.status 2018-12-08 01:49:02 +00:00
compar.c
compile.c raise instead of rb_bug 2018-12-09 01:34:23 +00:00
complex.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-04 02:24:15 +00:00
configure.ac Native coroutine implementation for ppc64le Linux 2018-12-10 23:22:56 +00:00
constant.h
cont.c Avoid GCing dead stack after switching away from a fiber 2018-12-01 03:49:52 +00:00
debug.c
debug_counter.c
debug_counter.h support theap for T_HASH. [Feature #14989] 2018-10-30 22:11:51 +00:00
dir.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-05 01:09:44 +00:00
dln.c
dln.h
dln_find.c
dmydln.c
dmyenc.c
dmyext.c
encindex.h
encoding.c
enum.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
enumerator.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
error.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
eval.c process.c: avoid dlclose before exec 2018-11-26 15:12:31 +00:00
eval_error.c eval_error.c: log10(0) is ERANGE 2018-11-15 09:03:03 +00:00
eval_intern.h
eval_jump.c
file.c file.c: use correct integer-conversion function 2018-10-23 12:23:04 +00:00
gc.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
gc.h
gem_prelude.rb
golf_prelude.rb
goruby.c
hash.c Initialize bin 2018-12-10 02:01:21 +00:00
hrtime.h
ia64.S Change Makefile rule for assembly to use .S rather than .s 2018-11-24 11:35:29 +00:00
id_table.c
id_table.h
inits.c initialize VM postponed_job first. [Bug #15288] 2018-11-08 05:35:46 +00:00
insns.def Speed up hash literals by duping 2018-12-06 18:28:21 +00:00
internal.h Add missing declaration to export 2018-12-06 15:33:54 +00:00
io.c io.c (io_fflush): eliminate redundant rb_io_check_closed 2018-12-06 10:41:07 +00:00
iseq.c Return same ISeq object for one src. 2018-12-06 10:52:27 +00:00
iseq.h `script_compiled` TracePoint event [Feature #15287] 2018-12-06 13:42:32 +00:00
lex.c.blt
load.c `script_compiled` TracePoint event [Feature #15287] 2018-12-06 13:42:32 +00:00
loadpath.c
localeinit.c
main.c
marshal.c avoid division by zero 2018-11-16 01:52:39 +00:00
math.c
method.h Revert "Symbol refinements" 2018-12-04 04:22:08 +00:00
miniinit.c
mjit.c Removed never-happening case 2018-12-09 01:22:16 +00:00
mjit.h vm_trace.c: MJIT-limited thread-safety for postponed_job 2018-11-26 15:47:20 +00:00
mjit_compile.c mjit.c: copy call cache values to MJIT worker 2018-10-21 14:23:24 +00:00
mjit_worker.c Enable MJIT on AIX 2018-12-04 22:19:09 +00:00
node.c Removed unreachable code 2018-10-12 12:54:21 +00:00
node.h Parse the source in SCRIPT_LINES__ as array 2018-11-10 11:40:33 +00:00
numeric.c Make some internal functions static 2018-11-16 06:52:00 +00:00
object.c Show the class of the receiver [Feature #15231] 2018-12-06 23:03:54 +00:00
pack.c pack.c: cast from double to float can be undefined 2018-11-16 09:04:34 +00:00
parse.y Fix locations of NODE_UNDEF in undef with multiple args 2018-11-25 12:31:35 +00:00
prelude.rb `TracePoint#enable(target_line:)` is supported. [Feature #15289] 2018-11-26 20:16:14 +00:00
probes.d
probes_helper.h
proc.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
process.c process.c (retry_fork_async_signal_safe): fix -Wclobbered 2018-12-04 01:41:55 +00:00
random.c suppress integer overflow warnings 2018-11-13 00:40:52 +00:00
range.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
rational.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
re.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-04 02:24:15 +00:00
regcomp.c
regenc.c
regenc.h
regerror.c regerror.c: lenghten MAX_ERROR_PAR_LEN to contain old property names 2018-10-16 09:10:56 +00:00
regexec.c
regint.h
regparse.c convert check for array length to assertion and comment out 2018-12-07 07:20:26 +00:00
regparse.h
regsyntax.c
ruby-runner.c Give the MJIT header path name 2018-12-08 01:50:39 +00:00
ruby.c ruby.c: do not surface MJIT to user 2018-11-19 14:00:49 +00:00
ruby_assert.h
ruby_atomic.h
rubystub.c
safe.c
signal.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
siphash.c
siphash.h blacklist UBSAN's unsigned integer overflow 2018-11-07 04:09:05 +00:00
sparc.c
sprintf.c
st.c Adjust reserved hash values 2018-12-07 12:03:16 +00:00
strftime.c Prefer `rb_fstring_lit` over `rb_fstring_cstr` 2018-10-13 09:59:22 +00:00
string.c implement special behavior for Georgian for String#capitalize 2018-12-09 23:14:29 +00:00
struct.c * expand tabs. 2018-11-05 08:02:31 +00:00
symbol.c
symbol.h
thread.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
thread_pthread.c Revert "thread_pthread.c: fix memory leak from fork loop leapfrog (v2)" 2018-12-08 22:04:43 +00:00
thread_pthread.h
thread_sync.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
thread_win32.c add disabling MJIT features option. 2018-10-20 06:53:00 +00:00
thread_win32.h
time.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
timev.h Timezone support by Time [Feature #14850] 2018-10-08 02:35:31 +00:00
transcode.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
transcode_data.h
transient_heap.c adopt sanitizer API 2018-11-06 10:06:07 +00:00
transient_heap.h introduce USE_TRANSIENT_HEAP to enable/disable theap. 2018-11-01 08:53:44 +00:00
util.c suppress integer overflow warnings 2018-11-15 07:34:01 +00:00
variable.c Prefer rb_check_arity when 0 or 1 arguments 2018-12-06 07:49:24 +00:00
version.c add disabling MJIT features option. 2018-10-20 06:53:00 +00:00
version.h * 2018-12-11 2018-12-10 15:48:49 +00:00
vm.c Return same ISeq object for one src. 2018-12-06 10:52:27 +00:00
vm_args.c Revert "Symbol refinements" 2018-12-04 04:22:08 +00:00
vm_backtrace.c Make some internal functions static 2018-11-16 06:52:00 +00:00
vm_core.h Return same ISeq object for one src. 2018-12-06 10:52:27 +00:00
vm_debug.h
vm_dump.c * expand tabs. [ci skip] 2018-11-07 12:48:39 +00:00
vm_eval.c `script_compiled` TracePoint event [Feature #15287] 2018-12-06 13:42:32 +00:00
vm_exec.c
vm_exec.h
vm_insnhelper.c Return same ISeq object for one src. 2018-12-06 10:52:27 +00:00
vm_insnhelper.h
vm_method.c Warn redefinitions of some methods on Object 2018-12-06 23:06:13 +00:00
vm_opts.h vm_opts.h: share USE_IC_FOR_IVAR as OPT_IC_FOR_IVAR 2018-10-14 11:25:36 +00:00
vm_trace.c * expand tabs. 2018-12-06 13:42:35 +00:00
vsnprintf.c avoid division by zero 2018-11-16 01:52:39 +00:00
wercker.yml wercker.yml: debug problematic test on test-all 2018-11-18 09:32:29 +00:00

README.md

Build Status Build status wercker status

What's Ruby

Ruby is the interpreted scripting language for quick and easy object-oriented programming. It has many features to process text files and to do system management tasks (as in Perl). It is simple, straight-forward, and extensible.

Features of Ruby

  • Simple Syntax
  • Normal Object-oriented Features (e.g. class, method calls)
  • Advanced Object-oriented Features (e.g. mix-in, singleton-method)
  • Operator Overloading
  • Exception Handling
  • Iterators and Closures
  • Garbage Collection
  • Dynamic Loading of Object Files (on some architectures)
  • Highly Portable (works on many Unix-like/POSIX compatible platforms as well as Windows, macOS, Haiku, etc.) cf. https://github.com/ruby/ruby/blob/trunk/doc/contributing.rdoc#platform-maintainers

How to get Ruby

For a complete list of ways to install Ruby, including using third-party tools like rvm, see:

https://www.ruby-lang.org/en/downloads/

The trunk of the Ruby source tree can be checked out with the following command:

$ svn co https://svn.ruby-lang.org/repos/ruby/trunk/ ruby

Or if you are using git then use the following command:

$ git clone https://github.com/ruby/ruby.git

There are some other branches under development. Try the following command to see the list of branches:

$ svn ls https://svn.ruby-lang.org/repos/ruby/branches/

Or if you are using git then use the following command:

$ git ls-remote https://github.com/ruby/ruby.git

Ruby home page

The URL of the Ruby home page is:

https://www.ruby-lang.org/

Mailing list

There is a mailing list to talk about Ruby. To subscribe to this list, please send the following phrase:

subscribe

in the mail body (not subject) to the address ruby-talk-request@ruby-lang.org.

How to compile and install

This is what you need to do to compile and install Ruby:

  1. If you want to use Microsoft Visual C++ to compile Ruby, read win32/README.win32 instead of this document.

  2. If ./configure does not exist or is older than configure.ac, run autoconf to (re)generate configure.

  3. Run ./configure, which will generate config.h and Makefile.

    Some C compiler flags may be added by default depending on your environment. Specify optflags=.. and warnflags=.. as necessary to override them.

  4. Edit defines.h if you need. Usually this step will not be needed.

  5. Remove comment mark(#) before the module names from ext/Setup (or add module names if not present), if you want to link modules statically.

    If you don't want to compile non static extension modules (probably on architectures which do not allow dynamic loading), remove comment mark from the line "#option nodynamic" in ext/Setup.

    Usually this step will not be needed.

  6. Run make.

    • On Mac, set RUBY_CODESIGN environment variable with a signing identity. It uses the identity to sign ruby binary. See also codesign(1).
  7. Optionally, run 'make check' to check whether the compiled Ruby interpreter works well. If you see the message "check succeeded", your Ruby works as it should (hopefully).

  8. Optionally, run make update-gems and make extract-gems.

    If you want to install bundled gems, run make update-gems and make extract-gems before running make install.

  9. Run 'make install'.

    This command will create the following directories and install files into them.

    • ${DESTDIR}${prefix}/bin
    • ${DESTDIR}${prefix}/include/ruby-${MAJOR}.${MINOR}.${TEENY}
    • ${DESTDIR}${prefix}/include/ruby-${MAJOR}.${MINOR}.${TEENY}/${PLATFORM}
    • ${DESTDIR}${prefix}/lib
    • ${DESTDIR}${prefix}/lib/ruby
    • ${DESTDIR}${prefix}/lib/ruby/${MAJOR}.${MINOR}.${TEENY}
    • ${DESTDIR}${prefix}/lib/ruby/${MAJOR}.${MINOR}.${TEENY}/${PLATFORM}
    • ${DESTDIR}${prefix}/lib/ruby/site_ruby
    • ${DESTDIR}${prefix}/lib/ruby/site_ruby/${MAJOR}.${MINOR}.${TEENY}
    • ${DESTDIR}${prefix}/lib/ruby/site_ruby/${MAJOR}.${MINOR}.${TEENY}/${PLATFORM}
    • ${DESTDIR}${prefix}/lib/ruby/vendor_ruby
    • ${DESTDIR}${prefix}/lib/ruby/vendor_ruby/${MAJOR}.${MINOR}.${TEENY}
    • ${DESTDIR}${prefix}/lib/ruby/vendor_ruby/${MAJOR}.${MINOR}.${TEENY}/${PLATFORM}
    • ${DESTDIR}${prefix}/lib/ruby/gems/${MAJOR}.${MINOR}.${TEENY}
    • ${DESTDIR}${prefix}/share/man/man1
    • ${DESTDIR}${prefix}/share/ri/${MAJOR}.${MINOR}.${TEENY}/system

    If Ruby's API version is 'x.y.z', the ${MAJOR} is 'x', the ${MINOR} is 'y', and the ${TEENY} is 'z'.

    NOTE: teeny of the API version may be different from one of Ruby's program version

    You may have to be a super user to install Ruby.

If you fail to compile Ruby, please send the detailed error report with the error log and machine/OS type, to help others.

Some extension libraries may not get compiled because of lack of necessary external libraries and/or headers, then you will need to run 'make distclean-ext' to remove old configuration after installing them in such case.

Copying

See the file COPYING.

Feedback

Questions about the Ruby language can be asked on the Ruby-Talk mailing list (https://www.ruby-lang.org/en/community/mailing-lists) or on websites like (https://stackoverflow.com).

Bug reports should be filed at https://bugs.ruby-lang.org. Read HowToReport for more information.

Contributing

See the file CONTRIBUTING.md

The Author

Ruby was originally designed and developed by Yukihiro Matsumoto (Matz) in 1995.

matz@ruby-lang.org