/python-throatwobbler

PyTone Revitalization in Python 3

Primary LanguagePythonGNU General Public License v2.0GPL-2.0

PyTone

   MP3 Jukebox redux
   _________________________________________________________________

Summary

   PyTone is a music jukebox written in Python with a curses based GUI.
   While providing advanced features like crossfading and multiple
   players, special emphasis is put on ease of use, turning PyTone into
   an ideal jukebox system for use at parties.

Features

     * concise curses based GUI
     * simple song selection
          + using an arbitrary number of music databases with hierarchical
            (artist/album/songs, some tags/artist/album/songs) navigation,
          + from list of top and last played songs,
          + from list of most recently added songs,
          + random song list,
          + stored playlists, or
          + alternatively from file system
     * editable playlist:
          + deletion
          + move song up/down
          + delete played songs
          + shuffle
          + repetition and automatic addition of random songs, when the 
            playlist is empty
          + save to and load from .m3u file
     * pluggable players, currently
          + internal MP3/Ogg Vorbis player with crossfading and/or
          + xmms based external player and/or
          + mpg321 or (the non-free) mpg123 based external player
     * display of information for currently selected song:
          + ID3 tag
          + length, bitrate, sample rate, BPM, ReplayGain information, part
            of a compilation, podcast
          + times played and skipped
          + last played
          + song rating (1 to 5 stars)
     * plays currently selected song on second player (if your computer
       has a second sound card or one card with more than one line out)
     * search functionality:
          + quick search by first letter
          + incremental search by regular expression
     * random song selection taking into account song rating and time at
       which song was last played
     * description of important key bindings in status bar and context 
       sensitive help
     * random song suggestion
     * logging of played songs
     * execution of arbitrary command when playback of new song starts
     * basic mixer functionality
     * customizable key bindings
     * customizable look
     * English, French, German, Italian and Polish user interface
     * external control, e.g. from the shell
     * plugin system; currently plugins for the AudioScrobbler service and
       for displaying the title in the terminal window and using xosd are
       included

Software prerequisites

     * Python 2.3 (available from [2]here); 
     * for the mad based internal player (optional):
          + Python header files,
          + pymad (available from [3]here) and
          + pyvorbis (optional, available from [4]here),
          + pyao (available from [4]here, please use version 0.82 or above) or 
            the new Python OSS module in Python 2.3.
          + libao header files (available from here, if you want to compile
            the C version of the output ring-buffer.
     * for the xmms based external player (optional):
          + xmms 1.2.6 or higher (available [5]here) and
          + pyxmms (available from [6]here)
     * for the mpg321 or mpg123 based external player (optional):
          + mpg321 (available from [7]here) or
          + mpg123 (available from [8]here)
     * for the mixer interface (optional):
          + Python OSS module (included in Python 2.3 or available from [9] here)

Download

   The latest version of PyTone can be downloaded as gzipped tar archive
   from [10]here.

Installation

   If you want to use the internal libmad based player, you have to build
   one C extension module located in the pcm subdirectory. This
   can be done simply via

     $ python setup.py build_ext -i

   Note that by default this builds also a C extension module for the output
   ring-buffer, which requires the libao header files (see above). If you are
   happy with the Python version of the output buffer, you can disable
   building the C module by setting "buildbufferedaoext = False" at the top of
   the setup.py file before running the above command.

   To enable support for transparent terminals (only needed for Python 2.3.x)
   set "buildcursext = True" at the top of the setup.py file before running the
   above command.

Configuration

   All configuration options of PyTone can be found in the sample configuration
   file conf/pytonerc. Side-wide configuration goes into /etc/pytonerc, user
   specific changes can be put into ~/.pytone/pytonerc. Note that you only have
   to supply options you want to change. Note that you only have to supply
   options you want to change. Furthermore, while most of the standard settings
   will probably fit your needs, you have to change the variable musicbasedir
   in the section [database.main] of the main database, which specifies the
   root of your primary MP3 collection. A minimal version of your configuration
   file should thus contain

     # minimal ~/.pytone/pytonerc defining the root of your music collection
     [database.main]
     musicbasedir=/root/of/your/music/collection

Usage

   After having adjusted the basic configuration variables to your personal
   needs, just start the program with

     $ ./pytone

   and look how the database is being rebuilt. The key bindings described
   below should say all about the use of PyTone. A list of command line
   options can be obtained by

     $ ./pytone --help

   Then let it rock...

   The remote control of PyTone is possible using the  pytonectl script.
   For a list of available options use:

     $ ./pytonectl --help

   In order for the remote control to work, either the socketfile
   or the enableserver option have to be set in the [network] section
   of the pytonerc file. By default, the former is the case.

Key bindings

   In database/filelist window (left half of screen)

   ArrowUp                      move selection up
   ArrowDown                    move selection down
   PageUp/CTRL-P                move selection one page up
   PageDown/CTRL-N              move selection one page down
   Home/CTRL-A                  move selection to beginning
   End/CTRL-E                   move selection to end
   ArrowRight/Enter/Space       enter directory / add song
   ArrowLeft                    exit directory
   i/ALT+ArrowRight             add song or directory (recursively)
   r                            insert random selection of selected directory
                                (including subdirs)
   u                            update ID3 information for song/directory
   D                            delete / undelete currently selected
                                song/directory
   ALT+Enter                    immediately play song
   TAB                          switch to playlist window
   ALT+<character>              Quicksearch: jump to next entry that begins
                                with character
   CTRL-S//                     Search in list
   f                            Focus on songs matching approximately a search
                                string

   In playlist window (lower right quarter half of screen)

   ArrowUp                      move selection up
   ArrowDown                    move selection down
   PageUp/CTRL-P                move selection one page up
   PageDown/CTRL-N              move selection one page down
   Home/CTRL-A                  move selection to beginning
   End/CTRL-E                   move selection to end
   +                            move selected song up
   -                            move selected song down
   d                            delete selected song
   ALT+Enter                    immediately play song
   r                            shuffle playlist
   TAB/ArrowLeft/h              switch to database/filelist window
   ArrowRight/l                 jump to currently selected song in filelist window

   Always active

   p                            start/pause playing
   S                            stop playing
   n                            advance to next song in playlist
   b                            go back to previous song in playlist
   >                            fast forward in song
   <                            rewind in song
   BACKSPACE                    delete played songs
   CTRL-D                       clear playlist
   CTRL-W                       save playlist to file
   CTRL-R                       load playlist from file
   (                            decrease output volume
   )                            increase output volume
   {                            decrease playback speed
   }                            increase playback speed
   ~                            reset playback speed to normal
   1 - 5                        change rating of selected item
   ALT-1 - ALT-5                change rating of currently playing song
   ?                            show help
   !                            show message log
   %                            show statistical information about database(s)
   =                            show information about selected item
   L                            show lyrics of selected song
   CTRL-V                       toggle information shown in item info window
   F10                          toggle UI layout (one/two column)
   CTRL-X CTRL-X                exit program (the keypresses have to be 
                                maximally one tenth of a second apart)


Mailing list

   For discussions on PyTone, a mailing list has been created. For more
   information on subscribing and for the list archive, see [11]here.

History

   PyTone was written since my favourite MP3 Jukebox (KJukebox) wasn't
   maintained anymore. Its simple user interface and good usability even
   without a mouse combined with the crossfading ability of the player,
   have not been reached by any other free program. Especially for the
   use at a party, KJukebox was very well suited.

   However, after looking around on the net for sometime, I found [11]mjs,
   a curses based MP3 Jukebox system, which featured a really simple and
   efficient GUI. Unfortunately, it was written in C and already the
   first attempts to tailor it to my needs showed that probably a Python
   version of this program would be a great win. That's how the
   development of PyTone started...

   After one week of intensive programming version 1.0 of what was then
   called pyjuke was ready and was deployed during a three day long
   party. It proved to be very usable (even on a 38400 baud serial
   terminal) and astoundingly stable, even under extreme, Woodstock like
   conditions (very heavy rain + deep mud :-) )

   Subsequently, the internal mad based player was written, which
   provides crossfading capabilities without using xmms, a new, more
   imaginative name was found (kudos to Harry!) and PyTone was released.


Copyright and author

   PyTone was written by Jörg Lehmann and is free software licensed under
   the GNU GPL Version 2.

   Please send comments, wishes, bug reports and patches to the
   [11]mailing list or directly to me, 

     Jörg Lehmann <joerg@luga.de>

   Of course, I always like to hear of happy users of PyTone.

Links

   1. http://packages.debian.org/unstable/sound/pytone.html
   2. http://www.python.org/
   3. http://spacepants.org/src/pymad/
   4. http://www.andrewchatham.com/pyogg/
   5. http://www.xmms.org/
   6. http://www.via.ecp.fr/~flo/index.en.html
   7. http://mpg321.sourceforge.net/
   8. http://www.mpg123.de/
   9. http://indra.com/~tim/ossmodule/
   10. http://www.luga.de/pytone/PyTone-latest.tar.gz
   11. https://www.luga.de/mailman/listinfo/pytone-users/
   12. http://mjs.sourceforge.net/