NEWS for Ruby 2.1.0

This document is a list of user visible feature changes made between releases except for bug fixes.

Note that each entry is kept so brief that no reason behind or reference information is supplied with. For a full list of changes with all sufficient information, see the ChangeLog file.

Changes since the 2.0.0 release

Language changes

  • Now the default values of keyword arguments can be omitted. Those “required keyword arguments” need giving explicitly at the call time.

  • Added suffixes for integer and float literals: ‘r’, ‘i’, and ‘ri’.

    • “42r” and “3.14r” are evaluated as Rational(42, 1) and 3.14.rationalize, respectively. But exponential form with ‘r’ suffix like “6.022e+23r” is not accepted because it is misleading.

    • “42i” and “3.14i” are evaluated as Complex(0, 42) and Complex(0, 3.14), respectively.

    • “42ri” and “3.14ri” are evaluated as Complex(0, 42r) and Complex(0, 3.14r), respectively.

  • def-expr now returns the symbol of its name instead of nil.

Core classes updates (outstanding ones only)

  • Array

    • New methods

  • Binding

  • Enumerable

  • Exception

    • New methods

      • Exception#cause provides the previous exception which has been caught at where raising the new exception.

  • GC

    • improvements:

      • introduced the generational GC a.k.a RGenGC.

    • added environment variables:

      • RUBY_GC_HEAP_INIT_SLOTS

      • RUBY_GC_HEAP_FREE_SLOTS

      • RUBY_GC_HEAP_GROWTH_FACTOR

      • RUBY_GC_HEAP_GROWTH_MAX_SLOTS

      • RUBY_GC_MALLOC_LIMIT_MAX

      • RUBY_GC_MALLOC_LIMIT_GROWTH_FACTOR

      • RUBY_GC_OLDMALLOC_LIMIT

      • RUBY_GC_OLDMALLOC_LIMIT_MAX

      • RUBY_GC_OLDMALLOC_LIMIT_GROWTH_FACTOR

    • obsoleted environment variables:

      • RUBY_FREE_MIN (Use RUBY_GC_HEAP_FREE_SLOTS instead)

      • RUBY_HEAP_MIN_SLOTS (Use RUBY_GC_HEAP_INIT_SLOTS instead)

  • Integer

    • New methods

      • Fixnum#bit_length

      • Bignum#bit_length

    • Bignum performance improvement

      • Use GMP if available. GMP is used only for several operations: multiplication, division, radix conversion, GCD

  • IO

    • extended methods:

      • IO#seek supports SEEK_DATA and SEEK_HOLE as whence.

      • IO#seek accepts symbols (:CUR, :END, :SET, :DATA, :HOLE) for 2nd argument.

      • IO#read_nonblock accepts optional ‘exception: false` to return symbols

      • IO#write_nonblock accepts optional ‘exception: false` to return symbols

  • Kernel

    • New methods:

      • Kernel#singleton_method

  • Module

    • New methods:

      • Module#using, which activates refinements of the specified module only in the current class or module definition.

      • Module#singleton_class? returns true if the receiver is a singleton class or false if it is an ordinary class or module.

    • extended methods:

  • Mutex

    • misc

      • Mutex#owned? is no longer experimental.

  • Numeric

    • extended methods:

      • Numeric#step allows the limit argument to be omitted, in which case an infinite sequence of numbers is generated. Keyword arguments ‘to` and `by` are introduced for ease of use. `by` can be 0, in which case the same value will be generated indefinitely.

  • Process

  • String

    • “literal”.freeze is now optimized to return the same object

    • New methods:

      • String#scrub and String#scrub! verify and fix invalid byte sequence. If you want to use this function with older Ruby, consider to use string-scrub.gem.

  • Symbol

    • All symbols are now frozen.

  • pack/unpack (Array/String)

    • Q! and q! directives for long long type if platform has the type.

  • toplevel

    • extended methods:

      • main.using is no longer experimental. The method activates refinements in the ancestors of the argument module to support refinement inheritance by Module#include.

Core classes compatibility issues (excluding feature bug fixes)

  • Hash

    • incompatible changes:

      • Hash#reject will return plain Hash object in the future versions, that is the original object’s subclass, instance variables, default value, and taintedness will be no longer copied, so now warnings are emitted when called with such Hash.

  • IO

    • incompatible changes:

      • open ignore internal encoding if external encoding is ASCII-8BIT.

  • Kernel#eval, Kernel#instance_eval, and Module#module_eval.

    • Copies the scope information of the original environment, which means that private, protected, public, and module_function without arguments do not affect the environment outside the eval string. For example, ‘class Foo; eval “private”; def foo; end; end’ doesn’t make Foo#foo private.

  • Kernel#untrusted?, untrust, and trust

    • These methods are deprecated and their behavior is the same as tainted?, taint, and untaint, respectively. If $VERBOSE is true, they show warnings.

  • Module#ancestors

    • The ancestors of a singleton class now include singleton classes, in particular itself.

  • Module#define_method and Object#define_singleton_method

    • Now they return the symbols of the defined methods, not the methods/procs themselves.

  • Numeric#quo

  • Proc

    • Returning from lambda proc now always exits from the Proc, not from the method where the lambda is created. Returning from non-lambda proc exits from the method, same as the former behavior.

String

* If invalid: :replace is specified for String#encode, replace
  invalid byte sequence even if the destination encoding equals to
  the source encoding.

Stdlib updates (outstanding ones only)

Stdlib compatibility issues (excluding feature bug fixes)

  • Set

    • incompatible changes:

      • Set#to_set now returns self instead of generating a copy.

  • URI

    • incompatible changes:

      • URI.decode_www_form follows current WHATWG URL Standard. It gets encoding argument to specify the character encoding. It now allows loose percent encoded strings, but denies ;-separator.

      • URI.encode_www_form follows current WHATWG URL Standard. It gets encoding argument to convert before percent encode. UTF-16 strings aren’t converted to UTF-8 before percent encode by default.

  • curses

Built-in global variables compatibility issues

  • $SAFE

    • $SAFE=4 is obsolete. If $SAFE is set to 4 or larger, an ArgumentError is raised.

C API updates

  • rb_gc_set_params() is deprecated. This is only used in Ruby internal.

  • rb_gc_count() added. This returns the number of times GC occurred.

  • rb_gc_stat() added. This allows access to specific GC.stat() values from C without any allocation overhead.

  • rb_gc_latest_gc_info() added. This allows access to GC.latest_gc_info().

  • rb_postponed_job_register() added. Takes a function callback which is invoked when the VM is in a consistent state, i.e. to perform work from a C signal handler.

  • rb_profile_frames() added. Provides low-cost access to the current ruby stack for callstack profiling.

  • rb_tracepoint_new() supports new internal events accessible only from C:

    • RUBY_INTERNAL_EVENT_NEWOBJ

    • RUBY_INTERNAL_EVENT_FREEOBJ

    • RUBY_INTERNAL_EVENT_GC_START

    • RUBY_INTERNAL_EVENT_GC_END_MARK

    • RUBY_INTERNAL_EVENT_GC_END_SWEEP

    • Note that you *can not* specify “internal events” with normal events (such as RUBY_EVENT_CALL, RUBY_EVENT_RETURN) simultaneously.