Tag Archives: Fauxdacious

Fauxdacious Version 3.83-Final Released

Fauxdacious Version 3.83-final Released for Linux and Windows: 

* FIXED filewriter plugin to “fail over” to “unknown” for the filename if the playing filename is too long or invalid (needed for youtube streams, etc.).  Also fixed a potential null-pointer reference.

* FIXED (rebuilt) FauxdaciousURLHelper.exe (Windows version binary) to add missing utf8_heavy module needed to fetch some IHeartRadio streams (Linux version not effected, which uses the Perl script).

* Added “close after song change.” checkbox for STDOUT output to “close” STDOUT when either song stops playing or record is toggled off in order to avoid errors in the created output stream.  Otherwise, output to STDOUT accumulates as a single long stream until recording stops.  This allows for combining multiple songs into a single output file, but can produces (somewhat harmless) errors at end of playback in such files.  The default is TRUE (checked) (properly close and prevent errors and only record the last song (overwrite).

* Added fixups for ugly but common stream title formats.

* Mandate SDL2 in Fauxdacious main, remove choice to use SDL1 in plugins.

* Merged all Fauxdacious commits through ace32cd; and plugin commits through: a666f70.

* Merged Audacious commits: 7886b7b; and plugin commits:  #9816dc6, 4f327c6, 10abf7d, 94d95fc, b13a35d.

Fauxdacious Version 3.83-beta3 Released

Fauxdacious Version 3.83-beta3 Released for Linux and Windows: 

* ADDED DVD-player plugin now included in the Windows version!  NOTE: For some reason, the livdvdnav library does not return the DVD Title string on Windows, so DVD cover art won’t work and all DVD titles are shown as “Unknown Title”.  TODO:  Try to figure out why.

* Addressed “smudgy” menu issue on some menus (Still not perfect on all menus, but much better).

WARNING:  Playing DVDs that contain CSS encryption DRM requires a special decrypting software library that is ILLEGAL in many jurisdictions.  This plugin software does NOT contain such decrypting software, but can make use of it in jurisdictions where such use is not prohibited.  It is the sole responsibility and liability of the user to ensure that such decrypting software is legal to use in their jurisdiction before installing and using such software with this plugin or any other software and / or hardware capable of playing DVD discs.  NOTE:  To play (legally purchased) encrypted DVDs in you region, (if it is legal to use libdvdcss in your jurisdiction), you will need to obtain a copy of libdvdcss-2.dll and manually place it in the bin/ directory where you installed Fauxdacious (where fauxdacious.exe and libdvdread-4.dll exist).

To play any DVDs, you will also need to edit your audacious config file (usually C:\Users\<username>\AppData\Local\audacious\config and add the following lines (or adjust as you see fit):

[dvd]
device=D: #(Or the drive letter of your DVD drive) libdvdread quirk: Add "\" if NOT using libdvdcss!
highlightbuttons=TRUE
play_video=TRUE
title_track_only=TRUE
video_qsize=5
video_windowtitle=Fauxdacious DVD #(Or whatever you want displayed in the titlebar)
video_xmove=1
video_ysize=-1

* FIXED bug that occasionally hangs Fauxdacious on startup when loading up with a wild-card list of files (usually .wav files), ie:  fauxdacious ~/Music/*.wav (Fauxdacious commit #8e3ba79).  This was due to a mutex deadlock in our song-specific equalizer-preset feature code.

* I gave up and made SDL v2 a REQUIREMENT now for Fauxdacious itself (The new DVD plugin already requires SDL2).  This is due to the fact that the nasty old issue of gtk-window vs SDL segfault kerfuffle resurfaced again (see plugin commit #5c09006 for a brief history of this issue), so now we will properly initialize SDL in main() since SDL seems to want to pretend like it has the “main()” function and must be initialized very early (now in main()) in order to play nicely with gtk windows created later (Fauxdacious commit #cec5946).  TODO:  Add this to the configure script!

* ADDED cover-art via the user_tag_file option for both DVDs and Audio CDs.  User must manually obtain cover art images and store the image files, rename them to the same name matching the respective CD or DVD title (shown in the playlist) and place them either in the [dvd|CDDA].cover_art_path (config file option) or the default: ~/.config/audacious[_instancename]/ directory (if not specified) – (plugin commits #5b0f6d7 and #cce218a).  The manual requirement is currently due to my inability to find free urls for reliably locating cover art programatically by searching with the information at Fauxdacious’s disposal (the CD/DVD “Title” string and disk IDs).  If I or someone else can find and provide URLS for such libraries and scrape logic (ok if separate ones for Audio-CDs and/or DVDs), I’ll be happy to test and include in a future release!

* MERGED (mostly) our stdin streaming feature with that of Audacious.  Our implementation of this feature predates Audacious’s and required specifying the file extension (as “stdin://-.mp3” for mp3) but theirs does not (“-“).  Since they now support stdin piping, including seekability via buffering during probing, I’ve now REMOVED my (now ancient) “hacks” to the sndfile, vorbis, and gio plugins previously needed to support stdin streaming without seeking, and remerged their latest versions of these plugins (less maintenance for me – yay)!  I’m leaving it in ffaudio for now though as it handles so many different formats (commit #8524685, and plugin commits # 7b0be4f, 9d4cfa3, 240e090 and 2ba6b75).

With Fauxdacious, one can still include the extension (the old Fauxdacious way) and save the overhead of probing all the plugins, however, the extension is still REQUIRED for non-“Input” plugins such as cue-sheets (“-.cue”) and playlist files (“-.pls”, etc.), as these do not “probe” to determine what’s being piped in!  Believe me, I spent a day trying to get the Fauxdacious core to “probe” playlists and cue-sheets piped in via stdin, but the underlying Audacious architecture simply doesn’t permit it as written.

Also removed the added Fauxdacious requirement of specifying “stdin://-” (instead of just “-“), though the old way is still acceptable.  NOTE:  This did result in one minor regression:  when piping a simple line-separated list of items to play (ie. “ls *.mp3 | fauxdacious -“), one must now specify either “-.txt”, “-.ls” or “-.m3u” (doesn’t matter which) instead of just “-” as I’ve removed the old code in main() that specifically handled this and now use the standard m3u playlist plugin for this.

* Instance numbers (single digits) can now be combined with single-letter command-line options, ie. “fauxdacious -Dc2”, and instance# 0 is now a synanymn for the default instance (name: audacious) (commit #712b923).

* Merge in all Fauxdacious commits through 712b923 and plugin commits through b4882eb.

* Merge in Audacious commits:  20ecbff, 9303781, baabb80, 79dcc0f, e859ae3, 11b4856 (plugin commit a7ba191 has long been part of Fauxdacious).

Fauxdacious(tm) Media Player for Linux (and Windows) Released

Introducing
I’m pleased to announce the release of Fauxdacious(tm) Media Player, v.3.83-final!   Fauxdacious is my FORK of “Audacious“.   The reason for this fork was that I’ve accumulated numerous changes (hacks) that I’ve made over the years to Audacious.   I’ve also added some big new features, namely video-playing capability and a shiny new DVD-player plugin!  While I’ve submitted the patches of most of my enhancements to the Audacious team for mainline inclusion, they’ve rejected most and completely redid one in a way that I felt limited it’s usefulness.   The final straw came when I rewrote their FFMpeg plugin to support an option to display the video portion of media that contains video and they rejected it out of hand.   I was initially pretty perturbed with them because I believe this enhancement is a very useful addition and I started to get the impression that they really aren’t interested in code contributions from outside parties and started to write a rather angry screed here to my dear readers, but after further contemplation, I have concluded that it’s not warranted nor helpful to anyone.
I think the problem is that Audacious is a very mature (and very good, I might add) software project and therefore they are more limited in what they can and should change, and that their perceived “not invented here” attitude may be necessary at this point to maintain it’s integrity.   By forking, I can be more open to new ideas and features, which can potentially take it in new directions.  It should be remembered that Audacious itself was originally a fork of the now defunct XMMS media player!   I plan to continue offering further patches and changes I make to Fauxdacious available to the Audacious team for their consideration, but will no longer be concerned about whether they choose to include them.   I can also therefore be more open to new patches offered by others, which the Audacious team may reject, as well as cherry-picking new bugfixes, upgrades, and features that they include into their future releases.
Please be advised that though I’ve been a computer programmer for over thirty years, my C++ skills are somewhat limited and Audacious is huge and very complex, so my ability to support and fix bugs is somewhat limited (but I’m getting better at it)!   Therefore, if you have an issue with Fauxdacious, your best bet would be to first check their forums, then try real Audacious.   You need to determine if it fails there also, or if the issue only affects Fauxdacious!   If Audacious replicates the bug, then report it there, but if not, then notify me (as it is then an issue with my Fauxdacious patches), and I need to fix it!   Please DO NOT file bugs with Audacious regarding this project unless you can replicate it there without notifying me first!   This will be non-trivial, since it is somewhat challenging to install both Fauxdacious and Audacious on the same system at the same time.   By installing one, you can overwrite parts of the other unless you are very careful, but you should still be able to switch between the two!
Fauxdacious Features not currently found in Audacious:
1)   A “DVD-player” plugin for playing DVDs (video, audio & menus) (Now for both Linux/Unix and Windows, may work on Mac too, but I can’t test)!
2)   A “visualization” option for displaying the video of ffmpeg files and streams that contain a video stream in a popup window.   Since Audacious already has “visualization” plugins that pop up a separate window to display stuff like fractals, equalizer graphs, etc. that are tied to what’s playing, my original idea was to create a “visualization” plugin that would display the actual video part of the stream, if it contained one.   I ended up rewriting their “FFaudio” plugin to add options for handling video and, so far, it handles any video stream that ffmpeg / ffplay can play! (See my previous post for history / details on how it works)  Screenshot below with my new “Lavadacious” skin (included):
3)  Restoration of XMMS’s “auto-preset” feature that permits creation of song/stream specific equalizer settings.  In the equalizer window (when using the WinAmp Skin interface, the [Auto] and [Preset] buttons now work again)!  When you “Export” a “Preset” file, the window pops up with the name of the currently-playing song displayed as the default file name and the default directory is the Audacious config directory.  If you save your preset file there under that name and you turn the [Auto] button on, and restart the song, Fauxdacious will load the matching preset file from there for that song/stream while it is playing, then restore the default equalizer presets when advancing to another song.  The [Preset] button also lights up if Fauxdacious is currently using a song/stream specific preset.  NOTE:  The Audacious team is currently working on a similar capability at my request, and I am likely to replace this with theirs when they do!
4)   The ability to toggle the recently-added Audacious record / dub option via it’s “audtool” DBus-based command-line tool permitting creation of quicker one-button desktop launcher activation, or even script activation of dubbing, ie. using Cron to record your favorite late-night radio show!  NOTE:  The Audacious team has merged this patch in their latest GIT at my request!
5)   Filewriter option to automatically deactivate equalizer and all effects plugins when recording so they’re not doubled down on during playback.   NOTE:  This has been replaced (in Fauxdacious v. 3.7-beta2) with the Audacious team’s latest GIT patch (after my request) which is better!
6)   Option to divert audio output to stdout in the user’s choice of selected audio formats for further processing by another program.   This is a rejected feature added to Audacious’s “FileWriter” plugin.   The idea here is to be able to use Fauxdacious as an audio component in pipes.  It also permits continuous recording across multiple files / tracks into a single stream.
7)   (UPDATE:  as of v3.83-beta3, we now support Audacious’s way of doing this (in addition to our prev. way), removing many of our code changes!)  Better (imho) stdin input (for streaming) of most formats as well as playlists.   Again this is for using Fauxdacious as a component in pipes.   Audacious actually implemented this at my urging a while back, but my rejected patch not only permits streaming media through stdin, but also lists of media files to process via simple ls commands, etc.  ie. generated by a script, etc.   Audacious now supports this via a slightly more complicated syntax, however.  For a simple example:
ls ~/Music/*Swift*.mp3 | fauxdacious -Dc -.txt
8)   New option (-P) to use the Pause button to simply mute (ie. commercials) while stream continues to play (silently), allowing you to listen to something else in another instance (see feature 10 below).   I often keep two instances open while listening to online commercial radio streams (which are in commercial for nearly half the time anyway with typically 5-6 minute breaks).   I have the other instance playing my own (legally) downloaded music without the Pause-Mute option, and with one button-click, can switch to and resume my music where it left off while the commercials (in the first instance) blather on (muted) to the bit bucket! 😀   Otherwise, one must either pause the radio stream, and resume where it left off (at the beginning of the commercial break) or mute the system’s speakers preventing the playing of anything else!
9)   Command line option “-D” – Delete all playlists.  Audacious added multiple playlists via tabs in their GTK/Qt interfaces which is quite nice, but I could never get used to it as I only use the classic WinAmp skin interface, which only supports (displays) a single playlist.   When starting Audacious with a new file or list of files, by default, it creates a new playlist, leaving all the others intact and invisible to you, which becomes annoying.   By starting Fauxdacious with “-D”, any existing playlists are deleted for you.   A second new option “-c” clears all entries from the current playlist.   by starting up with “-Dc”, you are guaranteed to start up with a clean slate containing only items listed as arguments.   If you start it with no arguments, you start up with a clean, empty playlist!
10)   New “-z” option to start up without the equalizer on.
11)   New “-#” / “-n” / –new=<instance-name> options to activate a new “instance” of Fauxdacious by specifying an alternate config directory name (~/.config/audacious_<instance-name>/).   I use this, as described in the script below with two separate instances of Fauxdacious running at the same time with different playlists (and / or different configurations).   The default config directory is named “audacious” (~/.config/audacious/).   a new, separate “instance” is specified by “–new=newconfig” where “newconfig” is the name of a different config directory (can be a copy).   This “instance-name” can then be used in the “audtool” command to specify which instance of Fauxdacious to manipulate!  If just -n is given, just a new instance is created, but the default config file is used and it can not be manipulated with audtool.  The default instance name is “audacious” (not “fauxdacious”) with nothing appended to the end of it.  -# works just like Audacious instances, except the config. directory is “audacious_#” instead of “audacious-#”.
Here’s my script for toggling between music and radio (and adjust the volume difference between the radio and my music) in two separate instances of Fauxdacious (the 2nd called “radio”) activated by a desktop launcher button:
audStatus=`cat /tmp/audstatus`
if [ "X$audStatus" = "X1" ]; then
     audtool instance radio playback-pause set-volume -12
     audtool playback-play
     echo "2" >/tmp/audstatus
else
     audtool playback-stop
     audtool instance radio playback-play set-volume +12
     echo "1" >/tmp/audstatus
fi
12)  Additional skins, namely my very own “Lavadacious”, which I designed to match the violet “Lavafox” theme I use in Firefox and in my current desktop theme.  There is also a “DefaultRed” skin based on the Audacious “Default” skin, and additional flavors of the “Refugee” skin.
13)  Ability to play Youtube and Vimeo videos using (an included) Perl “helper” script (FauxdaciousUrlHelper.pl) in the contrib/ directory for prefetching the video title and extracting and adding the hidden “live-stream” to the playlist in lieu of the Youtube url.  You need to copy FauxdaciousUrlHelper.pl from the contrib directory to somewhere in your executable path, like /usr/local/bin/ (Linux/Unix users – the install script takes care of this for Windows users!) AND add the new config option:  [audacious].url_helper=FauxdaciousUrlHelper.pl and [audacious].user_tag_data=TRUE to your config file (~/.config/audacious[_instancename]/config or C:\Users\<username>\AppData\Local\audacious[_instancename]\config).  M$-Windows users will also probably need to add a new [neon] section and [neon].ignore_ssl_certs=TRUE as well.  This helper also replaces and obsoletes the previous “getTuneinStream.pl” helper script as well as the “youtube-dl” transport plugin!  You can also edit this script to handle other weird stream urls that need modification, if you can get around in Perl scripting!
14)  Ability to play most Tunein.com and IHeart.com radio stations (that contain an actual live stream; with Perl and the new (provided) FauxdaciousUrlHelper.pl url-helper script mentioned in the previous paragraph.
15)  Ability to save tag metadata (title, artist, etc.) to files in media formats that don’t support tags, as well as streams (URLs) by adding the option: [audacious].user_tag_data=TRUE to your config file.  Such metadata will be stored in a text file (user_tag_data) in your audacious config directory.  Leveraging this option, you can now download your favorate CD and DVD cover images and use them for cover art when playing your Audio CDs and DVDs with Fauxdacious!
The Audacious team leader told me that it was not worth my effort (or theirs) to add video capability to Audacious since there are many excellent video players out there, but I disagree.   Sure, there are (I like VLC and Mplayer myself), but I really prefer the Audacious interface, and I’m spoiled used to it!   I also like to use Audacious’s sound-enhancing effects plugins while listening to audio or video! I admit that I probably use my audio player a bit differently than most.   I’m sort of a Linux command-line and scripting kinda guy and that’s what most of these hacks are for.   If you are too and / or like being able to watch videos while using Audacious’s wonderful audio-enhancing plugins, features, and beautiful classic WinAmp skins, then Fauxdacious is definitely for you!
Ok, so how do you get Fauxdacious?!
DISCLAIMER:   First of all, before downloading and installing Fauxdacious, please be aware that I consider this “beta”-quality software and therefore likely to contain a few bugs.   Therefore, I provide you this software “as-is” and I assume no liability for any damages resulting from it’s installation and use.   By using this software, you acknowledge that you are assuming all risk of any damages or injury that may result from such use!
NOTE:   If you are using M$-Windows, SKIP all this below and simply download, unzip, and run the Windows self-installing binary which you can download directly here! or read more about it first here!
1)   Uninstall libaudcore, audacious, and audacious-plugins from your system (if you are currently using Audacious).   This shouldn’t remove your Audacious configurations, but you should copy your ~/.config/audacious/* files somewhere else first, just in case something goes wrong!
2)   If you already have a fairly up-to-date version of Audacious running, you probably already have the dependencies installed.  If not, here’s a list.  Note, most of these aren’t required to actually get Fauxdacious (or Audacious) to run, but many are needed for particular plugins in order to process different types of media.
Depends: libasound2
Depends: libatk1.0-0
Depends: libaudcore3
Depends: libavcodec56
Depends: libavformat56
Depends: libavutil54
Depends: libbs2b0
Depends: libc6
Depends: libcairo2
Depends: libcddb2
Depends: libcdio-cdda1
Depends: libcdio13
Depends: libcue1
Depends: libcurl3-gnutls
Depends: libdbus-1-3
Depends: libdbus-glib-1-2
Depends: libfaad2
Depends: libflac8
Depends: libfluidsynth1
Depends: libfontconfig1
Depends: libfreetype6
Depends: libgcc1
Depends: libgdk-pixbuf2.0-0
Depends: libgl1-mesa-glx
Depends: libgl1-mesa-glx
Depends: libglib2.0-0
Depends: libgtk2.0-0
Depends: libjack-jackd2-0
Depends: libjack-jackd2-0 libjack0
Depends: liblircclient0
Depends: libmms0
Depends: libmodplug1
Depends: libmp3lame0
Depends: libmpg123-0
Depends: libneon27-gnutls
Depends: libnotify4
Depends: libogg0
Depends: libpango-1.0-0
Depends: libpangocairo-1.0-0
Depends: libpangoft2-1.0-0
Depends: libpulse0
Depends: libsamplerate0
Depends: libsdl2-2.0-0
Depends: libsidplayfp4
Depends: libsndfile1
Depends: libsndio6.0
Depends: libsoxr0
Depends: libstdc++6
Depends: libvorbis0a
Depends: libvorbisenc2
Depends: libvorbisfile3
Depends: libwavpack1
Depends: libx11-6
Depends: libxcomposite1
Depends: libxml2
Depends: libxrender1
Depends: libdvdread
Depends: libdvdnav
Depends: zlib1g
3)   Download both Fauxdacious and the Fauxdacious Plugins tarballs from these respective links.
As of 3/7/2017, you can also now download the bleeding-edge latest source code for both from my official Github site as well!
4)   Untar each.   Switch to the newly-created subdirectory (./fauxdacious-3.7/ for the first).  If you are running a pretty modern Debian-based Linux distro, you can probably simply open a terminal and do:
sudo make install
cd /usr/local/bin
sudo ln -s audacious fauxdacious
5)   If this does not work for you, you’ll need to compile from scratch.  This will involve installing the development versions of several of these libraries.  Here’s a list from the Audacious team and this command will install them for you on a Debian-based system:
sudo apt-get install git automake build-essential libasound2-dev \
libavformat-dev libbinio-dev libbs2b-dev libcddb2-dev libcdio-cdda-dev \
libcue-dev libcurl4-gnutls-dev libdbus-glib-1-dev libfaad-dev libflac-dev \
libfluidsynth-dev libgl1-mesa-dev libgtk2.0-dev libguess-dev \
libjack-jackd2-dev liblircclient-dev libmms-dev libmodplug-dev libmp3lame-dev \
libmpg123-dev libneon27-gnutls-dev libnotify-dev libpulse-dev \
libsamplerate0-dev libsdl2-dev libsidplayfp-dev libsndfile1-dev libsoxr-dev \
libvorbis-dev libwavpack-dev libxml2-dev libsndio-dev libswscale-dev libdvdread-dev libdvdnav-dev
6)   Repeat step 4 for the fauxdacious-plugins-3.7.tgz tarball by untarring and switching to the fauxdacious-plugins-3.7/ and try the “sudo make install” command there.
7)   After completing the installation of both tarballs, you should then do:
cd /usr/local/bin
sudo ln -s audacious fauxdacious
fauxdacious
If all this fails and / or you wish to go back to Audacious, simply switch back into fauxdacious-plugins-3.7/ and do a “make distclean” command, then do the same in fauxdacious-3.7/ and do the same thing, then reinstall your Audacious packages.  (libaudcore, audacious, and audacious-plugins) and you should be back to normal.
8)   To enable video play either go to [Settings].[Plugins].[Input] tab.[FFmpeg Plugin].[Settings] and check the “Play video stream…” box; or edit your “~/.config/audacious/config” file and add the following lines:  (You can change “Fauxdacious Video” to whatever title you would like to appear above the video window).  If you also use the Afterstep windowmanager (as I do), you may want to add the line “afterstep=TRUE” under the “[skins]” section!
[ffaudio]
play_video=TRUE
video_windowtitle=Fauxdacious Video
TO DO:   I still need to fix an annoying error msg. popup that occasionally comes up saying it can’t find a (should’ve been deleted) playlist.   Right now, it works fine in spite of this.  (FIXED in v3.71beta2)   Next step is to eventually figure out how to “package” all this up into Debian “packages” for simpler installation!   Another thing is including the QT interface (right now I use the WinAmp skins interface and built it with the GTK interface, but not the QT stuff.   (DONE!)  I also could use someone with Windows and a good C++ compiler to build a Windows binary version (Audacious has one).  This is something I’m completely clueless about though!  (DONE!)
UPDATE (4/29/17):  Version 3.83-beta2 Released
UPDATE (3/18/17):  Version 3.83-beta1 Released
%d bloggers like this: