NAME
    DBIx::Class::VirtualColumns - Add virtual columns to DBIx::Class
    schemata

SYNOPSIS
     package Your::Schema::Class;
     use strict;
     use warnings;
 
     use base 'DBIx::Class';
 
     __PACKAGE__->load_components(
       "VirtualColumns",
       "PK",
       "Core",
     );
 
     __PACKAGE__->table("sometable");
     __PACKAGE__->add_columns(qw/dbcol1 dbcol2/);
     __PACKAGE__->add_virtual_columns(qw/vcol1 vcol2 vcol3/);
 
     # =========================================================
     # Somewhere else
 
     my $item = $schema->resultset('Artist')->find($id);
     $item->vcol1('test'); # Set 'test'
     $item->get_column('vcol1'); # Return 'test'
 
     my $otheritem = $schema->resultset('Artist')->create({
         dbcol1 => 'value1',
         dbcol2 => 'value2',
         vcol1  => 'value3',
         vcol2  => 'value4',
     });
 
     $otheritem->vcol1(); # Now is 'value3'
 
     # Get the column metadata just like for a regular DBIC column
     my $info = $result_source->column_info('vcol1');

DESCRIPTION
    This module allows to specify 'virtual columns' in DBIx::Class schema
    classes. Virtual columns behave almost like regular columns but are not
    stored in the database. They may be used to store temporary information
    in the DBIx::Class::Row object and without introducting an additional
    interface.

    Most DBIx::Class methods like "set_column", "set_columns", "get_column",
    "get_columns", "column_info", ... will work with regular as well as
    virtual columns.

USAGE
    Use this module if you want to add 'virtual' columns to a DBIC class
    which behave like real columns (e.g. if you want to use the
    "set_column", "get_column" methods)

    However if you only want to add non-column data to DBIx::Class::Row
    objects, then there are easier/better ways:

     __PACKAGE__->mk_group_accessors(simple => qw(foo bar baz));

METHODS
  add_virtual_columns
    Adds virtual columns to the result source. If supplied key => hashref
    pairs, uses the hashref as the column_info for that column. Repeated
    calls of this method will add more columns, not replace them.

     $table->add_virtual_columns(qw/column1 column2/); 
     OR 
     $table->add_virtual_columns(column1 => \%column1_info, column2 => \%column2_info, ...);

    The column names given will be created as accessor methods on your
    "DBIx::Class::Row objects", you can change the name of the accessor by
    supplying an "accessor" in the column_info hash.

    The following options are currently recognised/used by
    DBIx::Class::VirtualColumns:

    *   accessor

        Use this to set the name of the accessor method for this column. If
        not set, the name of the column will be used.

  add_virtual_column
    Shortcut for add_virtual_columns

  has_any_column
    Returns true if the source has a virtual or regular column of this name,
    false otherwise.

  has_virtual_column
    Returns true if the source has a virtual column of this name, false
    otherwise.

  remove_virtual_columns
     $table->remove_columns(qw/col1 col2 col3/);

    Removes virtual columns from the result source.

  remove_virtual_column
    Shortcut for remove_virtual_columns

  _virtual_filter
    Splits attributes for regular and virtual columns

  new
    Overloaded method. "new" in DBIx::Class::Row

  get_column
    Overloaded method. "get_colum" in DBIx::Class::Row

  get_columns
    Overloaded method. "get_colums" in DBIx::Class::Row

  store_column
    Overloaded method. "store_column" in DBIx::Class::Row

  set_column
    Overloaded method. "set_column" in DBIx::Class::Row

  column_info
    Overloaded method. "column_info" in DBIx::Class::ResultSource

    Additionally returns the HASH key 'virtual' which indicates if the
    requested column is virtual or not.

  update
    Overloaded method. "update" in DBIx::Class::Row

CAVEATS
    The best way to add non-column data to DBIC objects is to use
    Class::Accessor::Grouped.

     __PACKAGE__->mk_group_accessors(simple => qw(foo bar baz));

    Use DBIx::Class::VirtualColumns only if you rely on DBIx::Class::Row
    methods like "set_column", "get_column", ...

SUPPORT
    This module was just a proof of concept, and is not actively developed
    anymore. Patches are still welcome though.

    Please report any bugs to "bug-dbix-class-virtualcolumns@rt.cpan.org",
    or through the web interface at
    <http://rt.cpan.org/Public/Bug/Report.html?Queue=DBIx::Class::VirtualCol
    umns>. I will be notified, and then you'll automatically be notified of
    progress on your report as I make changes.

AUTHOR
        Maroš Kollár
        CPAN ID: MAROS
        maros [at] k-1.com
        L<http://www.revdev.at>

ACKNOWLEDGEMENTS
    This module was written for Revdev <http://www.revdev.at>, a nice litte
    software company I run with Koki and Domm
    (<http://search.cpan.org/~domm/>).

COPYRIGHT
    DBIx::Class::VirtualColumns is Copyright (c) 2008 Maroš Kollár -
    <http://www.revdev.at>

    This program is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.

    The full text of the license can be found in the LICENSE file included
    with this module.