[#33161] Call/CC and Ruby iterators. — olczyk@... (Thaddeus L Olczyk)

Reading about call/cc in Scheme I get the impression that it is very

11 messages 2002/02/05

[#33242] favicon.ico — Dave Thomas <Dave@...>

19 messages 2002/02/06
[#33256] Re: favicon.ico — Leon Torres <leon@...> 2002/02/06

[#33435] Reg: tiny contest: who's faster? (add_a_gram) — grady@... (Steven Grady)

> My current solution works correctly with various inputs.

17 messages 2002/02/08

[#33500] Ruby Embedded Documentation — William Djaja Tjokroaminata <billtj@...>

Hi,

24 messages 2002/02/10
[#33502] Re: Ruby Embedded Documentation — "Lyle Johnson" <ljohnson@...> 2002/02/10

> Now, I am using Ruby on Linux, and I have downloaded Ruby version

[#33615] Name resolution in Ruby — stern@... (Alan Stern)

I've been struggling to understand how name resolution is supposed to

16 messages 2002/02/11

[#33617] choice of HTML templating system — Paul Brannan <paul@...>

I am not a web developer, nor do I pretend to be one.

23 messages 2002/02/11

[#33619] make first letter lowercase — sebi@... (sebi)

hello,

20 messages 2002/02/11
[#33620] Re: [newbie] make first letter lowercase — Tobias Reif <tobiasreif@...> 2002/02/11

sebi wrote:

[#33624] Re: [newbie] make first letter lowercase — "Jeff 'japhy' Pinyan" <jeffp@...> 2002/02/11

On Feb 11, Tobias Reif said:

[#33632] Re: [newbie] make first letter lowercase — Mathieu Bouchard <matju@...> 2002/02/12

[#33731] simple XML parsing (greedy / non-greedy — Ron Jeffries <ronjeffries@...>

Suppose I had this text

14 messages 2002/02/13

[#33743] qualms about respond_to? idiom — David Alan Black <dblack@...>

Hi --

28 messages 2002/02/13
[#33751] Re: qualms about respond_to? idiom — Dave Thomas <Dave@...> 2002/02/13

David Alan Black <dblack@candle.superlink.net> writes:

[#33754] Re: qualms about respond_to? idiom — David Alan Black <dblack@...> 2002/02/13

Hi --

[#33848] "Powered by Ruby" banner — Yuri Leikind <YuriLeikind@...>

Hello Ruby folks,

78 messages 2002/02/14
[#33909] Re: "Powered by Ruby" banner — Leon Torres <leon@...> 2002/02/14

On Thu, 14 Feb 2002, Yuri Leikind wrote:

[#33916] RE: "Powered by Ruby" banner — "Jack Dempsey" <dempsejn@...> 2002/02/15

A modest submission:

[#33929] Re: "Powered by Ruby" banner — yet another bill smith <bigbill.smith@...> 2002/02/15

Kent Dahl wrote:

[#33932] OT Netscape 4.x? was Re: "Powered by Ruby" banner — Chris Gehlker <gehlker@...> 2002/02/15

On 2/15/02 5:54 AM, "yet another bill smith" <bigbill.smith@verizon.net>

[#33933] RE: OT Netscape 4.x? was Re: "Powered by Ruby" banner — "Jack Dempsey" <dempsejn@...> 2002/02/15

i just don't understand why it didn't show up! dhtml/javascript, ok, but a

[#33937] Re: OT Netscape 4.x? was Re: "Powered by Ruby" banner — Chris Gehlker <gehlker@...> 2002/02/15

On 2/15/02 7:16 AM, "Jack Dempsey" <dempsejn@georgetown.edu> wrote:

[#33989] Re: OT OmniWeb [was: Netscape 4.x?] — Sean Russell <ser@...> 2002/02/16

Chris Gehlker wrote:

[#33991] Re: OT OmniWeb [was: Netscape 4.x?] — Rob Partington <rjp@...> 2002/02/16

In message <3c6e5e01_1@spamkiller.newsgroups.com>,

[#33993] Re: OT OmniWeb [was: Netscape 4.x?] — Thomas Hurst <tom.hurst@...> 2002/02/16

* Rob Partington (rjp@browser.org) wrote:

[#33925] Re: "Powered by Ruby" banner — Martin Maciaszek <mmaciaszek@...> 2002/02/15

In article <3C6CFCCA.5AD5CA67@scnsoft.com>, Yuri Leikind wrote:

[#33956] Re: "Powered by Ruby" banner — Leon Torres <leon@...> 2002/02/15

On Fri, 15 Feb 2002, Martin Maciaszek wrote:

[#33851] Ruby and .NET — Patrik Sundberg <ps@...>

I have been reading a bit about .NET for the last couple of days and must say

53 messages 2002/02/14

[#34024] Compiled companion language for Ruby? — Erik Terpstra <erik@...>

Hmmm, seems that my previous post was in a different thread, I'll try

12 messages 2002/02/16

[#34036] The GUI Returns — "Horacio Lopez" <vruz@...>

Hello all,

33 messages 2002/02/17

[#34162] Epic4/Ruby — Thomas Hurst <tom.hurst@...>

Rejoice, for you no longer have to put up with that evil excuse for a

34 messages 2002/02/18

[#34185] Operator overloading and multiple arguments — ptkwt@...1.aracnet.com (Phil Tomson)

I'm trying to overload the '<=' operator in a class in order to use it for

10 messages 2002/02/18

[#34217] Ruby for web development — beripome@... (Billy)

Hi all,

21 messages 2002/02/19

[#34350] FAQ for comp.lang.ruby — "Hal E. Fulton" <hal9000@...>

RUBY NEWSGROUP FAQ -- Welcome to comp.lang.ruby! (Revised 2001-2-18)

15 messages 2002/02/20

[#34375] Setting the Ruby continued — <jostein.berntsen@...>

Hi,

24 messages 2002/02/20
[#34384] Re: Setting the Ruby continued — Paulo Schreiner <paulo@...> 2002/02/20

Also VERY important:

[#34467] recursive require — Ron Jeffries <ronjeffries@...>

I'm having a really odd thing happen with two files that mutually

18 messages 2002/02/21

[#34503] special characters — Tobias Reif <tobiasreif@...>

Hi all,

13 messages 2002/02/22

[#34517] Windows Installer Ruby 166-0 available — Andrew Hunt <andy@...>

16 messages 2002/02/22

[#34597] rdoc/xml questions — Dave Thomas <Dave@...>

24 messages 2002/02/23

[#34631] Object/Memory Management — "Sean O'Dell" <sean@...>

I'm new to Ruby and the community here (I've been learning Ruby for a grand

44 messages 2002/02/23

[#34682] duplicate method name — Ron Jeffries <ronjeffries@...>

I just found a case in a test file where i had two tests of the same

16 messages 2002/02/24
[#34687] Re: duplicate method name — s@... (Stefan Schmiedl) 2002/02/24

Hi Ron.

[#34791] Style Question — Ron Jeffries <ronjeffries@...>

So I'm building this set theory library. The "only" object is supposed

13 messages 2002/02/25

[#34912] RCR?: parallel to until: as_soon_as — Tobias Reif <tobiasreif@...>

Hi,

18 messages 2002/02/26

[#34972] OT A Question on work styles — Chris Gehlker <gehlker@...>

As a Mac baby I just had to step through ruby in GDB *from the command line*

20 messages 2002/02/28

[#35015] Time Comparison — "Sean O'Dell" <sean@...>

I am using the time object to compare times between two files and I'm

21 messages 2002/02/28

Re: Name resolution in Ruby

From: "Chr. Rippel" <chr_news@...>
Date: 2002-02-13 20:14:54 UTC
List: ruby-talk #33789
"Alan Stern" <stern@rowland.org> wrote in,
....
> This is currently under discussion in a separate thread.  I think a
> consensus is growing that class variables really ought to behave more
> like instance variables of the class itself, with appropriate accessor
> methods.

I wrote something to this affect but this was not quite what I mend.
The current class variable behavior is really very usefull but it is
possible to simulate this behavior with instance and/or local variables
and accessor methods. This has the added advantage of a more fine
tuned control of visibility (and no interpretation headaches). Here is
an example of a public ``class attribute" with a protected writer attribute
that is invisible on the meta level
----
class A
    var = "a"

    define_method(:var) { var }
    protected
    define_method(:var=) {|x| var = x }
end

p A.new.var  # => "a"

class B   < A 
   def initialize(x)
      self.var = x
   end
end

B.new(3)
p A.new.var  # => 3
class << A
    var   # raises a NameError exception
end
----

Since we already have an implementation of class variables there is
no point to get rid(t?)e of them (they are definitely faster;-).
However it is at least a theoretical possibility to for go their 
implementation in a rewrite like Rite.

>
....
> >  a class is just an object like any other objects.
>
> While largely true, that's not entirely correct.  Ordinary objects and
> classes differ in the way their metaclasses are created.  For
> instance, suppose that x is an ordinary object (not a class) and that
> C is a class.  Then C always has a metaclass -- it is created at the
> same time as C (I think) -- but x only has a metaclass if you create
> one explicitly.  Also, if C is a subclass of B, then Meta-C is a
> subclass of Meta-B.  This means that, although Meta-x's superclass is
> x's original class, Meta-C's superclass is not C's original class but
> instead is C's superclass's metaclass.

This is true but this is not relevant for scoping rules, in fact it is possbile
to define constants on the meta class level or more generally singleton
classes. I appended a script illustrating the Meta-class system (note the use
of class variables;-)

....
> > A> The overall effect is that constants behave as though they really do
> > A> have a static scope.
> >
> >  This is the intented use, I think.

Local scope is an illusion created by coding convention on top of Ruby's
static scope - but you can always should yourself in the foot;-)

----
A = Class.new
x = Class.new A
Sub = Class.new x
Sub.const_set :Super ,x

p Sub.ancestors      # => [Sub, Sub::Super, A, Object, Kernel]

class Sub
  class Super
    p Module.nesting # => [Sub::Super, Sub]
  end
end

Normal = x
class Normal
    # prevent creation of Sub::Super::Sub
    Sub = ::Sub
    class Sub
        p Module.nesting # => [Sub, Sub::Super]
    end
end
 
class A
    L = "A"
end

class Sub
    L = "Sub"
    class Super
        K = 1
        p L    # => "Sub"
    end
        remove_const :L
        p K   # => 1
    class Super
        p L   # => "B"
    end
end

class Binding
  def search_path
    nest = eval("Module.nesting",self)
    __self =eval("self",self)
    if __self.is_a? Module 
      nest.concat __self.ancestors.select {|m| not nest.include? m}
    else
      nest.concat __self.type.ancestors.select {|m| not nest.include? m}
    end
  end
end


class Sub
  class Super
     p binding.search_path
     # => [Sub::Super, Sub, A, Object, Kernel]
  end
end


# Search path is not transitive!

class A; 
   F = "A"
end
class B < A; end
class C < B; end

class C
  G = "visible in C::Z"
  p Module.constants - Object.constants
  # => ["F", "L"]
  class X;    end
  class Y < X;end
  class Z < Y
    p Module.constants - Object.constants
    # => ["G", "Z", "X", "Y"]
    p binding.search_path
    # => [C::Z, C, C::Y, C::X, Object, Kernel]
  end
end
----

/Christoph



----
# A meta class illustrations script 
class Class
  @@to_s  = nil
  @@level = nil
  attr_reader :inst
  def superclasses
    res = [self]
    tmp = self
    res.push tmp while tmp = tmp.superclass
    return res
  end
  def each_superclass
    klass = self
    yield klass
    yield klass while klass = klass.superclass
    self
  end
  def level
    @level || 0
  end
  def singleton?; true end
  alias :old_to_s :to_s
  private :old_to_s
  def to_s
    if singleton?
      if level.zero?
        (old_to_s.sub(/^(#<Class:)/){''})\
        .sub(/(>)$/){"_Sing(#{inst})"}
      else 
        @to_s
      end
    else
      old_to_s
    end
  end
  alias  :inspect :to_s
  protected  
  def __meta
    super
    @@to_s = to_s.concat '_Meta'
    @@level   = level + 1
    @meta.instance_eval do
      @to_s  = @@to_s
      @level = @@level
    end
    superclass.__meta if superclass
    if level.nonzero?
      def self.__meta; @meta end
    end
    return @meta
  end
end

class Object
  @@inst = nil
  class << self
     def singleton?; false end
     undef :inst
  end
  def meta(level = 1)
    return self if level.zero?
    return __meta.meta(level-1)
  end
  def singleton_type 
    class << self; self end
  end
  protected
  def __meta
    @meta = singleton_type
    @@inst = self
    @meta.instance_eval do
      @inst = @@inst
    end
    @meta
  end
end

class A;     end
class B < A; end

class C < B
  def initialize num
    @num = num
  end
  def inspect; @num.inspect end
  alias :to_s :inspect
end

def class_chain klass
  unless klass.level.zero? && klass.singleton?
    puts  klass.superclasses.join(" < ")
  else
    res = klass.superclasses
    puts res.shift.to_s.concat(" << ").concat(res.join(" < "))
  end
end

# Examples

class_chain C.meta
class_chain Class.meta
class_chain C.new({}).meta
class_chain Math::E.meta

puts "\n\"Higher\" order\n\n"

class_chain Object.meta(2) 
class_chain C.meta(2)
class_chain Math::PI.meta(2)
class_chain Module.meta(3)
class_chain C.meta(3)


n = 0
ObjectSpace.each_object(Class) do |klass| klass
  n+=1 if klass.singleton?
end
puts "\nNumber of Singletons controlled by GC == #{n}" 

----
C_Meta < B_Meta < A_Meta < Object_Meta < Class < Module < Object
Class_Meta < Module_Meta < Object_Meta < Class < Module < Object
C_Sing({}) << C < B < A < Object
Float_Sing(2.718281828) << Float < Numeric < Object

"Higher" order

Object_Meta_Meta < Class < Module < Object
C_Meta_Meta < Class < Module < Object
Float_Sing(3.141592654)_Meta < Class < Module < Object
Module_Meta_Meta_Meta < Class < Module < Object
C_Meta_Meta_Meta < Class < Module < Object

Number of Singletons controlled by GC == 0
----

In This Thread