Terminology: class methods versus kernel methods

"One secret about kernel methods like print: they are
actually class methods," according to why's poignant guide to ruby.
This is frustrating for me, because I first thought "oh, that's like a
static class method, a la Math.whatever()," and then accepted the
"kernel" terminology.

Kernel means class methods?

Thufir wrote:

"One secret about kernel methods like print: they are
actually class methods," according to why's poignant guide to ruby.
This is frustrating for me, because I first thought "oh, that's like a
static class method, a la Math.whatever()," and then accepted the
"kernel" terminology.

Kernel means class methods?

No. Kernel methods are methods defined on the Kernel module.

Class methods is not strictly correct either. print and others are usually called module methods.

Cheers

···

--
Ola Bini (http://ola-bini.blogspot.com) JRuby Core Developer
Developer, ThoughtWorks Studios (http://studios.thoughtworks.com)
Practical JRuby on Rails (http://apress.com/book/view/9781590598818\)

"Yields falsehood when quined" yields falsehood when quined.

No, and I don't understand what why means.

print is an instance method of the Kernel module.

The Object class includes Kernel, so the instance methods of Kernel
are effectively instance methods of every object, at least in Ruby
1.8.

I think the only sense that print is a class method is that Module,
and therefore Class inherits it from Object which gets it from
including Kernel. In the same sense then ==, object_id, ... are class
methods. In other words classes are objects.

Ruby 1.9 introduces a BasicObject which doesn't include kernel and can
be used for advanced use cases such as proxies which need to minimize
the number of methods they implement.

···

On 10/23/07, Thufir <hawat.thufir@gmail.com> wrote:

"One secret about kernel methods like print: they are
actually class methods," according to why's poignant guide to ruby.
This is frustrating for me, because I first thought "oh, that's like a
static class method, a la Math.whatever()," and then accepted the
"kernel" terminology.

Kernel means class methods?

--
Rick DeNatale

My blog on Ruby
http://talklikeaduck.denhaven2.com/

[...]

> Kernel means class methods?

No. Kernel methods are methods defined on the Kernel module.

Class methods is not strictly correct either. print and others are
usually called module methods.

[...]

I've got a lot to learn.

thanks,

Thufir

···

On Oct 23, 2:43 pm, Ola Bini <ola.b...@gmail.com> wrote:

[...]

print is an instance method of the Kernel module.

The Object class includes Kernel, so the instance methods of Kernel
are effectively instance methods of every object, at least in Ruby
1.8.

[...]

Kernel is a class, sub-class, of Object?

-Thufir

···

On Oct 23, 2:45 pm, "Rick DeNatale" <rick.denat...@gmail.com> wrote:

No, it's a module, and it's included into Object.

baggio:~ pergesu$ irb
irb(main):001:0> Kernel.class
=> Module
irb(main):002:0> Object.included_modules
=> [Kernel]

Pat

···

On 10/23/07, Thufir <hawat.thufir@gmail.com> wrote:

On Oct 23, 2:45 pm, "Rick DeNatale" <rick.denat...@gmail.com> wrote:
[...]
> print is an instance method of the Kernel module.
>
> The Object class includes Kernel, so the instance methods of Kernel
> are effectively instance methods of every object, at least in Ruby
> 1.8.
[...]

Kernel is a class, sub-class, of Object?

-Thufir

Hi --

[...]

print is an instance method of the Kernel module.

The Object class includes Kernel, so the instance methods of Kernel
are effectively instance methods of every object, at least in Ruby
1.8.

[...]

Kernel is a class, sub-class, of Object?

Kernel is a module. Object mixes it in -- essentially:

   class Object
     include Kernel
   end

so that every instance of Object, or a subclass of Object, gets access
to the instance methods defined in Kernel.

Of course, the module Kernel is, itself, an Object :slight_smile: You'll find
that if you look closely at the top of the object tree in Ruby, there
are some circularities:

   - Kernel is a Module
   - Module is a Class
   - Class is a subclass of Module
   - Object is a Class
   - Class is an Object

etc. Don't worry about it, though. The reason there's circularity at
the top of the object tree is so that the rest of the object tree --
i.e., everything you really need to do -- makes sense.

David

···

On Wed, 24 Oct 2007, Thufir wrote:

On Oct 23, 2:45 pm, "Rick DeNatale" <rick.denat...@gmail.com> wrote:

--
Upcoming training by David A. Black/Ruby Power and Light, LLC:
   * Advancing With Rails, Edison, NJ, November 6-9
   * Advancing With Rails, Berlin, Germany, November 19-22
   * Intro to Rails, London, UK, December 3-6 (by Skills Matter)
See http://www.rubypal.com for details!

Ok. Is this composition? A work around for multiple inheritance?
Weird and wild stuff.

thanks to all,

Thufir

···

On Wed, 24 Oct 2007 07:05:52 +0900, David A. Black wrote:

Kernel is a module. Object mixes it in -- essentially:

   class Object
     include Kernel
   end

so that every instance of Object, or a subclass of Object, gets access
to the instance methods defined in Kernel.

Not at all weird and wild and neither a workaround :slight_smile:
Mixins are one of the cornerstones of Ruby and they are not a workaround
for MI but a replacement. A deliberate and IMHO excellent choice of Matz.

Robert

···

On 10/24/07, Thufir <hawat.thufir@gmail.com> wrote:

On Wed, 24 Oct 2007 07:05:52 +0900, David A. Black wrote:

> Kernel is a module. Object mixes it in -- essentially:
>
> class Object
> include Kernel
> end
>
> so that every instance of Object, or a subclass of Object, gets access
> to the instance methods defined in Kernel.

Ok. Is this composition? A work around for multiple inheritance?
Weird and wild stuff.

--
what do I think about Ruby?
http://ruby-smalltalk.blogspot.com/