--- nfo/patches/cpan/Tangram/Storage.pm 2002/12/16 05:14:43 1.4 +++ nfo/patches/cpan/Tangram/Storage.pm 2003/04/23 23:40:58 1.8 @@ -253,9 +253,23 @@ { my $self = shift; - eval ("use Data::UUID;"); - my $ug = Data::UUID->new(); - my $guid = $ug->create_str(); + my $guid; + + # try to use Data::UUID first ... + eval("use Data::UUID;"); + if (!$@) { + my $ug = Data::UUID->new(); + $guid = $ug->create_str(); + + # ... if this fails, try to fallback to Data::UUID::PurePerl instead ... + } else { + eval("use Data::UUID::PurePerl;"); + if (!$@) { + $guid = Data::UUID::PurePerl::generate_id(); + } else { + croak "couldn't create globally unique identifier"; + } + } return $guid; } @@ -468,12 +482,8 @@ return $self->id($obj) if $self->id($obj); - # insert global unique identifier in object to persist across re-deploys - $obj->{guid} = $self->make_guid(); - - # debug - use Data::Dumper; - print Dumper($obj); + # insert global unique identifier in object to persist across re-deploys + $obj->{guid} = $self->make_guid(); $saving->insert($obj); @@ -695,6 +705,7 @@ my $row = _fetch_object_state($self, $id, $class); my $obj = $self->read_object($id, $class->{name}, $row); + return undef unless defined $row; # ??? $self->{-residue} = \@row; @@ -712,6 +723,7 @@ my $class = $self->{schema}->classdef( $self->{id2class}{ int(substr($id, -$self->{cid_size})) } ); my $row = _fetch_object_state($self, $id, $class); + return undef unless defined $row; _row_to_object($self, $obj, $id, $class->{name}, $row); return $obj; @@ -783,6 +795,10 @@ $sth->execute($self->{export_id}->($id)); my $state = [ $sth->fetchrow_array() ]; + unless (@$state) { + return undef unless $sth->err; + croak "error during load of object id=$id: $sth->err"; + } $sth->finish(); return $state;