development fork of ruby/ruby
Перейти к файлу
hsbt d61b1e9eaa Added documentation
Added documentaiton for installation of bundled gems.

  [Bug #13724][ruby-core:81938]

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@59962 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2017-09-19 02:39:40 +00:00
basictest basictest: --run-opt option 2016-10-19 05:22:51 +00:00
benchmark benchmarks for String#scan 2017-08-04 04:25:12 +00:00
bin Rollback to v1.15.4 version. 2017-09-08 08:50:57 +00:00
bootstraptest bootstraptest/runner.rb: keyword argument 2017-06-21 01:34:33 +00:00
ccan
coverage
cygwin MFLAGS for nmake 2017-02-10 06:12:22 +00:00
defs vcs.rb: commit 2017-07-26 12:44:12 +00:00
doc Exclude Changelog files from documentation. 2017-09-01 03:34:18 +00:00
enc remove Unicode 9.0.0-related files 2017-09-06 08:12:02 +00:00
ext Use https instead of ftp for libffi downloading. 2017-09-19 02:25:16 +00:00
gems Update bundled gems. 2017-09-11 02:29:11 +00:00
include ruby.h: unnormalized Fixnum value 2017-09-07 03:24:08 +00:00
lib Define the MIME type for JSON in WEBrick::HTTPUtils::DefaultMimeTypes. 2017-09-19 01:54:28 +00:00
man * man/ruby.1: Move paragraph which is related to -S, not -s. 2017-08-04 17:05:43 +00:00
misc Import ruby-electric.el version 2.3.1 from upstream 2017-08-10 12:37:04 +00:00
missing string.c: for small crypt_data 2017-05-24 06:55:09 +00:00
nacl
sample Fix NoMethodError [ci skip] 2017-05-03 01:44:52 +00:00
spec Enabled temporary disabled examples of bundler rspec. 2017-09-19 00:37:38 +00:00
template pack insn_operand_info and insn_len_info 2017-08-22 04:40:16 +00:00
test parse.y: lex by lvar 2017-09-19 00:22:56 +00:00
tool make-snapshot: after-update 2017-09-17 06:50:31 +00:00
win32 LIBPATHENV on Windows 2017-09-13 15:28:16 +00:00
.document Exclude Changelog files from documentation. 2017-09-01 03:34:18 +00:00
.editorconfig Add *.gemspec to .editorconfig [ci skip] 2017-09-12 11:15:27 +00:00
.gdbinit output some strings without quotes 2017-09-12 12:49:38 +00:00
.gitattributes rename ruby-runner as bin/ruby 2017-09-15 17:42:00 +00:00
.gitignore rename ruby-runner as bin/ruby 2017-09-15 17:42:00 +00:00
.indent.pro
.travis.yml Update credentials for Travis/Slack integration. 2017-09-05 08:25:26 +00:00
BSDL
CONTRIBUTING.md
COPYING COPYING: expand tabs 2017-02-18 22:38:35 +00:00
COPYING.ja
GPL
KNOWNBUGS.rb gc.c: expand sorted pages 2017-06-22 00:59:54 +00:00
LEGAL replace copyrights by explanatory text in data files for GB2312/GB12345 mappings 2017-09-01 10:22:09 +00:00
Makefile.in Rename bin/ruby as exe/ruby 2017-09-17 04:14:51 +00:00
NEWS error.c: KeyError#receiver and KeyError#key 2017-09-18 08:05:53 +00:00
README.EXT
README.EXT.ja
README.ja.md README{,.ja}.md: Drop support for BeOS now that Haiku is stable since 2.3.0. [ci skip] 2016-09-13 12:26:04 +00:00
README.md Added documentation 2017-09-19 02:39:40 +00:00
acinclude.m4
aclocal.m4
addr2line.c get rid of strcpy 2016-12-26 09:28:46 +00:00
addr2line.h
appveyor.yml appveyor.yml: num of jobs 2017-06-18 01:15:35 +00:00
array.c array.c: refine binomial_coefficient 2017-08-30 08:26:16 +00:00
bignum.c bignum.c: fix inexact estimation 2017-04-15 15:29:09 +00:00
class.c non-keywords hash 2017-08-20 06:08:25 +00:00
common.mk Rename bin/ruby as exe/ruby 2017-09-17 04:14:51 +00:00
compar.c Comparable#clamp 2016-08-11 07:24:25 +00:00
compile.c intern instruction 2017-09-18 05:16:37 +00:00
complex.c complex.c: remove deprecated functions 2017-02-21 06:07:21 +00:00
configure.in configure.in: use newer libtool only 2017-09-18 07:52:58 +00:00
constant.h
cont.c cont.c: update comment to match r59776 [ci skip] 2017-09-12 18:41:05 +00:00
debug.c debug.c: add FMODE constants 2017-07-05 06:32:54 +00:00
debug_counter.c debug_counter.c: debug_counter_names [ci skip] 2017-03-10 07:18:03 +00:00
debug_counter.h rename absolute_path to realpath internally and introduce pathobj. 2017-06-01 00:05:33 +00:00
dir.c dir.c: fix up r59527 2017-08-08 10:43:19 +00:00
dln.c get rid of strcpy 2016-12-26 09:28:46 +00:00
dln.h
dln_find.c
dmydln.c
dmyenc.c
dmyext.c
encindex.h
encoding.c encoding.c: handle needmore error from rb_enc_precise_mbclen() 2016-12-14 12:32:42 +00:00
enum.c enum.c: make constant argument static 2017-08-11 02:44:30 +00:00
enumerator.c enumerator.c: fix nested maps 2017-06-10 10:26:32 +00:00
error.c error.c: KeyError#receiver and KeyError#key 2017-09-18 08:05:53 +00:00
eval.c vm_core.h: ruby_error_stackfatal 2017-08-21 06:46:46 +00:00
eval_error.c move fields to ec. 2017-06-28 14:27:49 +00:00
eval_intern.h UNALIGNED_MEMBER_ACCESS only for clang 2017-07-30 14:59:40 +00:00
eval_jump.c move fields to ec. 2017-06-28 14:27:49 +00:00
file.c file.c: [DOC] separators at dirname and basename 2017-09-16 11:50:56 +00:00
gc.c move th->machine to ec->machine. 2017-09-10 15:49:45 +00:00
gc.h thread.c: during GC for thread 2017-04-12 14:47:50 +00:00
gem_prelude.rb
golf_prelude.rb Use `%i`-literal instead of array of symbols 2017-09-07 12:31:50 +00:00
goruby.c goruby.c: FD leak [ci skip] 2017-03-09 03:38:06 +00:00
hash.c error.c: KeyError#receiver and KeyError#key 2017-09-18 08:05:53 +00:00
ia64.s
id_table.c adjust styles [ci skip] 2017-05-10 00:39:26 +00:00
id_table.h
inits.c
insns.def intern instruction 2017-09-18 05:16:37 +00:00
internal.h error.c: KeyError#receiver and KeyError#key 2017-09-18 08:05:53 +00:00
io.c File#path: Raise IOError when a file is O_TMPFILE 2017-08-31 11:14:36 +00:00
iseq.c Remove a meaningless local variable assignment 2017-08-21 13:38:35 +00:00
iseq.h Refactor the internal data format for coverage measurement 2017-09-03 14:26:06 +00:00
lex.c.blt
load.c move fields to ec. 2017-06-28 14:27:49 +00:00
loadpath.c
localeinit.c debug.c: parse locale and filesystem codepages 2017-06-06 03:45:02 +00:00
main.c main.c: RUBY_DEBUG_ENV in devel 2017-06-30 04:19:12 +00:00
marshal.c marshal.c: revert r57631 partially 2017-02-15 08:38:01 +00:00
math.c math.c: check argument to lgamma_r 2017-05-13 01:05:30 +00:00
method.h Revert r59612 2017-08-17 23:31:41 +00:00
miniinit.c
node.c Introduce NODE_UNLESS for branch coverage 2017-09-14 05:27:02 +00:00
node.h node.h: Remove a not used macro 2017-09-17 07:19:20 +00:00
numeric.c numeric.c: fix for small number 2017-05-27 01:26:31 +00:00
object.c object.c: fix conversion failure message 2017-09-15 02:01:59 +00:00
pack.c Workaround for optimization bug of Oracle Solaris Studio 12.4 and 12.5 2017-04-14 19:12:51 +00:00
parse.y parse.y: lex by lvar 2017-09-19 00:22:56 +00:00
prelude.rb Revert r57690 except for read_nonblock 2017-02-23 02:40:17 +00:00
probes.d
probes_helper.h
proc.c proc.c: [DOC] fixup r59720 2017-09-02 06:17:52 +00:00
process.c process.c: null bytes 2017-07-14 04:43:16 +00:00
random.c Random.urandom raises RuntimeError instead of returning nil 2017-09-13 12:46:13 +00:00
range.c Improve performance of Range#{min,max} 2017-05-30 02:57:33 +00:00
rational.c Improve performance of implicit type conversion 2017-05-31 12:30:57 +00:00
re.c re.c: remove unused rb_memcmp() function 2017-09-18 05:37:29 +00:00
regcomp.c Merge Onigmo 6.1.1 2017-02-11 15:08:33 +00:00
regenc.c Merge Onigmo 6.1.1 2017-02-11 15:08:33 +00:00
regenc.h fix UTF-32 valid_encoding? 2017-03-09 02:04:10 +00:00
regerror.c get rid of strcat 2016-12-26 09:28:47 +00:00
regexec.c Merge Onigmo 6.1.1 2017-02-11 15:08:33 +00:00
regint.h Merge Onigmo 6.1.1 2017-02-11 15:08:33 +00:00
regparse.c regparse.c: initialize return values 2017-02-20 09:46:12 +00:00
regparse.h Merge Onigmo 6.1.1 2017-02-11 15:08:33 +00:00
regsyntax.c Merge Onigmo 6.0.0 2016-12-10 17:47:04 +00:00
ruby-runner.c ruby-runner.c: reduce duplicate code 2017-09-15 19:25:46 +00:00
ruby.c ruby.c: ignore non-option in shebang line 2017-08-10 05:54:56 +00:00
ruby_assert.h
ruby_atomic.h
rubystub.c rubystub.c: sys/param.h for MAXPATHLEN 2016-08-20 05:58:58 +00:00
safe.c move several fields from rb_thread_t to rb_execution_context_t. 2017-06-26 07:56:44 +00:00
signal.c signal.c: fatal stack 2017-08-22 02:46:16 +00:00
siphash.c switch SipHash from SipHash24 to SipHash13 variant 2017-01-20 06:01:23 +00:00
siphash.h switch SipHash from SipHash24 to SipHash13 variant 2017-01-20 06:01:23 +00:00
sparc.c
sprintf.c error.c: KeyError#receiver and KeyError#key 2017-09-18 08:05:53 +00:00
st.c st.c: fix num_entries 2017-09-05 07:52:08 +00:00
strftime.c adjust styles [ci skip] 2017-05-10 00:39:26 +00:00
string.c refinements in string interpolation 2017-09-18 02:27:13 +00:00
struct.c struct.c: improve rdoc for Struct 2017-03-01 19:59:03 +00:00
symbol.c symbol.c (rb_id2str): eliminate branch to set class 2017-02-03 23:55:06 +00:00
symbol.h
thread.c thread.c: Clear an array for method coverage 2017-09-18 05:17:21 +00:00
thread_pthread.c move th->machine to ec->machine. 2017-09-10 15:49:45 +00:00
thread_pthread.h
thread_sync.c UNALIGNED_MEMBER_ACCESS 2017-07-30 14:48:45 +00:00
thread_win32.c move th->machine to ec->machine. 2017-09-10 15:49:45 +00:00
thread_win32.h
time.c time.c (Time#-): Fix documentation. 2017-09-14 14:54:29 +00:00
timev.h
transcode.c * lib/net/http/header.rb: Fix typo. [ci skip][fix GH-1407] 2016-08-16 02:18:51 +00:00
transcode_data.h
util.c Merge latest dtoa.c [Bug #13545] 2017-05-19 14:14:52 +00:00
variable.c variable.c (autoload_sleep_done): avoid needless list_node init 2017-05-22 23:41:50 +00:00
version.c
version.h * 2017-09-19 2017-09-19 00:22:57 +00:00
vm.c vm.c: fix `cfp consistency error' which occurs 2017-09-18 08:21:08 +00:00
vm_args.c vm_args.c: prefer optarg to keyword splat 2017-08-10 00:32:12 +00:00
vm_backtrace.c introduce rb_thread_ptr() to replace GetThreadPtr(). 2017-06-28 04:49:30 +00:00
vm_core.h suppress unused argument warning 2017-09-11 08:50:07 +00:00
vm_debug.h
vm_dump.c Fix typos [ci skip] 2017-09-15 12:03:42 +00:00
vm_eval.c signal.c: fatal stack 2017-08-22 02:46:16 +00:00
vm_exec.c move fields to ec. 2017-06-28 14:27:49 +00:00
vm_exec.h rename rb_execution_context_t::stack(_size) to vm_stack(_size). 2017-08-10 04:55:12 +00:00
vm_insnhelper.c intern instruction 2017-09-18 05:16:37 +00:00
vm_insnhelper.h rename rb_execution_context_t::stack(_size) to vm_stack(_size). 2017-08-10 04:55:12 +00:00
vm_method.c vm_method.c: alias warning at refined method 2017-08-17 14:58:11 +00:00
vm_opts.h
vm_trace.c suppress warnings when RUBY_USE_SETJMPEX 2017-08-02 03:02:22 +00:00
vsnprintf.c unused member 2017-05-23 11:35:54 +00:00

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, Mac OS X, 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 git://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 mailto: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.in, 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 extract-gems before run 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.

mailto:matz@ruby-lang.org