From f339fb70d8bbbb0b89ae0465448c9f7e17f30c3b Mon Sep 17 00:00:00 2001 From: matz Date: Wed, 16 Jun 2004 14:21:34 +0000 Subject: * eval.c (rb_mod_freeze): prepare string representation before freezing. [ruby-talk:103646] git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8@6469 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- object.c | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) (limited to 'object.c') diff --git a/object.c b/object.c index dd6b1f3ae..b65259609 100644 --- a/object.c +++ b/object.c @@ -1239,6 +1239,21 @@ rb_mod_to_s(klass) return rb_str_dup(rb_class_path(klass)); } +/* + * call-seq: + * mod.freeze + * + * Prevents further modifications to mod. + */ + +static VALUE +rb_mod_freeze(mod) + VALUE mod; +{ + rb_mod_to_s(mod); + return rb_obj_freeze(mod); +} + /* * call-seq: * mod === obj => true or false @@ -2570,6 +2585,7 @@ Init_Object() rb_define_method(rb_cSymbol, "id2name", sym_to_s, 0); rb_define_method(rb_cSymbol, "to_sym", sym_to_sym, 0); + rb_define_method(rb_cModule, "freeze", rb_mod_freeze, 0); rb_define_method(rb_cModule, "===", rb_mod_eqq, 1); rb_define_method(rb_cModule, "==", rb_obj_equal, 1); rb_define_method(rb_cModule, "<=>", rb_mod_cmp, 1); -- cgit