Cue Sheet splitter improvements/fixes + German translation updates.

This commit is contained in:
LoRd_MuldeR 2011-05-15 15:14:33 +02:00
parent 55b5393768
commit 9296fc32b6
16 changed files with 361 additions and 105 deletions

View File

@ -254,11 +254,11 @@
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>An unknown error has occured!</source> <source>Failed to load the Cue Sheet file:</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>Failed to load the Cue Sheet file:</source> <source>The specified file could not be found!</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message> <message>
@ -266,7 +266,7 @@
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>The specified file could not be found!</source> <source>An unknown error has occured!</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message> <message>
@ -297,6 +297,10 @@
<source>LameXP</source> <source>LameXP</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Error: The selected output directory could not be created!</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Error: The selected output directory is not writable!</source> <source>Error: The selected output directory is not writable!</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
@ -321,6 +325,18 @@
<source>Splitting file(s), please wait...</source> <source>Splitting file(s), please wait...</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>An unexpected error has occured while splitting the Cue Sheet!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Imported %1 track(s) from the Cue Sheet and skipped %2 track(s).</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Cue Sheet Completed</source>
<translation type="unfinished"></translation>
</message>
</context> </context>
<context> <context>
<name>CueSheetImport</name> <name>CueSheetImport</name>
@ -328,6 +344,14 @@
<source>Import Cue Sheet</source> <source>Import Cue Sheet</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Existing Source File</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Missing Source File (Tracks will be skipped!)</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source> Output Directory </source> <source> Output Directory </source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
@ -340,14 +364,6 @@
<source>Discard</source> <source>Discard</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Existing Source File</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Missing Source File (Tracks will be skipped!)</source>
<translation type="unfinished"></translation>
</message>
</context> </context>
<context> <context>
<name>CueSheetModel</name> <name>CueSheetModel</name>
@ -363,6 +379,10 @@
<source>Index</source> <source>Index</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Duration</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>File %1</source> <source>File %1</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
@ -379,10 +399,6 @@
<source>Unknown Title</source> <source>Unknown Title</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Duration</source>
<translation type="unfinished"></translation>
</message>
</context> </context>
<context> <context>
<name>DecoderRegistry</name> <name>DecoderRegistry</name>
@ -1037,6 +1053,10 @@
<source>Check for Beta Updates</source> <source>Check for Beta Updates</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Import Cue Sheet</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Adding file(s), please wait...</source> <source>Adding file(s), please wait...</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
@ -1485,6 +1505,14 @@
<source>The WMA Decoder notifications have been re-enabled.</source> <source>The WMA Decoder notifications have been re-enabled.</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Open Cue Sheet</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Cue Sheet File</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Beta Updates</source> <source>Beta Updates</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
@ -1521,18 +1549,6 @@
<source>The LameXP shell integration has been re-enabled.</source> <source>The LameXP shell integration has been re-enabled.</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Import Cue Sheet</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Open Cue Sheet</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Cue Sheet File</source>
<translation type="unfinished"></translation>
</message>
</context> </context>
<context> <context>
<name>MetaInfo</name> <name>MetaInfo</name>

View File

@ -243,145 +243,161 @@
<name>CueImportDialog</name> <name>CueImportDialog</name>
<message> <message>
<source>Import Cue Sheet</source> <source>Import Cue Sheet</source>
<translation type="unfinished"></translation> <translation>Cuehseet Assistent</translation>
</message> </message>
<message> <message>
<source>The following Cue Sheet will be split and imported into LameXP.</source> <source>The following Cue Sheet will be split and imported into LameXP.</source>
<translation type="unfinished"></translation> <translation>Das folgende Cuesheet wird aufgeteilt und in LameXP importiert.</translation>
</message> </message>
<message> <message>
<source>Loading Cue Sheet file, please be patient...</source> <source>Loading Cue Sheet file, please be patient...</source>
<translation type="unfinished"></translation> <translation>Cuesheet Datei wird geladen, bitte warten...</translation>
</message> </message>
<message> <message>
<source>An unknown error has occured!</source> <source>An unknown error has occured!</source>
<translation type="unfinished"></translation> <translation>Ein unbekannter Fehler ist aufgetreten!</translation>
</message> </message>
<message> <message>
<source>Failed to load the Cue Sheet file:</source> <source>Failed to load the Cue Sheet file:</source>
<translation type="unfinished"></translation> <translation>Fehler beim Laden der Cuesheet Datei:</translation>
</message> </message>
<message> <message>
<source>Cue Sheet Error</source> <source>Cue Sheet Error</source>
<translation type="unfinished"></translation> <translation>Cuesheet Fehler</translation>
</message> </message>
<message> <message>
<source>The specified file could not be found!</source> <source>The specified file could not be found!</source>
<translation type="unfinished"></translation> <translation>Die angegebene Datei konnte nicht gefunden werden!</translation>
</message> </message>
<message> <message>
<source>The file could not be opened for reading. Make sure you have the required rights!</source> <source>The file could not be opened for reading. Make sure you have the required rights!</source>
<translation type="unfinished"></translation> <translation>Datei kann nicht geöffnet werden. Stellen Sie sicher, dass Sie über die notwendigen Rechte verfügen!</translation>
</message> </message>
<message> <message>
<source>The provided file does not look like a valid Cue Sheet disc image file!</source> <source>The provided file does not look like a valid Cue Sheet disc image file!</source>
<translation type="unfinished"></translation> <translation>Die angegebene Datei scheint keine gültige Cuesheet Datei zu sein!</translation>
</message> </message>
<message> <message>
<source>Could not find any supported audio track in the Cue Sheet image!</source> <source>Could not find any supported audio track in the Cue Sheet image!</source>
<translation type="unfinished"></translation> <translation>Es konnte kein unterstützter Audio-Track im Cuesheet gefunden werden!</translation>
</message> </message>
<message> <message>
<source>Note that LameXP can not handle &quot;binary&quot; Cue Sheet images.</source> <source>Note that LameXP can not handle &quot;binary&quot; Cue Sheet images.</source>
<translation type="unfinished"></translation> <translation>Beachten Sie, dass LameXP keine &quot;binären&quot; Cuesheets unterstützt.</translation>
</message> </message>
<message> <message>
<source>The selected Cue Sheet file contains inconsistent information. Take care!</source> <source>The selected Cue Sheet file contains inconsistent information. Take care!</source>
<translation type="unfinished"></translation> <translation>Das Cuesheet enthält inkonsistente Informationen. Bitte geben Sie Acht!</translation>
</message> </message>
<message> <message>
<source>Choose Output Directory</source> <source>Choose Output Directory</source>
<translation type="unfinished"></translation> <translation>Ausgabe-Verzeichnis auswählen</translation>
</message> </message>
<message> <message>
<source>LameXP</source> <source>LameXP</source>
<translation type="unfinished">LameXP</translation> <translation>LameXP</translation>
</message> </message>
<message> <message>
<source>Error: The selected output directory is not writable!</source> <source>Error: The selected output directory is not writable!</source>
<translation type="unfinished"></translation> <translation>Fehler: Im Ausgabe-Verzeichnis kann nicht geschrieben werden!</translation>
</message> </message>
<message> <message>
<source>Low Diskspace Warning</source> <source>Low Diskspace Warning</source>
<translation type="unfinished">Warnung: Wenig freier Festplattenspeicher</translation> <translation>Warnung: Wenig freier Festplattenspeicher</translation>
</message> </message>
<message> <message>
<source>There are less than %1 GB of free diskspace available in the selected output directory.</source> <source>There are less than %1 GB of free diskspace available in the selected output directory.</source>
<translation type="unfinished"></translation> <translation>Es sind weniger als %1 GB freier Speicherplatz im Ausgabe-Verzeichnis verfügbar.</translation>
</message> </message>
<message> <message>
<source>It is highly recommend to free up more diskspace before proceeding with the import!</source> <source>It is highly recommend to free up more diskspace before proceeding with the import!</source>
<translation type="unfinished"></translation> <translation>Es wird dringend empfohlen, vor dem Fortfahren mehr Speicherplatz freizugeben!</translation>
</message> </message>
<message> <message>
<source>Analyzing file(s), please wait...</source> <source>Analyzing file(s), please wait...</source>
<translation type="unfinished"></translation> <translation>Analysiere Dateien, bitte warten...</translation>
</message> </message>
<message> <message>
<source>Splitting file(s), please wait...</source> <source>Splitting file(s), please wait...</source>
<translation type="unfinished"></translation> <translation>Dateien werden aufgeteilt, bitte warten...</translation>
</message>
<message>
<source>Error: The selected output directory could not be created!</source>
<translation>Fehler: Das Ausgabe-Verzeichnis konnte nicht erstellt werden!</translation>
</message>
<message>
<source>An unexpected error has occured while splitting the Cue Sheet!</source>
<translation>Beim Aufteilen des Cuesheets is ein unerwarteter Fehler aufgetreten!</translation>
</message>
<message>
<source>Imported %1 track(s) from the Cue Sheet and skipped %2 track(s).</source>
<translation>%1 Datei(ein) wurden aus dem Cuesheet importiert und %2 Datei(en) übersprungen.</translation>
</message>
<message>
<source>Cue Sheet Completed</source>
<translation>Cuesheet Abgeschlossen</translation>
</message> </message>
</context> </context>
<context> <context>
<name>CueSheetImport</name> <name>CueSheetImport</name>
<message> <message>
<source>Import Cue Sheet</source> <source>Import Cue Sheet</source>
<translation type="unfinished"></translation> <translation>Cuesheet Importieren</translation>
</message> </message>
<message> <message>
<source> Output Directory </source> <source> Output Directory </source>
<translation type="unfinished"></translation> <translation> Ausgabe-Verzeichnis </translation>
</message> </message>
<message> <message>
<source>Browse...</source> <source>Browse...</source>
<translation type="unfinished">Durchsuchen...</translation> <translation>Durchsuchen...</translation>
</message> </message>
<message> <message>
<source>Discard</source> <source>Discard</source>
<translation type="unfinished">Schließen</translation> <translation>Schließen</translation>
</message> </message>
<message> <message>
<source>Existing Source File</source> <source>Existing Source File</source>
<translation type="unfinished"></translation> <translation>Existierende Quelldatei</translation>
</message> </message>
<message> <message>
<source>Missing Source File (Tracks will be skipped!)</source> <source>Missing Source File (Tracks will be skipped!)</source>
<translation type="unfinished"></translation> <translation>Fehlende Quelldatei (Tracks werden übersprungen!)</translation>
</message> </message>
</context> </context>
<context> <context>
<name>CueSheetModel</name> <name>CueSheetModel</name>
<message> <message>
<source>No.</source> <source>No.</source>
<translation type="unfinished"></translation> <translation>Nr.</translation>
</message> </message>
<message> <message>
<source>File / Track</source> <source>File / Track</source>
<translation type="unfinished"></translation> <translation>Datei / Track</translation>
</message> </message>
<message> <message>
<source>Index</source> <source>Index</source>
<translation type="unfinished"></translation> <translation>Index</translation>
</message> </message>
<message> <message>
<source>File %1</source> <source>File %1</source>
<translation type="unfinished"></translation> <translation>Datei %1</translation>
</message> </message>
<message> <message>
<source>Track %1</source> <source>Track %1</source>
<translation type="unfinished"></translation> <translation>Titel %1</translation>
</message> </message>
<message> <message>
<source>Unknown Artist</source> <source>Unknown Artist</source>
<translation type="unfinished"></translation> <translation>Unbekannter Künstler</translation>
</message> </message>
<message> <message>
<source>Unknown Title</source> <source>Unknown Title</source>
<translation type="unfinished"></translation> <translation>Unbekannter Titel</translation>
</message> </message>
<message> <message>
<source>Duration</source> <source>Duration</source>
<translation type="unfinished">Dauer</translation> <translation>Dauer</translation>
</message> </message>
</context> </context>
<context> <context>
@ -1524,15 +1540,15 @@
</message> </message>
<message> <message>
<source>Import Cue Sheet</source> <source>Import Cue Sheet</source>
<translation type="unfinished"></translation> <translation>Cuesheet importieren</translation>
</message> </message>
<message> <message>
<source>Open Cue Sheet</source> <source>Open Cue Sheet</source>
<translation type="unfinished"></translation> <translation>Cuesheet öffnen</translation>
</message> </message>
<message> <message>
<source>Cue Sheet File</source> <source>Cue Sheet File</source>
<translation type="unfinished"></translation> <translation>Cuesheet Datei</translation>
</message> </message>
</context> </context>
<context> <context>

View File

@ -321,6 +321,22 @@
<source>Splitting file(s), please wait...</source> <source>Splitting file(s), please wait...</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Error: The selected output directory could not be created!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>An unexpected error has occured while splitting the Cue Sheet!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Imported %1 track(s) from the Cue Sheet and skipped %2 track(s).</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Cue Sheet Completed</source>
<translation type="unfinished"></translation>
</message>
</context> </context>
<context> <context>
<name>CueSheetImport</name> <name>CueSheetImport</name>

View File

@ -325,6 +325,22 @@
<source>Splitting file(s), please wait...</source> <source>Splitting file(s), please wait...</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Error: The selected output directory could not be created!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>An unexpected error has occured while splitting the Cue Sheet!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Imported %1 track(s) from the Cue Sheet and skipped %2 track(s).</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Cue Sheet Completed</source>
<translation type="unfinished"></translation>
</message>
</context> </context>
<context> <context>
<name>CueSheetImport</name> <name>CueSheetImport</name>

View File

@ -321,6 +321,22 @@
<source>Splitting file(s), please wait...</source> <source>Splitting file(s), please wait...</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Error: The selected output directory could not be created!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>An unexpected error has occured while splitting the Cue Sheet!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Imported %1 track(s) from the Cue Sheet and skipped %2 track(s).</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Cue Sheet Completed</source>
<translation type="unfinished"></translation>
</message>
</context> </context>
<context> <context>
<name>CueSheetImport</name> <name>CueSheetImport</name>

View File

@ -321,6 +321,22 @@
<source>Splitting file(s), please wait...</source> <source>Splitting file(s), please wait...</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Error: The selected output directory could not be created!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>An unexpected error has occured while splitting the Cue Sheet!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Imported %1 track(s) from the Cue Sheet and skipped %2 track(s).</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Cue Sheet Completed</source>
<translation type="unfinished"></translation>
</message>
</context> </context>
<context> <context>
<name>CueSheetImport</name> <name>CueSheetImport</name>

View File

@ -321,6 +321,22 @@
<source>Splitting file(s), please wait...</source> <source>Splitting file(s), please wait...</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Error: The selected output directory could not be created!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>An unexpected error has occured while splitting the Cue Sheet!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Imported %1 track(s) from the Cue Sheet and skipped %2 track(s).</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Cue Sheet Completed</source>
<translation type="unfinished"></translation>
</message>
</context> </context>
<context> <context>
<name>CueSheetImport</name> <name>CueSheetImport</name>

View File

@ -321,6 +321,22 @@
<source>Splitting file(s), please wait...</source> <source>Splitting file(s), please wait...</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Error: The selected output directory could not be created!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>An unexpected error has occured while splitting the Cue Sheet!</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Imported %1 track(s) from the Cue Sheet and skipped %2 track(s).</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Cue Sheet Completed</source>
<translation type="unfinished"></translation>
</message>
</context> </context>
<context> <context>
<name>CueSheetImport</name> <name>CueSheetImport</name>

View File

@ -1,3 +1,4 @@
..\..\gui\CueSheetImport.ui
..\..\gui\DropBox.ui ..\..\gui\DropBox.ui
..\..\gui\LogViewDialog.ui ..\..\gui\LogViewDialog.ui
..\..\gui\MainWindow.ui ..\..\gui\MainWindow.ui
@ -23,6 +24,7 @@
..\..\src\Decoder_WavPack.cpp ..\..\src\Decoder_WavPack.cpp
..\..\src\Decoder_WMA.cpp ..\..\src\Decoder_WMA.cpp
..\..\src\Dialog_About.cpp ..\..\src\Dialog_About.cpp
..\..\src\Dialog_CueImport.cpp
..\..\src\Dialog_DropBox.cpp ..\..\src\Dialog_DropBox.cpp
..\..\src\Dialog_LogView.cpp ..\..\src\Dialog_LogView.cpp
..\..\src\Dialog_MainWindow.cpp ..\..\src\Dialog_MainWindow.cpp
@ -49,6 +51,7 @@
..\..\src\Main.cpp ..\..\src\Main.cpp
..\..\src\Model_Artwork.cpp ..\..\src\Model_Artwork.cpp
..\..\src\Model_AudioFile.cpp ..\..\src\Model_AudioFile.cpp
..\..\src\Model_CueSheet.cpp
..\..\src\Model_FileList.cpp ..\..\src\Model_FileList.cpp
..\..\src\Model_FileSystem.cpp ..\..\src\Model_FileSystem.cpp
..\..\src\Model_MetaInfo.cpp ..\..\src\Model_MetaInfo.cpp
@ -57,6 +60,7 @@
..\..\src\PlaylistImporter.cpp ..\..\src\PlaylistImporter.cpp
..\..\src\Registry_Decoder.cpp ..\..\src\Registry_Decoder.cpp
..\..\src\ShellIntegration.cpp ..\..\src\ShellIntegration.cpp
..\..\src\Thread_CueSplitter.cpp
..\..\src\Thread_DiskObserver.cpp ..\..\src\Thread_DiskObserver.cpp
..\..\src\Thread_FileAnalyzer.cpp ..\..\src\Thread_FileAnalyzer.cpp
..\..\src\Thread_Initialization.cpp ..\..\src\Thread_Initialization.cpp
@ -83,6 +87,7 @@
..\..\src\Decoder_WavPack.h ..\..\src\Decoder_WavPack.h
..\..\src\Decoder_WMA.h ..\..\src\Decoder_WMA.h
..\..\src\Dialog_About.h ..\..\src\Dialog_About.h
..\..\src\Dialog_CueImport.h
..\..\src\Dialog_DropBox.h ..\..\src\Dialog_DropBox.h
..\..\src\Dialog_LogView.h ..\..\src\Dialog_LogView.h
..\..\src\Dialog_MainWindow.h ..\..\src\Dialog_MainWindow.h
@ -108,6 +113,7 @@
..\..\src\LockedFile.h ..\..\src\LockedFile.h
..\..\src\Model_Artwork.h ..\..\src\Model_Artwork.h
..\..\src\Model_AudioFile.h ..\..\src\Model_AudioFile.h
..\..\src\Model_CueSheet.h
..\..\src\Model_FileList.h ..\..\src\Model_FileList.h
..\..\src\Model_FileSystem.h ..\..\src\Model_FileSystem.h
..\..\src\Model_MetaInfo.h ..\..\src\Model_MetaInfo.h
@ -118,6 +124,7 @@
..\..\src\Resource.h ..\..\src\Resource.h
..\..\src\ShellIntegration.h ..\..\src\ShellIntegration.h
..\..\src\Targetver.h ..\..\src\Targetver.h
..\..\src\Thread_CueSplitter.h
..\..\src\Thread_DiskObserver.h ..\..\src\Thread_DiskObserver.h
..\..\src\Thread_FileAnalyzer.h ..\..\src\Thread_FileAnalyzer.h
..\..\src\Thread_Initialization.h ..\..\src\Thread_Initialization.h

Binary file not shown.

View File

@ -30,7 +30,7 @@
#define VER_LAMEXP_MINOR_LO 2 #define VER_LAMEXP_MINOR_LO 2
#define VER_LAMEXP_TYPE Alpha #define VER_LAMEXP_TYPE Alpha
#define VER_LAMEXP_PATCH 15 #define VER_LAMEXP_PATCH 15
#define VER_LAMEXP_BUILD 520 #define VER_LAMEXP_BUILD 523
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
// Tools versions // Tools versions

View File

@ -101,12 +101,7 @@ int CueImportDialog::exec(void)
progress->show(tr("Loading Cue Sheet file, please be patient...")); progress->show(tr("Loading Cue Sheet file, please be patient..."));
QFileInfo cueFileInfo(m_cueFileName); QFileInfo cueFileInfo(m_cueFileName);
QDir outputDir(cueFileInfo.canonicalPath()); if(!cueFileInfo.exists() || !cueFileInfo.isFile())
m_outputDir = outputDir.canonicalPath();
setWindowTitle(QString("%1: %2").arg(windowTitle().split(":", QString::SkipEmptyParts).first().trimmed(), cueFileInfo.fileName()));
if(!cueFileInfo.exists() || !cueFileInfo.isFile() || m_outputDir.isEmpty())
{ {
QString text = QString("<nobr>%1</nobr><br><nobr>%2</nobr><br><br><nobr>%3</nobr>").arg(tr("Failed to load the Cue Sheet file:"), QDir::toNativeSeparators(m_cueFileName), tr("The specified file could not be found!")).replace("-", "&minus;"); QString text = QString("<nobr>%1</nobr><br><nobr>%2</nobr><br><br><nobr>%3</nobr>").arg(tr("Failed to load the Cue Sheet file:"), QDir::toNativeSeparators(m_cueFileName), tr("The specified file could not be found!")).replace("-", "&minus;");
QMessageBox::warning(progress, tr("Cue Sheet Error"), text); QMessageBox::warning(progress, tr("Cue Sheet Error"), text);
@ -115,11 +110,8 @@ int CueImportDialog::exec(void)
return CueSheetModel::ErrorIOFailure; return CueSheetModel::ErrorIOFailure;
} }
outputDir.mkdir(cueFileInfo.completeBaseName()); m_outputDir = QString("%1/%2").arg(cueFileInfo.canonicalPath(), cueFileInfo.completeBaseName());
if(outputDir.cd(cueFileInfo.completeBaseName())) setWindowTitle(QString("%1: %2").arg(windowTitle().split(":", QString::SkipEmptyParts).first().trimmed(), cueFileInfo.fileName()));
{
m_outputDir = outputDir.canonicalPath();
}
int iResult = m_model->loadCueSheet(m_cueFileName, QApplication::instance()); int iResult = m_model->loadCueSheet(m_cueFileName, QApplication::instance());
if(iResult != CueSheetModel::ErrorSuccess) if(iResult != CueSheetModel::ErrorSuccess)
@ -176,6 +168,14 @@ void CueImportDialog::importButtonClicked(void)
static const __int64 minimumFreeDiskspaceMultiplier = 2i64; static const __int64 minimumFreeDiskspaceMultiplier = 2i64;
static const char *writeTestBuffer = "LAMEXP_WRITE_TEST"; static const char *writeTestBuffer = "LAMEXP_WRITE_TEST";
QDir outputDir(m_outputDir);
outputDir.mkpath(".");
if(!(outputDir.exists() && outputDir.isReadable()))
{
QMessageBox::warning(this, tr("LameXP"), QString("<nobr>%2</nobr>").arg(tr("Error: The selected output directory could not be created!")));
return;
}
QFile writeTest(QString("%1/~%2.txt").arg(m_outputDir, lamexp_rand_str())); QFile writeTest(QString("%1/~%2.txt").arg(m_outputDir, lamexp_rand_str()));
if(!(writeTest.open(QIODevice::ReadWrite) && (writeTest.write(writeTestBuffer) == strlen(writeTestBuffer)))) if(!(writeTest.open(QIODevice::ReadWrite) && (writeTest.write(writeTestBuffer) == strlen(writeTestBuffer))))
{ {
@ -247,7 +247,7 @@ void CueImportDialog::analyzeFiles(QStringList &files)
{ {
m_fileInfo.clear(); m_fileInfo.clear();
WorkingBanner *progress = new WorkingBanner(dynamic_cast<QWidget*>(parent())); WorkingBanner *progress = new WorkingBanner(this);
FileAnalyzer *analyzer = new FileAnalyzer(files); FileAnalyzer *analyzer = new FileAnalyzer(files);
connect(analyzer, SIGNAL(fileSelected(QString)), progress, SLOT(setText(QString)), Qt::QueuedConnection); connect(analyzer, SIGNAL(fileSelected(QString)), progress, SLOT(setText(QString)), Qt::QueuedConnection);
@ -260,12 +260,15 @@ void CueImportDialog::analyzeFiles(QStringList &files)
void CueImportDialog::splitFiles(void) void CueImportDialog::splitFiles(void)
{ {
int nTracksSkipped = 0;
WorkingBanner *progress = new WorkingBanner(this); WorkingBanner *progress = new WorkingBanner(this);
CueSplitter *splitter = new CueSplitter(m_outputDir, QFileInfo(m_cueFileName).completeBaseName().replace(".", " ").left(42).trimmed(), m_fileInfo); CueSplitter *splitter = new CueSplitter(m_outputDir, QFileInfo(m_cueFileName).completeBaseName().replace(".", " ").left(42).trimmed(), m_fileInfo);
splitter->setAlbumInfo(m_model->getAlbumPerformer(), m_model->getAlbumTitle());
connect(splitter, SIGNAL(fileSelected(QString)), progress, SLOT(setText(QString)), Qt::QueuedConnection); connect(splitter, SIGNAL(fileSelected(QString)), progress, SLOT(setText(QString)), Qt::QueuedConnection);
connect(splitter, SIGNAL(fileSplit(AudioFileModel)), m_fileList, SLOT(addFile(AudioFileModel)), Qt::QueuedConnection); connect(splitter, SIGNAL(fileSplit(AudioFileModel)), m_fileList, SLOT(addFile(AudioFileModel)), Qt::QueuedConnection);
int nFiles = m_model->getFileCount(); int nFiles = m_model->getFileCount();
for(int i = 0; i < nFiles; i++) for(int i = 0; i < nFiles; i++)
{ {
@ -282,6 +285,7 @@ void CueImportDialog::splitFiles(void)
AudioFileModel metaInfo(QString().sprintf("cue://File%02d/Track%02d", i, j)); AudioFileModel metaInfo(QString().sprintf("cue://File%02d/Track%02d", i, j));
metaInfo.setFileName(m_model->getTrackTitle(i, j)); metaInfo.setFileName(m_model->getTrackTitle(i, j));
metaInfo.setFileArtist(m_model->getTrackPerformer(i, j)); metaInfo.setFileArtist(m_model->getTrackPerformer(i, j));
metaInfo.setFilePosition(trackNo);
try try
{ {
@ -290,6 +294,7 @@ void CueImportDialog::splitFiles(void)
catch(char *err) catch(char *err)
{ {
qWarning("Failed to add track #%02d: %s", trackNo, err); qWarning("Failed to add track #%02d: %s", trackNo, err);
nTracksSkipped++;
} }
} }
} }
@ -297,6 +302,16 @@ void CueImportDialog::splitFiles(void)
progress->show(tr("Splitting file(s), please wait..."), splitter); progress->show(tr("Splitting file(s), please wait..."), splitter);
progress->close(); progress->close();
if(!splitter->getSuccess())
{
QMessageBox::warning(this, tr("Cue Sheet Error"), tr("An unexpected error has occured while splitting the Cue Sheet!"));
}
else
{
QString text = tr("Imported %1 track(s) from the Cue Sheet and skipped %2 track(s).").arg(QString::number(splitter->getTracksSuccess()), QString::number(splitter->getTracksSkipped() + nTracksSkipped));
QMessageBox::information(this, tr("Cue Sheet Completed"), text);
}
LAMEXP_DELETE(splitter); LAMEXP_DELETE(splitter);
LAMEXP_DELETE(progress); LAMEXP_DELETE(progress);
} }

View File

@ -96,6 +96,9 @@ private:
//////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////
CueSheetModel::CueSheetModel() CueSheetModel::CueSheetModel()
:
m_fileIcon(":/icons/music.png"),
m_trackIcon(":/icons/control_play_blue.png")
{ {
int trackNo = 0; int trackNo = 0;
@ -273,6 +276,22 @@ QVariant CueSheetModel::data(const QModelIndex &index, int role) const
return QDir::toNativeSeparators(trackPtr->parent()->fileName()); return QDir::toNativeSeparators(trackPtr->parent()->fileName());
} }
} }
else if(role == Qt::DecorationRole)
{
if(index.column() == 0)
{
CueSheetItem *item = reinterpret_cast<CueSheetItem*>(index.internalPointer());
if(dynamic_cast<CueSheetFile*>(item))
{
return m_fileIcon;
}
else if(dynamic_cast<CueSheetTrack*>(item))
{
return m_trackIcon;
}
}
}
else if(role == Qt::FontRole) else if(role == Qt::FontRole)
{ {
QFont font("Monospace"); QFont font("Monospace");
@ -456,8 +475,8 @@ int CueSheetModel::parseCueFile(QFile &cueFile, const QDir &baseDir, QCoreApplic
CueSheetFile *currentFile = NULL; CueSheetFile *currentFile = NULL;
CueSheetTrack *currentTrack = NULL; CueSheetTrack *currentTrack = NULL;
QString albumTitle; m_albumTitle.clear();
QString albumPerformer; m_albumPerformer.clear();
//Loop over the Cue Sheet until all lines were processed //Loop over the Cue Sheet until all lines were processed
for(int lines = 0; lines < INT_MAX; lines++) for(int lines = 0; lines < INT_MAX; lines++)
@ -487,8 +506,6 @@ int CueSheetModel::parseCueFile(QFile &cueFile, const QDir &baseDir, QCoreApplic
{ {
if(currentTrack->isValid()) if(currentTrack->isValid())
{ {
currentTrack->setTitle(albumTitle, true);
currentTrack->setPerformer(albumPerformer, true);
currentFile->addTrack(currentTrack); currentFile->addTrack(currentTrack);
currentTrack = NULL; currentTrack = NULL;
} }
@ -537,8 +554,6 @@ int CueSheetModel::parseCueFile(QFile &cueFile, const QDir &baseDir, QCoreApplic
{ {
if(currentTrack->isValid()) if(currentTrack->isValid())
{ {
currentTrack->setTitle(albumTitle, true);
currentTrack->setPerformer(albumPerformer, true);
currentFile->addTrack(currentTrack); currentFile->addTrack(currentTrack);
currentTrack = NULL; currentTrack = NULL;
} }
@ -585,7 +600,7 @@ int CueSheetModel::parseCueFile(QFile &cueFile, const QDir &baseDir, QCoreApplic
{ {
if(bPreamble) if(bPreamble)
{ {
albumTitle = rxTitle.cap(1); m_albumTitle = rxTitle.cap(1).simplified();
} }
else if(currentFile && currentTrack) else if(currentFile && currentTrack)
{ {
@ -600,7 +615,7 @@ int CueSheetModel::parseCueFile(QFile &cueFile, const QDir &baseDir, QCoreApplic
{ {
if(bPreamble) if(bPreamble)
{ {
albumPerformer = rxPerformer.cap(1); m_albumPerformer = rxPerformer.cap(1).simplified();
} }
else if(currentFile && currentTrack) else if(currentFile && currentTrack)
{ {
@ -618,8 +633,6 @@ int CueSheetModel::parseCueFile(QFile &cueFile, const QDir &baseDir, QCoreApplic
{ {
if(currentTrack->isValid()) if(currentTrack->isValid())
{ {
currentTrack->setTitle(albumTitle, true);
currentTrack->setPerformer(albumPerformer, true);
currentFile->addTrack(currentTrack); currentFile->addTrack(currentTrack);
currentTrack = NULL; currentTrack = NULL;
} }
@ -749,7 +762,7 @@ QString CueSheetModel::indexToString(const double index) const
} }
else else
{ {
int temp = static_cast<int>(index * 100.0); int temp = static_cast<int>(floor(0.5 + (index * 100.0)));
int msec = temp % 100; int msec = temp % 100;
int secs = temp / 100; int secs = temp / 100;

View File

@ -65,6 +65,8 @@ public:
void getTrackIndex(int fileIndex, int trackIndex, double *startIndex, double *duration); void getTrackIndex(int fileIndex, int trackIndex, double *startIndex, double *duration);
QString getTrackPerformer(int fileIndex, int trackIndex); QString getTrackPerformer(int fileIndex, int trackIndex);
QString getTrackTitle(int fileIndex, int trackIndex); QString getTrackTitle(int fileIndex, int trackIndex);
QString getAlbumPerformer(void) { return m_albumPerformer; }
QString getAlbumTitle(void) { return m_albumTitle; }
//Cue Sheet functions //Cue Sheet functions
int loadCueSheet(const QString &cueFile, QCoreApplication *application = NULL); int loadCueSheet(const QString &cueFile, QCoreApplication *application = NULL);
@ -73,5 +75,11 @@ private:
int parseCueFile(QFile &cueFile, const QDir &baseDir, QCoreApplication *application); int parseCueFile(QFile &cueFile, const QDir &baseDir, QCoreApplication *application);
double parseTimeIndex(const QString &index); double parseTimeIndex(const QString &index);
QString indexToString(const double index) const; QString indexToString(const double index) const;
QList<CueSheetFile*> m_files; QList<CueSheetFile*> m_files;
QString m_albumTitle;
QString m_albumPerformer;
const QIcon m_fileIcon;
const QIcon m_trackIcon;
}; };

View File

@ -50,6 +50,9 @@ CueSplitter::CueSplitter(const QString &outputDir, const QString &baseName, cons
qFatal("Invalid path to SoX binary. Tool not initialized properly."); qFatal("Invalid path to SoX binary. Tool not initialized properly.");
} }
m_albumPerformer.clear();
m_albumTitle.clear();
qDebug("\n[CueSplitter::CueSplitter]"); qDebug("\n[CueSplitter::CueSplitter]");
int nInputFiles = inputFiles.count(); int nInputFiles = inputFiles.count();
@ -70,6 +73,8 @@ CueSplitter::CueSplitter(const QString &outputDir, const QString &baseName, cons
void CueSplitter::run() void CueSplitter::run()
{ {
m_bSuccess = false; m_bSuccess = false;
m_nTracksSuccess = 0;
m_nTracksSkipped = 0;
m_abortFlag = false; m_abortFlag = false;
int nTracks = min(min(min(m_trackFile.count(), m_trackNo.count()), min(m_trackOffset.count(), m_trackLength.count())), m_trackMetaInfo.count()); int nTracks = min(min(min(m_trackFile.count(), m_trackNo.count()), min(m_trackOffset.count(), m_trackLength.count())), m_trackMetaInfo.count());
@ -113,6 +118,12 @@ void CueSplitter::addTrack(const int trackNo, const QString &file, const double
} }
} }
void CueSplitter::setAlbumInfo(const QString &performer, const QString &title)
{
if(!performer.isEmpty()) m_albumPerformer = performer;
if(!title.isEmpty()) m_albumTitle = title;
}
//////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////
// Privtae Functions // Privtae Functions
//////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////
@ -125,13 +136,13 @@ void CueSplitter::splitFile(const QString &output, const int trackNo, const QStr
qDebug("Length: %f", length); qDebug("Length: %f", length);
qDebug("Artist: <%s>", metaInfo.fileArtist().toUtf8().constData()); qDebug("Artist: <%s>", metaInfo.fileArtist().toUtf8().constData());
qDebug("Title: <%s>", metaInfo.fileName().toUtf8().constData()); qDebug("Title: <%s>", metaInfo.fileName().toUtf8().constData());
QRegExp regExp("In:(\\d+)(\\.\\d+)*%");
QString baseName = QFileInfo(output).fileName(); QString baseName = QFileInfo(output).fileName();
if(!m_inputFiles.contains(file)) if(!m_inputFiles.contains(file))
{ {
qWarning("Unknown input file, skipping!"); qWarning("Unknown input file, skipping!");
m_nTracksSkipped++;
return; return;
} }
@ -139,22 +150,51 @@ void CueSplitter::splitFile(const QString &output, const int trackNo, const QStr
if(inputFileInfo.formatContainerType().compare("Wave", Qt::CaseInsensitive) || inputFileInfo.formatAudioType().compare("PCM", Qt::CaseInsensitive)) if(inputFileInfo.formatContainerType().compare("Wave", Qt::CaseInsensitive) || inputFileInfo.formatAudioType().compare("PCM", Qt::CaseInsensitive))
{ {
qWarning("Sorry, only Wave/PCM files are supported at this time!"); qWarning("Sorry, only Wave/PCM files are supported at this time!");
m_nTracksSkipped++;
return; return;
} }
AudioFileModel outFileInfo(metaInfo);
outFileInfo.setFilePath(output);
outFileInfo.setFormatContainerType(inputFileInfo.formatContainerType());
outFileInfo.setFormatAudioType(inputFileInfo.formatAudioType());
if(length != std::numeric_limits<double>::infinity())
{
outFileInfo.setFileDuration(static_cast<unsigned int>(abs(length)));
}
if(!m_albumTitle.isEmpty())
{
outFileInfo.setFileAlbum(m_albumTitle);
}
if(!m_albumPerformer.isEmpty() && outFileInfo.fileArtist().isEmpty())
{
outFileInfo.setFileArtist(m_albumPerformer);
}
QStringList args; QStringList args;
args << "-S" << "-V3"; args << "-S" << "-V3";
args << "--guard" << "--temp" << "."; args << "--guard" << "--temp" << ".";
args << QDir::toNativeSeparators(file); args << QDir::toNativeSeparators(file);
args << QDir::toNativeSeparators(output); args << QDir::toNativeSeparators(output);
args << "trim";
args << indexToString(offset);
if((length != std::numeric_limits<double>::quiet_NaN()) && (length != std::numeric_limits<double>::infinity())) if(offset != 0.0 || length != std::numeric_limits<double>::infinity())
{ {
args << indexToString(length); args << "trim";
args << indexToString(offset);
if((length != std::numeric_limits<double>::quiet_NaN()) && (length != std::numeric_limits<double>::infinity()))
{
args << indexToString(length);
}
} }
QRegExp rxProgress("In:(\\d+)(\\.\\d+)*%", Qt::CaseInsensitive);
QRegExp rxChannels("Channels\\s*:\\s*(\\d+)", Qt::CaseInsensitive);
QRegExp rxSamplerate("Sample Rate\\s*:\\s*(\\d+)", Qt::CaseInsensitive);
QRegExp rxPrecision("Precision\\s*:\\s*(\\d+)-bit", Qt::CaseInsensitive);
QRegExp rxDuration("Duration\\s*:\\s*(\\d\\d):(\\d\\d):(\\d\\d).(\\d\\d)", Qt::CaseInsensitive);
QProcess process; QProcess process;
process.setProcessChannelMode(QProcess::MergedChannels); process.setProcessChannelMode(QProcess::MergedChannels);
process.setReadChannel(QProcess::StandardOutput); process.setReadChannel(QProcess::StandardOutput);
@ -167,6 +207,7 @@ void CueSplitter::splitFile(const QString &output, const int trackNo, const QStr
qWarning("Error message: \"%s\"\n", process.errorString().toLatin1().constData()); qWarning("Error message: \"%s\"\n", process.errorString().toLatin1().constData());
process.kill(); process.kill();
process.waitForFinished(-1); process.waitForFinished(-1);
m_nTracksSkipped++;
return; return;
} }
@ -188,18 +229,58 @@ void CueSplitter::splitFile(const QString &output, const int trackNo, const QStr
{ {
QByteArray line = process.readLine(); QByteArray line = process.readLine();
QString text = QString::fromUtf8(line.constData()).simplified(); QString text = QString::fromUtf8(line.constData()).simplified();
if(regExp.lastIndexIn(text) >= 0) if(rxProgress.lastIndexIn(text) >= 0)
{ {
bool ok = false; bool ok = false;
int progress = regExp.cap(1).toInt(&ok); int progress = rxProgress.cap(1).toInt(&ok);
if(ok) if(ok)
{ {
emit fileSelected(QString("%1 [%2%]").arg(baseName, QString::number(progress))); emit fileSelected(QString("%1 [%2%]").arg(baseName, QString::number(progress)));
} }
} }
else if(rxChannels.lastIndexIn(text) >= 0)
{
bool ok = false;
unsigned int channels = rxChannels.cap(1).toUInt(&ok);
if(ok) outFileInfo.setFormatAudioChannels(channels);
}
else if(rxSamplerate.lastIndexIn(text) >= 0)
{
bool ok = false;
unsigned int samplerate = rxSamplerate.cap(1).toUInt(&ok);
if(ok) outFileInfo.setFormatAudioSamplerate(samplerate);
}
else if(rxPrecision.lastIndexIn(text) >= 0)
{
bool ok = false;
unsigned int precision = rxPrecision.cap(1).toUInt(&ok);
if(ok) outFileInfo.setFormatAudioBitdepth(precision);
}
else if(rxDuration.lastIndexIn(text) >= 0)
{
bool ok1 = false, ok2 = false, ok3 = false;
unsigned int hh = rxDuration.cap(1).toUInt(&ok1);
unsigned int mm = rxDuration.cap(2).toUInt(&ok2);
unsigned int ss = rxDuration.cap(3).toUInt(&ok3);
if(ok1 && ok2 && ok3)
{
unsigned intputLen = (hh * 3600) + (mm * 60) + ss;
if(length == std::numeric_limits<double>::infinity())
{
qDebug("Duration updated from SoX info!");
outFileInfo.setFileDuration(max(0, intputLen - static_cast<unsigned int>(floor(offset + 0.5))));
}
else
{
unsigned int trackEnd = static_cast<unsigned int>(floor(offset + 0.5)) + static_cast<unsigned int>(floor(length + 0.5));
if(trackEnd > intputLen) qWarning("Track is out of bounds: End of track exceeds input file duration!");
}
}
}
} }
} }
process.waitForFinished();
if(process.state() != QProcess::NotRunning) if(process.state() != QProcess::NotRunning)
{ {
process.kill(); process.kill();
@ -208,16 +289,13 @@ void CueSplitter::splitFile(const QString &output, const int trackNo, const QStr
if(process.exitStatus() != QProcess::NormalExit || QFileInfo(output).size() == 0) if(process.exitStatus() != QProcess::NormalExit || QFileInfo(output).size() == 0)
{ {
qWarning("Splitting has failed!"); qWarning("Splitting has failed !!!");
m_nTracksSkipped++;
return; return;
} }
AudioFileModel outFileInfo(metaInfo);
outFileInfo.setFilePath(output);
outFileInfo.setFormatContainerType(inputFileInfo.formatContainerType());
outFileInfo.setFormatAudioType(inputFileInfo.formatAudioType());
outFileInfo.setFileDuration(static_cast<unsigned int>(abs(length)));
emit fileSplit(outFileInfo); emit fileSplit(outFileInfo);
m_nTracksSuccess++;
} }
QString CueSplitter::indexToString(const double index) const QString CueSplitter::indexToString(const double index) const
@ -227,7 +305,7 @@ QString CueSplitter::indexToString(const double index) const
return QString(); return QString();
} }
int temp = static_cast<int>(index * 1000.0); int temp = static_cast<int>(floor(0.5 + (index * 1000.0)));
int msec = temp % 1000; int msec = temp % 1000;
int secs = temp / 1000; int secs = temp / 1000;

View File

@ -42,7 +42,10 @@ public:
CueSplitter(const QString &outputDir, const QString &baseName, const QList<AudioFileModel> &inputFiles); CueSplitter(const QString &outputDir, const QString &baseName, const QList<AudioFileModel> &inputFiles);
void run(); void run();
bool getSuccess(void) { return !isRunning() && m_bSuccess; } bool getSuccess(void) { return !isRunning() && m_bSuccess; }
unsigned int getTracksSuccess(void) { return m_nTracksSuccess; }
unsigned int getTracksSkipped(void) { return m_nTracksSkipped; }
void addTrack(const int trackNo, const QString &file, const double offset, const double length, const AudioFileModel &metaInfo); void addTrack(const int trackNo, const QString &file, const double offset, const double length, const AudioFileModel &metaInfo);
void setAlbumInfo(const QString &performer, const QString &title);
signals: signals:
void fileSelected(const QString &fileName); void fileSelected(const QString &fileName);
@ -55,9 +58,13 @@ private:
const QString m_soxBin; const QString m_soxBin;
const QString m_outputDir; const QString m_outputDir;
const QString m_baseName; const QString m_baseName;
unsigned int m_nTracksSuccess;
unsigned int m_nTracksSkipped;
bool m_bSuccess; bool m_bSuccess;
volatile bool m_abortFlag; volatile bool m_abortFlag;
QString m_albumTitle;
QString m_albumPerformer;
QMap<QString,AudioFileModel> m_inputFiles; QMap<QString,AudioFileModel> m_inputFiles;
QList<QString> m_trackFile; QList<QString> m_trackFile;
QList<int> m_trackNo; QList<int> m_trackNo;