diff options
author | Joe Peterson <lavajoe@gentoo.org> | 2009-06-23 17:37:10 +0000 |
---|---|---|
committer | Joe Peterson <lavajoe@gentoo.org> | 2009-06-23 17:37:10 +0000 |
commit | 002cecf13e8c1fe87fbee5910d5ff35bd4d63a86 (patch) | |
tree | 56f4ce207754ffe886e09d08f2916618f6125a10 /media-sound/squeezecenter | |
parent | EAPI=2 (diff) | |
download | gentoo-2-002cecf13e8c1fe87fbee5910d5ff35bd4d63a86.tar.gz gentoo-2-002cecf13e8c1fe87fbee5910d5ff35bd4d63a86.tar.bz2 gentoo-2-002cecf13e8c1fe87fbee5910d5ff35bd4d63a86.zip |
Add new version 7.3.3
(Portage version: 2.1.6.13/cvs/Linux x86_64)
Diffstat (limited to 'media-sound/squeezecenter')
9 files changed, 1211 insertions, 1 deletions
diff --git a/media-sound/squeezecenter/ChangeLog b/media-sound/squeezecenter/ChangeLog index 20239532d923..eea8c1cbf11e 100644 --- a/media-sound/squeezecenter/ChangeLog +++ b/media-sound/squeezecenter/ChangeLog @@ -1,6 +1,19 @@ # ChangeLog for media-sound/squeezecenter # Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/media-sound/squeezecenter/ChangeLog,v 1.40 2009/04/10 05:41:46 lavajoe Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-sound/squeezecenter/ChangeLog,v 1.41 2009/06/23 17:37:10 lavajoe Exp $ + +*squeezecenter-7.3.3 (23 Jun 2009) + + 23 Jun 2009; Joe Peterson <lavajoe@gentoo.org> + +squeezecenter-7.3.3.ebuild, + +files/squeezecenter-7.3.3-aac-transcode-gentoo.patch, + +files/squeezecenter-7.3.3-build-perl-modules-gentoo.patch, + +files/squeezecenter-7.3.3-json-xs-gentoo.patch, + +files/squeezecenter-7.3.3-mDNSResponder-gentoo.patch, + +files/squeezecenter-7.3.3-squeezeslave.patch, + +files/squeezecenter-7.3.3-squeezeslave-2.patch, + +files/squeezecenter-7.3.3-squeezeslave-3.patch: + Add new version 7.3.3 10 Apr 2009; Joe Peterson <lavajoe@gentoo.org> +files/squeezecenter-7.2.1-build-perl-modules-gentoo.patch, diff --git a/media-sound/squeezecenter/files/squeezecenter-7.3.3-aac-transcode-gentoo.patch b/media-sound/squeezecenter/files/squeezecenter-7.3.3-aac-transcode-gentoo.patch new file mode 100644 index 000000000000..de0f6bd2e1e8 --- /dev/null +++ b/media-sound/squeezecenter/files/squeezecenter-7.3.3-aac-transcode-gentoo.patch @@ -0,0 +1,37 @@ +--- convert.conf.old 2009-06-17 10:48:13.000000000 +0100 ++++ convert.conf 2009-06-17 10:48:13.000000000 +0100 +@@ -82,8 +82,8 @@ + [faad] -q -w -f 1 $FILE$ | [lame] --silent -q $QUALITY$ $BITRATE - - + + mov mp3 * * +- # FRB:{BITRATE=-B %B}D:{RESAMPLE=--resample %D} +- [mov123] $FILE$ | [lame] -s 44100 --silent -q $QUALITY$ $RESAMPLE$ -v $BITRATE$ -r --big-endian - - ++ # FB:{BITRATE=-B %B}D:{RESAMPLE=--resample %D} ++ [faad] -q -w -f 2 $FILE$ | [lame] -s 44100 --silent -q $QUALITY$ $RESAMPLE$ -v $BITRATE$ -r --big-endian - - + + alc mp3 * * + # FB:{BITRATE=-B %B}D:{RESAMPLE=--resample %D} +@@ -173,9 +173,9 @@ + # IF + [faad] -q -w -f 2 -b 1 -s 44100 $FILE$ + +-mov aif * * +- # FR +- [mov123] $FILE$ ++mov wav * * ++ # F ++ [faad] -q -w -f 2 $FILE$ + + wma wma * * + - +@@ -221,8 +221,8 @@ + [faad] -q -w -f 1 $FILE$ | [flac] -cs --totally-silent --compression-level-0 --ignore-chunk-sizes - + + mov flc * * +- # FR +- [mov123] $FILE$ | [flac] -cs --totally-silent --compression-level-0 --endian big --sign signed --channels 2 --bps 16 --sample-rate 44100 - ++ # F ++ [faad] -q -w -f 2 $FILE$ | [flac] -cs --totally-silent --compression-level-0 --endian little --sign signed --channels 2 --bps 16 --sample-rate 44100 - + + alc flc * * + # F diff --git a/media-sound/squeezecenter/files/squeezecenter-7.3.3-build-perl-modules-gentoo.patch b/media-sound/squeezecenter/files/squeezecenter-7.3.3-build-perl-modules-gentoo.patch new file mode 100644 index 000000000000..b40f1fcb6e90 --- /dev/null +++ b/media-sound/squeezecenter/files/squeezecenter-7.3.3-build-perl-modules-gentoo.patch @@ -0,0 +1,81 @@ +--- Bin/build-perl-modules.pl.old 2009-06-17 10:48:13.513324795 +0100 ++++ Bin/build-perl-modules.pl 2009-05-26 12:37:27.147159782 +0100 +@@ -21,25 +21,12 @@ + + # NOTE: If you change this in a future version of SC, create a new + # versioned directory under vendor/src for all files for that version +-my $SOURCE = 'http://svn.slimdevices.com/repos/slim/vendor/src/7.3'; + my $dlext = $Config{'dlext'}; + + # The list of all the packages needed. + my %packages = ( + 'Class::XSAccessor::Array' => 'Class-XSAccessor-Array-0.05.tar.gz', +- 'Compress::Zlib' => 'Compress-Zlib-1.41.tar.gz', +- 'DBI' => 'DBI-1.604.tar.gz', +- 'DBD::mysql' => 'DBD-mysql-3.0002.tar.gz', +- 'Digest::SHA1' => 'Digest-SHA1-2.11.tar.gz', +- 'Encode::Detect' => 'Encode-Detect-1.00.tar.gz', +- 'JSON::XS' => 'JSON-XS-1.5.tar.gz', +- 'HTML::Parser' => 'HTML-Parser-3.48.tar.gz', + 'POE::XS::Queue::Array' => 'POE-XS-Queue-Array-0.002.tar.gz', +- 'Template' => 'Template-Toolkit-2.15.tar.gz', +- 'Time::HiRes' => 'Time-HiRes-1.86.tar.gz', +- 'XML::Parser::Expat' => 'XML-Parser-2.34.tar.gz', +- 'YAML::Syck' => 'YAML-Syck-0.64.tar.gz', +- 'GD' => 'GD-2.35.tar.gz', + ); + + # Don't need Class::C3::XS if you're running 5.10 +@@ -197,36 +184,16 @@ + } + } + ++ # Utilise AutoXS::Header as we need that to support the following builds. ++ chdir($pwd) or die "Couldn't change to $pwd : $!"; ++ # Include this when performing the following builds. ++ $ENV{'PERL5LIB'} = cwd() . "/AutoXS-Header-0.03/lib"; ++ + for my $package (@packages) { + + chdir($pwd) or die "Couldn't change to $pwd : $!"; + +- print "\nDownloading $package to: $pwd\n"; +- +- # Remove any previous version. +- unlink $package; +- +- if ($downloadUsing eq 'lwp') { +- +- LWP::Simple::getstore("$SOURCE/$package?view=auto", $package); +- +- } elsif ($downloadUsing =~ /curl$/) { +- +- `$downloadUsing --silent -o $package $SOURCE/$package?view=auto`; +- +- } else { +- +- `$downloadUsing -q -O $package $SOURCE/$package?view=auto`; +- } +- +- unless (-r $package) { +- print "Something looks wrong - I couldn't read $pwd/$package, which I just downloaded.\n"; +- } +- +- print "Uncompressing..\n"; +- `gzip -d < $package | tar xvf -`; +- +- unlink $package; ++ print "\nBuilding $package\n"; + + # Just the directory name. + my ($packageDir) = ($package =~ /(\S+?)\.tar\.gz/); +--- Slim/bootstrap.pm.old 2009-06-17 10:48:13.000000000 +0100 ++++ Slim/bootstrap.pm 2009-06-17 10:48:13.581149121 +0100 +@@ -176,7 +176,6 @@ + + print "The following modules failed to load: $failed\n\n"; + +- print "To download and compile them, please run: $libPath/Bin/build-perl-modules.pl $failed\n\n"; + print "Exiting..\n"; + + exit; diff --git a/media-sound/squeezecenter/files/squeezecenter-7.3.3-json-xs-gentoo.patch b/media-sound/squeezecenter/files/squeezecenter-7.3.3-json-xs-gentoo.patch new file mode 100644 index 000000000000..507f1580e421 --- /dev/null +++ b/media-sound/squeezecenter/files/squeezecenter-7.3.3-json-xs-gentoo.patch @@ -0,0 +1,33 @@ +--- Slim/Formats/XML.pm.old 2009-03-23 20:59:53.000000000 +0000 ++++ Slim/Formats/XML.pm 2009-06-17 10:48:13.000000000 +0100 +@@ -13,7 +13,7 @@ + use strict; + use File::Slurp; + use HTML::Entities; +-use JSON::XS qw(from_json); ++use JSON::XS::VersionOneAndTwo; + use Scalar::Util qw(weaken); + use URI::Escape qw(uri_escape); + use XML::Simple; +--- Slim/Plugin/LastFM/ProtocolHandler.pm.old 2009-03-23 21:44:12.045581972 +0000 ++++ Slim/Plugin/LastFM/ProtocolHandler.pm 2009-06-17 10:48:13.000000000 +0100 +@@ -7,7 +7,7 @@ + use strict; + use base qw(Slim::Player::Protocols::HTTP); + +-use JSON::XS qw(from_json); ++use JSON::XS::VersionOneAndTwo; + use URI::Escape qw(uri_escape_utf8); + + use Slim::Player::Playlist; +--- Slim/Plugin/Sirius/ProtocolHandler.pm.old 2009-03-23 21:44:12.000000000 +0000 ++++ Slim/Plugin/Sirius/ProtocolHandler.pm 2009-06-17 10:48:13.547934811 +0100 +@@ -19,7 +19,7 @@ + use Slim::Utils::Timers; + + use HTTP::Request; +-use JSON::XS qw(from_json); ++use JSON::XS::VersionOneAndTwo; + use URI::Escape qw(uri_escape); + + my $log = Slim::Utils::Log->addLogCategory( { diff --git a/media-sound/squeezecenter/files/squeezecenter-7.3.3-mDNSResponder-gentoo.patch b/media-sound/squeezecenter/files/squeezecenter-7.3.3-mDNSResponder-gentoo.patch new file mode 100644 index 000000000000..6cb5739c37f5 --- /dev/null +++ b/media-sound/squeezecenter/files/squeezecenter-7.3.3-mDNSResponder-gentoo.patch @@ -0,0 +1,15 @@ +--- Slim/Networking/mDNS.pm.old 2009-03-10 21:09:33.000000000 +0000 ++++ Slim/Networking/mDNS.pm 2009-03-10 21:09:33.000000000 +0000 +@@ -131,11 +131,10 @@ + + my ($name, $port) = @$data; + ++ print CONF "\n"; + print CONF "$name\n"; + print CONF "$service\n"; +- print CONF "TXT\n"; + print CONF "$port\n"; +- print CONF "\n"; + } + + close(CONF); diff --git a/media-sound/squeezecenter/files/squeezecenter-7.3.3-squeezeslave-2.patch b/media-sound/squeezecenter/files/squeezecenter-7.3.3-squeezeslave-2.patch new file mode 100644 index 000000000000..934aa5c836bf --- /dev/null +++ b/media-sound/squeezecenter/files/squeezecenter-7.3.3-squeezeslave-2.patch @@ -0,0 +1,31 @@ +Index: Slim/Player/SqueezeSlave.pm +=================================================================== +--- Slim/Player/SqueezeSlave.pm (revision 26719) ++++ Slim/Player/SqueezeSlave.pm (revision 26720) +@@ -102,6 +102,7 @@ + ); + + sub dBToFixed { ++ my $client = shift; + my $db = shift; + + # Map a floating point dB value to a 16.16 fixed point value to +@@ -147,7 +148,7 @@ + # With new style volume, let's try -49.5dB as the lowest + # value. + my $db = ($volume - 100)/2; +- $newGain = dBToFixed($db); ++ $newGain = $client->dBToFixed($db); + } + + my $data = pack('NNCCNN', $oldGain, $oldGain, $prefs->client($client)->get('digitalVolumeControl'), $preamp, $newGain, $newGain); +@@ -203,6 +204,9 @@ + sub hasDigitalOut { + return 0; + } ++sub hasPowerControl { ++ return 0; ++} + + sub pcm_sample_rates { + my $client = shift; diff --git a/media-sound/squeezecenter/files/squeezecenter-7.3.3-squeezeslave-3.patch b/media-sound/squeezecenter/files/squeezecenter-7.3.3-squeezeslave-3.patch new file mode 100644 index 000000000000..3634fd3a3079 --- /dev/null +++ b/media-sound/squeezecenter/files/squeezecenter-7.3.3-squeezeslave-3.patch @@ -0,0 +1,13 @@ +Index: Slim/Player/SqueezeSlave.pm +=================================================================== +--- Slim/Player/SqueezeSlave.pm (revision 25815) ++++ Slim/Player/SqueezeSlave.pm (revision 25816) +@@ -133,7 +133,7 @@ + my $newvolume = shift; + + my $volume = $client->Slim::Player::Client::volume($newvolume, @_); +- my $preamp = 255 - int(2 * $prefs->client($client)->get('preampVolumeControl')); ++ my $preamp = 255 - int(2 * ($prefs->client($client)->get('preampVolumeControl') || 0)); + + if (defined($newvolume)) { + # Old style volume: diff --git a/media-sound/squeezecenter/files/squeezecenter-7.3.3-squeezeslave.patch b/media-sound/squeezecenter/files/squeezecenter-7.3.3-squeezeslave.patch new file mode 100644 index 000000000000..3ade990a358e --- /dev/null +++ b/media-sound/squeezecenter/files/squeezecenter-7.3.3-squeezeslave.patch @@ -0,0 +1,514 @@ +Index: Slim/Networking/Slimproto.pm +=================================================================== +--- Slim/Networking/Slimproto.pm (revision 25808) ++++ Slim/Networking/Slimproto.pm (revision 25809) +@@ -1081,7 +1081,7 @@ + } elsif ($deviceids[$deviceid] eq 'squeezeslave') { + + $client_class = 'Slim::Player::SqueezeSlave'; +- $display_class = 'Slim::Display::NoDisplay'; ++ $display_class = 'Slim::Display::Text'; + + } elsif ($deviceids[$deviceid] eq 'squeezeplay' || $deviceids[$deviceid] eq 'controller') { + +Index: Slim/Player/SqueezeSlave.pm +=================================================================== +--- Slim/Player/SqueezeSlave.pm (revision 25808) ++++ Slim/Player/SqueezeSlave.pm (revision 25809) +@@ -36,22 +36,9 @@ + our $defaultPrefs = { + 'replayGainMode' => 0, + 'minSyncAdjust' => 30, # ms ++ 'maxBitrate' => 0, # no bitrate limiting + }; + +-# Keep track of direct stream redirects +-our $redirects = {}; +- +- +-sub new { +- my $class = shift; +- +- my $client = $class->SUPER::new(@_); +- +- bless $client, $class; +- +- return $client; +-} +- + sub initPrefs { + my $client = shift; + +@@ -74,7 +61,7 @@ + + sub modelName { 'Squeezeslave' } + +-sub hasIR { return 0; } ++sub hasIR { 1 } + + # in order of preference based on whether we're connected via wired or wireless... + sub formats { +@@ -130,6 +117,17 @@ + } + } + ++sub canDoReplayGain { ++ my $client = shift; ++ my $replay_gain = shift; ++ ++ if (defined($replay_gain)) { ++ return $client->dBToFixed($replay_gain); ++ } ++ ++ return 0; ++} ++ + sub volume { + my $client = shift; + my $newvolume = shift; +@@ -304,4 +302,28 @@ + } + + ++# We need to implement this to allow us to receive SETD commands ++# and we need SETD to support custom display widths ++sub directBodyFrame { ++ return 1; ++} ++ ++# Allow the player to define it's display width ++sub playerSettingsFrame { ++ my $client = shift; ++ my $data_ref = shift; ++ ++ my $value; ++ my $id = unpack('C', $$data_ref); ++ ++ # New SETD command 0xfe for display width ++ if ($id == 0xfe) { ++ $value = (unpack('CC', $$data_ref))[1]; ++ if ($value > 10 && $value < 200) { ++ $client->display->widthOverride(1, $value); ++ $client->update; ++ } ++ } ++} ++ + 1; +Index: Slim/Display/Text.pm +=================================================================== +--- Slim/Display/Text.pm (revision 25808) ++++ Slim/Display/Text.pm (revision 25809) +@@ -14,8 +14,8 @@ + =head1 DESCRIPTION + + L<Slim::Display::Text> +- Display code for text (character) based displays: Slimp3, SB1 +- - 40 character x 2 lines ++ Display code for text (character) based displays: Slimp3, SB1, squeezeslave ++ - 40 (or client controlled) character x 2 lines + - server side animation + + =cut +@@ -33,6 +33,8 @@ + my $scroll_pad_scroll = 6; # chars of padding between scrolling text + my $scroll_pad_ticker = 8; # chars of padding in ticker mode + ++my $defaultWidth = 40; # default character width of display (unless client tells us otherwise) ++ + our $defaultPrefs = { + 'doublesize' => 0, + 'offDisplaySize' => 0, +@@ -44,34 +46,7 @@ + 'playingDisplayModes' => [0..5] + }; + +-# Display Modes + +-my @modes = ( +- # mode 0 +- { desc => ['BLANK'], +- bar => 0, secs => 0, width => 40, }, +- # mode 1 +- { desc => ['ELAPSED'], +- bar => 0, secs => 1, width => 40, }, +- # mode 2 +- { desc => ['REMAINING'], +- bar => 0, secs => -1, width => 40, }, +- # mode 3 +- { desc => ['PROGRESS_BAR'], +- bar => 1, secs => 0, width => 40, }, +- # mode 4 +- { desc => ['ELAPSED', 'AND', 'PROGRESS_BAR'], +- bar => 1, secs => 1, width => 40, }, +- # mode 5 +- { desc => ['REMAINING', 'AND', 'PROGRESS_BAR'], +- bar => 1, secs => -1, width => 40, }, +- # mode 6 +- { desc => ['SETUP_SHOWBUFFERFULLNESS'], +- bar => 1, secs => 0, width => 40, fullness => 1, }, +-); +- +-my $nmodes = $#modes; +- + sub initPrefs { + my $display = shift; + +@@ -101,7 +76,8 @@ + } + + sub displayWidth { +- return 40; ++ my $display = shift; ++ return $display->widthOverride || $defaultWidth; + } + + sub vfdmodel { +@@ -109,7 +85,6 @@ + my $client = $display->client; + + if ($client->isa('Slim::Player::SLIMP3')) { +- + if ($client->revision >= 2.2) { + my $mac = $client->macaddress(); + if ($mac eq '00:04:20:03:04:e0') { +@@ -124,7 +99,8 @@ + } else { + return 'noritake-katakana'; + } +- ++ } elsif ($client->isa('Slim::Player::SqueezeSlave')) { ++ return 'squeezeslave'; + } else { + # Squeezebox 1 + return 'noritake-european'; +@@ -198,11 +174,11 @@ + $sc->{newscroll} = 0; + $sc->{present} = 1; + +- # force initialisation of cache if size = 0 (used to init cache) +- if ($sc->{ssize} != 40) { +- $sc->{ssize} = 40; ++ # force (re)initialisation of cache if size changed ++ if ($sc->{ssize} != $display->displayWidth) { + $sc->{double} = 0; + $sc->{changed} = 1; ++ $sc->{ssize} = $display->displayWidth; + } + + # check display hash for text size definitions +@@ -232,12 +208,13 @@ + if ($sc->{changed}) { + foreach my $l (0..1) { + $sc->{line}[$l] = undef; $sc->{linetext}[$l] = ''; $sc->{linefinish}[$l] = 0; +- $sc->{overlay}[$l] = undef; $sc->{overlaytext}[$l] = ''; $sc->{overlaystart}[$l] = 40; ++ $sc->{overlay}[$l] = undef; $sc->{overlaytext}[$l] = ''; $sc->{overlaystart}[$l] = $display->displayWidth; + $sc->{center}[$l] = undef; $sc->{centertext}[$l] = ''; + } + $sc->{scroll} = 0; + $sc->{scrollline} = undef; + } ++ + if (!$scroll) { + $sc->{scroll} = 0; + $sc->{scrollline} = undef; +@@ -298,17 +275,17 @@ + } else { + $sc->{overlaytext}[$l] = ''; + } +- if (lineLength($sc->{overlaytext}[$l]) > 40 ) { +- $sc->{overlaytext}[$l] = subString($sc->{overlaytext}[$l], 0, 40); +- $sc->{overlaystart}[$l] = 40; ++ if (lineLength($sc->{overlaytext}[$l]) > $display->displayWidth ) { ++ $sc->{overlaytext}[$l] = subString($sc->{overlaytext}[$l], 0, $display->displayWidth); ++ $sc->{overlaystart}[$l] = $display->displayWidth; + } else { +- $sc->{overlaystart}[$l] = 40 - lineLength($sc->{overlaytext}[$l]); ++ $sc->{overlaystart}[$l] = $display->displayWidth - lineLength($sc->{overlaytext}[$l]); + } + $sc->{changed} = 1; + } elsif (!defined($screen->{overlay}[$l]) && defined($sc->{overlay}[$l])) { + $sc->{overlay}[$l] = undef; + $sc->{overlaytext}[$l] = ''; +- $sc->{overlaystart}[$l] = 40; ++ $sc->{overlaystart}[$l] = $display->displayWidth; + $sc->{changed} = 1; + } + } +@@ -320,22 +297,22 @@ + $sc->{center}[$l] = $screen->{center}[$l]; + next if ($double && $l == 0); + if (!$double) { +- my $len = lineLength($sc->{center}[$l]); +- if ($len < 39) { +- $sc->{centertext}[$l] = ' ' x ((40 - $len)/2) . $screen->{center}[$l] . +- ' ' x (40 - $len - int((40 - $len)/2)); ++ my $len = lineLength($screen->{center}[$l]); ++ if ($len < $display->displayWidth - 1) { ++ $sc->{centertext}[$l] = ' ' x (($display->displayWidth - $len)/2) . $screen->{center}[$l] . ++ ' ' x ($display->displayWidth - $len - int(($display->displayWidth - $len)/2)); + } else { +- $sc->{centertext}[$l] = subString($sc->{center}[$l] . ' ', 0 ,40); ++ $sc->{centertext}[$l] = subString($screen->{center}[$l] . ' ', 0, $display->displayWidth); + } + } else { + my ($center1, $center2) = Slim::Display::Lib::TextVFD::doubleSize($client,$screen->{center}[1]); + my $len = lineLength($center1); +- if ($len < 39) { +- $sc->{centertext}[0] = ' ' x ((40 - $len)/2) . $center1 . ' ' x (40 - $len - int((40 - $len)/2)); +- $sc->{centertext}[1] = ' ' x ((40 - $len)/2) . $center2 . ' ' x (40 - $len - int((40 - $len)/2)); ++ if ($len < $display->displayWidth - 1) { ++ $sc->{centertext}[0] = ' ' x (($display->displayWidth - $len)/2) . $center1 . ' ' x ($display->displayWidth - $len - int(($display->displayWidth - $len)/2)); ++ $sc->{centertext}[1] = ' ' x (($display->displayWidth - $len)/2) . $center2 . ' ' x ($display->displayWidth - $len - int(($display->displayWidth - $len)/2)); + } else { +- $sc->{centertext}[0] = subString($center1 . ' ', 0 ,40); +- $sc->{centertext}[1] = subString($center2 . ' ', 0 ,40); ++ $sc->{centertext}[0] = subString($center1 . ' ', 0 ,$display->displayWidth); ++ $sc->{centertext}[1] = subString($center2 . ' ', 0 ,$display->displayWidth); + } + } + $sc->{changed} = 1; +@@ -426,11 +403,11 @@ + $sc->{scrollstart} = 0; + if ($scroll == 1) { + # normal wrapped text scrolling +- $scrolltext .= ' ' x $scroll_pad_scroll . subString($scrolltext, 0, 40); ++ $scrolltext .= ' ' x $scroll_pad_scroll . subString($scrolltext, 0, $display->displayWidth); + $sc->{scrollend} = $sc->{linefinish}[$l] + $scroll_pad_scroll; + } else { + # don't wrap text - scroll to end only +- $sc->{scrollend} = $sc->{linefinish}[$l] - 40; ++ $sc->{scrollend} = $sc->{linefinish}[$l] - $display->displayWidth; + } + + if (!$double || $l == 0) { +@@ -472,7 +449,7 @@ + my $line2 = $$line2start . $$line2end; + + $display->killAnimation(); +- $display->pushUpdate([\$line1, \$line2, 0, 5, 40, 0.02]); ++ $display->pushUpdate([\$line1, \$line2, 0, 4, $display->displayWidth, 0.02]); + } + + sub pushRight { +@@ -489,7 +466,7 @@ + my $line2 = $$line2end . $$line2start; + + $display->killAnimation(); +- $display->pushUpdate([\$line1, \$line2, 40, -5, 0, 0.02]); ++ $display->pushUpdate([\$line1, \$line2, $display->displayWidth, -4, 0, 0.02]); + } + + sub pushUp { +@@ -536,9 +513,12 @@ + my ($line1, $line2, $offset, $delta, $end, $deltatime) = @$params; + + $offset += $delta; ++ # With custom widths, offset may not be a factor of the width, so fix up to avoid problems! ++ $offset=$end if ($delta > 0 && $offset > $end); ++ $offset=$end if ($delta < 0 && $offset < $end); + +- my $screenline1 = subString($$line1, $offset, 40); +- my $screenline2 = subString($$line2, $offset, 40); ++ my $screenline1 = subString($$line1, $offset, $display->displayWidth); ++ my $screenline2 = subString($$line2, $offset, $display->displayWidth); + + Slim::Display::Lib::TextVFD::vfdUpdate($display->client, $screenline1, $screenline2); + +@@ -556,7 +536,7 @@ + + my $render = $display->render($display->renderCache()); + my $line1 = ${$render->{screen1}->{lineref}[1]}; +- my $line2 = ' ' x 40; ++ my $line2 = ' ' x $display->displayWidth; + + Slim::Display::Lib::TextVFD::vfdUpdate($display->client, $line1, $line2); + +@@ -569,7 +549,7 @@ + my $display = shift; + + my $render = $display->render($display->renderCache()); +- my $line1 = ' ' x 40; ++ my $line1 = ' ' x $display->displayWidth; + my $line2 = ${$render->{screen1}->{lineref}[0]}; + + Slim::Display::Lib::TextVFD::vfdUpdate($display->client, $line1, $line2); +@@ -598,12 +578,37 @@ + } + + sub modes { ++ my $display = shift; ++ # Display Modes ++ ++ my @modes = ( ++ # mode 0 ++ { desc => ['BLANK'], ++ bar => 0, secs => 0, width => $display->displayWidth, }, ++ # mode 1 ++ { desc => ['ELAPSED'], ++ bar => 0, secs => 1, width => $display->displayWidth, }, ++ # mode 2 ++ { desc => ['REMAINING'], ++ bar => 0, secs => -1, width => $display->displayWidth, }, ++ # mode 3 ++ { desc => ['PROGRESS_BAR'], ++ bar => 1, secs => 0, width => $display->displayWidth, }, ++ # mode 4 ++ { desc => ['ELAPSED', 'AND', 'PROGRESS_BAR'], ++ bar => 1, secs => 1, width => $display->displayWidth, }, ++ # mode 5 ++ { desc => ['REMAINING', 'AND', 'PROGRESS_BAR'], ++ bar => 1, secs => -1, width => $display->displayWidth, }, ++ # mode 6 ++ { desc => ['SETUP_SHOWBUFFERFULLNESS'], ++ bar => 1, secs => 0, width => $display->displayWidth, fullness => 1, }, ++ ); ++ + return \@modes; + } + +-sub nmodes { +- return $nmodes; +-} ++sub nmodes { 6 } + + sub scrollUpdateDisplay { + # update scrolling for character display +@@ -637,11 +642,11 @@ + } else { + # both lines scrolling + if ($padlen) { +- $line1 = subString(${$scroll->{scrollline1ref}} . $pad, $scroll->{offset}, 40); +- $line2 = subString(${$scroll->{scrollline2ref}} . $pad, $scroll->{offset}, 40); ++ $line1 = subString(${$scroll->{scrollline1ref}} . $pad, $scroll->{offset}, $display->displayWidth); ++ $line2 = subString(${$scroll->{scrollline2ref}} . $pad, $scroll->{offset}, $display->displayWidth); + } else { +- $line1 = subString(${$scroll->{scrollline1ref}}, $scroll->{offset}, 40); +- $line2 = subString(${$scroll->{scrollline2ref}}, $scroll->{offset}, 40); ++ $line1 = subString(${$scroll->{scrollline1ref}}, $scroll->{offset}, $display->displayWidth); ++ $line2 = subString(${$scroll->{scrollline2ref}}, $scroll->{offset}, $display->displayWidth); + } + } + +Index: Slim/Display/Lib/TextVFD.pm +=================================================================== +--- Slim/Display/Lib/TextVFD.pm (revision 25808) ++++ Slim/Display/Lib/TextVFD.pm (revision 25809) +@@ -66,7 +66,6 @@ + + my $vfdReset = $vfdCodeCmd . $vfdCommand{"INCSC"} . $vfdCodeCmd . $vfdCommand{"HOME"}; + +-my $spaces = ' ' x 40; + + my %symbolmap = ( + 'katakana' => { +@@ -86,6 +85,13 @@ + 'rightarrow' => chr(0x7e), + 'hardspace' => chr(0x20), + 'solidblock' => chr(0x1f), ++ }, ++ 'squeezeslave' => { # These are from an Imon VFD, but squeezeslave can remap for other types ++ 'rightarrow' => chr(0x10), ++ 'hardspace' => chr(0x20), ++ 'solidblock' => chr(0x0B), ++ 'notesymbol' => chr(0x91), ++ 'bell' => chr(0x98), + } + ); + +@@ -121,6 +127,21 @@ + 'Zbottom' => '/', + 'leftvbar' => '|', + 'rightvbar' => '|', ++ 'rightprogress0' => ']', ++ 'rightprogress1' => ']', ++ 'rightprogress2' => ']', ++ 'rightprogress3' => ']', ++ 'rightprogress4' => ']', ++ 'leftprogress0' => '[', ++ 'leftprogress1' => '[', ++ 'leftprogress2' => '[', ++ 'leftprogress3' => '[', ++ 'leftprogress4' => '[', ++ 'middleprogress0' => ' ', ++ 'middleprogress1' => '.', ++ 'middleprogress2' => ':', ++ 'middleprogress3' => '!', ++ 'middleprogress4' => '|', + ); + + sub vfdUpdate { +@@ -133,6 +154,9 @@ + my $cur = -1; + my $pos; + ++ my $displaywidth = $client->display->displayWidth; ++ my $spaces = ' ' x $displaywidth; ++ + # convert to the VFD char set + my $lang = $client->vfdmodel; + if (!$lang) { +@@ -225,8 +249,10 @@ + + my $encodedCustom = "\x1F" . $custom . "\x1F"; + +- if ($usedCustom < 8) { # Room to add this one ++ my $maxCustom = $lang eq "squeezeslave" ? 0 : 8; # squeezeslave doesn't allow any custom character definitions + ++ if ($usedCustom < $maxCustom) { # Room to add this one ++ + while(defined $customUsed{$nextChr}) { + + $nextChr = chr(ord($nextChr)+1); +@@ -266,7 +292,6 @@ + delete $newCustom{$custom}; + } + } +- + if ($lang eq 'european') { + # why can't we all just get along? + $line =~ tr{\x1f\x92\xa1\xa2\xa3\xa4\xa5\xa6\xa8\xa9\xab\xad\xaf \xbb\xbf \xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf \xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf \xe0\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef \xf0\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe\xff} +@@ -275,8 +300,9 @@ + # translate iso8859-1 to vfd charset + $line =~ tr{\x1f\x92\x0e\x0f\x5c\x70\x7e\x7f\xa0\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xad\xae\xaf\xb0\xb1\xb2\xb3\xb4\xb5\xb6\xb7\xb8\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe\xff} + {\xff\x27\x19\x7e\x8c\xf0\x8e\x8f\x20\x98\xec\x92\xeb\x5c\x98\x8f\xde\x63\x61\x3c\xa3\x2d\x72\xb0\xdf\xb7\x32\x33\x60\xe4\xf1\x94\x2c\x31\xdf\x3e\x25\x25\x25\x3f\x81\x81\x82\x82\x80\x81\x90\x99\x45\x45\x45\x45\x49\x49\x49\x49\x44\xee\x4f\x4f\x4f\x4f\x86\x78\x30\x55\x55\x55\x8a\x59\x70\xe2\x84\x83\x84\x84\xe1\x84\x91\x99\x65\x65\x65\x65\x69\x69\x69\x69\x95\xee\x6f\x6f\x6f\x6f\xef\xfd\x88\x75\x75\x75\xf5\x79\xf0\x79}; +- } elsif ($lang eq 'latin1') { ++ } elsif (($lang eq 'latin1') || ($lang eq 'squeezeslave')) { + # golly, the latin1 character map _is_ latin1. Also, translate funky windows apostrophes to legal ones. ++ # squeezeslave uses latin1 too + $line =~ tr{\x92} + {\x26}; + }; +@@ -287,9 +313,10 @@ + my $vfdmodel = $client->vfdmodel(); + + # force the display out of 4 bit mode if it got there somehow, then set the brightness ++ # not used for Squeezeslave + if ( $vfdmodel =~ 'futaba') { + $vfddata .= $vfdCodeCmd . $vfdBrightFutaba[$brightness]; +- } else { ++ } elsif ( $vfdmodel ne 'squeezeslave') { + $vfddata .= $noritakeBrightPrelude . $vfdBright[$brightness]; + } + +@@ -310,17 +337,17 @@ + $line =~ s/(.)/$vfdCodeChar$1/gos; + + # split the line in two and move the cursor to the second line +- $line = substr($line, 0, 80) . $vfdCodeCmd . $vfdCommand{"HOME2"} . substr($line, 80); ++ $line = substr($line, 0, 2 * $displaywidth) . $vfdCodeCmd . $vfdCommand{"HOME2"} . substr($line, 2 * $displaywidth); + + $vfddata .= $line; + + # set the cursor + if ($cur >= 0) { + +- if ($cur < 40) { ++ if ($cur < $displaywidth) { + $vfddata .= $vfdCodeCmd.(pack 'C', (0b10000000 + $cur)); + } else { +- $vfddata .= $vfdCodeCmd.(pack 'C', (0b11000000 + $cur - 40)); ++ $vfddata .= $vfdCodeCmd.(pack 'C', (0b11000000 + $cur - $displaywidth)); + } + + # turn on the cursor diff --git a/media-sound/squeezecenter/squeezecenter-7.3.3.ebuild b/media-sound/squeezecenter/squeezecenter-7.3.3.ebuild new file mode 100644 index 000000000000..cd8d85547de1 --- /dev/null +++ b/media-sound/squeezecenter/squeezecenter-7.3.3.ebuild @@ -0,0 +1,473 @@ +# Copyright 1999-2009 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/media-sound/squeezecenter/squeezecenter-7.3.3.ebuild,v 1.1 2009/06/23 17:37:10 lavajoe Exp $ + +inherit eutils + +MAJOR_VER="${PV:0:3}" +MINOR_VER="${PV:4:1}" +SRC_DIR="SqueezeCenter_v${MAJOR_VER}.${MINOR_VER}" +MY_P="squeezecenter-${MAJOR_VER}.${MINOR_VER}-noCPAN" + +DESCRIPTION="Logitech SqueezeCenter music server" +HOMEPAGE="http://www.slimdevices.com/pi_features.html" +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~amd64 ~x86" +IUSE="lame wavpack musepack alac ogg bonjour flac avahi aac" + +#SRC_URI="http://www.slimdevices.com/downloads/${SRC_DIR}/${MY_P}.tgz +SRC_URI="http://downloads.slimdevices.com/${SRC_DIR}/${MY_P}.tgz + mirror://gentoo/SqueezeCenter-AutoXS-Header-0.03.tar.gz + mirror://gentoo/SqueezeCenter-Class-XSAccessor-Array-0.05.tar.gz + mirror://gentoo/SqueezeCenter-POE-XS-Queue-Array-0.002.tar.gz" + +# Note: virtual/perl-Module-Build necessary because of SC bug#5882 +# (http://bugs.slimdevices.com/show_bug.cgi?id=5882). +DEPEND=" + dev-perl/File-Which + virtual/perl-Module-Build + virtual/logger + virtual/mysql + avahi? ( net-dns/avahi ) + " +# Note: dev-perl/GD necessary because of SC bug#6143 +# (http://bugs.slimdevices.com/show_bug.cgi?id=6143). +RDEPEND=" + dev-perl/File-Which + virtual/logger + virtual/mysql + avahi? ( net-dns/avahi ) + >=dev-lang/perl-5.8.8 + >=dev-perl/GD-2.35 + >=virtual/perl-Compress-Zlib-2.015 + >=dev-perl/YAML-Syck-1.05 + >=dev-perl/DBD-mysql-4.00.5 + >=dev-perl/DBI-1.607 + >=dev-perl/Digest-SHA1-2.11 + >=dev-perl/Encode-Detect-1.01 + >=dev-perl/HTML-Parser-3.56 + >=dev-perl/JSON-XS-2.2.3.1 + >=dev-perl/Template-Toolkit-2.19 + >=virtual/perl-Time-HiRes-1.97.15 + >=dev-perl/XML-Parser-2.36 + >=dev-perl/Cache-Cache-1.04 + >=dev-perl/Class-Data-Inheritable-0.08 + >=dev-perl/Class-Inspector-1.23 + >=dev-perl/File-Next-1.02 + >=virtual/perl-File-Temp-0.20 + >=dev-perl/File-Which-0.05 + >=perl-core/i18n-langtags-0.35 + >=dev-perl/IO-String-1.08 + >=dev-perl/Log-Log4perl-1.13 + >=dev-perl/libwww-perl-5.805 + >=perl-core/CGI-3.29 + >=dev-perl/TimeDate-1.16 + >=dev-perl/Math-VecStat-0.08 + >=dev-perl/Net-DNS-0.63 + >=dev-perl/Net-IP-1.25 + >=dev-perl/Path-Class-0.16 + >=dev-perl/SQL-Abstract-1.22 + >=dev-perl/SQL-Abstract-Limit-0.12 + >=dev-perl/URI-1.35 + >=dev-perl/XML-Simple-2.18 + >=perl-core/version-0.76 + >=dev-perl/Carp-Clan-5.9 + >=dev-perl/Readonly-1.03 + >=dev-perl/Carp-Assert-0.20 + >=dev-perl/Class-Virtual-0.06 + >=dev-perl/File-Slurp-9999.13 + >=dev-perl/Exporter-Lite-0.02 + >=dev-perl/Tie-IxHash-1.21 + >=virtual/perl-Module-Pluggable-3.6 + >=dev-perl/Archive-Zip-1.23 + lame? ( media-sound/lame ) + alac? ( media-sound/alac_decoder ) + wavpack? ( media-sound/wavpack ) + bonjour? ( net-misc/mDNSResponder ) + flac? ( + media-libs/flac + media-sound/sox + ) + musepack? ( media-sound/musepack-tools ) + ogg? ( media-sound/sox ) + aac? ( media-libs/faad2 ) + " + +S="${WORKDIR}/${MY_P}" + +# Selected contents of SqueezeCenter's local CPAN collection that we include +# in the installation. This removes duplication of CPAN modules. (See Gentoo +# bug #251494). +CPANKEEP=" + Class/XSAccessor/Array.pm + POE/XS/Queue/Array.pm + + JSON/XS/VersionOneAndTwo.pm + Class/Accessor/ + Class/Accessor.pm + Class/C3.pm + Class/Data/Accessor.pm + Algorithm/C3.pm + Data/ + DBIx/ + File/BOM.pm + Net/UPnP/ + Net/UPnP.pm + POE/Queue/Array.pm + Proc/Background/ + Proc/Background.pm + Text/Unidecode/ + Text/Unidecode.pm + Tie/Cache/LRU/ + Tie/Cache/LRU.pm + Tie/LLHash.pm + Tie/RegexpHash.pm + URI/Find.pm + PAR/ + PAR.pm + enum.pm + " + +PREFS="/var/lib/squeezecenter/prefs/squeezecenter.prefs" +LIVE_PREFS="/var/lib/squeezecenter/prefs/server.prefs" +DOCDIR="/usr/share/doc/squeezecenter-${PV}" +SHAREDIR="/usr/share/squeezecenter" +LIBDIR="/usr/lib/squeezecenter" +DBUSER="squeezecenter" +OLDPLUGINSDIR=/opt/squeezecenter/Plugins +NEWPLUGINSDIR=/var/lib/squeezecenter/Plugins + +pkg_setup() { + # Sox has optional OGG and FLAC support, so make sure it has that included + # if required + if use ogg; then + if ! built_with_use media-sound/sox ogg; then + eerror "media-sound/sox not built with USE=ogg" + die "SqueezeCenter needs media-sound/sox to be built with USE=ogg" + fi + fi + if use flac; then + if ! built_with_use media-sound/sox flac; then + eerror "media-sound/sox not built with USE=flac" + die "SqueezeCenter needs media-sound/sox to be built with USE=flac" + fi + fi + + # Create the user and group if not already present + enewgroup squeezecenter + enewuser squeezecenter -1 -1 "/dev/null" squeezecenter +} + +src_unpack() { + unpack ${A} + cd "${S}" + + # Apply patches + epatch "${FILESDIR}/${PF}-mDNSResponder-gentoo.patch" + epatch "${FILESDIR}/${PF}-build-perl-modules-gentoo.patch" + epatch "${FILESDIR}/${PF}-aac-transcode-gentoo.patch" + epatch "${FILESDIR}/${PF}-json-xs-gentoo.patch" + epatch "${FILESDIR}/${PF}-squeezeslave.patch" + epatch "${FILESDIR}/${PF}-squeezeslave-2.patch" + epatch "${FILESDIR}/${PF}-squeezeslave-3.patch" +} + +src_compile() { + einfo "Building required Perl modules (some warnings are normal here) ..." + echo -e "\n${S}\n${WORKDIR}" | Bin/build-perl-modules.pl || die "Unable to build Perl modules" +} + +src_install() { + + # The main Perl executables + exeinto /usr/sbin + newexe slimserver.pl squeezecenter-server + newexe scanner.pl squeezecenter-scanner + newexe cleanup.pl squeezecenter-cleanup + + # Get the Perl package name and version + eval `perl '-V:package'` + eval `perl '-V:version'` + + # The custom OS module for Gentoo - provides OS-specific path details + cp "${FILESDIR}/gentoo-filepaths.pm" "Slim/Utils/OS/Custom.pm" || die "Unable to install Gentoo custom OS module" + + # The server Perl modules + dodir "/usr/lib/${package}/vendor_perl/${version}" + cp -r Slim "${D}/usr/lib/${package}/vendor_perl/${version}" || die "Unable to install server Perl modules" + + # Compiled CPAN module go under lib as they are arch-specific + dodir "/usr/lib/squeezecenter/CPAN" + cp -r CPAN/arch "${D}/usr/lib/squeezecenter/CPAN" || die "Unable to install compiled CPAN modules" + + # Preseve some of the SqueezeCenter-packaged CPAN modules that Gentoo + # doesn't provide ebuilds for. + for ITEM in ${CPANKEEP}; do + dodir "/usr/lib/squeezecenter/CPAN/$(dirname ${ITEM})" + cp -r "CPAN/${ITEM}" "${D}/usr/lib/squeezecenter/CPAN/${ITEM}" || die "Unable to preserve CPAN item ${ITEM}" + done + + # Various directories of architecture-independent static files + dodir "${SHAREDIR}" + cp -r Firmware "${D}/${SHAREDIR}" || die "Unable to install firmware" + cp -r Graphics "${D}/${SHAREDIR}" || die "Unable to install Graphics" + cp -r HTML "${D}/${SHAREDIR}" || die "Unable to install HTML" + cp -r IR "${D}/${SHAREDIR}" || die "Unable to install IR" + cp -r SQL "${D}/${SHAREDIR}" || die "Unable to install SQL" + + # Architecture-dependent static files + dodir "${LIBDIR}" + cp -r lib/* "${D}/${LIBDIR}" || die "Unable to install architecture-dependent files" + + # Strings and version identification + insinto "${SHAREDIR}" + doins strings.txt + doins revision.txt + + # Documentation + dodoc Changelog*.html + dodoc Installation.txt + dodoc License*.txt + newdoc "${FILESDIR}/Gentoo-plugins-README.txt" Gentoo-plugins-README.txt + + # Configuration files + insinto /etc/squeezecenter + doins convert.conf + doins types.conf + doins modules.conf + + # Install init scripts + newconfd "${FILESDIR}/squeezecenter.conf.d" squeezecenter + newinitd "${FILESDIR}/squeezecenter.init.d" squeezecenter + + # Install default preferences + insinto /var/lib/squeezecenter/prefs + newins "${FILESDIR}/squeezecenter.prefs" squeezecenter.prefs + fowners squeezecenter:squeezecenter /var/lib/squeezecenter/prefs + fperms 770 /var/lib/squeezecenter/prefs + + # Install the SQL configuration scripts + insinto "${SHAREDIR}/SQL/mysql" + doins "${FILESDIR}/dbdrop-gentoo.sql" + doins "${FILESDIR}/dbcreate-gentoo.sql" + + # Initialize run directory (where the PID file lives) + dodir /var/run/squeezecenter + fowners squeezecenter:squeezecenter /var/run/squeezecenter + fperms 770 /var/run/squeezecenter + + # Initialize server cache directory + dodir /var/lib/squeezecenter/cache + fowners squeezecenter:squeezecenter /var/lib/squeezecenter/cache + fperms 770 /var/lib/squeezecenter/cache + + # Initialize the log directory + dodir /var/log/squeezecenter + fowners squeezecenter:squeezecenter /var/log/squeezecenter + fperms 770 /var/log/squeezecenter + touch "${D}/var/log/squeezecenter/server.log" + touch "${D}/var/log/squeezecenter/scanner.log" + touch "${D}/var/log/squeezecenter/perfmon.log" + fowners squeezecenter:squeezecenter /var/log/squeezecenter/server.log + fowners squeezecenter:squeezecenter /var/log/squeezecenter/scanner.log + fowners squeezecenter:squeezecenter /var/log/squeezecenter/perfmon.log + + # Initialise the user-installed plugins directory + dodir "${NEWPLUGINSDIR}" + + # Install logrotate support + insinto /etc/logrotate.d + newins "${FILESDIR}/squeezecenter.logrotate.d" squeezecenter + + # Install Avahi support (if USE flag is set) + if use avahi; then + insinto /etc/avahi/services + newins "${FILESDIR}/avahi-squeezecenter.service" squeezecenter.service + fi +} + +sc_starting_instr() { + elog "SqueezeCenter can be started with the following command:" + elog "\t/etc/init.d/squeezecenter start" + elog "" + elog "SqueezeCenter can be automatically started on each boot with the" + elog "following command:" + elog "\trc-update add squeezecenter default" + elog "" + elog "You might want to examine and modify the following configuration" + elog "file before starting SqueezeCenter:" + elog "\t/etc/conf.d/squeezecenter" + elog "" + + # Discover the port number from the preferences, but if it isn't there + # then report the standard one. + httpport=$(gawk '$1 == "httpport:" { print $2 }' "${ROOT}${LIVE_PREFS}" 2>/dev/null) + elog "You may access and configure SqueezeCenter by browsing to:" + elog "\thttp://localhost:${httpport:-9000}/" +} + +pkg_postinst() { + # FLAC and LAME are quite useful (but not essential) for SqueezeCenter - + # if they're not enabled then make sure the user understands that. + if ! use flac; then + ewarn "'flac' USE flag is not set. Although not essential, FLAC is required" + ewarn "for playing lossless WAV and FLAC (for Squeezebox 1), and for" + ewarn "playing other less common file types (if you have a Squeezebox 2, 3," + ewarn "Receiver or Transporter)." + ewarn "For maximum flexibility you are recommended to set the 'flac' USE flag". + ewarn "" + fi + if ! use lame; then + ewarn "'lame' USE flag is not set. Although not essential, LAME is" + ewarn "required if you want to limit the bandwidth your Squeezebox or" + ewarn "Transporter uses when streaming audio." + ewarn "For maximum flexibility you are recommended to set the 'lame' USE flag". + ewarn "" + fi + + # Album art requires PNG and JPEG support from GD, so if it's not there + # then warn the user. It's not mandatory as the user may not be using + # album art. + if ! built_with_use dev-perl/GD jpeg || \ + ! built_with_use dev-perl/GD png || \ + ! built_with_use media-libs/gd jpeg || \ + ! built_with_use media-libs/gd png; then + ewarn "For correct operation of album art through SqueezeCenter's web" + ewarn "interface the GD library and Perl module must be built with PNG" + ewarn "and JPEG support. If necessary you can add the following lines" + ewarn "to the file /etc/portage/package.use:" + ewarn "\tdev-perl/GD jpeg png" + ewarn "\tmedia-libs/gd jpeg png" + ewarn "And then rebuild those packages with:" + ewarn "\temerge --newuse dev-perl/GD media-libs/gd" + ewarn "" + fi + + # Point user to database configuration step + elog "If this is a new installation of SqueezeCenter then the database" + elog "must be configured prior to use. This can be done by running the" + elog "following command:" + elog "\temerge --config =${CATEGORY}/${PF}" + + # Remind user to configure Avahi if necessary + if use avahi; then + elog "" + elog "Avahi support installed. Remember to edit the folowing file if" + elog "you run SqueezeCenter's web interface on a port other than 9000:" + elog "\t/etc/avahi/services/squeezecenter.service" + fi + + elog "" + sc_starting_instr +} + +sc_remove_db_prefs() { + MY_PREFS=$1 + + einfo "Configuring SqueezeCenter database preferences (${MY_PREFS}) ..." + TMPPREFS="${T}"/squeezecenter-prefs-$$ + touch "${ROOT}${MY_PREFS}" + sed -e '/^dbusername:/d' -e '/^dbpassword:/d' -e '/^dbsource:/d' < "${ROOT}${MY_PREFS}" > "${TMPPREFS}" + mv "${TMPPREFS}" "${ROOT}${MY_PREFS}" + chown squeezecenter:squeezecenter "${ROOT}${MY_PREFS}" + chmod 660 "${ROOT}${MY_PREFS}" +} + +sc_update_prefs() { + MY_PREFS=$1 + MY_DBUSER=$2 + MY_DBUSER_PASSWD=$3 + + echo "dbusername: ${MY_DBUSER}" >> "${ROOT}${MY_PREFS}" + echo "dbpassword: ${MY_DBUSER_PASSWD}" >> "${ROOT}${MY_PREFS}" + echo "dbsource: dbi:mysql:database=${MY_DBUSER};mysql_socket=/var/run/mysqld/mysqld.sock" >> "${ROOT}${MY_PREFS}" +} + +pkg_config() { + einfo "Press ENTER to create the SqueezeCenter database and set proper" + einfo "permissions on it. You will be prompted for the MySQL 'root' user's" + einfo "password during this process (note that the MySQL 'root' user is" + einfo "independent of the Linux 'root' user and so may have a different" + einfo "password)." + einfo "" + einfo "If you already have a SqueezeCenter database set up then this" + einfo "process will clear the existing database (your music files will not," + einfo "however, be affected)." + einfo "" + einfo "Alternatively, press Control-C to abort now..." + read + + # Get the MySQL root password from the user (not echoed to the terminal) + einfo "The MySQL 'root' user password is required to create the" + einfo "SqueezeCenter user and database." + DONE=0 + while [ $DONE -eq 0 ]; do + trap "stty echo; echo" EXIT + stty -echo + read -p "MySQL root password: " ROOT_PASSWD; echo + stty echo + trap ":" EXIT + echo quit | mysql --user=root --password="${ROOT_PASSWD}" >/dev/null 2>&1 && DONE=1 + if [ $DONE -eq 0 ]; then + eerror "Incorrect MySQL root password, or MySQL is not running" + fi + done + + # Get the new password for the SqueezeCenter MySQL database user, and + # have it re-entered to confirm it. We should trivially check it's not + # the same as the MySQL root password. + einfo "A new MySQL user will be added to own the SqueezeCenter database." + einfo "Please enter the password for this new user (${DBUSER})." + DONE=0 + while [ $DONE -eq 0 ]; do + trap "stty echo; echo" EXIT + stty -echo + read -p "MySQL ${DBUSER} password: " DBUSER_PASSWD; echo + stty echo + trap ":" EXIT + if [ -z "$DBUSER_PASSWD" ]; then + eerror "The password should not be blank; try again." + elif [ "$DBUSER_PASSWD" == "$ROOT_PASSWD" ]; then + eerror "The ${DBUSER} password should be different to the root password" + else + DONE=1 + fi + done + + # Drop the existing database and user - note we don't care about errors + # from this as it probably just indicates that the database wasn't + # yet present. + einfo "Dropping old SqueezeCenter database and user ..." + sed -e "s/__DATABASE__/${DBUSER}/" -e "s/__DBUSER__/${DBUSER}/" < "${SHAREDIR}/SQL/mysql/dbdrop-gentoo.sql" | mysql --user=root --password="${ROOT_PASSWD}" >/dev/null 2>&1 + + # Drop and create the SqueezeCenter user and database. + einfo "Creating SqueezeCenter MySQL user and database (${DBUSER}) ..." + sed -e "s/__DATABASE__/${DBUSER}/" -e "s/__DBUSER__/${DBUSER}/" -e "s/__DBPASSWORD__/${DBUSER_PASSWD}/" < "${SHAREDIR}/SQL/mysql/dbcreate-gentoo.sql" | mysql --user=root --password="${ROOT_PASSWD}" || die "Unable to create MySQL database and user" + + # Remove the existing MySQL preferences from SqueezeCenter (if any). + sc_remove_db_prefs "${PREFS}" + [ -f "${LIVE_PREFS}" ] && sc_remove_db_prefs ${LIVE_PREFS} + + # Insert the external MySQL configuration into the preferences. + sc_update_prefs "${PREFS}" "${DBUSER}" "${DBUSER_PASSWD}" + [ -f "${LIVE_PREFS}" ] && sc_update_prefs "${LIVE_PREFS}" "${DBUSER}" "${DBUSER_PASSWD}" + + # Phew - all done. Give some tips on what to do now. + einfo "Database configuration complete." + einfo "" + sc_starting_instr +} + +pkg_preinst() { + # Warn the user if there are old plugins that he may need to migrate + if [ -d "${OLDPLUGINSDIR}" ]; then + if [ ! -z "$(ls ${OLDPLUGINSDIR})" ]; then + ewarn "Note: It appears that plugins are installed in the old location of:" + ewarn "${OLDPLUGINSDIR}" + ewarn "If these are to be used then they must be migrated to the new location:" + ewarn "${NEWPLUGINSDIR}" + ewarn "" + fi + fi +} |