The Ruby Programming Language [mirror]
Go to file
nobu dd3851d278 Rename test classes to allow stable test count when running test-all -j
[Fix GH-1763]

From: MSP-Greg <MSP-Greg@users.noreply.github.com>

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@62738 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2018-03-13 06:29:02 +00:00
basictest
benchmark use `--version`. 2018-02-21 08:51:49 +00:00
bin erb.rb: deprecate safe_level of ERB.new 2018-02-22 13:28:25 +00:00
bootstraptest error.c: bypass Exception.new 2018-02-20 10:08:27 +00:00
ccan
coverage
cygwin
defs defs/id.def: predefine to_f ID 2018-02-27 08:15:27 +00:00
doc Fix a typo [ci skip] 2018-03-08 13:00:04 +00:00
enc Refactor ERB version checking for keyword arguments 2018-02-27 11:12:23 +00:00
ext ripper: fix escaped space 2018-03-12 07:55:17 +00:00
gems Update minitest-5.11.3 on bundled gems. 2018-02-23 05:09:11 +00:00
include Signature of rb_uint2inum and rb_int2inum 2018-02-20 09:38:55 +00:00
lib Hash instead of Set 2018-03-13 01:28:28 +00:00
man
misc
missing
sample erb.rb: deprecate safe_level of ERB.new 2018-02-22 13:28:25 +00:00
spec Bug Fix Enumerator::Lazy#uniq state for multiple call 2018-03-13 01:00:08 +00:00
template configure.ac: library options to MAINLIBS 2018-03-02 01:37:53 +00:00
test Rename test classes to allow stable test count when running test-all -j 2018-03-13 06:29:02 +00:00
tool Add direct marking on iseq operands 2018-03-09 20:11:45 +00:00
win32 configure.ac: --disable-mathn option 2018-03-09 04:24:48 +00:00
.document
.editorconfig
.gdbinit .gdbinit (print_lineno): support a succinct bitvector implementation [ci skip] 2018-02-10 06:02:37 +00:00
.gitattributes
.gitignore Ignore rb_mjit_min_header- instead of rb_mjit_header- 2018-02-22 07:34:43 +00:00
.indent.pro
.travis.yml .travis.yml: resurrect notification to #commits 2018-02-11 06:33:45 +00:00
BSDL
CONTRIBUTING.md
COPYING
COPYING.ja
GPL
KNOWNBUGS.rb
LEGAL Update url with 404 status on LEGAL file. 2018-02-21 07:12:17 +00:00
Makefile.in configure.ac: --disable-mathn option 2018-03-09 04:24:48 +00:00
NEWS NEWS: resurrect ticket number [ci skip] 2018-02-28 14:31:17 +00:00
README.EXT
README.EXT.ja
README.ja.md README.ja.md: Mac OS X -> macOS [ci skip] 2018-02-18 08:11:50 +00:00
README.md README.md: removed unnecessary schemes 2018-03-05 07:21:54 +00:00
aclocal.m4 aclocal.m4: remove ruby_check_va_copy.m4 2018-02-18 05:12:26 +00:00
addr2line.c
addr2line.h
appveyor.yml appveyor.yml: refactor r62402 2018-02-14 14:09:32 +00:00
array.c Add a new #filter alias for #select 2018-02-25 13:52:07 +00:00
bignum.c rb_int_powm: call rb_int_pow directly 2018-02-24 15:36:09 +00:00
class.c
common.mk mjit_compile.c: use local variables for stack 2018-03-04 07:04:40 +00:00
compar.c
compile.c compile.c: mark all ISeq ancestors as catch_except_p 2018-03-10 14:52:12 +00:00
complex.c Removed useless assertions [ci skip] 2018-03-09 03:51:04 +00:00
configure.ac configure.ac: --disable-mathn option 2018-03-09 04:24:48 +00:00
constant.h vm_insnhelper.c: rb_autoloading_value flag 2018-02-13 09:34:43 +00:00
cont.c
debug.c
debug_counter.c
debug_counter.h debug_counter.h: include __FILE__ to recurse 2018-02-09 03:15:21 +00:00
dir.c [DOC] missing docs at toplevel 2018-02-23 02:18:52 +00:00
dln.c
dln.h
dln_find.c
dmydln.c
dmyenc.c
dmyext.c
encindex.h
encoding.c
enum.c Add a new #filter alias for #select 2018-02-25 13:52:07 +00:00
enumerator.c Bug Fix Enumerator::Lazy#uniq state for multiple call 2018-03-13 01:00:08 +00:00
error.c Add missing class FrozenError to Exception subclasses list documentation 2018-03-13 02:00:42 +00:00
eval.c vm.c: disable dtrace in jit source 2018-02-20 03:15:33 +00:00
eval_error.c eval_error.c: reset attributes 2018-03-13 03:48:56 +00:00
eval_intern.h
eval_jump.c
file.c file.c: realpath on special symlink 2018-02-28 05:43:53 +00:00
gc.c [DOC] missing docs at toplevel 2018-02-23 02:18:52 +00:00
gc.h
gem_prelude.rb
golf_prelude.rb
goruby.c
hash.c Add a new #filter alias for #select 2018-02-25 13:52:07 +00:00
ia64.s
id_table.c
id_table.h
inits.c
insns.def Add direct marking on iseq operands 2018-03-09 20:11:45 +00:00
internal.h mjit.c: no va_copy 2018-02-18 05:10:52 +00:00
io.c [DOC] missing docs at toplevel 2018-02-23 02:18:52 +00:00
iseq.c Fix warning: cast from pointer to integer of different size 2018-03-10 00:34:24 +00:00
iseq.h Fix error: implicit conversion loses integer precision 2018-03-10 00:33:11 +00:00
lex.c.blt
load.c load.c: reduce memory usage of loaded_features_index 2018-02-14 18:38:33 +00:00
loadpath.c
localeinit.c
main.c
marshal.c
math.c math.c: calling order 2018-03-09 03:57:34 +00:00
method.h
miniinit.c
mjit.c mjit.c: keep mutex unlocked on destroy 2018-03-10 07:05:32 +00:00
mjit.h mjit.h: compare as pointer 2018-02-14 05:11:02 +00:00
mjit_compile.c mjit_compile.c: use local variables for stack 2018-03-04 07:04:40 +00:00
node.c
node.h
numeric.c [DOC] obsolete classes 2018-02-23 02:16:43 +00:00
object.c object.c: conversions with ID 2018-03-07 07:43:07 +00:00
pack.c
parse.y ripper: fix escaped space 2018-03-12 07:55:17 +00:00
prelude.rb
probes.d
probes_helper.h vm.c: disable dtrace in jit source 2018-02-20 03:15:33 +00:00
proc.c no ID cache in Init functions 2018-02-16 08:39:48 +00:00
process.c guard before noreturn function 2018-02-25 03:08:40 +00:00
random.c random.c: Random.extend Formatter 2018-02-27 13:28:31 +00:00
range.c Use RB_INTEGER_TYPE_P instead of rb_obj_is_kind_of 2018-02-26 07:57:15 +00:00
rational.c Removed useless assertions [ci skip] 2018-03-09 03:51:04 +00:00
re.c re.c: fixed escaped multibyte char 2018-03-11 00:05:12 +00:00
regcomp.c
regenc.c
regenc.h
regerror.c
regexec.c
regint.h
regparse.c
regparse.h
regsyntax.c
ruby-runner.c
ruby.c ruby.c: fix typo in r62530 2018-02-22 15:29:33 +00:00
ruby_assert.h
ruby_atomic.h
rubystub.c
safe.c
signal.c signal.c: refine error messages 2018-03-10 11:26:54 +00:00
siphash.c
siphash.h
sparc.c
sprintf.c
st.c st.c: retry operations if rebuilt 2018-02-13 10:02:07 +00:00
strftime.c
string.c
struct.c
symbol.c
symbol.h
thread.c thread.c: deadlock in backtrace 2018-03-06 05:15:57 +00:00
thread_pthread.c Tiny Fix for ASYNC BUG error message copying 2018-03-05 06:56:09 +00:00
thread_pthread.h
thread_sync.c thread.c: reset waitq of keeping mutexes in child 2018-03-05 22:58:13 +00:00
thread_win32.c
thread_win32.h
time.c
timev.h
transcode.c [DOC] missing docs at toplevel 2018-02-23 02:18:52 +00:00
transcode_data.h
util.c
variable.c variable.c: flags at autoloading 2018-02-13 09:36:35 +00:00
version.c version.h: get rid of duplication 2018-02-24 02:55:03 +00:00
version.h * 2018-03-13 2018-03-12 15:19:38 +00:00
vm.c add prefix to the function name. 2018-03-05 01:17:08 +00:00
vm_args.c
vm_backtrace.c
vm_core.h Fix error: implicit conversion loses integer precision 2018-03-10 00:33:11 +00:00
vm_debug.h
vm_dump.c
vm_eval.c vm.c: add mjit_enable_p flag 2018-03-03 04:07:02 +00:00
vm_exec.c vm_exec.c: reduced repeated same calls 2018-03-04 01:52:19 +00:00
vm_exec.h mjit_compile.c: use local variables for stack 2018-03-04 07:04:40 +00:00
vm_insnhelper.c Add direct marking on iseq operands 2018-03-09 20:11:45 +00:00
vm_insnhelper.h mjit_compile.c: use local variables for stack 2018-03-04 07:04:40 +00:00
vm_method.c Fix setting method visibility on method wrapped with prepend 2018-03-12 06:54:43 +00:00
vm_opts.h
vm_trace.c
vsnprintf.c

README.md

Build Status Build 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://bugs.ruby-lang.org/projects/ruby-trunk/wiki/SupportedPlatforms

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 Ruby distribution files can be found on the following FTP site:

ftp://ftp.ruby-lang.org/pub/ruby/

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 git://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