Skip to content

Commit

Permalink
file consolidator works
Browse files Browse the repository at this point in the history
  • Loading branch information
jcm93 committed Dec 7, 2017
1 parent cac4e83 commit 05544f5
Show file tree
Hide file tree
Showing 11 changed files with 394 additions and 138 deletions.
4 changes: 4 additions & 0 deletions jmc.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@
0D51C8A81EAC1646002F6182 /* URLStringFormatter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D51C8A71EAC1646002F6182 /* URLStringFormatter.swift */; };
0D51C8AA1EAC1866002F6182 /* TransformerURLStringToURL.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D51C8A91EAC1866002F6182 /* TransformerURLStringToURL.swift */; };
0D51C8B21EB01731002F6182 /* JMTabView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D51C8B11EB01731002F6182 /* JMTabView.swift */; };
0D5682731FD8A3AD0031C94B /* AtomicFileMoveOperation.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D5682721FD8A3AD0031C94B /* AtomicFileMoveOperation.swift */; };
0D58F7491D18E84F001A99F5 /* TableViewYouCanPressSpacebarOn.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D58F7481D18E84F001A99F5 /* TableViewYouCanPressSpacebarOn.swift */; };
0D58F74B1D18F778001A99F5 /* SourceListThatYouCanPressSpacebarOn.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D58F74A1D18F778001A99F5 /* SourceListThatYouCanPressSpacebarOn.swift */; };
0D592A221EDF6BCE0054D553 /* TrackExtension.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D592A211EDF6BCE0054D553 /* TrackExtension.swift */; };
Expand Down Expand Up @@ -276,6 +277,7 @@
0D51C8A71EAC1646002F6182 /* URLStringFormatter.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; name = URLStringFormatter.swift; path = Backend/Formatters/URLStringFormatter.swift; sourceTree = "<group>"; };
0D51C8A91EAC1866002F6182 /* TransformerURLStringToURL.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; name = TransformerURLStringToURL.swift; path = Backend/Formatters/TransformerURLStringToURL.swift; sourceTree = "<group>"; };
0D51C8B11EB01731002F6182 /* JMTabView.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; name = JMTabView.swift; path = "Other Windows/JMTabView.swift"; sourceTree = "<group>"; };
0D5682721FD8A3AD0031C94B /* AtomicFileMoveOperation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AtomicFileMoveOperation.swift; sourceTree = "<group>"; };
0D58F7481D18E84F001A99F5 /* TableViewYouCanPressSpacebarOn.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; name = TableViewYouCanPressSpacebarOn.swift; path = "Main Interface Components/Main Table View/TableViewYouCanPressSpacebarOn.swift"; sourceTree = "<group>"; };
0D58F74A1D18F778001A99F5 /* SourceListThatYouCanPressSpacebarOn.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; name = SourceListThatYouCanPressSpacebarOn.swift; path = "Main Interface Components/Subview Controllers/SourceListThatYouCanPressSpacebarOn.swift"; sourceTree = "<group>"; };
0D592A211EDF6BCE0054D553 /* TrackExtension.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; name = TrackExtension.swift; path = "Core Data Shit/TrackExtension.swift"; sourceTree = "<group>"; };
Expand Down Expand Up @@ -797,6 +799,7 @@
isa = PBXGroup;
children = (
0D76F6A71D24B9AC00C6E70F /* DatabaseManager.swift */,
0D5682721FD8A3AD0031C94B /* AtomicFileMoveOperation.swift */,
0DA02D311EF9D41A00DDE5A9 /* MediaMetadataHandler.swift */,
0DAA85891EDFE90E004BF089 /* OrganizationFieldToken.swift */,
0DE486931EA92B78009B226B /* AddFilesQueueLoop.swift */,
Expand Down Expand Up @@ -1083,6 +1086,7 @@
0D592A411EDF6C8B0054D553 /* Composer+CoreDataClass.swift in Sources */,
0D0C2AA71E88D8DA00CA82C3 /* MTImageCell.swift in Sources */,
0D2D06D01EE32FB600A8EC66 /* Album+CoreDataProperties.swift in Sources */,
0D5682731FD8A3AD0031C94B /* AtomicFileMoveOperation.swift in Sources */,
0DA02D321EF9D41A00DDE5A9 /* MediaMetadataHandler.swift in Sources */,
0D447BB91EB2B73F00372A80 /* JMTextField.swift in Sources */,
0D592A421EDF6C8B0054D553 /* Composer+CoreDataProperties.swift in Sources */,
Expand Down
Binary file not shown.
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
ignoreCount = "0"
continueAfterRunningActions = "No"
filePath = "jmc/Delegate:Main Window Controller/MainWindowController.swift"
timestampString = "534234841.407924"
timestampString = "534310826.455271"
startingColumnNumber = "9223372036854775807"
endingColumnNumber = "9223372036854775807"
startingLineNumber = "336"
Expand Down
2 changes: 1 addition & 1 deletion jmc/AlbumFileLocationViewController.swift
Original file line number Diff line number Diff line change
Expand Up @@ -156,7 +156,6 @@ class AlbumFilePathTree: NSObject {
index += 1
DispatchQueue.main.async {
visualUpdateHandler?.increment(thingsDone: index)
print("incrementing \(index)")
}
}
}
Expand Down Expand Up @@ -230,6 +229,7 @@ class AlbumFileLocationViewController: NSViewController, NSOutlineViewDataSource
if self.isSearching == true {
self.isSearching = false
self.outlineView.reloadData()
self.outlineView.expandItem(nil, expandChildren: true)
}
let nodes = self.masterTree.getNodesForObjects(objects: items)
var indexSet = IndexSet()
Expand Down
16 changes: 16 additions & 0 deletions jmc/AtomicFileMoveOperation.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
//
// AtomicFileMoveOperation.swift
// jmc
//
// Created by John Moody on 12/6/17.
// Copyright © 2017 John Moody. All rights reserved.
//

import Cocoa

class AtomicFileMoveOperation: Operation {

override func main() {

}
}
91 changes: 87 additions & 4 deletions jmc/Backend/Database:Filesystem Management/DatabaseManager.swift
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@ class DatabaseManager: NSObject {
let fileManager = FileManager.default
var undoFileLocations = [Track : [String]]()
var currentTrack: Track?
var consolidationShouldStop: Bool = false

func getArtworkFromFile(_ urlString: String) -> Data? {
print("checking for art in file")
Expand Down Expand Up @@ -510,6 +511,88 @@ class DatabaseManager: NSObject {
return (mediaURLs, errors)
}

func consolidateLibrary(withLocations newLocationDictionary: [NSObject : URL], visualUpdateHandler: ProgressBarController?, moves: Bool) {
//assume called on not-main queue
let subContext = NSManagedObjectContext(concurrencyType: .privateQueueConcurrencyType)
subContext.parent = managedContext
var index = 0
let count = newLocationDictionary.count
DispatchQueue.main.async {
visualUpdateHandler?.prepareForNewTask(actionName: "Consolidating", thingName: "tracks", thingCount: count)
}
for (object, newURL) in newLocationDictionary {
guard self.consolidationShouldStop != true else { break }
defer {
index += 1
DispatchQueue.main.async {
visualUpdateHandler?.increment(thingsDone: index)
}
}
let object = object as! NSManagedObject
let subContextObject = subContext.object(with: object.objectID)
guard let oldURL = {() -> URL? in
switch subContextObject {
case let subContextObject as Track:
return URL(string: subContextObject.location ?? "")
case let subContextObject as AlbumFile:
return URL(string: subContextObject.location ?? "")
case let subContextObject as AlbumArtwork:
return URL(string: subContextObject.location ?? "")
default:
return nil
}
}() else { continue }
do {
try fileManager.createDirectory(at: newURL.deletingLastPathComponent(), withIntermediateDirectories: true, attributes: nil)
} catch {
print(error)
}
do {
switch moves {
case true:
try fileManager.moveItem(at: oldURL, to: newURL)
case false:
try fileManager.copyItem(at: oldURL, to: newURL)
}
} catch {
print(error)
//append error
continue
}
switch subContextObject {
case let subContextObject as Track:
subContextObject.location = newURL.absoluteString
case let subContextObject as AlbumFile:
subContextObject.location = newURL.absoluteString
case let subContextObject as AlbumArtwork:
subContextObject.location = newURL.absoluteString
default:
break
}
do {
try subContext.save()
DispatchQueue.main.async {
do {
try managedContext.save()
} catch {
self.consolidationShouldStop = true
}
}
} catch {
self.consolidationShouldStop = true
continue
}
}
if self.consolidationShouldStop == true {
print("failure")
} else {
print("success")
}
DispatchQueue.main.async {
visualUpdateHandler?.finish()
}
}

func removeNetworkedLibrary(_ library: Library) {
removeSource(library: library)
}
Expand Down Expand Up @@ -659,7 +742,7 @@ class DatabaseManager: NSObject {
let volumeURL = getVolumeOfURL(url: url)
if let existingVolume = addedVolumes[volumeURL] {
track.volume = existingVolume
} else if let existingVolume = checkIfVolumeExists(withURL: volumeURL) {
} else if let existingVolume = checkIfVolumeExists(withURL: volumeURL, subcontext: subContext) {
track.volume = subContext.object(with: existingVolume.objectID) as! Volume
} else {
let newVolume = NSEntityDescription.insertNewObject(forEntityName: "Volume", into: subContext) as! Volume
Expand Down Expand Up @@ -696,7 +779,7 @@ class DatabaseManager: NSObject {
let artistCheck = fileMetadataDictionary[kArtistKey] as? String ?? ""
if let alreadyAddedArtist = addedArtists[artistCheck] {
track.artist = alreadyAddedArtist
} else if let alreadyAddedArtist = checkIfArtistExists(artistCheck) {
} else if let alreadyAddedArtist = checkIfArtistExists(artistCheck, subcontext: subContext) {
track.artist = subContext.object(with: alreadyAddedArtist.objectID) as! Artist
} else {
let newArtist = NSEntityDescription.insertNewObject(forEntityName: "Artist", into: subContext) as! Artist
Expand All @@ -710,7 +793,7 @@ class DatabaseManager: NSObject {
let albumCheck = fileMetadataDictionary[kAlbumKey] as? String ?? ""
if let alreadyAddedAlbum = addedAlbums[track.artist!]?[albumCheck] {
track.album = alreadyAddedAlbum
} else if let alreadyAddedAlbum = checkIfAlbumExists(withName: albumCheck, withArtist: track.artist!) {
} else if let alreadyAddedAlbum = checkIfAlbumExists(withName: albumCheck, withArtist: track.artist!, subcontext: subContext) {
track.album = subContext.object(with: alreadyAddedAlbum.objectID) as! Album
} else {
let newAlbum = NSEntityDescription.insertNewObject(forEntityName: "Album", into: subContext) as! Album
Expand All @@ -734,7 +817,7 @@ class DatabaseManager: NSObject {
if let composerCheck = fileMetadataDictionary[kComposerKey] as? String {
if let alreadyAddedComposer = addedComposers[composerCheck] {
track.composer = alreadyAddedComposer
} else if let alreadyAddedComposer = checkIfComposerExists(composerCheck) {
} else if let alreadyAddedComposer = checkIfComposerExists(composerCheck, subcontext: subContext) {
track.composer = subContext.object(with: alreadyAddedComposer.objectID) as! Composer
} else {
let newComposer = NSEntityDescription.insertNewObject(forEntityName: "Composer", into: subContext) as! Composer
Expand Down
20 changes: 10 additions & 10 deletions jmc/Backend/GlobalFunctions.swift
Original file line number Diff line number Diff line change
Expand Up @@ -253,12 +253,12 @@ func getVolumeOfURL(url: URL) -> URL {
}
}

func checkIfVolumeExists(withURL url: URL) -> Volume? {
func checkIfVolumeExists(withURL url: URL, subcontext: NSManagedObjectContext? = nil) -> Volume? {
let fetch = NSFetchRequest<Volume>(entityName: "Volume")
let predicate = NSPredicate(format: "location == %@", url.absoluteString)
fetch.predicate = predicate
do {
let results = try managedContext.fetch(fetch)
let results = subcontext != nil ? (try subcontext!.fetch(fetch)) : (try managedContext.fetch(fetch))
if results.count > 0 {
return results[0]
} else {
Expand Down Expand Up @@ -503,12 +503,12 @@ var jmcUnknownComposer = {() -> Composer in
}
}

func checkIfArtistExists(_ name: String) -> Artist? {
func checkIfArtistExists(_ name: String, subcontext: NSManagedObjectContext? = nil) -> Artist? {
let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Artist")
let predicate = NSPredicate(format: "name == %@", name)
request.predicate = predicate
do {
let result = try managedContext.fetch(request) as! [Artist]
let result = subcontext != nil ? (try subcontext!.fetch(request) as! [Artist]) : (try managedContext.fetch(request) as! [Artist])
if result.count > 0 {
return result[0]
} else {
Expand All @@ -520,12 +520,12 @@ func checkIfArtistExists(_ name: String) -> Artist? {
}
}

func checkIfAlbumExists(withName name: String, withArtist artist: Artist) -> Album? {
func checkIfAlbumExists(withName name: String, withArtist artist: Artist, subcontext: NSManagedObjectContext? = nil) -> Album? {
let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Album")
let predicate = NSPredicate(format: "name == %@ and album_artist == %@", name, artist)
request.predicate = predicate
do {
let result = try managedContext.fetch(request) as! [Album]
let result = subcontext != nil ? (try subcontext!.fetch(request) as! [Album]) : (try managedContext.fetch(request) as! [Album])
if result.count > 0 {
return result[0]
} else {
Expand All @@ -537,12 +537,12 @@ func checkIfAlbumExists(withName name: String, withArtist artist: Artist) -> Alb
}
}

func checkIfComposerExists(_ name: String) -> Composer? {
func checkIfComposerExists(_ name: String, subcontext: NSManagedObjectContext? = nil) -> Composer? {
let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Composer")
let predicate = NSPredicate(format: "name == %@", name)
request.predicate = predicate
do {
let result = try managedContext.fetch(request) as! [Composer]
let result = subcontext != nil ? (try subcontext!.fetch(request) as! [Composer]) : (try managedContext.fetch(request) as! [Composer])
if result.count > 0 {
return result[0]
} else {
Expand All @@ -554,12 +554,12 @@ func checkIfComposerExists(_ name: String) -> Composer? {
}
}

func checkIfCachedOrderExists(_ name: String) -> CachedOrder? {
func checkIfCachedOrderExists(_ name: String, subcontext: NSManagedObjectContext? = nil) -> CachedOrder? {
let request = NSFetchRequest<NSFetchRequestResult>(entityName: "CachedOrder")
let predicate = NSPredicate(format: "order == %@", name)
request.predicate = predicate
do {
let result = try managedContext.fetch(request) as! [CachedOrder]
let result = subcontext != nil ? (try subcontext!.fetch(request) as! [CachedOrder]) : (try managedContext.fetch(request) as! [CachedOrder])
if result.count > 0 {
return result[0]
} else {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -332,11 +332,11 @@ class MainWindowController: NSWindowController, NSSearchFieldDelegate, NSWindowD
self.skipBackward()
}
@IBAction func tempBreak(_ sender: AnyObject) {
//self.skip()
print("dongels")
self.skip()
/*print("dongels")
let fr = NSFetchRequest<Track>(entityName: "Track")
let result = try? managedContext.fetch(fr)
print(result?.count)
print(result?.count)*/
}
@IBAction func addPlaylistButton(_ sender: AnyObject) {
sourceListViewController!.createPlaylist(nil, smart_criteria: nil)
Expand Down
Loading

0 comments on commit 05544f5

Please sign in to comment.