/[cvs]/nfo/perl/libs/Data/Storage/Handler/Tangram.pm
ViewVC logotype

Diff of /nfo/perl/libs/Data/Storage/Handler/Tangram.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.19 by joko, Mon Dec 16 06:46:09 2002 UTC revision 1.22 by jonen, Wed Dec 18 22:28:16 2002 UTC
# Line 3  Line 3 
3  #  $Id$  #  $Id$
4  #  #
5  #  $Log$  #  $Log$
6    #  Revision 1.22  2002/12/18 22:28:16  jonen
7    #  + added extended logging at 'getObjectByGuid()'
8    #
9    #  Revision 1.21  2002/12/16 22:20:49  jonen
10    #  + fixed bug at 'getObjectByGuid()'
11    #
12    #  Revision 1.20  2002/12/16 20:49:17  jonen
13    #  + added sub 'getObjectByGuid()'
14    #  + added functionality to use 'getObjectByGuid' at 'getObjectAsHash()'
15    #
16  #  Revision 1.19  2002/12/16 06:46:09  joko  #  Revision 1.19  2002/12/16 06:46:09  joko
17  #  + attempt to introduce a generic '_patchSchema' - cancelled!  #  + attempt to introduce a generic '_patchSchema' - cancelled!
18  #  #
# Line 549  sub getObject { Line 559  sub getObject {
559    return $object if $object;    return $object if $object;
560  }  }
561    
562    sub getObjectByGuid {
563      my $self = shift;
564      my $guid = shift;
565      my $options = shift;
566      
567      # Guid and Classname is needed
568      if(!$guid || !$options->{classname}) {
569       $logger->error( __PACKAGE__ . "->getObjectByGuid: No 'guid' OR no Classname in options hash was given but needed!" );
570        return;
571      }
572      
573      # TODO: create a deep_unload method (currently _all_ objects are unloaded)
574      # unload($oid) will only unload object, not deep object hashes
575      $self->{_COREHANDLE}->unload() if ($options->{destroy});
576    
577      # search for object with given Classname and Guid
578      my $obj_tmp = $self->{_COREHANDLE}->remote($options->{classname});
579      my @result = $self->{_COREHANDLE}->select($obj_tmp, $obj_tmp->{guid} eq $guid);
580      
581      # we searched for global unique identifer of some object,
582      # so I think we can trust there would be only one result
583      if($result[0]) {
584        return $result[0];
585      } else {
586        $logger->error( __PACKAGE__ . "->getObjectByGuid: No Object with Classname $options->{classname} and GUID $guid found!" );
587        return;
588      }
589      
590    }
591    
592  sub getObjectAsHash {  sub getObjectAsHash {
593    my $self = shift;    my $self = shift;
594    my $oid = shift;    my $oid = shift;
595    my $options = shift;    my $options = shift;  
596    my $obj = $self->getObject($oid, $options);    my $obj;
597      
598      if($options->{guid}) {
599        $obj = $self->getObjectByGuid($oid, $options);
600      } else {
601        $obj = $self->getObject($oid, $options);
602      }
603        
604    # build options (a callback to unload autovivified objects) for 'expand'    # build options (a callback to unload autovivified objects) for 'expand'
605    # TODO: use $logger to write to debug here!    # TODO: use $logger to write to debug here!

Legend:
Removed from v.1.19  
changed lines
  Added in v.1.22

MailToCvsAdmin">MailToCvsAdmin
ViewVC Help
Powered by ViewVC 1.1.26 RSS 2.0 feed