148 lines
4.5 KiB
Plaintext
148 lines
4.5 KiB
Plaintext
$OpenBSD: patch-cddb_pl,v 1.2 2002/11/10 12:14:44 wilfried Exp $
|
|
|
|
--- cddb.pl.orig Thu Oct 10 02:55:24 2002
|
|
+++ cddb.pl Sat Nov 9 09:37:21 2002
|
|
@@ -26,7 +26,7 @@ use strict;
|
|
|
|
use Getopt::Std;
|
|
my %option = ();
|
|
-getopts("oghdtsiSfDlO", \%option);
|
|
+getopts("oghdtsSfDlO", \%option);
|
|
|
|
if($option{h}) {
|
|
print "$0: gets CDDB info of a CD\n";
|
|
@@ -34,8 +34,7 @@ if($option{h}) {
|
|
print " -o offline mode - just stores CD info\n";
|
|
print " -d output in xmcd format\n";
|
|
print " -s save in xmcd format\n";
|
|
- print " -i write to mysql db\n";
|
|
- print " -O overwrite file or db\n";
|
|
+ print " -O overwrite file\n";
|
|
print " -t output toc\n";
|
|
print " -l output lame command\n";
|
|
print " -f http mode (e.g. through firewalls)\n";
|
|
@@ -58,7 +57,7 @@ my $xmcddir="/tmp/xmcd";
|
|
# $config{CDDB_HOST}="freedb.freedb.org"; # set cddb host
|
|
# $config{CDDB_PORT}=888; # set cddb port
|
|
# $config{CDDB_MODE}="cddb"; # set cddb mode: cddb or http, this is switched with -f
|
|
-# $config{CD_DEVICE}="/dev/cdrom"; # set cd device
|
|
+# $config{CD_DEVICE}="/dev/cd0c"; # set cd device
|
|
|
|
# $config{HELLO_ID} ="root nowhere.com fastrip 0.77"; # hello string: username hostname clientname version
|
|
|
|
@@ -77,19 +76,6 @@ $config{input}=1; # 1: ask user if mor
|
|
$config{multi}=0; # 1: do not ask user and get all of them
|
|
# 0: just the first one
|
|
|
|
-my %db;
|
|
-
|
|
-if($option{i}) {
|
|
- require DBI;
|
|
-
|
|
- $db{host} = "localhost:3306";
|
|
- $db{name} = "mp3-test";
|
|
- $db{table_cds} = "cds";
|
|
- $db{table_tracks} = "tracks";
|
|
- $db{user} = "root";
|
|
- $db{passwd} = "xxx";
|
|
-}
|
|
-
|
|
if($option{o}) {
|
|
my $ids=get_discids($config{CD_DEVICE});
|
|
|
|
@@ -150,8 +136,6 @@ if($option{g}) {
|
|
|
|
if($option{d} || $option{s}) {
|
|
print_xmcd(\%cd,$option{s});
|
|
- } elsif($option{i}) {
|
|
- insert_db(\%cd,\%db);
|
|
} elsif($option{l}) {
|
|
print_lame(\%cd);
|
|
} else {
|
|
@@ -186,8 +170,6 @@ unless($config{multi}) {
|
|
|
|
if($option{d} || $option{s}) {
|
|
print_xmcd(\%cd,$option{s});
|
|
- } elsif($option{i}) {
|
|
- insert_db(\%cd,\%db);
|
|
} elsif($option{l}) {
|
|
print_lame(\%cd);
|
|
} else {
|
|
@@ -216,8 +198,6 @@ unless($config{multi}) {
|
|
|
|
if($option{d} || $option{s}) {
|
|
print_xmcd($c,$option{s});
|
|
- } elsif($option{i}) {
|
|
- insert_db($c,\%db);
|
|
} elsif($option{l}) {
|
|
print_lame($c);
|
|
print "\n";
|
|
@@ -291,67 +271,6 @@ sub print_xmcd {
|
|
close OUT;
|
|
}
|
|
}
|
|
-
|
|
-sub insert_db {
|
|
- my $cd=shift;
|
|
- my $db=shift;
|
|
-
|
|
- my ($artist, $title, $category, $cddbid, $trackno) =
|
|
- ($cd->{artist}, $cd->{title}, $cd->{cat}, $cd->{id}, $cd->{tno});
|
|
-
|
|
- my $sql = "SELECT cddbid FROM $db->{table_cds} WHERE CDDBID = \'$cddbid\'";
|
|
- my $dbh = DBI->connect("dbi:mysql:$db->{name}:$db->{host}",
|
|
- $db->{user},$db->{passwd}) or die "cannot connect to db: $DBI::errstr";
|
|
- my $sth = $dbh->prepare($sql);
|
|
- my $r = $sth->execute or die "cannot check for cd: $DBI::errstr";
|
|
- if ($r == 1) {
|
|
- print "cd already in db\n";
|
|
- if($option{O}) {
|
|
- my $sql = "DELETE FROM $db->{table_cds} WHERE CDDBID = \'$cddbid\'";
|
|
- my $sth = $dbh->prepare($sql);
|
|
- my $r = $sth->execute or die "cannot delete from $db->{table_cds}: $DBI::errstr";
|
|
- $sql = "DELETE FROM $db->{table_tracks} WHERE CDDBID = \'$cddbid\'";
|
|
- $sth = $dbh->prepare($sql);
|
|
- $r = $sth->execute or die "cannot delete from $db->{table_tracks}: $DBI::errstr";
|
|
- } else {
|
|
- exit;
|
|
- }
|
|
- }
|
|
-
|
|
- $title =~ s/'/\\'/g;
|
|
- $artist =~ s/'/\\'/g;
|
|
- $category =~ s/'/\\'/g;
|
|
-
|
|
- $sql = "INSERT INTO $db->{table_cds} (cddbid, artist, title, category, tracks) VALUES (\'$cddbid\', \'$artist\', \'$title\', \'$category\' , \'$trackno\')";
|
|
- $sth = $dbh->prepare($sql);
|
|
- $r = $sth->execute or die "failed to insert cd: $DBI::errstr";
|
|
-
|
|
- my $n=1;
|
|
-
|
|
- print "titel: $title\n";
|
|
- print "artist: $artist\n";
|
|
- print "category: $category\n\n";
|
|
-
|
|
- for my $t ( @{$cd->{track}} ) {
|
|
- $t =~ s/'/\\'/g;
|
|
- my $dur=($cd->{frames}[$n]-1-$cd->{frames}[$n-1])/75;
|
|
- my $hour=int($dur/3600);
|
|
- my $min=int($dur/60-$hour*60);
|
|
- my $sec=$dur-$hour*3600-$min*60;
|
|
- my $fr=substr(sprintf("%5.2f",$sec-int($sec)),2,3);
|
|
- my $time=sprintf "%.2d:%.2d:%.2d%s",$hour,$min,int($sec),$fr;
|
|
-
|
|
- print "track $n: $t [$time]\n";
|
|
-
|
|
- my $sql = "INSERT INTO $db->{table_tracks} (cddbid, title, trackno, time)
|
|
- VALUES (\'$cddbid\',\'$t\', \'$n\', \'$time\')";
|
|
- my $sth = $dbh->prepare($sql);
|
|
- my $r = $sth->execute or die "failed to insert track $n: $DBI::errstr";
|
|
- $n++;
|
|
- }
|
|
-
|
|
- $dbh->disconnect();
|
|
-}
|
|
|
|
sub print_lame {
|
|
my $cd=shift;
|