DBIx::Class::Schema::Loader::RelBuilder - Builds relationships for DBIx::Class::Schema::Loader |
DBIx::Class::Schema::Loader::RelBuilder - Builds relationships for DBIx::Class::Schema::Loader
See the DBIx::Class::Schema::Loader manpage
This class builds relationships for the DBIx::Class::Schema::Loader manpage. This is module is not (yet) for external use.
Arguments: schema_class (scalar), inflect_plural, inflect_singular
$schema_class
should be a schema class name, where the source
classes have already been set up and registered. Column info, primary
key, and unique constraints will be drawn from this schema for all
of the existing source monikers.
Options inflect_plural and inflect_singular are optional, and are better documented in the DBIx::Class::Schema::Loader::Base manpage.
Arguments: local_moniker (scalar), fk_info (arrayref)
This generates the code for the relationships of a given table.
local_moniker
is the moniker name of the table which had the REFERENCES
statements. The fk_info arrayref's contents should take the form:
[ { local_columns => [ 'col2', 'col3' ], remote_columns => [ 'col5', 'col7' ], remote_moniker => 'AnotherTableMoniker', }, { local_columns => [ 'col1', 'col4' ], remote_columns => [ 'col1', 'col2' ], remote_moniker => 'YetAnotherTableMoniker', }, # ... ],
This method will return the generated relationships as a hashref keyed on the class names. The values are arrayrefs of hashes containing method name and arguments, like so:
{ 'Some::Source::Class' => [ { method => 'belongs_to', arguments => [ 'col1', 'Another::Source::Class' ], { method => 'has_many', arguments => [ 'anothers', 'Yet::Another::Source::Class', 'col15' ], ], 'Another::Source::Class' => [ # ... ], # ... }
DBIx::Class::Schema::Loader::RelBuilder - Builds relationships for DBIx::Class::Schema::Loader |