I’ll begin by saying that I love Native Instruments, and software and hardware that they make. Not all of it is a hit, but overall, the company is definitely one of the undisputed leaders and innovators in the Digital Audio space. I own Komplete versions 2 to 10, Traktor S4, S5, F1, Kore2 and a few others.
Tested with Traktor 2.6.5 on Windows 7 x64 Ultimate: Go to Traktor's preferences and check 'Analyze news imported tracks'. Then in Traktor's browsing window, go the folder you want to analyze and right-click 'Import to Collection'. It will analyze all tracks contained in this folder including its subfolders (and recursively). TRAKTOR creates a backup of your Track Collection each time you close the program. TRAKTOR labels these backups with the precise date and time of their creation. Follow the below steps to import a backup of your Track Collection to TRAKTOR PRO 2: Right-click on the Track Collection in the Browser-tree and choose Import another Collection. What I tried to do instead was to do a backup of my entire collection and upload it into my new computer, but when I went to look at the outcome of this backup, I noticed the audio files all come with this weird code with them, like so:0FF2772C&ME - The Rapture Pt.II (Original.aiff or 0B934EF5aaaron - tales of creation (origin.aiff. Information about collection work (songs added or deleted and playlists created during a session) will be lost if Traktor crashes – so you’ll need to use the “Save Collection” (see below) command to create a manual save function. First, don’t get too afraid: Traktor is a remarkably stable program.
'Not a Rant' Rant
In the past I created albums using NI tools and plug-ins, some of which are available on iTunes, and as a disclosure — I’ve never pirated any of NI software by principle — being a software engineer, I was able to appreciate the colossal effort they’ve put into each and every synth I used.
Reality Strikes
That said, being a software developer I have also been continually amazed at how abysmal — specifically the file management interfaces are in NI products. With the CoreAudio™ plug-ins I can usually get around it, since I use Logic Pro X® as a DAW.
But nowhere is the file management shortcomings are more in-your-face-obvious, aggravating, and frustrating, than in their flagship DJ mixing product — Traktor DJ Pro.
It Should Have Been There Five Years Ago
Traktor has been around for quite a few years now, and the same complaints I had five years ago, are still valid today. And what I want is not really rocket science, no, what I want is complete basics.
Hopefully someone from NI will read this blog post, and add these feature requests that should have been there from the beginning to their list. And if and when Traktor comes out with some of these features implemented, I promise to go back and update this post:
Simple UNDO functionality when working with Playlists?
Single key DELETE of a track from a playlist? If I did it wrong, I can always undo. Or can I?
Key binding. How about map Cmd-D to delete from a collection + disk?
How about copy a tree of playlists and then paste it elsewhere?
What about 'De-Duplicate All Playlists' under a given root node?
Or, playlist properties, such as 'this playlist should never have duplicates, so if I add one — ignore it!'
What about automatically finding and updating file locations (if the files move) using Spotlight?
Or, show play list on another display while I DJ
Etc… etc… etc.
Instead of this, you are supposed to sit their with your mouse and organize your tracks by looking at a 15px tall line of text. Thank God for the Ctrl-Scroll feature on the Mac. Oh, that’s right, they did make the line height configurable in the later versions of Traktor. But still, you can’t hit Delete key to delete (without a stupid confirmation, and with a no-brainer Undo option) a track from a playlist! In 2016! I don’t have enough exclamation points to emphasize this one.
But that’s not even all. In addition to these basic things we’ve come to expect from a well designed (from UX-standpoint) modern software, there are just glaring bugs like the one I will try to address in this blog post.
It hit me earlier today, and feeling fed up with Traktor’s misbehavior with file management for years, I decided to finally take it to the Interwebs, and help fellow Traktorians, abused daily by this software in all so many nasty ways, to heal maybe just some of their PTSD-related nightmares.
Ok, Perhaps it IS a Rant
I mean, honestly, I could rant about how absolutely abysmal Traktor’s file management is for a long time, but it would get boring fast. Instead of a rant, I’ll just make a short allegorical side note that’s barely visible on this blog, and not at all emphasized. Feel free to skip if you are in a hurry.
Dear Traktor. If you and are were to get married, I would parade you like a trophy wife. You look gorgeous. You are the envy of the town. Your ability to mix drinks is beyond imaginable. Your effects are from the future, and your style pushes the boundary of what’s possible today.
And so why, why is it that in the bedroom you are one lousy celibate prude? Why is it that you won’t push the boundary of what’s possible there too? When I ask you to import a collection that you yourself, just a few seconds ago saved to disk… Why!!! Do you give me the dreaded 'Could Not Read Collection/Playlist File' error? Wasn’t it you damn yourself who just created that file to begin with? Wasn’t that you who used ugly caps to write nasty XML tags into the file that makes even the ugliest formats look pretty by comparison?
So here I am, calling on you, Traktor-wife, to go and train with some kinky clan in San Francisco, and finally learn how to manage files easily, quickly, cleanly, repeatedly, consistently, how to automatically detect that the hard-drive’s name has changed and just remap the top folder without invalidating the entire collection! How hard is that? Open source your file management software, and the community will fix it in a weekend. Who, am I kidding, in an hour.
What if I move a folder? Rename my hard disk? Move to another computer? Oh God, no no no, all of that breaks Traktor! Rename back, quick! Oh wait, but the collection file is already saved and overwritten, and all my playlists are goooooone! Fuuuuuuuuuck!
Anyway, you get the point. I guess that was a bit of a rant after all :) With that out of the way, time to address the elephant in the room.
Problem: 'Could Not Read Collection/Playlist file'
This shows up very briefly in red when you open Traktor and voila — the playlists are empty.
Diagnosis
The problem, in my case, and as I have suspected, was that the XML file collections.nml
was not a properly formed XML file.
In my case it contained illegal (possibly UTF8) characters that came from a bogus filename of one of the imported files. Presence of this data in the XML file rendered it unreadable for most XML parsers, including the one Traktor uses internally.
Good software would have captured the error from the XML parser, which often includes the exact line and column where the error occurs, and often even the data. It would have printed this error on the screen, so that I could go and manually try to fix this. Instead Traktor swallowed this error, not printing it anywhere, — even in its own log file! — and proceeded to boot with a blank set. Because that’s what you’ve asked, right?' |
Not to mention the fact it was Traktor in the first place that create this file!
So, Why Did This Happen?
Restarted a Traktor post importing a large collection of new or creating new playlists or folders
Tried to import a collection from a backup, or someone else’s file
Some other way ended up adding a new file that contained bad characters, that Traktor failed to filter out.
What’s Going On?
The file where Traktor stores its data is called collection.nml
. It usually lives in Traktor’s home folder (which you can change via it’s Settings > File Management). The same folder may also have a file called collection_backup_invalid.nml
or collection_backup_outdated.nml
.
The first thing you’d want to do is to figure out which of these files contains the collections you would like to become 'active' collection, and once you do — please make a copy/backup of that file. Gopro software for mac.
Let’s say you started Traktor with a blank set (so the initialcollections.nml
file is very small), and then added a ton of files and samples, organized playlists, etc. It’s not until you normally exit Traktor that it will save your most recent changes to a file. (By the way, do not Force-Quit Traktor after making many changes to your play lists, or your changes won’t be saved). So if we list the files in Finder using the list view (see image below) we should be able to tell which of them is a tiny file, and which of them is a larger file with the real tracks.
Let’s say you determine that it is the 'invalid' file that contains your actual data:
Now we have a backup file of your full collection, so we can proceed to munge the invalid file until it’s valid.
Detecting XML Errors
Digitool reports lite software 2020 download. I detected the error using the xmllint
tool that’s installed on Mac OS-X by default. If you don’t have one, you can install it with Homebrew:
The above commands (as well as subsequent commands) are meant to run inside Terminal (or do yourself a favor, and install iTerm2 please).
You need to cd
into the Traktor’s Root directory (I explain in the next section how to find your root folder, but this section is for the impatient).
Now run the following command (assuming that your old collection is in the file collection_backup_invalid.nml
— this happens when Traktor boots up, it will move your old one into this file, while regular collection.nml
will be a tiny valid but blank as a dead fish’s stare.)
On my machine I saw the following:
From this you can deduce that the character following MidBass3 in the title of that track is something that trips XML parser. What we want is to see no output at all when we run xmllint --noout
— this would indicate that the XML parsed successfully.
How to fix this XML corruption?
This is largely up to you. But it revolves around these steps:
Quit Traktor! This is the most important step :)
Run
xmllint
to find errors as shown aboveUse your favorite editor to remove the errors
You can remove entire lines from the file but then you risk having other parts of the file reference something that doesn’t exist. So I think it’s much safer to…
Use find/replace to 'fix' bad filenames or bad titles, or any other bad string in the XML file.
Your editor’s capabilities will determine how exactly you’ll proceed.
Save & repeat until no more errors are found.
In my case, I used regular expressions and vim
editor to replace the offending file names. My steps were:
Open the file
collection_backup_invalid.nml
in an editor capable of doing global find/replace with regular expressions, for examplevim collection_backup_invalid.nml
Run the following replacement command in 'Vim':
:% s#MidBass(d)?[^'a-zA-Z0-9._ ]+.?*'#MidBass1-bad'#g
and press ENTER. See below for regex explanation if you care.Save the file (vim:
:w
and ENTER).Run
xmllint
again. Find more errors and repeat for all occurrences of errors until no more errors are printed.
In the above fix we have likely messed up the actual file entry for MidBass[1,2,3,etc], and won’t be able to open that particular file (or files), but the gain is that if the XML file is now, hopefully, valid, we should be able to copy it into collection.nml
and boot Traktor again.
Once XML is Clean
WARNING: command below assumes that your collection.nml
is a tiny file that’s been overwritten by Traktor, and that collection_backup_invalid.nml
contains the 'fixed up' content we want.
Let’s copy our fixed file over the one that Traktor will use during it’s boot:
And now lets try to start Traktor again. If you are as lucky as I was — your Traktor will now boot, and all your old playlists will still be there :)
Longer Explanation with Screenshots
Finding Traktor’s Root Folder
The first thing you will need to figure out is your Traktor’s 'Root' folder. Go to 'Settings, File Management' and it will be the first folder in the list, as shown below.
Next, let’s open that folder in Finder.
Finding Traktor’s Log File
First of all — notice the Logs
folder there. Inside of it is the Traktor.log
file. Double-click this file, and the Console Application should pop up on Mac OS-X.
While you are debugging Traktor it’s a good idea to keep Console open, as it will automatically show any new messages printed to the log file at the bottom. Which will be helpful, because the actual error message shown during Traktor’s boot time does not stick for very long:
Backup Entire Collection Traktor Program
WARNING: Could not read collection/playlist file:Macintosh HD:Users:boo:Documents:Native Instruments:Traktor 2.10.2:collection.nml
I recommend to keep this window open while we perform any operations below, and in the future — if you ever experience issues with Traktor — this should be the first place you look.
Replacing Things in VIM
As you may remember, I used the following regex to 'fix' my file:
Basically, % means all file, 's' means replace, # becomes a delimiter of what I am replacing with what is the replacement.
Backup Entire Collection Traktor Programs
My search is 'MidBass', followed by an optional digit which I am capturing (and using later as '1). The optional digit must be followed by a character NOT from the classes described, meaning it should be a non-text, non-digit, etc. character (meaning — a baddie daddy lamata ). It can then optionally be followed by any other character until a double quote, but '?' makes it non-greedy and stops at the first match (instead of matching all the way till the end of the string).
Conclusion
I hope this helped some of the Traktor users out there with the head scratching problem.
In the meantime, I hope that NI will fix these issues and update their File Management interface to be more modern, robust, flexible and consistent. Because it’s already about 10 years late to the party.
~ Konstantin / (aka DJ LeftCtrl, aka producer/composer PolyGroovers).
Chad (MIK Mod)If you haven't already, before starting backup Traktor's Collection.nml file.
Select the files in Traktor, right click on them, and choose 'Import to Collection' if they are not already in the Track Collection. Your songs absolutely must be in the Track Collection before MIK can write the cue points to them.
When the files are imported to Traktor you should have them analyzed for BPM and generate the beatgrid:
Tip: If you are not sure if the files have already been analyzed in Traktor, select all files in the Track Collection, right click on the selection, and choose Analyze.
Select the location of Traktor's Collection.nml file in MIK's Personalize/Export Cue Points tab.
Drag the files over from Traktor's Track Collection to Mixed In Key’s analysis queue, then close Traktor.
Analyze the files in Mixed In Key, or, if they had already been analyzed once click the 'Export Cue Points' button in the Personalize/Export Cue Points tab.
Open Traktor. Add your tracks from your Track Collection to a deck and you should see the cue points along with the beat grid.
Troubleshooting:
Traktor Pro 2.0.2+ is required.
Sometimes Traktor does not close properly on Windows. Go to the Task Manager and ensure that Traktor isn't running in the background.
You must have your songs in the Track Collection of Traktor so that they will be added to the Collection.nml file. Cue points are stored in this file so if MIK has any problem accessing it the cue points will not be written.
If you are seeing errors for any of your files in MIK, such as a permissions issue or decoding error none of the above will work, the errors would need to be resolved before starting this procedure.
If any of your files already have cue points placed on them MIK will not write new cue points for those files unless you enable the overwrite existing cue points option in MIK. Make sure to backup your collection.nml file before using this feature.
On Sunday, September 27, 2015 4:26 AM dernetteoli wrote:
If you have upgraded Traktor Mixed in key will always build the link the latest version in your directory.
BUT: Traktor is not automatically updating the root file after an upgrade. If you navigate in Traktor to
PREFERENCES > FILE MANAGEMENT > ROOT DIR
It also needs to be the link to the latest installed Traktor version as it is in Mixed in key
For me the root dir was linked to version 2.7.1 rather than 2.8.1
If none of the above helps getting a look at your collection.nml file at key stages throughout the process could really help to narrow things down. Please make copies of the collection.nml file and label them appropriately, like this:
Closed Traktor Before MIK Analysis.nml - this file will tell us if the audio file you want MIK to write cue points for is properly saved in Traktor's Track Collection.
After MIK Cue Points Exported Traktor Not Yet Opened.nml - this one will tell us if the cue points have been written.
After MIK Cue Points Exported and Traktor Opened.nml - this one will tell us if Traktor is removing MIK's cue points when it is launched.
After Closing Traktor.nml - this one will tell us if Traktor is removing MIK's cue points when it is closed.
If you're still having trouble:
- start simple and try it with just one song.
- Select an audio file, and remove it from MIK's collection.
- Also remove it from Traktor's collection.
- Re-import it into Traktor's Track Collection and make sure that it is analyzed and has a beatgrid set.
- Check your settings in MIK, make sure the collection.nml file is selected and that MIK is set to overwrite existing cue points.
- Drag that file from Traktor's Track Collection into Mixed In Key.
- MIK won't begin processing until you close Traktor, do so now.
- Analyze the file in MIK, and observe Traktor's Collection.nml file to see if it's 'date modified' is updated. If it isn't then MIK most likely either can't find it or it does not have appropriate permissions to edit the file.
- Open Traktor again and drag that file to a deck to check for cue points.
- If that doesn't solve the problem for you please place all of the Collection.nml files you copied together in a .zip folder and send them to contact@mixedinkey.com.