aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--hash.c29
-rw-r--r--test/ruby/test_env.rb18
3 files changed, 39 insertions, 13 deletions
diff --git a/ChangeLog b/ChangeLog
index 34745a3297..4c99baee38 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Tue Jun 24 10:50:06 2014 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * hash.c (env_path_str_new): make PATH environment variable
+ string, to be frozen.
+
Tue Jun 24 10:40:52 2014 SHIBATA Hiroshi <shibata.hiroshi@gmail.com>
* tool/make-snapshot: download bundle gems when package making.
diff --git a/hash.c b/hash.c
index c509deef30..69ffe75b17 100644
--- a/hash.c
+++ b/hash.c
@@ -2514,6 +2514,20 @@ env_str_new(const char *ptr, long len)
}
static VALUE
+env_path_str_new(const char *ptr)
+{
+#ifdef _WIN32
+ VALUE str = rb_enc_str_new_cstr(ptr, rb_utf8_encoding());
+ str = rb_str_conv_enc(str, NULL, rb_filesystem_encoding());
+#else
+ VALUE str = rb_filesystem_str_new_cstr(ptr);
+#endif
+
+ rb_obj_freeze(str);
+ return str;
+}
+
+static VALUE
env_str_new2(const char *ptr)
{
if (!ptr) return Qnil;
@@ -2584,14 +2598,7 @@ rb_f_getenv(VALUE obj, VALUE name)
env = getenv(nam);
if (env) {
if (ENVMATCH(nam, PATH_ENV) && !env_path_tainted(env)) {
-#ifdef _WIN32
- VALUE str = rb_str_conv_enc(rb_str_new(env, strlen(env)), rb_utf8_encoding(), rb_filesystem_encoding());
-#else
- VALUE str = rb_filesystem_str_new_cstr(env);
-#endif
-
- rb_obj_freeze(str);
- return str;
+ return env_path_str_new(env);
}
return env_str_new2(env);
}
@@ -2638,11 +2645,7 @@ env_fetch(int argc, VALUE *argv)
return if_none;
}
if (ENVMATCH(nam, PATH_ENV) && !env_path_tainted(env))
-#ifdef _WIN32
- return rb_str_conv_enc(rb_str_new(env, strlen(env)), rb_utf8_encoding(), rb_filesystem_encoding());
-#else
- return rb_filesystem_str_new_cstr(env);
-#endif
+ return env_path_str_new(env);
return env_str_new2(env);
}
diff --git a/test/ruby/test_env.rb b/test/ruby/test_env.rb
index 17c5d57d25..847b5f819b 100644
--- a/test/ruby/test_env.rb
+++ b/test/ruby/test_env.rb
@@ -408,4 +408,22 @@ class TestEnv < Test::Unit::TestCase
keys.each {|k| ENV.delete(k)}
end
end
+
+ def test_frozen
+ ENV[PATH_ENV] = "/"
+ ENV.each do |k, v|
+ assert_predicate(k, :frozen?)
+ assert_predicate(v, :frozen?)
+ end
+ ENV.each_key do |k|
+ assert_predicate(k, :frozen?)
+ end
+ ENV.each_value do |v|
+ assert_predicate(v, :frozen?)
+ end
+ ENV.each_key do |k|
+ assert_predicate(ENV[k], :frozen?, "[#{k.dump}]")
+ assert_predicate(ENV.fetch(k), :frozen?, "fetch(#{k.dump})")
+ end
+ end
end