diff options
| author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-09-09 06:46:31 +0000 |
|---|---|---|
| committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-09-09 06:46:31 +0000 |
| commit | 6261e58116bb92dabf51460742de0aa177b297f6 (patch) | |
| tree | 4aa96fb05b18df3231f438cbee3231241fc38d8f | |
| parent | e8380aecdc022ab2c81d011833cb771dab259cea (diff) | |
| download | ruby-6261e58116bb92dabf51460742de0aa177b297f6.tar.gz ruby-6261e58116bb92dabf51460742de0aa177b297f6.tar.xz ruby-6261e58116bb92dabf51460742de0aa177b297f6.zip | |
* load.c (rb_feature_provided): fixed for autoloading extension
library without suffix.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@24817 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
| -rw-r--r-- | ChangeLog | 6 | ||||
| -rw-r--r-- | load.c | 4 | ||||
| -rw-r--r-- | test/ruby/test_autoload.rb | 12 |
3 files changed, 20 insertions, 2 deletions
@@ -1,6 +1,12 @@ +Wed Sep 9 15:46:28 2009 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * load.c (rb_feature_provided): fixed for autoloading extension + library without suffix. + Wed Sep 9 15:24:32 2009 TAKANO Mitsuhiro (takano32) <tak@no32.tk> * include/ruby/st.h : revert previous commit. + * ext/objspace/objspace.c : remove st_memsize declare. Wed Sep 9 14:07:19 2009 TAKANO Mitsuhiro (takano32) <tak@no32.tk> @@ -233,7 +233,7 @@ rb_feature_provided(const char *feature, const char **loading) return FALSE; } } - if (rb_feature_p(feature, feature + strlen(feature), TRUE, FALSE, loading)) + if (rb_feature_p(feature, 0, TRUE, FALSE, loading)) return TRUE; return FALSE; } @@ -473,7 +473,7 @@ search_required(VALUE fname, volatile VALUE *path, int safe_level) OBJ_FREEZE(tmp); if (rb_find_file_ext_safe(&tmp, loadable_ext + 1, safe_level)) { ext = strrchr(ftptr = RSTRING_PTR(tmp), '.'); - if (!rb_feature_p(ftptr, ext, Qfalse, Qtrue, &loading) || loading) + if (!rb_feature_p(ftptr, ext, FALSE, TRUE, &loading) || loading) *path = tmp; return 's'; } diff --git a/test/ruby/test_autoload.rb b/test/ruby/test_autoload.rb new file mode 100644 index 000000000..c2039086c --- /dev/null +++ b/test/ruby/test_autoload.rb @@ -0,0 +1,12 @@ +require 'test/unit' +require_relative 'envutil' + +class TestAutoload < Test::Unit::TestCase + def test_autoload_so + # Continuation is always available, unless excluded intentionally. + assert_in_out_err([], <<-INPUT, [], []) + autoload :Continuation, "continuation" + begin Continuation; rescue LoadError; end + INPUT + end +end |
