File: Lock.pm

package info (click to toggle)
liblockfile-simple-perl 0.2.5-1
  • links: PTS
  • area: main
  • in suites: woody
  • size: 220 kB
  • ctags: 204
  • sloc: perl: 507; makefile: 435; sh: 111; ansic: 1
file content (73 lines) | stat: -rw-r--r-- 1,337 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
;# $Id
;#
;#  Copyright (c) 1998-1999, Raphael Manfredi
;#  
;#  You may redistribute only under the terms of the Artistic License,
;#  as specified in the README file that comes with the distribution.
;#
;# $Log: Lock.pm,v $
;# Revision 0.2.1.1  2000/01/04 21:16:28  ram
;# patch1: track where lock was issued in the code
;#
;# Revision 0.2  1999/12/07 20:51:04  ram
;# Baseline for 0.2 release.
;#

use strict;

########################################################################
package LockFile::Lock;

#
# A lock instance -- deferred class.
#

#
# ->_lock_init
#
# Common lock initialization
#
# Attributes:
#
#	scheme		the LockFile::* object that created the lock
#	filename	where lock was taken
#	line		line in filename where lock was taken
#
sub _lock_init {
	my $self = shift;
	my ($scheme, $filename, $line) = @_;
	$self->{'scheme'} = $scheme;
	$self->{'filename'} = $filename;
	$self->{'line'} = $line;
}

#
# Common attribute access
#

sub scheme		{ $_[0]->{'scheme'} }
sub filename	{ $_[0]->{'filename'} }
sub line		{ $_[0]->{'line'} }

#
# ->release
#
# Release the lock
#
sub release {
	my $self = shift;
	return $self->scheme->release($self);
}

#
# ->where
#
# Returns '"filename", line #' where lock was taken.
#
sub where {
	my $self = shift;
	return sprintf '"%s", line %d', $self->filename, $self->line;
}

1;