1 |
dpavlin |
1 |
# Dobrica Pavlinusic, <dpavlin@rot13.org> 06/28/07 23:28:21 CEST |
2 |
|
|
|
3 |
|
|
package EPrints; |
4 |
|
|
|
5 |
|
|
use Exporter 'import'; |
6 |
|
|
@EXPORT_OK = qw(_x); |
7 |
|
|
|
8 |
|
|
use Encode qw/from_to decode_utf8 decode/; |
9 |
|
|
use Data::Dump qw/dump/; |
10 |
|
|
|
11 |
|
|
use strict; |
12 |
|
|
use warnings; |
13 |
|
|
|
14 |
|
|
my $debug = 0; |
15 |
|
|
|
16 |
|
|
my $connect = "DBI:mysql:dbname=eprints"; |
17 |
|
|
|
18 |
|
|
my $dbh = DBI->connect($connect,"dpavlin","") || die $DBI::errstr; |
19 |
|
|
|
20 |
|
|
sub dbh { |
21 |
|
|
my $self = shift; |
22 |
|
|
return $dbh; |
23 |
|
|
} |
24 |
|
|
|
25 |
|
|
my $id; |
26 |
|
|
|
27 |
|
|
sub id { |
28 |
|
|
my $self = shift; |
29 |
|
|
if ( defined( $_[0] ) ) { |
30 |
|
|
$id = $_[0]; |
31 |
|
|
warn "# id = $id\n" if $debug; |
32 |
|
|
} |
33 |
|
|
return $id; |
34 |
|
|
} |
35 |
|
|
|
36 |
|
|
sub lookup { |
37 |
|
|
my $self = shift; |
38 |
|
|
my $field = shift; |
39 |
|
|
|
40 |
|
|
my $sql = qq{ |
41 |
|
|
SELECT $field |
42 |
|
|
FROM archive_$field |
43 |
|
|
WHERE eprintid = $id |
44 |
|
|
}; |
45 |
|
|
warn "# sql: $sql\n" if $debug; |
46 |
|
|
my @results = map { _x( $_->{$field} ) } @{ $dbh->selectall_arrayref($sql, { Slice => {} }) }; |
47 |
|
|
|
48 |
|
|
warn "# loookup( $field, $id ) = ", dump( @results ),$/ if $debug; |
49 |
|
|
return join(" ", @results); |
50 |
|
|
} |
51 |
|
|
|
52 |
|
|
sub _x { |
53 |
|
|
my $v = join(" ", @_); |
54 |
|
|
decode_utf8( $v ); |
55 |
|
|
from_to( $v, 'utf-8', 'iso-8859-2' ); |
56 |
|
|
warn "_x($v)\n" if $debug; |
57 |
|
|
return "$v "; |
58 |
|
|
} |
59 |
|
|
|
60 |
|
|
1; |