/usr/share/perl5/Rose/DB/Generic.pm is in librose-db-perl 0.778-1.
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 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 | package Rose::DB::Generic;
use strict;
use Rose::DB;
our $VERSION = '0.11';
#
# Object methods
#
sub build_dsn
{
my($self_or_class, %args) = @_;
my %info;
$info{'dbname'} = $args{'db'} || $args{'database'};
$info{'host'} = $args{'host'};
$info{'port'} = $args{'port'};
return
"dbi:$args{'dbi_driver'}:" .
join(';', map { "$_=$info{$_}" } grep { defined $info{$_} }
qw(dbname host port));
}
sub last_insertid_from_sth { }
1;
__END__
=head1 NAME
Rose::DB::Generic - Generic driver class for Rose::DB.
=head1 SYNOPSIS
use Rose::DB;
Rose::DB->register_db(
dsn => 'dbi:SomeDB:...', # unknown driver
username => 'devuser',
password => 'mysecret',
);
Rose::DB->default_domain('development');
Rose::DB->default_type('main');
...
$db = Rose::DB->new; # $db is really a Rose::DB::Generic object
...
=head1 DESCRIPTION
This is the subclass that L<Rose::DB> blesses an object into (by default) when the L<driver|Rose::DB::Registry::Entry/driver> specified in the registry entry is has no class name registered in the L<driver class map|Rose::DB/driver_class>.
To maximize the chance that this class will work with an unsupported database, do the following.
=over 4
=item * Use a L<driver|Rose::DB::Registry::Entry/driver> name that exactly matches the L<DBI> "DBD::..." driver name. Even though L<Rose::DB> L<driver|Rose::DB::Registry::Entry/driver>s are case-insensitive, using the exact spelling and letter case will allow this generic L<Rose::DB> driver to connect successfully.
=item * Specify the DSN explicitly rather than providing the pieces separately (host, database, port, etc.) and then relying upon this class to assemble them into L<DBI> DSN. This class will assemble a DSN, but it may not be in the format that an unsupported driver expects.
=back
This class inherits from L<Rose::DB>. See the L<Rose::DB> documentation for information on the inherited methods.
=head1 AUTHOR
John C. Siracusa (siracusa@gmail.com)
=head1 LICENSE
Copyright (c) 2010 by John C. Siracusa. All rights reserved. This program is
free software; you can redistribute it and/or modify it under the same terms
as Perl itself.
|