X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=bin%2Fid3fs-tag;h=0b1f20e5fa9d3cf2a1f3a2d4468b046c6d17cba5;hb=f768e5fc4f33962bfac1142c546776cc0e239ec0;hp=42650c3ea86658eb082b63086d9444ca23d9c641;hpb=c90fade565eeffaff51cc240c30e05f6e1f6e196;p=id3fs.git diff --git a/bin/id3fs-tag b/bin/id3fs-tag index 42650c3..0b1f20e 100755 --- a/bin/id3fs-tag +++ b/bin/id3fs-tag @@ -19,18 +19,21 @@ use lib '/home/ianb/projects/id3fs/id3fs/lib'; # FIXME: remove use strict; use Getopt::Long qw(Configure); +use File::Find; use ID3FS::AudioFile; use vars qw($me); $me=($0=~/(?:.*\/)?(.*)/)[0]; +my @extensions=qw(mp3); # FIXME: flac ogg my $verbose=0; my $help=0; my ($artist, $album, $track, $tracknum, $year, $v1genre, $comment, $delete_artist, $delete_album, $delete_track, $delete_tracknum, $delete_year, $delete_v1genre, $delete_comment, $delete_all, - $delete_genre, $genre, $add_tags, $delete_tags, @replace_tags); + $delete_genre, $genre, $add_tags, $delete_tags, $overwrite_tagvals, + $delete_tagvals); -Configure(qw(no_ignore_case)); +Configure(qw(bundling no_ignore_case)); my $optret=GetOptions( "verbose|v" => \$verbose, "help|h" => \$help, @@ -52,58 +55,70 @@ my $optret=GetOptions( "delete-genre|delete-all-tags|G" => \$delete_genre, "genre|g|replace-all-tags|R=s" => \$genre, "add-tags|tags|t=s" => \$add_tags, + "overwrite-tagvals|tagvals|o=s" => \$overwrite_tagvals, "delete-tags|T=s" => \$delete_tags, - "replace-tags|r=s{2}" => \@replace_tags, + "delete-tags-with-values|O=s" => \$delete_tagvals, ); usage() if(!@ARGV || !$optret || $help); -while(my $filename=shift @ARGV) +while(my $path=shift @ARGV) { - unless(-f $filename) + unless(-e $path) { - warn("$me: $filename: not found\n"); + warn("$me: $path: not found\n"); next; } - my $file=ID3FS::AudioFile->new($filename); - my $changes=0; - $changes = do_deletes($file); - $changes += do_adds($file); - if($changes) - { - do_write($file); - } - else + File::Find::find( {wanted => \&wanted, follow => 1, no_chdir => 1}, $path); +} + +sub wanted +{ + my $ext=''; + if(/.*\.(.*)/) { $ext=lc($1); } + if(-f && scalar(grep({ $ext eq lc($_);} @extensions))) { - do_display($file); + my $file=ID3FS::AudioFile->new($_); + return unless($file); + my $changes=0; + $changes = do_deletes($file); + $changes += do_adds($file); + if($changes) + { + do_write($file); + } + else + { + do_display($file); + } } } sub do_deletes { my($file)=@_; - $file->delete_artist() if($delete_artist); - $file->delete_album() if($delete_album); - $file->delete_track() if($delete_track); - $file->delete_tracknum() if($delete_tracknum); - $file->delete_year() if($delete_year); - $file->delete_v1genre() if($delete_v1genre); - $file->delete_comment() if($delete_comment); - $file->delete_genre() if($delete_genre); - $file->delete_tags($delete_tags) if($delete_tags); - if(@replace_tags && $replace_tags[0]) + if($delete_all) { - $file->delete_tags($replace_tags[0]); + $file->delete_all(); + # we don't want to save the tag if we've deleted it + return 0; } - $file->delete_all() if($delete_all); - - # we don't want to save the tag if we've deleted it - return 0 if($delete_all); - - my $donesomething=($delete_artist || $delete_album || $delete_track || - $delete_tracknum || $delete_year || $delete_v1genre || - $delete_comment || $delete_genre || $delete_tags || - (@replace_tags && $replace_tags[0])); + $file->delete_artist() if($delete_artist); + $file->delete_album() if($delete_album); + $file->delete_track() if($delete_track); + $file->delete_tracknum() if($delete_tracknum); + $file->delete_year() if($delete_year); + $file->delete_v1genre() if($delete_v1genre); + $file->delete_comment() if($delete_comment); + $file->delete_genre() if($delete_genre || $genre); + $file->delete_tags($delete_tags, 0) if($delete_tags); + $file->delete_tags($delete_tagvals, 1) if($delete_tagvals); + $file->delete_tags($overwrite_tagvals, 1) if($overwrite_tagvals); + + my $donesomething=($delete_artist || $delete_album || $delete_track || + $delete_tracknum || $delete_year || $delete_v1genre || + $delete_comment || $delete_genre || $delete_tags || + $delete_tagvals || defined($genre) || $overwrite_tagvals); return($donesomething ? 1 : 0); } @@ -117,19 +132,15 @@ sub do_adds $file->year($year) if($year); $file->v1genre($v1genre) if($v1genre); $file->comment($comment) if($comment); - $file->genre($genre) if($genre); $file->add_tags($add_tags) if($add_tags); - if(@replace_tags && $replace_tags[0]) - { - $file->add_tags($replace_tags[1]); - } + $file->add_tags($genre) if($genre); + $file->add_tags($overwrite_tagvals) if($overwrite_tagvals); my $donesomething=(defined($artist) || defined($album) || defined($track) || defined($tracknum) || defined($year) || defined($v1genre) || defined($comment) || defined($genre) || - defined($add_tags) || - (@replace_tags && defined($replace_tags[1]))); + defined($add_tags) || defined($overwrite_tagvals)); return( $donesomething ? 1 : 0 ); } @@ -151,18 +162,16 @@ sub do_display my $v1genre=$file->v1genre(); my @tags=$file->tags(); @tags = map { (ref($_) eq "ARRAY") ? join('/', grep {defined;} @{$_}) : $_; } @tags; - use Data::Dumper; - print Dumper \@tags; if($verbose) { print $file->path(), ":\n"; - print "tracknum: $tracknum\n" if($tracknum); - print "artist: $artist\n" if($artist); - print "album: $album\n" if($album); - print "song: $track\n" if($track); - print "year: $year\n" if($year); - print "v1genre: $v1genre\n" if($v1genre); - print "comment: $comment\n" if($comment); + print " tracknum: $tracknum\n" if($tracknum); + print " artist: $artist\n" if($artist); + print " album: $album\n" if($album); + print " song: $track\n" if($track); + print " year: $year\n" if($year); + print " v1genre: $v1genre\n" if($v1genre); + print " comment: $comment\n" if($comment); } else { @@ -170,10 +179,13 @@ sub do_display $year, $v1genre, $comment); @fields=map { defined($_) ? $_ : ""; } @fields; print join(':', @fields), "\n"; - if(@tags) - { - print "tags:", join(", ", @tags), "\n"; - } + } + if(@tags) + { + if($verbose) { print " tags: "; } +# else { print $file->path() . ":tags:"; } + else { print "tags:"; } + print join(", ", @tags), "\n"; } }