mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* vm_core.h (rb_vm_t): move `rb_execution_context_t::safe_level` to
`rb_vm_t::safe_level_` because `$SAFE` is a process (VM) global state.
* vm_core.h (rb_proc_t): remove `rb_proc_t::safe_level` because `Proc`
objects don't need to keep `$SAFE` at the creation.
Also make `is_from_method` and `is_lambda` as 1 bit fields.
* cont.c (cont_restore_thread): no need to keep `$SAFE` for Continuation.
* eval.c (ruby_cleanup): use `rb_set_safe_level_force()` instead of access
`vm->safe_level_` directly.
* eval_jump.c: End procs `END{}` doesn't keep `$SAFE`.
* proc.c (proc_dup): removed and introduce `rb_proc_dup` in vm.c.
* safe.c (rb_set_safe_level): don't check `$SAFE` 1 -> 0 changes.
* safe.c (safe_setter): use `rb_set_safe_level()`.
* thread.c (rb_thread_safe_level): `Thread#safe_level` returns `$SAFE`.
It should be obsolete.
* transcode.c (load_transcoder_entry): `rb_safe_level()` only returns
0 or 1 so that this check is not needed.
* vm.c (vm_proc_create_from_captured): don't need to keep `$SAFE` for Proc.
* vm.c (rb_proc_create): renamed to `proc_create`.
* vm.c (rb_proc_dup): moved from proc.c.
* vm.c (vm_invoke_proc): do not need to set and restore `$SAFE`
for `Proc#call`.
* vm_eval.c (rb_eval_cmd): rename a local variable to represent clearer
meaning.
* lib/drb/drb.rb: restore `$SAFE`.
* lib/erb.rb: restore `$SAFE`, too.
* test/lib/leakchecker.rb: check `$SAFE == 0` at the end of tests.
* test/rubygems/test_gem.rb: do not set `$SAFE = 1`.
* bootstraptest/test_proc.rb: catch up this change.
* spec/ruby/optional/capi/string_spec.rb: ditto.
* test/bigdecimal/test_bigdecimal.rb: ditto.
* test/fiddle/test_func.rb: ditto.
* test/fiddle/test_handle.rb: ditto.
* test/net/imap/test_imap_response_parser.rb: ditto.
* test/pathname/test_pathname.rb: ditto.
* test/readline/test_readline.rb: ditto.
* test/ruby/test_file.rb: ditto.
* test/ruby/test_optimization.rb: ditto.
* test/ruby/test_proc.rb: ditto.
* test/ruby/test_require.rb: ditto.
* test/ruby/test_thread.rb: ditto.
* test/rubygems/test_gem_specification.rb: ditto.
* test/test_tempfile.rb: ditto.
* test/test_tmpdir.rb: ditto.
* test/win32ole/test_win32ole.rb: ditto.
* test/win32ole/test_win32ole_event.rb: ditto.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@61510 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
|
||
|---|---|---|
| .. | ||
| ext | ||
| fixtures | ||
| array_spec.rb | ||
| bignum_spec.rb | ||
| boolean_spec.rb | ||
| class_spec.rb | ||
| complex_spec.rb | ||
| constants_spec.rb | ||
| data_spec.rb | ||
| encoding_spec.rb | ||
| enumerator_spec.rb | ||
| exception_spec.rb | ||
| file_spec.rb | ||
| fixnum_spec.rb | ||
| float_spec.rb | ||
| gc_spec.rb | ||
| globals_spec.rb | ||
| hash_spec.rb | ||
| integer_spec.rb | ||
| io_spec.rb | ||
| kernel_spec.rb | ||
| marshal_spec.rb | ||
| module_spec.rb | ||
| mutex_spec.rb | ||
| numeric_spec.rb | ||
| object_spec.rb | ||
| proc_spec.rb | ||
| rake_helper.rb | ||
| range_spec.rb | ||
| rational_spec.rb | ||
| README | ||
| regexp_spec.rb | ||
| spec_helper.rb | ||
| st_spec.rb | ||
| string_spec.rb | ||
| struct_spec.rb | ||
| symbol_spec.rb | ||
| thread_spec.rb | ||
| time_spec.rb | ||
| typed_data_spec.rb | ||
| util_spec.rb | ||
C-API Specs
These specs test the C-API from Ruby. The following are conventions for the
specs:
1. Put specs for functions related to a Ruby class in a file named according
to the class. For example, for rb_ary_new function, put the specs in
optional/capi/array_spec.rb
2. Put the C file containing the C functions for array_spec.rb in
optional/capi/ext/array_spec.c
3. Add a '#define HAVE_RB_ARY_NEW 1' to rubyspec.h
4. Name the C extension class 'CApiArraySpecs'.
5. Name the C functions 'array_spec_rb_ary_new'.
6. Wrap the code in the optional/capi/ext/array_spec.c in
'#ifdef HAVE_RB_ARY_NEW'
6. Attach the C function to the class using the name 'rb_ary_new'