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
nobu 9bc73cd81f array.c: improve operations on small arrays
[Feature #13884]

Reduce number of memory allocations for "and", "or" and "diff"
operations on small arrays

Very often, arrays are used to filter parameters and to select
interesting items from 2 collections and very often these
collections are small enough, for example:

```ruby
SAFE_COLUMNS = [:id, :title, :created_at]

def columns
  @all_columns & SAFE_COLUMNS
end
```

In this patch, I got rid of unnecessary memory allocations for
small arrays when "and", "or" and "diff" operations are performed.

name             | HEAD  | PATCH
-----------------+------:+------:
array_small_and  | 0.615 | 0.263
array_small_diff | 0.676 | 0.282
array_small_or   | 0.953 | 0.463

name             | PATCH
-----------------+------:
array_small_and  | 2.343
array_small_diff | 2.392
array_small_or   | 2.056

name             | HEAD  | PATCH
-----------------+------:+------:
array_small_and  | 1.429 | 1.005
array_small_diff | 1.493 | 0.878
array_small_or   | 1.672 | 1.152

name             | PATCH
-----------------+------:
array_small_and  | 1.422
array_small_diff | 1.700
array_small_or   | 1.452

Author:    Dmitry Bochkarev <dimabochkarev@gmail.com>

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@60057 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2017-09-29 07:43:22 +00:00
basictest
benchmark array.c: improve operations on small arrays 2017-09-29 07:43:22 +00:00
bin removed bin/bundle_ruby, It was ignored upstream gemspec. 2017-09-23 04:37:58 +00:00
bootstraptest bootstraptest/runner.rb: keyword argument 2017-06-21 01:34:33 +00:00
ccan
coverage
cygwin
defs gmake.mk: order test-bundler 2017-09-21 12:26:16 +00:00
doc Show rb_data_type_t definition [ci skip] 2017-09-26 23:28:07 +00:00
enc remove Unicode 9.0.0-related files 2017-09-06 08:12:02 +00:00
ext pty.c: shrink repeated device names 2017-09-27 05:27:07 +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 Net::HTTP.new: Support no_proxy parameter [Feature #11195] 2017-09-28 10:51:37 +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 Update trick2013/yhara for Ruby 2.4 2017-09-22 11:21:34 +00:00
spec array.c: improve operations on small arrays 2017-09-29 07:43:22 +00:00
template ruby-runner.c: RUBYLIB 2017-09-24 01:48:25 +00:00
test array.c: improve operations on small arrays 2017-09-29 07:43:22 +00:00
tool run-lcov.rb: support overwritten tmpdir path 2017-09-26 04:59:39 +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 Adapt tools to follow spec/rubyspec => spec/ruby rename 2017-09-20 20:19:54 +00:00
acinclude.m4
aclocal.m4
addr2line.c
addr2line.h
appveyor.yml Remove DevKit path, change zlib link 2017-09-27 21:55:32 +00:00
array.c array.c: improve operations on small arrays 2017-09-29 07:43:22 +00:00
bignum.c numeric.c: use NUM2DBL 2017-09-22 03:05:02 +00:00
BSDL
class.c non-keywords hash 2017-08-20 06:08:25 +00:00
common.mk Release gvl while doing (f)stat 2017-09-26 04:13:37 +00:00
compar.c
compile.c Enable to take branch coverages for safe method invocations 2017-09-23 00:17:35 +00:00
complex.c complex.c: no overflow 2017-09-27 02:55:03 +00:00
configure.in configure.in: install_name without teeny 2017-09-25 06:31:38 +00:00
constant.h
cont.c cont.c: update comment to match r59776 [ci skip] 2017-09-12 18:41:05 +00:00
CONTRIBUTING.md
COPYING
COPYING.ja
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
dln.h
dln_find.c
dmydln.c
dmyenc.c
dmyext.c
encindex.h
encoding.c
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 vm.c: unused function 2017-09-25 21:52:00 +00:00
eval_jump.c move fields to ec. 2017-06-28 14:27:49 +00:00
file.c Release gvl while doing (f)stat 2017-09-26 04:13:37 +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
GPL
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 Fix overflow detection for LLP64 arch [Bug #13748] 2017-09-25 08:19:10 +00:00
io.c io.c: fix segfault with closing socket on Windows 2017-09-28 13:43:21 +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
KNOWNBUGS.rb gc.c: expand sorted pages 2017-06-22 00:59:54 +00:00
LEGAL Removed ubygems.rb. rubygems.rb is always loaded now. 2017-09-24 07:52:25 +00:00
lex.c.blt
load.c vm.c: fetch retval iff necessary 2017-09-25 21:51:56 +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
Makefile.in configure.in: install_name without teeny 2017-09-25 06:31:38 +00:00
marshal.c
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
NEWS Net::HTTP.new: Support no_proxy parameter [Feature #11195] 2017-09-28 10:51:37 +00:00
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 complex.c: no overflow 2017-09-27 02:55:03 +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: moved duplicate conditions 2017-09-26 13:40:14 +00:00
prelude.rb
probes.d
probes_helper.h
proc.c proc.c: [DOC] fixup r59720 2017-09-02 06:17:52 +00:00
process.c process: block/unblock signals around fork 2017-09-20 18:47:14 +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
README.EXT
README.EXT.ja
README.ja.md
README.md Added documentation 2017-09-19 02:39:40 +00:00
regcomp.c
regenc.c
regenc.h
regerror.c
regexec.c
regint.h
regparse.c
regparse.h
regsyntax.c
ruby-runner.c ruby-runner.c: RUBYLIB 2017-09-24 01:48:25 +00:00
ruby.c ruby.c: show help messages of --dump 2017-09-20 05:01:09 +00:00
ruby_assert.h
ruby_atomic.h
rubystub.c
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
siphash.h
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 dup String#split return value 2017-09-23 07:09:07 +00:00
struct.c
symbol.c
symbol.h
thread.c thread.c: Use 'Class.new' instead of 'Class::new' in doc codes. 2017-09-25 06:05:52 +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#at receives 3rd argument which specifies the unit of 2nd argument [Feature #13919] 2017-09-25 06:20:10 +00:00
timev.h
transcode.c
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-28 2017-09-27 21:55:33 +00:00
vm.c vm.c: unused function 2017-09-25 21:52:00 +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 check_funcall_missing() should call respond_to_missing?(name, priv=true) 2017-09-20 22:02:10 +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

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