[#37730] [Ruby 1.9 - Bug #4962][Open] come back gem_prelude! — Yusuke Endoh <mame@...>

24 messages 2011/07/02

[#37840] [Ruby 1.9 - Feature #4985][Open] Add %S[] support for making a list of symbols — Aaron Patterson <aaron@...>

23 messages 2011/07/07

[#37866] [Backport87 - Feature #4996][Open] About 1.8.7 EOL — Shyouhei Urabe <shyouhei@...>

22 messages 2011/07/08

[#37913] [Ruby 1.9 - Bug #5003][Open] Enumerator#next segfaults in OS X Lion (10.7) — Ganesh Gunasegaran <ganesh.gunas@...>

16 messages 2011/07/09

[#37917] [Ruby 1.9 - Feature #5005][Open] Provide convenient access to original methods — Lazaridis Ilias <ilias@...>

13 messages 2011/07/09

[#37932] [Ruby 1.9 - Feature #5008][Open] Equal rights for Hash (like Array, String, Integer, Float) — Suraj Kurapati <sunaku@...>

31 messages 2011/07/09

[#37936] [Ruby 1.9 - Feature #5010][Open] Add Slop(-like) in stdlib and deprecate current OptionParser API — Rodrigo Rosenfeld Rosas <rr.rosas@...>

29 messages 2011/07/09

[#37968] [Ruby 1.9 - Bug #5015][Open] method_added" is called in addition to "method_undefined — Lazaridis Ilias <ilias@...>

14 messages 2011/07/10

[#38096] [Ruby 1.9 - Feature #5033][Open] PATCH: 1.9: gc_mark_children: Avoid gc_mark() tail recursion, use goto again. — Kurt Stephens <ks.ruby@...>

14 messages 2011/07/16

[#38109] [Ruby 1.9 - Bug #5034][Open] C Source Code formatting — Lazaridis Ilias <ilias@...>

18 messages 2011/07/16

[#38171] [Ruby 1.9 - Bug #5047][Open] Segfault (most likely involving require) — Jack Christensen <jack@...>

21 messages 2011/07/18

[#38182] [Ruby 1.9 - Feature #5054][Open] Compress a sequence of ends — ANDO Yasushi ANDO <andyjpn@...>

68 messages 2011/07/19

[#38197] [Ruby 1.9 - Feature #5056][Open] About 1.9 EOL — Shyouhei Urabe <shyouhei@...>

39 messages 2011/07/19
[#38900] [Ruby 1.9 - Feature #5056] About 1.9 EOL — Shota Fukumori <sorah@...> 2011/08/10

[#38902] Re: [Ruby 1.9 - Feature #5056] About 1.9 EOL — Yukihiro Matsumoto <matz@...> 2011/08/10

Hi,

[#39048] Re: [Ruby 1.9 - Feature #5056] About 1.9 EOL — SASADA Koichi <ko1@...> 2011/08/22

Hi,

[#39055] Re: [Ruby 1.9 - Feature #5056] About 1.9 EOL — Lucas Nussbaum <lucas@...> 2011/08/23

On 23/08/11 at 06:50 +0900, SASADA Koichi wrote:

[#38295] [Ruby 1.9 - Feature #5064][Open] HTTP user-agent class — Eric Hodel <drbrain@...7.net>

15 messages 2011/07/21

[#38391] [Ruby 1.9 - Bug #5076][Open] Mac OS X Lion Support — Yui NARUSE <naruse@...>

17 messages 2011/07/22

[#38503] [Ruby 1.9 - Feature #5096][Open] offer Logger-compatibility for ext — Eric Wong <normalperson@...>

16 messages 2011/07/25

[#38510] [Ruby 1.9 - Feature #5097][Assigned] Supported platforms of Ruby 1.9.3 — Yui NARUSE <naruse@...>

42 messages 2011/07/26

[#38526] [Backport92 - Backport #5099][Open] Backport r31875 load path performance problem — Aaron Patterson <aaron@...>

19 messages 2011/07/26

[#38538] [Ruby 1.9 - Feature #5101][Open] allow optional timeout for TCPSocket.new — Eric Wong <normalperson@...>

15 messages 2011/07/27

[#38610] [Ruby 1.9 - Feature #5120][Open] String#split needs to be logical — Alexey Muranov <muranov@...>

18 messages 2011/07/30

[#38623] [Ruby 1.9 - Feature #5123][Open] Alias Hash 1.9 as OrderedHash — Alexey Muranov <muranov@...>

14 messages 2011/07/31

[ruby-core:37779] [Ruby 1.9 - Feature #3908] private constant

From: Yusuke Endoh <mame@...>
Date: 2011-07-04 16:42:43 UTC
List: ruby-core #37779
Issue #3908 has been updated by Yusuke Endoh.

Assignee changed from Yusuke Endoh to Yukihiro Matsumoto
Target version changed from 1.9.3 to 1.9.x


----------------------------------------
Feature #3908: private constant
http://redmine.ruby-lang.org/issues/3908

Author: Yusuke Endoh
Status: Assigned
Priority: Normal
Assignee: Yukihiro Matsumoto
Category: core
Target version: 1.9.x


=begin
 Hi,
 
 I'd propose "private constant."
 Private constant provides method-like visibility for constant.
 
 
 === Sample code ===
 
   module SomeModule
     class PublicClass
       ...
     end
 
     class PrivateClass
       ...
     end
 
     # you can make "PrivateClass" private by private_constant method
     private_constant :PrivateClass
   end
 
   # we can refer access constant as is conventionally done
   p SomeModule::PublicClass  #=> SomeModule::PublicClass
 
   # a RuntimeError is raised when we attempt to refer private constant
   p SomeModule::PrivateClass  #=> private constant (RuntimeError)
 
   # we can even refer private constant from its parent scope
   module SomeModule
     p PrivateClass  #=> SomeModule::PrivateClass
   end
 
 
 === Background ===
 
 Traditionally, there is no way to prevent users from using your classes.
 It is too easy for user to access any internal class (e.g., CGI::Html3,
 Enumerator::Generator, Matrix::Scalar, URI::Util, etc).
 We can only write a document to ask users not to use them.
 
 RubySpec inspired me to propose this feature.  RubySpec declares the
 policy that no spec should be written for private method.  Nevertheless,
 there were some specs for internal classes, such as CGI::Html3 (FYI,
 such specs are already deleted).
 I thought this was because there is no way to explicitly declare that
 the constants are "internal use only."
 
 
 === Proposal ===
 
 Private constant is a scoped constant that can be referred only from
 its parent scope.  It can be used for declaring "the constant is
 for internal use," like private method.
 
 When users try to refer private constant, they can realize that they
 are going to use non-guaranteed feature, because the constant cannot
 be referred so easily.  Even so, they can use such a feature with
 self-responsibility, by explicitly opening its parent scope.
 
 Since the default visibility is public, this feature does not break
 any compatibility.
 
 
 === Current status ===
 
 I first suggested this at [ruby-dev:39685].
 Matz approved my proposal [ruby-dev:39686]
 Yugui has also approved [ruby-dev:40254], but said that it is needed
 to discuss in ruby-core list before commit.
 
 The patches are attached.  make check and make test-rubyspec are all
 passed.
 
 
 What do you think?
 I'll commit the patch unless there is objection.
 
 -- 
 Yusuke ENDOH <mame@tsg.ne.jp>
=end



-- 
http://redmine.ruby-lang.org

In This Thread

Prev Next