X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FUUIDColumns.pm;h=e28b6379d2764fd07d377d7886833f8ef00b7df3;hb=refs%2Ftags%2Fv0.02006;hp=7eca6bb134049a359d5d7021f73cdfa883f6047d;hpb=773544fd3440aba91e3a5ea2246e7818b895ce30;p=dbsrgits%2FDBIx-Class-UUIDColumns.git diff --git a/lib/DBIx/Class/UUIDColumns.pm b/lib/DBIx/Class/UUIDColumns.pm index 7eca6bb..e28b637 100644 --- a/lib/DBIx/Class/UUIDColumns.pm +++ b/lib/DBIx/Class/UUIDColumns.pm @@ -1,28 +1,32 @@ package DBIx::Class::UUIDColumns; - use strict; use warnings; - use vars qw($VERSION); -use base qw/DBIx::Class/; -__PACKAGE__->mk_classdata( 'uuid_auto_columns' => [] ); -__PACKAGE__->mk_classdata( 'uuid_maker' ); -__PACKAGE__->uuid_class( __PACKAGE__->_find_uuid_module ); +BEGIN { + use base qw/DBIx::Class Class::Accessor::Grouped/; + + __PACKAGE__->mk_group_accessors('inherited', qw/uuid_auto_columns uuid_maker/); +}; +__PACKAGE__->uuid_class(__PACKAGE__->_find_uuid_module); # Always remember to do all digits for the version even if they're 0 # i.e. first release of 0.XX *must* be 0.XX000. This avoids fBSD ports # brain damage and presumably various other packaging systems too -$VERSION = '0.06002'; +$VERSION = '0.02006'; -# be compatible with Class::DBI::UUID sub uuid_columns { my $self = shift; - for (@_) { - $self->throw_exception("column $_ doesn't exist") unless $self->has_column($_); - } - $self->uuid_auto_columns(\@_); + + if (scalar @_) { + for (@_) { + $self->throw_exception("column $_ doesn't exist") unless $self->has_column($_); + } + $self->uuid_auto_columns(\@_); + }; + + return $self->uuid_auto_columns || []; } sub uuid_class { @@ -45,7 +49,7 @@ sub uuid_class { sub insert { my $self = shift; - for my $column (@{$self->uuid_auto_columns}) { + for my $column (@{$self->uuid_columns}) { $self->store_column( $column, $self->get_uuid ) unless defined $self->get_column( $column ); } @@ -59,6 +63,8 @@ sub get_uuid { sub _find_uuid_module { if (eval{require Data::UUID}) { return '::Data::UUID'; + } elsif (eval{require Data::GUID}) { + return '::Data::GUID'; } elsif ($^O ne 'openbsd' && eval{require APR::UUID}) { # APR::UUID on openbsd causes some as yet unfound nastiness for XS return '::APR::UUID'; @@ -72,8 +78,10 @@ sub _find_uuid_module { return '::Win32::Guidgen'; } elsif (eval{require Win32API::GUID}) { return '::Win32API::GUID'; + } elsif (eval{require UUID::Random}) { + return '::UUID::Random'; } else { - shift->throw_exception('no suitable uuid module could be found') + die 'no suitable uuid module could be found for use with DBIx::Class::UUIDColumns'; }; }; @@ -86,14 +94,17 @@ DBIx::Class::UUIDColumns - Implicit uuid columns =head1 SYNOPSIS - package Artist; - __PACKAGE__->load_components(qw/UUIDColumns Core DB/); - __PACKAGE__->uuid_columns( 'artist_id' ); +In your L table class: + + __PACKAGE__->load_components(qw/UUIDColumns ... Core/); + __PACKAGE__->uuid_columns('artist_id'); + +B The component needs to be loaded I Core. =head1 DESCRIPTION -This L component resembles the behaviour of -L, to make some columns implicitly created as uuid. +This L component resembles the behaviour of L, +to make some columns implicitly created as uuid. When loaded, C will search for a suitable uuid generation module from the following list of supported modules: @@ -109,35 +120,41 @@ If no supporting module can be found, an exception will be thrown. *APR::UUID will not be loaded under OpenBSD due to an as yet unidentified XS issue. -If you would like to use a specific module, you can set C: +If you would like to use a specific module, you can set L: __PACKAGE__->uuid_class('::Data::UUID'); __PACKAGE__->uuid_class('MyUUIDGenerator'); -Note that the component needs to be loaded before Core. - =head1 METHODS -=head2 uuid_columns(@columns) +=head2 get_uuid + +Returns a uuid string from the current uuid_maker. + +=head2 insert + +Inserts a new uuid string into each column in L. -Takes a list of columns to be filled with uuids during insert. +=head2 uuid_columns - __PACKAGE__->uuid_columns('id'); +Gets/sets the list of columns to be filled with uuids during insert. -=head2 uuid_class($classname) + __PACKAGE__->uuid_columns('artist_id'); + +=head2 uuid_class Takes the name of a UUIDMaker subclass to be used for uuid value generation. This can be a fully qualified class name, or a shortcut name starting with :: -that matches one of the available DBIx::Class::UUIDColumns::UUIDMaker subclasses: +that matches one of the available L subclasses: __PACKAGE__->uuid_class('CustomUUIDGenerator'); # loads CustomeUUIDGenerator - __PACKAGE->uuid_class('::Data::UUID'); + __PACKAGE__->uuid_class('::Data::UUID'); # loads DBIx::Class::UUIDMaker::Data::UUID; -Note that C chacks to see that the specified class isa -DBIx::Class::UUIDColumns::UUIDMaker subbclass and throws and exception if it isn't. +Note that C checks to see that the specified class isa +L subclass and throws and exception if it isn't. =head2 uuid_maker @@ -149,9 +166,12 @@ Returns the current UUIDMaker instance for the given module. L -=head1 AUTHORS +=head1 AUTHOR Chia-liang Kao + +=head1 CONTRIBUTERS + Chris Laco =head1 LICENSE