I'm a new Ruby/Rails guy. Here's one question puzzling me:
Can we find the exact module lists mixin-ed for a class in Rails from the API doc? For example, if we have an instance of one subclass of ActiveRecord::Base, we can use validates method in this class such as following:
class Product < ActiveRecord::Base
has_many :line_items
validates :title, :description, :image_url, :presence => true
end
from rails api doc we can find that validates belongs to ActiveModel::Validations::ClassMethods, so ActiveRecore::Base must have ActiveModel::Validations::ClassMethods mixin, but I didn't find anything relating to this in the api reference. Can anyone tell me if I can find this info from api doc?
Thanks for all of your help in advance. I really hope my question doesn't sound too silly:)
Mixins provides a controlled way of adding functionality to classes. The code in the mixin starts to interact with code in the class. In Ruby, a code wrapped up in a module is called mixins that a class can include or extend. A class consist many mixins.
The truth is that you can put your modules anywhere. Personally, my main use for modules is to create namespaces for my Active Record models to help keep things organized. Those module definitions just end up in the same files as my Active Record models.
A user cannot access instance method directly with the use of the dot operator as he cannot make the instance of the module. To access the instance method defined inside the module, the user has to include the module inside a class and then use the class instance to access that method.
What is the difference between a class and a module? Modules are collections of methods and constants. They cannot generate instances. Classes may generate instances (objects), and have per-instance state (instance variables).
in console :
ActiveRecord::Base.included_modules
I don't see anything like that in any of the Rails documentation I've seen:
And with monkey patching, there probably isn't any way to know until Rails is all cranked up and you have an actual ActiveRecord::Base in your hands; for example, the PostgreSQL, MySQL, and SQLite adapters re-open ActiveRecord::Base and they might include extra modules along the way; other gems you're using and even your own code may do similar things.
If you just want to know the standard set of mixins, use the source (Luke!) or do as maniek suggests and ask ActiveRecord::Base in the Rails console.
In general, the Rails API documentation isn't that useful unless you already know what you're looking for and even then, digging into the source is often necessary.
Your best bet is to check the guides for what you need and read the source if that doesn't work.
Short Answer: You can't get your list from the documentation because the modules cannot be known until run time. Read the guides and the source if you need to know something.
Short answer is that you can't.
A long answer is merely an excuse (a lousy one): Ruby and Rails documentation is generated automatically, from the source. And Ruby is notorious for its metaprogramming abilities, so the fact that a method is included into a class can not be (easily) extracted by parsing the source. The only reliable way to get the list of methods in a class is to fire up a console and type SomeVeryImportantClass.methods
.
That said, it really is discouraging and frustrating to both new and experienced developers that one can't easily find in the docs some of the most frequently used methods. It is dissapointing that someone didn't think of a way to somehow include these cross-references, perhaps even manually.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With