/usr/share/perl5/Tangram/Driver/Sybase/Storage.pm is in libtangram-perl 2.10-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | package Tangram::Driver::Sybase::Storage;
use strict;
use Tangram::Storage;
use vars qw(@ISA);
@ISA = qw( Tangram::Storage );
use Tangram::Driver::Sybase::Expr::Date;
use Tangram::Driver::Sybase::Statement;
sub prepare
{
my ($self, $sql) = @_;
#print "prepare: $sql\n";
bless [ $self, $sql ], 'Tangram::Driver::Sybase::Statement';
}
*prepare_update = \*prepare;
*prepare_insert = \*prepare;
sub prepare_select
{
my ($self, $sql) = @_;
return $self->prepare($sql);
}
sub make_1st_id_in_tx
{
my ($self) = @_;
my $table = $self->{schema}{control};
$self->sql_do("UPDATE $table SET mark = mark + 1");
return $self->{db}->selectall_arrayref("SELECT mark from $table")->[0][0];
}
sub update_id_in_tx
{
my ($self, $mark) = @_;
$self->sql_do("UPDATE $self->{schema}{control} SET mark = $mark");
}
my %improved =
(
'Tangram::Type/TimeAndDate' => 'Tangram::Driver::Sybase::Expr::Date',
'Tangram::Type/Date' => 'Tangram::Driver::Sybase::Expr::Date',
);
sub expr
{
my $self = shift;
my $type = shift;
my ($expr, @remotes) = @_;
# is $type related to dates? if not, return default
my $improved = $improved{ref($type)} or return $type->expr(@_);
# $type is a Date; return a DateExpr
return $improved->new($type, $expr, @remotes);
}
1;
|