diff options
author | tpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2010-03-01 19:09:31 +0000 |
---|---|---|
committer | tpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2010-03-01 19:09:31 +0000 |
commit | f2cfda2a54780868dfe0af7bd652fcd4906547da (patch) | |
tree | c6ac23545528f5701818424f2af5f79ce3665e6c /src/replaygain.cpp | |
download | soundkonverter-f2cfda2a54780868dfe0af7bd652fcd4906547da.tar.gz soundkonverter-f2cfda2a54780868dfe0af7bd652fcd4906547da.zip |
Added KDE3 version of SoundKonverter
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/soundkonverter@1097614 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'src/replaygain.cpp')
-rwxr-xr-x | src/replaygain.cpp | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/src/replaygain.cpp b/src/replaygain.cpp new file mode 100755 index 0000000..f815a21 --- /dev/null +++ b/src/replaygain.cpp @@ -0,0 +1,96 @@ + +#include "replaygain.h" +#include "config.h" +#include "logger.h" +#include "replaygainpluginloader.h" + +#include <qfile.h> + +#include <kprocess.h> +#include <klocale.h> +#include <kurl.h> + +ReplayGain::ReplayGain( Config* _config, Logger* _logger ) +{ + config = _config; + logger = _logger; +} + +ReplayGain::~ReplayGain() +{} + +bool ReplayGain::apply( QStringList files, const QString& format, KProcess* proc, int logID, Mode mode ) +{ + QStringList params; + QString param, paramSplinter; + + proc->clearArguments(); + + ReplayGainPlugin* plugin = config->replaygainForFormat( format ); + if( plugin == 0 ) { // shouldn't happen + logger->log( logID, " NULL POINTER: ReplayGain::replaygain( ... ) / plugin" ); + return false; + } + + param = QString::null; + if( plugin->replaygain.param ) param.append( " " + plugin->replaygain.param ); + if( mode & remove ) { + if( plugin->replaygain.remove ) param.append( " " + plugin->replaygain.remove ); + } + else { + if( (mode & calc_track) && plugin->replaygain.track ) param.append( " " + plugin->replaygain.track ); + if( (mode & calc_album) && plugin->replaygain.album ) param.append( " " + plugin->replaygain.album ); + if( mode & force ) { + if( plugin->replaygain.force ) param.append( " " + plugin->replaygain.force ); + } + else { + if( plugin->replaygain.skip ) param.append( " " + plugin->replaygain.skip ); + } + } + +// if( plugin->replaygain.in_files.find("%p") != -1 ) { +// QString t_str = plugin->replaygain.in_files; +// t_str.replace( "%p", param ); +// param = plugin->replaygain.bin + " " + t_str; +// } +// else { +// param = plugin->replaygain.bin + param + " " + plugin->replaygain.in_files; +// } + + QString t_str = plugin->replaygain.in_files; + t_str.replace( "%p", param ); + param = config->binaries[plugin->replaygain.bin] + " " + t_str; + + // cosmetic surgery + param.simplifyWhiteSpace(); + + params = QStringList::split( ' ', param ); + + for( QStringList::Iterator it = params.begin(); it != params.end(); ++it ) + { + paramSplinter = *it; + if( paramSplinter == "%i" ) { + for( QStringList::Iterator b = files.begin(); b != files.end(); ++b ) { + *(proc) << KURL::decode_string( *b ); + } + } + else { + *(proc) << paramSplinter; + } + } + + for( QStringList::Iterator it = files.begin(); it != files.end(); ++it ) + { + *it = KURL::decode_string( *it ); + } + + param.replace( "%i", "\""+files.join("\" \"")+"\"" ); + logger->log( logID, " " + i18n("Executing") + ": `" + param + "'" ); + + proc->setPriority( config->data.general.priority ); + proc->start( KProcess::NotifyOnExit, KProcess::AllOutput ); + + return true; +} + +//QValueList<float> ReplayGain::getReplayGain( QString file ) {} // obsolete |