![show/hide quicksearch [+]](../images/find.png)
Sequel::Model is an object relational mapper built on top of Sequel core. Each model class is backed by a dataset instance, and many dataset methods can be called directly on the class. Model datasets return rows as model instances, which have fairly standard ORM instance behavior.
Sequel::Model is built completely out of plugins, the only method not part of a plugin is the plugin method itself. Plugins can override any class, instance, or dataset method defined by a previous plugin and call super to get the default behavior.
You can set the SEQUEL_NO_ASSOCIATIONS constant or environment variable to make Sequel not load the associations plugin by default.
Hooks that are called after an action. When overriding these, it is recommended to call super on the first line of your method, so later hooks are called before earlier hooks.
Map that stores model classes created with Sequel::Model(), to allow the reopening of classes when dealing with code reloading.
Hooks that are called before an action. Can return false to not do the action. When overriding these, it is recommended to call super as the last line of your method, so later hooks are called before earlier hooks.
Boolean settings that can be modified at the global, class, or instance level.
Class methods added to model that call the method of the same name on the dataset
Class instance variables to set to nil when a subclass is created, for -w compliance
Empty instance methods to create that the user can override to get hook/callback behavior. Just like any other method defined by Sequel, if you override one of these, you should call super to get the default behavior (while empty by default, they can also be defined by plugins). See the “Model Hooks” guide for more detail on hooks.
Class instance variables that are inherited in subclasses. If the value is :dup, dup is called on the superclass’s instance variable when creating the instance variable in the subclass. If the value is nil, the superclass’s instance variable is used directly in the subclass.
Regexp that determines if a method name is normal in the sense that it could be called directly in ruby code without using send. Used to avoid problems when using eval with a string to define methods.
The setter methods (methods ending with =) that are never allowed to be called automatically via set/update/new/etc..
Regular expression that determines if the method is a valid setter name (i.e. it ends with =).
Loads a plugin for use with the model class, passing optional arguments to the plugin. If the plugin is a module, load it directly. Otherwise, require the plugin from either sequel/plugins/#{plugin} or sequel_#{plugin}, and then attempt to load the module using a the camelized plugin name under Sequel::Plugins.
# File lib/sequel/model/plugins.rb, line 29 def self.plugin(plugin, *args, &blk) arg = args.first m = plugin.is_a?(Module) ? plugin : plugin_module(plugin) unless @plugins.include?(m) @plugins << m m.apply(self, *args, &blk) if m.respond_to?(:apply) include(m::InstanceMethods) if m.const_defined?("InstanceMethods") extend(m::ClassMethods)if m.const_defined?("ClassMethods") if m.const_defined?("DatasetMethods") dataset.extend(m::DatasetMethods) if @dataset dataset_method_modules << m::DatasetMethods meths = m::DatasetMethods.public_instance_methods.reject{|x| NORMAL_METHOD_NAME_REGEXP !~ x.to_s} def_dataset_method(*meths) unless meths.empty? end end m.configure(self, *args, &blk) if m.respond_to?(:configure) end
Generated with the Darkfish Rdoc Generator 2.