development fork of ruby/ruby
Перейти к файлу
Koichi Sasada 8655c2e690
RUBY_DEBUG_LOG: Logging debug information mechanism (#3279)
* RUBY_DEBUG_LOG: Logging debug information mechanism

This feature provides a mechanism to store logging information
to a file, stderr or memory space with simple macros.

The following information will be stored.
  * (1) __FILE__, __LINE__ in C
  * (2) __FILE__, __LINE__ in Ruby
  * (3) __func__ in C (message title)
  * (4) given string with sprintf format
  * (5) Thread number (if multiple threads are running)

This feature is enabled only USE_RUBY_DEBUG_LOG is enabled.
Release version should not enable it.

Running with the `RUBY_DEBUG_LOG` environment variable enables
this feature.

  # logging into a file
  RUBY_DEBUG_LOG=/path/to/file STDERR

  # logging into STDERR
  RUBY_DEBUG_LOG=stderr

  # logging into memory space (check with a debugger)
  # It will help if the timing is important.
  RUBY_DEBUG_LOG=mem

RUBY_DEBUG_LOG_FILTER environment variable can specify the fileter string.
If "(3) __func__ in C (message title)" contains the specified string, the
infomation will be stored (example: RUBY_DEBUG_LOG_FILTER=str will enable
only on str related information).

In a MRI source code, you can use the following macros:
  * RUBY_DEBUG_LOG(fmt, ...): Above (1) to (4) will be logged.
  * RUBY_DEBUG_LOG2(file, line, fmt, ...):
    Same as RUBY_DEBUG_LOG(), but (1) will be replaced with given file, line.
2020-07-03 16:55:54 +09:00
.github RUBY_DEBUG_LOG: Logging debug information mechanism (#3279) 2020-07-03 16:55:54 +09:00
basictest Raise RuntimeError for class variable overtaken in nonverbose mode 2020-06-18 08:21:29 -07:00
benchmark Mark some Integer methods as inline (#3264) 2020-06-27 10:07:47 -07:00
bin
bootstraptest
ccan
coroutine
coverage
cygwin
defs Removed duplicate target 2020-06-25 18:21:41 +09:00
doc Removed sdbm entries from doc 2020-06-19 08:26:47 +09:00
enc
ext Merge json-2.3.1 from flori/json 2020-07-01 18:50:39 +09:00
gems
include Revert "RBIMPL_UNREACHABLE_RETURN: evaluate the argument" 2020-06-29 12:33:17 +09:00
internal Renamed `nurat_sub` compliant with `rb_rational_plus` 2020-07-01 22:41:15 +09:00
lib Avoid deprecated OpenSSL::Digest constants 2020-06-29 13:25:32 +09:00
libexec
man
misc lldb_cruby.py: show the sign of Bignum [ci skip] 2020-06-23 15:56:59 +09:00
missing
sample
spec Avoid deprecated OpenSSL::Digest constants 2020-06-29 13:25:32 +09:00
template Ignore configurations in un-built extension libraries 2020-06-23 00:25:36 +09:00
test test/json/json_fixtures_test.rb: Prevent an "out of range" warning 2020-07-03 11:47:09 +09:00
tool Expose `assert_pattern_list` for drb test with test-unit gem. 2020-07-02 20:53:42 +09:00
win32
.dir-locals.el
.document Make Integer#zero? a separated method and builtin (#3226) 2020-06-20 14:55:09 -07:00
.editorconfig
.gdbinit
.gitattributes
.gitignore
.rspec_parallel
.travis.yml
BSDL
CONTRIBUTING.md
COPYING
COPYING.ja
GPL
KNOWNBUGS.rb
LEGAL Revert accidentally style-format 2020-06-19 08:26:47 +09:00
NEWS.md Avoid duplicated "when"s [ci skip] 2020-06-26 01:40:20 -07:00
README.EXT
README.EXT.ja
README.ja.md
README.md
aclocal.m4
addr2line.c
addr2line.h
appveyor.yml
array.c rb_ary_slice_bang: do not goto into a branch 2020-06-29 11:05:41 +09:00
array.rb [Feature #16254] Use `Primitive.func` style 2020-06-19 18:46:55 +09:00
ast.c node_children: do not goto into a branch 2020-06-29 11:05:41 +09:00
ast.rb Fix RubyVM::AbstractSyntaxTree document 2020-06-24 15:17:53 +09:00
bignum.c rb_big_aref: do not goto into a branch 2020-06-29 11:05:41 +09:00
builtin.c builtin_lookup: do not goto into a branch 2020-06-29 11:05:41 +09:00
builtin.h
class.c singleton_class_of: do not goto into a branch 2020-06-29 11:05:41 +09:00
common.mk Annotate Kernel#class as inline (#3250) 2020-06-23 23:49:03 -07:00
compar.c cmp_clamp: do not goto into a branch 2020-06-29 11:05:41 +09:00
compile.c compile_redo: fix wrong condition 2020-06-29 11:05:41 +09:00
complex.c
configure.ac
constant.h
cont.c
debug.c RUBY_DEBUG_LOG: Logging debug information mechanism (#3279) 2020-07-03 16:55:54 +09:00
debug_counter.c
debug_counter.h
dir.c glob_opendir: move cleanup codes at the end 2020-06-29 11:05:41 +09:00
dir.rb [Feature #16254] Use `Primitive.func` style 2020-06-19 18:46:55 +09:00
dln.c
dln.h
dln_find.c dln_find_1: do not goto into a branch 2020-06-29 11:05:41 +09:00
dmydln.c
dmyenc.c
dmyext.c
encindex.h
encoding.c
enum.c add spaces [ci skip] 2020-06-29 11:05:41 +09:00
enumerator.c
error.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
eval.c rb_class_modify_check: add UNREACHABLE 2020-06-29 11:43:48 +09:00
eval_error.c
eval_intern.h
eval_jump.c
file.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
gc.c get_envparam_double: do not goto into a branch 2020-06-29 11:05:41 +09:00
gc.h
gc.rb [Feature #16254] Use `Primitive.func` style 2020-06-19 18:46:55 +09:00
gem_prelude.rb
golf_prelude.rb
goruby.c goruby_options: do not goto into a branch 2020-06-29 11:05:41 +09:00
hash.c rb_hash_transient_heap_evacuate: do not goto into a branch 2020-06-29 11:05:41 +09:00
hrtime.h
id_table.c
id_table.h
inits.c Make Integer#zero? a separated method and builtin (#3226) 2020-06-20 14:55:09 -07:00
insns.def Trace :return of builtin methods 2020-06-23 23:42:38 -07:00
integer.rb integer.rbinc: do not generate C functions 2020-07-02 14:34:30 +09:00
internal.h
io.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
io.rb [Feature #16254] Use `Primitive.func` style 2020-06-19 18:46:55 +09:00
iseq.c fix return event and opt_invokebuiltin_delegate_leave (#3256) 2020-06-26 10:21:56 +09:00
iseq.h
kernel.rb Annotate Kernel#class as inline (#3250) 2020-06-23 23:49:03 -07:00
lex.c.blt
load.c search_required: do not goto into a branch 2020-06-29 11:05:41 +09:00
loadpath.c
localeinit.c
main.c
marshal.c r_object0: do not goto into a branch 2020-06-29 11:05:41 +09:00
math.c
method.h Extracted METHOD_ENTRY_CACHEABLE macro 2020-06-30 19:12:02 +09:00
mini_builtin.c
miniinit.c
mjit.c
mjit.h Do not JIT inline builtin methods 2020-06-24 22:59:34 -07:00
mjit_compile.c Show what's inlined first in "JIT inline" log 2020-06-25 23:50:19 -07:00
mjit_worker.c
node.c
node.h
numeric.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
object.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
pack.c
pack.rb [Feature #16254] Use `Primitive.func` style 2020-06-19 18:46:55 +09:00
parse.y Drop token info for endless method definition 2020-06-25 01:14:26 +09:00
prelude.rb
probes.d
probes_helper.h
proc.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
process.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
random.c rand_range: do not goto into a branch 2020-06-29 11:05:41 +09:00
range.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
rational.c Reduced working `Rational` object allocations 2020-07-01 22:41:16 +09:00
re.c
regcomp.c
regenc.c
regenc.h
regerror.c
regexec.c
regint.h
regparse.c
regparse.h
regsyntax.c
ruby-runner.c
ruby.c feature_option: do not goto into a branch 2020-06-29 11:05:41 +09:00
ruby_assert.h
ruby_atomic.h
rubystub.c
signal.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
siphash.c
siphash.h
sparc.c
sprintf.c
st.c
strftime.c rb_strftime_with_timespec: do not goto into a branch 2020-06-29 11:05:41 +09:00
string.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
struct.c
symbol.c rb_enc_symname_type: refactor split 2020-06-29 11:05:41 +09:00
symbol.h
thread.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
thread_pthread.c
thread_pthread.h
thread_sync.c rb_szqueue_push: do not goto into a branch 2020-06-29 11:05:41 +09:00
thread_win32.c
thread_win32.h
time.c find_time_t: reset status before goto 2020-06-29 11:05:41 +09:00
timev.h
trace_point.rb [Feature #16254] Use `Primitive.func` style 2020-06-19 18:46:55 +09:00
transcode.c make_econv_exception: do not goto into a branch 2020-06-29 11:05:41 +09:00
transcode_data.h
transient_heap.c
transient_heap.h
util.c
variable.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
variable.h
version.c
version.h * 2020-07-03 [ci skip] 2020-07-03 11:27:07 +09:00
vm.c vm_exec_handle_exception: do not goto into a branch 2020-06-29 11:05:41 +09:00
vm_args.c
vm_backtrace.c
vm_callinfo.h
vm_core.h Introduce Primitive.attr! to annotate 'inline' (#3242) 2020-06-20 17:13:03 -07:00
vm_debug.h RUBY_DEBUG_LOG: Logging debug information mechanism (#3279) 2020-07-03 16:55:54 +09:00
vm_dump.c
vm_eval.c add UNREACHABLE_RETURN 2020-06-29 11:05:41 +09:00
vm_exec.c
vm_exec.h
vm_insnhelper.c Extracted METHOD_ENTRY_CACHEABLE macro 2020-06-30 19:12:02 +09:00
vm_insnhelper.h Extracted METHOD_ENTRY_CACHEABLE macro 2020-06-30 19:12:02 +09:00
vm_method.c Split visibility cases 2020-06-30 19:12:05 +09:00
vm_opts.h
vm_trace.c tracepoint_inspect: do not goto into a branch 2020-06-29 11:05:41 +09:00
vsnprintf.c
warning.rb [Feature #16254] Use `Primitive.func` style 2020-06-19 18:46:55 +09:00

README.md

Build Status Build status Actions Status Actions Status Actions Status Actions Status Actions Status

What's Ruby

Ruby is an interpreted object-oriented programming language often used for web development. It also offers many scripting features to process plain text and serialized files, or manage system tasks. It is simple, straightforward, 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, macOS, Haiku, etc.) cf. https://github.com/ruby/ruby/blob/master/doc/contributing.rdoc#platform-maintainers

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/

Git

The mirror of the Ruby source tree can be checked out with the following command:

$ git clone https://github.com/ruby/ruby.git

There are some other branches under development. Try the following command to see the list of branches:

$ git ls-remote https://github.com/ruby/ruby.git

You may also want to use https://git.ruby-lang.org/ruby.git (actual master of Ruby source) if you are a committer.

Subversion

Stable branches for older Ruby versions can be checked out with the following command:

$ svn co https://svn.ruby-lang.org/repos/ruby/branches/ruby_2_6/ ruby

Try the following command to see the list of branches:

$ svn ls https://svn.ruby-lang.org/repos/ruby/branches/

Ruby home page

https://www.ruby-lang.org/

Mailing list

There is a mailing list to discuss Ruby. To subscribe to this list, please send the following phrase:

subscribe

in the mail body (not subject) to the address ruby-talk-request@ruby-lang.org.

How to compile and install

  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.ac, 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 include/ruby/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. 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).

Bugs should be reported 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.

matz@ruby-lang.org