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
Jeremy Evans 346301e232 Add rb_category_warn{,ing} for warning messages with categories
This adds the following C-API functions that can be used to emit
warnings with categories included:

```c
void rb_category_warn(const char *, const char*, ...)
void rb_category_warning(const char*, const char*, ...)
```

Internally in error.c, there is an rb_warn_category function
that will call Warning.warn with the string and the category
keyword if it doesn't have an arity of 1, and will call
Warning.warn with just the string if it has an arity of 1.
This refactors the rb_warn_deprecated{,_to_remove} functions
to use rb_warn_category.

This makes Kernel#warn accept a category keyword and pass it
to Warning.warn, so that Ruby methods can more easily emit
warnings with categories.  rb_warn_category makes sure that
the passed category is a already defined category symbol
before calling Warning.warn.

The only currently defined warning category is :deprecated,
since that is what is already used.  More categories can be
added in later commits.
2020-09-28 08:38:06 -07:00
.github Remove outdated comment [ci skip] 2020-09-27 14:26:38 +09:00
basictest
benchmark Improve the performance of super 2020-09-23 11:52:36 -07:00
bin
bootstraptest fix typo [ci skip] 2020-09-27 09:49:16 +09:00
ccan
coroutine
coverage
cygwin
defs
doc Update NEWS & documentation relating to scheduler. 2020-09-21 15:28:03 +12:00
enc
ext Refactor common heap iteration code 2020-09-28 08:20:23 -07:00
gems Bundle rbs gem as bundled gems (#3496) 2020-09-23 10:59:49 +09:00
include Add rb_category_warn{,ing} for warning messages with categories 2020-09-28 08:38:06 -07:00
internal Disable deprecation warning by the default [Feature #16345] 2020-09-25 09:50:33 +09:00
lib [ruby/racc] Turn debugging off 2020-09-28 18:08:51 +09:00
libexec Removed unused option on racc 2020-09-28 18:53:25 +09:00
man bundle-package.* was removed at upstream repo 2020-09-23 20:28:38 +09:00
misc Rudimentary support for disassembling rb_iseq_t 2020-09-22 13:40:57 -07:00
missing
sample
spec Add rb_category_warn{,ing} for warning messages with categories 2020-09-28 08:38:06 -07:00
template
test Make Warning.warn accept only category keyword 2020-09-28 08:38:06 -07:00
tool Disable deprecation warning by the default [Feature #16345] 2020-09-25 09:50:33 +09:00
util
win32
.dir-locals.el
.document
.editorconfig
.gdbinit
.gitattributes
.gitignore
.rspec_parallel
.travis.yml
aclocal.m4
addr2line.c
addr2line.h
appveyor.yml
array.c
array.rb
ast.c
ast.rb
bignum.c
BSDL
builtin.c
builtin.h
class.c
common.mk update-deps 2020-09-26 18:55:00 +09:00
compar.c
compile.c
complex.c
configure.ac Do not use clang on cygwin 2020-09-28 13:42:04 +09:00
constant.h
cont.c
CONTRIBUTING.md
COPYING
COPYING.ja
debug.c
debug_counter.c
debug_counter.h
dir.c Switch conflicting chdir warning to RuntimeError 2020-09-28 08:34:04 -07:00
dir.rb
dln.c
dln.h
dln_find.c
dmydln.c
dmyenc.c
dmyext.c
encindex.h
encoding.c
enum.c
enumerator.c
error.c Add rb_category_warn{,ing} for warning messages with categories 2020-09-28 08:38:06 -07:00
eval.c
eval_error.c
eval_intern.h
eval_jump.c
file.c Removed rb_find_file_ext_safe and rb_find_file_safe 2020-09-23 09:09:36 +09:00
gc.c sync rb_gc_register_mark_object() 2020-09-24 17:09:12 +09:00
gc.h
gc.rb
gem_prelude.rb
golf_prelude.rb
goruby.c
GPL
hash.c Fix ENV.except's docs 2020-09-26 12:02:00 -04:00
hrtime.h
id_table.c
id_table.h
inits.c Buffer protocol proposal (#3261) 2020-09-25 20:32:02 +09:00
insns.def
integer.rb
internal.h
io.c
io.rb
iseq.c
iseq.h
kernel.rb
KNOWNBUGS.rb
LEGAL
lex.c.blt
load.c
loadpath.c
localeinit.c
main.c
marshal.c
math.c
memory_view.c memory_view.c: prevent "warning: instance variable __memory_view__ not initialized" 2020-09-25 23:56:38 +09:00
method.h prohibi method call by defined_method in other racotrs 2020-09-25 20:37:38 +09:00
mini_builtin.c
miniinit.c
mjit.c
mjit.h
mjit_compile.c
mjit_worker.c
NEWS.md Fix a typo [ci skip] 2020-09-27 01:16:42 +09:00
node.c
node.h
numeric.c
object.c
pack.c
pack.rb
parse.y
prelude.rb
probes.d
probes_helper.h
proc.c
process.c
ractor.c Frozen Struct can be shareable. 2020-09-25 16:00:13 +09:00
ractor.h Ractor#close_outgoping cancel Ractor.yield 2020-09-25 00:25:38 +09:00
ractor.rb
ractor_pub.h
random.c
range.c freeze all Range objects. 2020-09-25 22:16:55 +09:00
rational.c
re.c
README.EXT
README.EXT.ja
README.ja.md
README.md
regcomp.c
regenc.c
regenc.h
regerror.c
regexec.c
regint.h
regparse.c
regparse.h
regsyntax.c
ruby-runner.c
ruby.c Disable deprecation warning by the default [Feature #16345] 2020-09-25 09:50:33 +09:00
ruby_assert.h
ruby_atomic.h fix typo [Bug #17194] 2020-09-26 18:24:28 +09:00
rubystub.c
scheduler.c Make Thread#join non-blocking. 2020-09-21 11:48:44 +12:00
signal.c
siphash.c
siphash.h
sparc.c
sprintf.c sprintf.c: Removed conflicting definition 2020-09-28 12:51:53 +09:00
st.c
strftime.c
string.c Enhanced RDoc for String#succ (#3590) 2020-09-25 15:13:10 -05:00
struct.c
symbol.c
symbol.h
thread.c Make Thread#join always convert its argument, as before 70f08f1eed 2020-09-21 16:22:04 +02:00
thread_pthread.c
thread_pthread.h
thread_sync.c Make Thread#join non-blocking. 2020-09-21 11:48:44 +12:00
thread_win32.c thread_win32.c: native_mutex_trylock is not used right now 2020-09-28 12:51:20 +09:00
thread_win32.h
time.c
timev.h
trace_point.rb
transcode.c
transcode_data.h
transient_heap.c
transient_heap.h
util.c
variable.c
variable.h
version.c
version.h * 2020-09-29 [ci skip] 2020-09-29 00:20:47 +09:00
vm.c Fix ASAN support when invalidating CCs 2020-09-28 08:20:23 -07:00
vm_args.c
vm_backtrace.c Document difference between Thread::Backtrace::Location#{,absolute_}path 2020-09-23 15:55:58 -07:00
vm_callinfo.h
vm_core.h Make Thread#join non-blocking. 2020-09-21 11:48:44 +12:00
vm_debug.h
vm_dump.c
vm_eval.c
vm_exec.c
vm_exec.h
vm_insnhelper.c prohibi method call by defined_method in other racotrs 2020-09-25 20:37:38 +09:00
vm_insnhelper.h
vm_method.c Fix ASAN support when invalidating CCs 2020-09-28 08:20:23 -07:00
vm_opts.h
vm_sync.c
vm_sync.h
vm_trace.c
vsnprintf.c
warning.rb Add rb_category_warn{,ing} for warning messages with categories 2020-09-28 08:38:06 -07:00

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