1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
The Ruby Programming Language [mirror]
Find a file
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
benchmark Copy the serial number from the super class to the singleton class 2016-09-12 15:40:09 +00:00
bin
bootstraptest Use qualified names 2016-08-30 06:22:30 +00:00
ccan
coverage
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
sample Use qualified names 2016-08-30 06:22:30 +00:00
spec
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
.editorconfig
.gdbinit * .gdbinit: follow r55766's VM change. 2016-08-24 07:56:51 +00:00
.gitattributes
.gitignore
.indent.pro
.travis.yml
acinclude.m4
aclocal.m4
addr2line.c
addr2line.h
appveyor.yml
array.c * array.c (flatten): use rb_obj_class instead of rb_class_of 2016-09-08 08:56:30 +00:00
bignum.c
BSDL
ChangeLog string.c: avoid signed integer overflow 2016-09-13 12:33:16 +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
compile.c
complex.c
configure.in
constant.h
cont.c
CONTRIBUTING.md
COPYING
COPYING.ja
debug.c
dir.c
dln.c
dln.h
dln_find.c
dmydln.c
dmyenc.c
dmyext.c
encindex.h
encoding.c
enum.c enum.c (enum_sort): prevent wasteful array duplicaion 2016-08-20 20:51:19 +00:00
enumerator.c
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
eval_intern.h
eval_jump.c
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
gem_prelude.rb
golf_prelude.rb
goruby.c goruby.c: call Init_golf [ci skip] 2016-08-23 08:00:09 +00:00
GPL
hash.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
ia64.s
id_table.c
id_table.h
inits.c
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
KNOWNBUGS.rb
LEGAL Use https instead of http in some URLs 2016-09-11 10:33:36 +00:00
lex.c.blt
load.c
loadpath.c
localeinit.c
main.c
Makefile.in
marshal.c
math.c
method.h
miniinit.c
NEWS NEWS: News about Module.used_modules. 2016-09-11 12:33:46 +00:00
node.c
node.h
numeric.c
object.c object.c: update rdoc 2016-09-09 03:02:23 +00:00
pack.c
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
probes_helper.h
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
range.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
rational.c
re.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +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 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
regcomp.c
regenc.c
regenc.h
regerror.c
regexec.c
regint.h
regparse.c
regparse.h
regsyntax.c
ruby-runner.c
ruby.c
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
signal.c replace fixnum by integer in documents. 2016-09-08 04:57:49 +00:00
siphash.c
siphash.h
sparc.c
sprintf.c Use PRIuSIZE format specifier for size_t values 2016-09-13 12:33:13 +00:00
st.c
strftime.c
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.h
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_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
time.c * time.c (time_arg): guard for mswin64 CI. 2016-09-12 15:16:09 +00:00
timev.h
transcode.c
transcode_data.h
util.c
variable.c variable.c: rb_deprecate_constant 2016-09-09 03:02:22 +00:00
version.c
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_backtrace.c
vm_core.h
vm_debug.h
vm_dump.c fix r56030 [Bug #12711] 2016-08-30 04:49:26 +00:00
vm_eval.c
vm_exec.c
vm_exec.h
vm_insnhelper.c * insns.def (setclassvariable, setconstant): warn when self is a 2016-09-08 04:44:51 +00:00
vm_insnhelper.h
vm_method.c
vm_opts.h
vm_trace.c
vsnprintf.c

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