development fork of ruby/ruby
Перейти к файлу
rhe 00fcd967d9 string.c: avoid signed integer overflow
The behavior on signed integer overflow is undefined. On platform with
sizeof(long)==4, it's fairly easy that 'len + termlen' overflows, where
len is the string length and termlen is the terminator length.

So, prevent the integer overflow by avoiding adding to a string length,
or casting to size_t before adding where the total size is passed to
{RE,}ALLOC*().

* string.c (STR_HEAP_SIZE, RESIZE_CAPA_TERM, str_new0, rb_str_buf_new,
  str_shared_replace, rb_str_init, str_make_independent_expand,
  rb_str_resize): Avoid overflow by casting the length to size_t. size_t
  should be able to represent LONG_MAX+termlen.

* string.c (rb_str_modify_expand): Check that the new length is in the
  range of long before resizing. Also refactor to use RESIZE_CAPA_TERM
  macro.

* string.c (str_buf_cat): Fix so that it does not create a negative
  length String. Also fix the condition for 'string sizes too big', the
  total length can be up to LONG_MAX.

* string.c (rb_str_plus): Check the resulting String length does not
  exceed LONG_MAX.

* string.c (rb_str_dump): Fix integer overflow. The dump result will be
  longer then the original String.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@56157 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2016-09-13 12:33:16 +00:00
basictest suppress warnings 2016-08-07 10:34:11 +00:00
benchmark Copy the serial number from the super class to the singleton class 2016-09-12 15:40:09 +00:00
bin * bin/erb: $SAFE=3 is obsolete. 2015-06-18 14:53:26 +00:00
bootstraptest Use qualified names 2016-08-30 06:22:30 +00:00
ccan ccan/list/list.h: suppress unused argument warnings 2015-09-06 07:10:54 +00:00
coverage fix a typo [ci skip] 2014-09-12 12:17:29 +00:00
cygwin rubystub 2016-08-20 02:20:34 +00:00
defs rubystub 2016-08-20 02:20:34 +00:00
doc Use https instead of http in some URLs 2016-09-11 10:33:36 +00:00
enc * unicode/8.0.0/casefold.h, name2ctype.h, unicode/data/8.0.0: 2016-09-07 08:35:39 +00:00
ext Use PRIuSIZE format specifier for size_t values 2016-09-13 12:33:13 +00:00
gems * gems/bundled_gems: sort lines. 2016-09-09 13:44:15 +00:00
include util.h: POSIX-noncompliant setenv 2016-09-07 08:50:39 +00:00
lib * lib/uri/mailto.rb: Removed needless `return` and use `.`` instead of `::` 2016-09-12 04:46:27 +00:00
man Use https instead of http in some URLs 2016-09-11 10:33:36 +00:00
misc Use https instead of http in some URLs 2016-09-11 10:33:36 +00:00
missing rubystub 2016-08-20 02:20:34 +00:00
nacl Fix PNaCl configure/link errors. 2014-10-22 12:19:21 +00:00
sample Use qualified names 2016-08-30 06:22:30 +00:00
spec default.mspec: OBJDIR 2016-04-21 21:59:01 +00:00
template Use https instead of http in some URLs 2016-09-11 10:33:36 +00:00
test * test/ruby/test_exception.rb: fix thread issues. 2016-09-13 09:39:08 +00:00
tool rbinstall.rb: gem bindir 2016-09-08 08:40:16 +00:00
win32 * win32/win32.c (rb_w32_write_console): should set writen length as the 2016-09-11 10:08:01 +00:00
.document * .document: removed needless entries. 2015-03-25 01:39:11 +00:00
.editorconfig .editorconfig: new 2012-09-15 23:16:15 +00:00
.gdbinit * .gdbinit: follow r55766's VM change. 2016-08-24 07:56:51 +00:00
.gitattributes add .gitattributes 2015-11-19 22:09:47 +00:00
.gitignore * ext/tk: Tk is removed from stdlib. [Feature #8539] 2016-08-09 06:44:45 +00:00
.indent.pro
.travis.yml ruby 2.0.0 has ended 2016-03-08 15:21:23 +00:00
BSDL * BSDL: update copyright notice for 2013. 2013-02-09 01:12:30 +00:00
CONTRIBUTING.md [DOC] Please see _the_ official issue tracker... [ci skip] 2014-06-13 23:42:35 +00:00
COPYING * ChangeLog: Remove trailing-whitespaces. 2016-05-11 01:33:30 +00:00
COPYING.ja Change encoding from EUC-JP to UTF-8. [Feature #5128] 2011-09-04 12:22:46 +00:00
ChangeLog string.c: avoid signed integer overflow 2016-09-13 12:33:16 +00:00
GPL * GPL: update text of GPLv2. [ruby-core:44488] [Bug #6328] 2012-06-03 13:07:58 +00:00
KNOWNBUGS.rb KNOWNBUGS.rb: Fixed typo, made more explicit [ci skip] 2015-12-13 01:45:00 +00:00
LEGAL Use https instead of http in some URLs 2016-09-11 10:33:36 +00:00
Makefile.in common.mk: MAKE_ENC 2016-08-16 08:41:59 +00:00
NEWS NEWS: News about Module.used_modules. 2016-09-11 12:33:46 +00:00
README.EXT README.EXT: add redirect [ruby-core:68631] 2015-03-25 21:43:58 +00:00
README.EXT.ja README.EXT.ja: add redirect [ruby-core:68631] 2015-03-30 13:08:16 +00:00
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 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
acinclude.m4 acinclude.m4: rename 2016-01-03 03:12:20 +00:00
aclocal.m4 aclocal.m4: add 2016-01-03 10:22:12 +00:00
addr2line.c * addr2line.c: drop to support ATARI ST platform. It was discontinued 2016-05-28 01:46:27 +00:00
addr2line.h * addr2line.c (fill_lines): loop reverse order not to overwrite 2014-03-26 04:30:43 +00:00
appveyor.yml * appveyor.yml: Update libressl version to 2.3.7. 2016-08-15 07:42:56 +00:00
array.c * array.c (flatten): use rb_obj_class instead of rb_class_of 2016-09-08 08:56:30 +00:00
bignum.c * bignum.c (rb_big2ulong): the old logic seems to try to avoid 2016-06-28 18:42:12 +00:00
class.c Copy the serial number from the super class to the singleton class 2016-09-12 15:40:09 +00:00
common.mk * common.mk (benchmark): fix lib path. 2016-09-12 21:04:25 +00:00
compar.c Comparable#clamp 2016-08-11 07:24:25 +00:00
compile.c * vm_core.h: revisit the structure of frame, block and env. 2016-07-28 11:02:30 +00:00
complex.c rb_funcallv 2016-07-29 11:57:14 +00:00
configure.in * configure.in, lib/mkmf.rb, win32/Makefile.sub (CSRCFLAG): make the 2016-07-11 16:30:03 +00:00
constant.h use id_table for constant tables 2015-12-29 20:19:14 +00:00
cont.c * vm_core.h: introduce VM_FRAME_RUBYFRAME_P() 2016-08-03 01:50:50 +00:00
debug.c * debug.c (ruby_debug_printf): use rb_raw_obj_info() 2016-07-25 08:00:46 +00:00
dir.c rb_funcallv 2016-07-29 11:57:14 +00:00
dln.c dln.c: move error message definition 2016-04-07 23:46:45 +00:00
dln.h dln.c: extra arguments 2013-06-30 01:58:51 +00:00
dln_find.c dln_find.c: MAXPATHLEN is not used already 2016-06-02 16:52:15 +00:00
dmydln.c * configure.in: add -Wsuggest-attribute=noreturn and suppress warnings. 2016-05-08 00:55:28 +00:00
dmyenc.c load.c: tweak the return value 2014-12-03 06:13:58 +00:00
dmyext.c dmyenc.c: separate 2014-11-27 20:02:32 +00:00
encindex.h revert r52336 (commit miss) 2015-10-29 05:30:50 +00:00
encoding.c * string.c (rb_str_change_terminator_length): New function to change 2016-07-05 10:45:23 +00:00
enum.c enum.c (enum_sort): prevent wasteful array duplicaion 2016-08-20 20:51:19 +00:00
enumerator.c rb_funcallv 2016-07-29 11:57:14 +00:00
error.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
eval.c thread.c: set cause by Thread#raise 2016-09-09 08:59:48 +00:00
eval_error.c Thread.report_on_exception 2016-06-06 00:25:38 +00:00
eval_intern.h * vm_core.h: revisit the structure of frame, block and env. 2016-07-28 11:02:30 +00:00
eval_jump.c eval_jump.c: restore previous error info 2016-04-22 06:09:29 +00:00
file.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
gc.c Use PRIuSIZE format specifier for size_t values 2016-09-13 12:33:13 +00:00
gc.h * gc.h, gc.c: introduce new debug function rb_obj_info_dump(VALUE obj) 2015-10-06 16:22:54 +00:00
gem_prelude.rb Reduce system calls by activating the `did_you_mean` gem. 2016-02-25 23:23:30 +00:00
golf_prelude.rb * golf_prelude.rb: syntax formatting for whitespace [Fixes GH-425] 2013-11-07 16:03:48 +00:00
goruby.c goruby.c: call Init_golf [ci skip] 2016-08-23 08:00:09 +00:00
hash.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
ia64.s * removed trailing spaces. 2012-06-09 21:36:05 +00:00
id_table.c id_table.c: extend, don't shrink 2016-08-14 13:35:42 +00:00
id_table.h id_table.h: dummy sentinel 2016-08-06 00:35:33 +00:00
inits.c * random.c (InitVM_Random): move Random::DEFAULT initialization 2015-11-30 20:32:42 +00:00
insns.def * insns.def (setclassvariable, setconstant): warn when self is a 2016-09-08 04:44:51 +00:00
internal.h variable.c: rb_deprecate_constant 2016-09-09 03:02:22 +00:00
io.c io.c: check if Integer 2016-09-08 08:59:00 +00:00
iseq.c Use PRIuSIZE format specifier for size_t values 2016-09-13 12:33:13 +00:00
iseq.h * iseq.h (struct iseq_compile_data): use struct rb_id_table 2016-05-14 18:43:11 +00:00
lex.c.blt parse.y: symbol literals for alias/undef 2016-03-16 14:10:27 +00:00
load.c * vm_core.h: revisit the structure of frame, block and env. 2016-07-28 11:02:30 +00:00
loadpath.c * loadpath.c (RUBY_REVISION): Defined to suppress revision.h 2013-06-17 11:56:21 +00:00
localeinit.c * remove trailing spaces. 2016-06-19 06:01:26 +00:00
main.c * include/ruby/debug.h: introdudced. 2012-11-20 12:57:49 +00:00
marshal.c remove SIGN_EXTEND_CHAR macro 2016-03-23 02:44:54 +00:00
math.c math.c: faster tanh 2016-08-02 12:42:42 +00:00
method.h * method.h: introduce the folliwing field and macros. 2015-11-18 08:15:51 +00:00
miniinit.c miniinit.c: built-in encoding aliases 2015-12-26 02:26:40 +00:00
node.c node.c: nd_alen only in the head 2016-08-15 11:31:36 +00:00
node.h * compile.c: fix typos. 2015-12-14 02:51:13 +00:00
numeric.c numeric.c: round_to_nearest 2016-08-15 01:59:58 +00:00
object.c object.c: update rdoc 2016-09-09 03:02:23 +00:00
pack.c * pack.c (pack_pack): use union instead of bare variable to ease 2016-07-05 02:08:55 +00:00
parse.y parse.y: heredoc token 2016-08-26 23:26:03 +00:00
prelude.rb Use qualified names 2016-08-30 06:22:30 +00:00
probes.d change lingering dtrace probe documentation from function- to method- 2015-05-30 02:04:26 +00:00
probes_helper.h vm.c: ruby_th_dtrace_setup 2015-10-29 05:32:19 +00:00
proc.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
process.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
random.c rb_funcallv 2016-07-29 11:57:14 +00:00
range.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
rational.c rb_funcallv 2016-07-29 11:57:14 +00:00
re.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
regcomp.c * regcomp.c (noname_disable_map): don't optimize out group 0 2016-07-01 19:37:43 +00:00
regenc.c * regenc.h/c, include/ruby/oniguruma.h, enc/ascii.c, big5.c, cp949.c, 2016-07-24 07:33:15 +00:00
regenc.h * regenc.h/c, include/ruby/oniguruma.h, enc/ascii.c, big5.c, cp949.c, 2016-07-24 07:33:15 +00:00
regerror.c * regcomp.c: Merge Onigmo 5.14.1 25a8a69fc05ae3b56a09. 2014-07-16 03:27:25 +00:00
regexec.c * regexec.c (ONIGENC_IS_MBC_ASCII_WORD): redefine optimized one. 2016-05-29 13:58:45 +00:00
regint.h revert UNALIGNED_WORD_ACCESS for GCC6 2016-04-30 15:39:03 +00:00
regparse.c * regparse.c (fetch_token_in_cc): raise error if given octal escaped 2016-05-25 09:45:22 +00:00
regparse.h regparse.h: ANSI alias rule fix 2015-12-09 08:02:06 +00:00
regsyntax.c * Merge Onigmo-5.13.1. [ruby-dev:45057] [Feature #5820] 2012-02-17 07:42:23 +00:00
ruby-runner.c ruby-runner.h 2016-04-14 01:30:12 +00:00
ruby.c ruby_cmdline_options_t 2016-08-19 10:44:53 +00:00
ruby_assert.h fix build with VM_CHECK_MODE > 0 2016-01-25 08:34:00 +00:00
ruby_atomic.h Revert r52995 2015-12-09 07:30:44 +00:00
rubystub.c rubystub.c: sys/param.h for MAXPATHLEN 2016-08-20 05:58:58 +00:00
safe.c * safe.c: removed needless doc related $SAFE=2 2015-06-18 14:47:37 +00:00
signal.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
siphash.c UNALIGNED_WORD_ACCESS on ppc64 2014-07-23 14:50:12 +00:00
siphash.h * siphash.h: check configure macros before include newer headers. 2012-11-09 15:34:31 +00:00
sparc.c * sparc.c: Use __asm__ instead of asm for gcc. 2013-04-27 10:06:20 +00:00
sprintf.c Use PRIuSIZE format specifier for size_t values 2016-09-13 12:33:13 +00:00
st.c * configure.in: check function attirbute const and pure, 2016-05-08 17:44:51 +00:00
strftime.c strftime.c: limit result size 2016-06-14 13:22:09 +00:00
string.c string.c: avoid signed integer overflow 2016-09-13 12:33:16 +00:00
struct.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
symbol.c * symbol.c (is_identchar): use ISDIGIT instead of rb_enc_isalnum. 2016-05-26 16:51:49 +00:00
symbol.h Use HAVE_BUILTIN___BUILTIN_CONSTANT_P 2016-05-20 13:33:10 +00:00
thread.c thread.c: set cause by Thread#raise 2016-09-09 08:59:48 +00:00
thread_pthread.c thread_pthread.c: check stack on co-routine case 2016-09-03 02:28:31 +00:00
thread_pthread.h * thread_pthread.c (register_ubf_list): renamed from 2015-11-30 20:33:20 +00:00
thread_sync.c thread_sync.c: alias_global_const 2016-08-28 08:53:22 +00:00
thread_win32.c Use PRIuSIZE format specifier for size_t values 2016-09-13 12:33:13 +00:00
thread_win32.h * ext/openssl/depend: remove dependency from internal headers. 2014-05-14 10:55:38 +00:00
time.c * time.c (time_arg): guard for mswin64 CI. 2016-09-12 15:16:09 +00:00
timev.h configure.in, win32/Makefile.sub: PACKED_STRUCT with VC 2014-02-25 07:00:10 +00:00
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 transcode_data.h: missing cast 2015-08-08 00:33:11 +00:00
util.c util.c: do not underflow 2016-07-15 08:08:59 +00:00
variable.c variable.c: rb_deprecate_constant 2016-09-09 03:02:22 +00:00
version.c version.c: no exit in ruby_show_copyright 2016-01-07 02:34:33 +00:00
version.h * 2016-09-13 2016-09-12 15:16:10 +00:00
vm.c Use PRIuSIZE format specifier for size_t values 2016-09-13 12:33:13 +00:00
vm_args.c * vm_core.h: revisit the structure of frame, block and env. 2016-07-28 11:02:30 +00:00
vm_backtrace.c * vm_core.h: introduce VM_FRAME_RUBYFRAME_P() 2016-08-03 01:50:50 +00:00
vm_core.h * vm_core.h: introduce VM_FRAME_RUBYFRAME_P() 2016-08-03 01:50:50 +00:00
vm_debug.h defines.h: RUBY_SYMBOL_EXPORT_{BEGIN,END} 2013-04-05 10:29:38 +00:00
vm_dump.c fix r56030 [Bug #12711] 2016-08-30 04:49:26 +00:00
vm_eval.c * vm_core.h: introduce VM_FRAME_RUBYFRAME_P() 2016-08-03 01:50:50 +00:00
vm_exec.c * vm_core.h: constify rb_iseq_constant_body::iseq_encoded and 2015-07-23 09:34:31 +00:00
vm_exec.h * vm_exec.h (VM_DEBUG_STACKOVERFLOW): added. 2013-12-18 05:33:50 +00:00
vm_insnhelper.c * insns.def (setclassvariable, setconstant): warn when self is a 2016-09-08 04:44:51 +00:00
vm_insnhelper.h * vm_core.h: revisit the structure of frame, block and env. 2016-07-28 11:02:30 +00:00
vm_method.c rb_funcallv 2016-07-29 11:57:14 +00:00
vm_opts.h iseq.h: rename member 2015-11-25 08:02:29 +00:00
vm_trace.c * vm_core.h: rename macros and make them inline functions. 2016-08-03 00:28:12 +00:00
vsnprintf.c Suppress false warnings 2016-06-18 02:25:27 +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.

  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. 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