/[wait]/trunk/lib/WAIT/Index.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Annotation of /trunk/lib/WAIT/Index.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 114 - (hide annotations)
Tue Jul 13 21:27:27 2004 UTC (19 years, 10 months ago) by dpavlin
File size: 3798 byte(s)
enought for today, still not passing all tests

1 ulpfr 13 # -*- Mode: Cperl -*-
2 ulpfr 10 # Index.pm --
3     # ITIID : $ITI$ $Header $__Header$
4     # Author : Ulrich Pfeifer
5     # Created On : Thu Aug 8 13:05:10 1996
6     # Last Modified By: Ulrich Pfeifer
7 dpavlin 89 # Last Modified On: Sun Nov 22 18:44:43 1998
8 ulpfr 10 # Language : CPerl
9 dpavlin 89 # Update Count : 107
10 ulpfr 10 # Status : Unknown, Use with caution!
11     #
12     # Copyright (c) 1996-1997, Ulrich Pfeifer
13     #
14    
15     package WAIT::Index;
16     use WAIT::IndexScan;
17     use strict;
18 dpavlin 108 use BerkeleyDB;
19 ulpfr 10 use Fcntl;
20 laperla 29 use vars qw($VERSION);
21 ulpfr 10
22 dpavlin 108 $VERSION = "2.000"; # Table.pm tests if we are loaded by checking $VERSION
23 laperla 29
24 ulpfr 10 sub new {
25     my $type = shift;
26     my %parm = @_;
27     my $self = {};
28    
29 dpavlin 114 for my $x (qw(path attr env subname maindbfile tablename)) {
30 dpavlin 108 unless ($self->{$x} = $parm{$x}) {
31     require Carp;
32     Carp::croak("No $x specified");
33     }
34 ulpfr 13 }
35 dpavlin 108 bless $self, ref($type) || $type;
36     }
37    
38     for my $accessor (qw(maindbfile tablename subname)) {
39     no strict 'refs';
40     *{$accessor} = sub {
41     my($self) = @_;
42     return $self->{$accessor} if $self->{$accessor};
43 ulpfr 13 require Carp;
44 dpavlin 108 Carp::confess("accessor $accessor not there");
45 ulpfr 13 }
46 ulpfr 10 }
47    
48     sub drop {
49     my $self = shift;
50     if ((caller)[0] eq 'WAIT::Table') { # Table knows about this
51 dpavlin 114 my $path = $self->{path};
52     ! (!-e $path or unlink $path);
53 ulpfr 13 } else { # notify our database
54     require Carp;
55     Carp::croak(ref($self)."::drop called directly");
56 ulpfr 10 }
57     }
58    
59     sub open {
60     my $self = shift;
61 dpavlin 114 my $path = $self->{path};
62 ulpfr 10
63 dpavlin 89 if (exists $self->{dbh}) {
64 ulpfr 10 $self->{dbh};
65     } else {
66 dpavlin 108 my $flags;
67     if ($self->{mode} & O_RDWR) {
68     $flags = DB_CREATE; # | DB_INIT_MPOOL | DB_INIT_CDB;
69 dpavlin 114 # warn "Flags on index $path set to 'writing'";
70 dpavlin 108 } else {
71     $flags = DB_RDONLY;
72 dpavlin 114 # warn "Flags on index $path set to 'readonly'";
73 dpavlin 108 }
74     $self->{dbh} = tie(%{$self->{db}}, 'BerkeleyDB::Btree',
75 dpavlin 114 # Filename => $path,
76 dpavlin 108 Filename => $self->maindbfile,
77     $self->{env} ? (Env => $self->{env}) : (),
78     Subname => join("/",$self->tablename,$self->subname),
79     Mode => 0664,
80     Flags => $flags,
81     $WAIT::Database::Cachesize?(Cachesize => $WAIT::Database::Cachesize):(),
82     $WAIT::Database::Pagesize?(Pagesize => $WAIT::Database::Pagesize):(),
83     ) or die $BerkeleyDB::Error;
84 ulpfr 10 }
85     }
86    
87     sub insert {
88     my $self = shift;
89     my $key = shift;
90     my %parm = @_;
91    
92     defined $self->{db} or $self->open;
93    
94     my $tuple = join($;, map($parm{$_}, @{$self->{attr}}));
95    
96     if (exists $self->{db}->{$tuple}) {
97     # duplicate entry
98     return undef;
99     }
100     $self->{db}->{$tuple} = $key;
101     }
102    
103     sub have {
104     my $self = shift;
105     my %parm = @_;
106    
107     defined $self->{db} or $self->open;
108    
109     my $tuple = join($;, map($parm{$_}, @{$self->{attr}}));
110    
111 ulpfr 82 $self->{db}->{$tuple};
112 ulpfr 10 }
113    
114     sub fetch {
115     my $self = shift;
116     my %parm = @_;
117     my @keys = @{$self->{attr}->[0]};
118 ulpfr 13
119 ulpfr 10 defined $self->{db} or $self->open;
120    
121     my $key = join($;, map($parm{$_}, @keys));
122     $self->{db}->{$key};
123     }
124    
125     sub delete {
126     my $self = shift;
127     my $key = shift;
128     my %parm = @_;
129    
130     defined $self->{db} or $self->open;
131    
132 ulpfr 19 my $tuple = join($;, map($parm{$_}||"", @{$self->{attr}}));
133 ulpfr 13
134 ulpfr 10 delete $self->{db}->{$tuple};
135     }
136    
137     sub sync {
138     my $self = shift;
139 dpavlin 89 $self->{dbh}->sync if $self->{dbh};
140 ulpfr 10 }
141    
142     sub close {
143     my $self = shift;
144    
145     delete $self->{scans} if defined $self->{scans};
146    
147 dpavlin 108 delete $self->{env};
148 ulpfr 10 if ($self->{dbh}) {
149     delete $self->{dbh};
150 dpavlin 89 untie %{$self->{db}};
151 dpavlin 114 for my $att (qw(db path maindbfile)) {
152 dpavlin 108 delete $self->{$att};
153     }
154 ulpfr 10 }
155     }
156    
157     #sub DESTROY { $_[0]->close }
158    
159     sub open_scan {
160     my $self = shift;
161     my $code = shift;
162 ulpfr 13
163 ulpfr 10 $self->{dbh} or $self->open;
164     new WAIT::IndexScan $self, $code;
165     }
166    
167     1;

Properties

Name Value
cvs2svn:cvs-rev 1.4

  ViewVC Help
Powered by ViewVC 1.1.26