diff --git a/.gitignore b/.gitignore index edc082c..fca9853 100644 --- a/.gitignore +++ b/.gitignore @@ -13,3 +13,4 @@ build/* xcuserdata profile *.moved-aside +DerivedData diff --git a/iNapi.xcodeproj/project.pbxproj b/iNapi.xcodeproj/project.pbxproj new file mode 100644 index 0000000..dd824e2 --- /dev/null +++ b/iNapi.xcodeproj/project.pbxproj @@ -0,0 +1,593 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 46; + objects = { + +/* Begin PBXBuildFile section */ + 2E20C37815003CA800A826A7 /* AppIcon.icns in Resources */ = {isa = PBXBuildFile; fileRef = 2E20C37715003CA800A826A7 /* AppIcon.icns */; }; + 2E30A1E615024A8100119004 /* Localizable.strings in Resources */ = {isa = PBXBuildFile; fileRef = 2E30A1E515024A8100119004 /* Localizable.strings */; }; + 2E30A1EE1502845400119004 /* NSData+MD5.m in Sources */ = {isa = PBXBuildFile; fileRef = 2E30A1ED1502845400119004 /* NSData+MD5.m */; }; + 2E30A1F1150284AD00119004 /* INPURLCreator.m in Sources */ = {isa = PBXBuildFile; fileRef = 2E30A1F0150284AD00119004 /* INPURLCreator.m */; }; + 2E30A1F41502872E00119004 /* INPMovieFilter.m in Sources */ = {isa = PBXBuildFile; fileRef = 2E30A1F31502872E00119004 /* INPMovieFilter.m */; }; + 2E4606AE15A4B631009C6878 /* DownloadStatusFailed.png in Resources */ = {isa = PBXBuildFile; fileRef = 2E4606AB15A4B631009C6878 /* DownloadStatusFailed.png */; }; + 2E4606AF15A4B631009C6878 /* DownloadStatusNotFound.png in Resources */ = {isa = PBXBuildFile; fileRef = 2E4606AC15A4B631009C6878 /* DownloadStatusNotFound.png */; }; + 2E4606B015A4B631009C6878 /* DownloadStatusSucceeded.png in Resources */ = {isa = PBXBuildFile; fileRef = 2E4606AD15A4B631009C6878 /* DownloadStatusSucceeded.png */; }; + 2E4606B415A4B6CF009C6878 /* INDownloadResult.m in Sources */ = {isa = PBXBuildFile; fileRef = 2E4606B315A4B6CF009C6878 /* INDownloadResult.m */; }; + 2E4847581593D23B00D1EBF4 /* INSubtitleDownloader.m in Sources */ = {isa = PBXBuildFile; fileRef = 2E4847571593D23B00D1EBF4 /* INSubtitleDownloader.m */; }; + 2E577C8414F952E300914F56 /* Cocoa.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 2E577C8314F952E300914F56 /* Cocoa.framework */; }; + 2E577C8E14F952E300914F56 /* InfoPlist.strings in Resources */ = {isa = PBXBuildFile; fileRef = 2E577C8C14F952E300914F56 /* InfoPlist.strings */; }; + 2E577C9014F952E300914F56 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 2E577C8F14F952E300914F56 /* main.m */; }; + 2E577C9414F952E300914F56 /* Credits.rtf in Resources */ = {isa = PBXBuildFile; fileRef = 2E577C9214F952E300914F56 /* Credits.rtf */; }; + 2E577CA214F952E400914F56 /* SenTestingKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 2E577CA114F952E400914F56 /* SenTestingKit.framework */; }; + 2E577CA314F952E400914F56 /* Cocoa.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 2E577C8314F952E300914F56 /* Cocoa.framework */; }; + 2E577CAB14F952E400914F56 /* InfoPlist.strings in Resources */ = {isa = PBXBuildFile; fileRef = 2E577CA914F952E400914F56 /* InfoPlist.strings */; }; + 2E577CAE14F952E400914F56 /* iNapiTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 2E577CAD14F952E400914F56 /* iNapiTests.m */; }; + 2E577CDB14F95F6100914F56 /* INPAppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 2E577CD114F95F6100914F56 /* INPAppDelegate.m */; }; + 2E577CDC14F95F6100914F56 /* MainMenu.xib in Resources */ = {isa = PBXBuildFile; fileRef = 2E577CD214F95F6100914F56 /* MainMenu.xib */; }; + 2E577CE414F9620800914F56 /* INPPreferencesWindowController.m in Sources */ = {isa = PBXBuildFile; fileRef = 2E577CE314F9620800914F56 /* INPPreferencesWindowController.m */; }; + 2E577CE614F9631000914F56 /* INPPreferencesWindow.xib in Resources */ = {isa = PBXBuildFile; fileRef = 2E577CE514F9631000914F56 /* INPPreferencesWindow.xib */; }; +/* End PBXBuildFile section */ + +/* Begin PBXContainerItemProxy section */ + 2E577CA414F952E400914F56 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 2E577C7614F952E300914F56 /* Project object */; + proxyType = 1; + remoteGlobalIDString = 2E577C7E14F952E300914F56; + remoteInfo = iNapi; + }; +/* End PBXContainerItemProxy section */ + +/* Begin PBXFileReference section */ + 2E20C37715003CA800A826A7 /* AppIcon.icns */ = {isa = PBXFileReference; lastKnownFileType = image.icns; path = AppIcon.icns; sourceTree = ""; }; + 2E30A1E515024A8100119004 /* Localizable.strings */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.strings; path = Localizable.strings; sourceTree = ""; }; + 2E30A1EC1502845400119004 /* NSData+MD5.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = "NSData+MD5.h"; sourceTree = ""; }; + 2E30A1ED1502845400119004 /* NSData+MD5.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = "NSData+MD5.m"; sourceTree = ""; }; + 2E30A1EF150284AD00119004 /* INPURLCreator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = INPURLCreator.h; sourceTree = ""; }; + 2E30A1F0150284AD00119004 /* INPURLCreator.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = INPURLCreator.m; sourceTree = ""; }; + 2E30A1F21502872E00119004 /* INPMovieFilter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = INPMovieFilter.h; sourceTree = ""; }; + 2E30A1F31502872E00119004 /* INPMovieFilter.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = INPMovieFilter.m; sourceTree = ""; }; + 2E4606AB15A4B631009C6878 /* DownloadStatusFailed.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = DownloadStatusFailed.png; sourceTree = ""; }; + 2E4606AC15A4B631009C6878 /* DownloadStatusNotFound.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = DownloadStatusNotFound.png; sourceTree = ""; }; + 2E4606AD15A4B631009C6878 /* DownloadStatusSucceeded.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = DownloadStatusSucceeded.png; sourceTree = ""; }; + 2E4606B215A4B6CF009C6878 /* INDownloadResult.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = INDownloadResult.h; sourceTree = ""; }; + 2E4606B315A4B6CF009C6878 /* INDownloadResult.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = INDownloadResult.m; sourceTree = ""; }; + 2E4847561593D23B00D1EBF4 /* INSubtitleDownloader.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = INSubtitleDownloader.h; sourceTree = ""; }; + 2E4847571593D23B00D1EBF4 /* INSubtitleDownloader.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = INSubtitleDownloader.m; sourceTree = ""; }; + 2E577C7F14F952E300914F56 /* iNapi.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = iNapi.app; sourceTree = BUILT_PRODUCTS_DIR; }; + 2E577C8314F952E300914F56 /* Cocoa.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Cocoa.framework; path = System/Library/Frameworks/Cocoa.framework; sourceTree = SDKROOT; }; + 2E577C8614F952E300914F56 /* AppKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = AppKit.framework; path = System/Library/Frameworks/AppKit.framework; sourceTree = SDKROOT; }; + 2E577C8714F952E300914F56 /* CoreData.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreData.framework; path = System/Library/Frameworks/CoreData.framework; sourceTree = SDKROOT; }; + 2E577C8814F952E300914F56 /* Foundation.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Foundation.framework; path = System/Library/Frameworks/Foundation.framework; sourceTree = SDKROOT; }; + 2E577C8B14F952E300914F56 /* iNapi-Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = "iNapi-Info.plist"; sourceTree = ""; }; + 2E577C8D14F952E300914F56 /* en */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = en; path = en.lproj/InfoPlist.strings; sourceTree = ""; }; + 2E577C8F14F952E300914F56 /* main.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = main.m; sourceTree = ""; }; + 2E577C9114F952E300914F56 /* iNapi-Prefix.pch */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "iNapi-Prefix.pch"; sourceTree = ""; }; + 2E577C9314F952E300914F56 /* en */ = {isa = PBXFileReference; lastKnownFileType = text.rtf; name = en; path = en.lproj/Credits.rtf; sourceTree = ""; }; + 2E577CA014F952E400914F56 /* iNapiTests.octest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = iNapiTests.octest; sourceTree = BUILT_PRODUCTS_DIR; }; + 2E577CA114F952E400914F56 /* SenTestingKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = SenTestingKit.framework; path = Library/Frameworks/SenTestingKit.framework; sourceTree = DEVELOPER_DIR; }; + 2E577CA814F952E400914F56 /* iNapiTests-Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = "iNapiTests-Info.plist"; sourceTree = ""; }; + 2E577CAA14F952E400914F56 /* en */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = en; path = en.lproj/InfoPlist.strings; sourceTree = ""; }; + 2E577CAC14F952E400914F56 /* iNapiTests.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = iNapiTests.h; sourceTree = ""; }; + 2E577CAD14F952E400914F56 /* iNapiTests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = iNapiTests.m; sourceTree = ""; }; + 2E577CD014F95F6100914F56 /* INPAppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = INPAppDelegate.h; sourceTree = ""; }; + 2E577CD114F95F6100914F56 /* INPAppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = INPAppDelegate.m; sourceTree = ""; }; + 2E577CD214F95F6100914F56 /* MainMenu.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = MainMenu.xib; sourceTree = ""; }; + 2E577CE214F9620800914F56 /* INPPreferencesWindowController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = INPPreferencesWindowController.h; sourceTree = ""; }; + 2E577CE314F9620800914F56 /* INPPreferencesWindowController.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = INPPreferencesWindowController.m; sourceTree = ""; }; + 2E577CE514F9631000914F56 /* INPPreferencesWindow.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = INPPreferencesWindow.xib; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 2E577C7C14F952E300914F56 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 2E577C8414F952E300914F56 /* Cocoa.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 2E577C9C14F952E400914F56 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 2E577CA214F952E400914F56 /* SenTestingKit.framework in Frameworks */, + 2E577CA314F952E400914F56 /* Cocoa.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 2E4606AA15A4B631009C6878 /* DownloadStatusImages */ = { + isa = PBXGroup; + children = ( + 2E4606AB15A4B631009C6878 /* DownloadStatusFailed.png */, + 2E4606AC15A4B631009C6878 /* DownloadStatusNotFound.png */, + 2E4606AD15A4B631009C6878 /* DownloadStatusSucceeded.png */, + ); + path = DownloadStatusImages; + sourceTree = ""; + }; + 2E577C7414F952E300914F56 = { + isa = PBXGroup; + children = ( + 2E577C8914F952E300914F56 /* iNapi */, + 2E577CA614F952E400914F56 /* iNapiTests */, + 2E577C8214F952E300914F56 /* Frameworks */, + 2E577C8014F952E300914F56 /* Products */, + ); + sourceTree = ""; + }; + 2E577C8014F952E300914F56 /* Products */ = { + isa = PBXGroup; + children = ( + 2E577C7F14F952E300914F56 /* iNapi.app */, + 2E577CA014F952E400914F56 /* iNapiTests.octest */, + ); + name = Products; + sourceTree = ""; + }; + 2E577C8214F952E300914F56 /* Frameworks */ = { + isa = PBXGroup; + children = ( + 2E577C8314F952E300914F56 /* Cocoa.framework */, + 2E577CA114F952E400914F56 /* SenTestingKit.framework */, + 2E577C8514F952E300914F56 /* Other Frameworks */, + ); + name = Frameworks; + sourceTree = ""; + }; + 2E577C8514F952E300914F56 /* Other Frameworks */ = { + isa = PBXGroup; + children = ( + 2E577C8614F952E300914F56 /* AppKit.framework */, + 2E577C8714F952E300914F56 /* CoreData.framework */, + 2E577C8814F952E300914F56 /* Foundation.framework */, + ); + name = "Other Frameworks"; + sourceTree = ""; + }; + 2E577C8914F952E300914F56 /* iNapi */ = { + isa = PBXGroup; + children = ( + 2E577CCE14F95F6100914F56 /* Classes */, + 2E577CD914F95F6100914F56 /* Externals */, + 2E577CDA14F95F6100914F56 /* Resources */, + 2E577C8A14F952E300914F56 /* Supporting Files */, + ); + path = iNapi; + sourceTree = ""; + }; + 2E577C8A14F952E300914F56 /* Supporting Files */ = { + isa = PBXGroup; + children = ( + 2E577C8B14F952E300914F56 /* iNapi-Info.plist */, + 2E577C8C14F952E300914F56 /* InfoPlist.strings */, + 2E577C8F14F952E300914F56 /* main.m */, + 2E577C9114F952E300914F56 /* iNapi-Prefix.pch */, + 2E577C9214F952E300914F56 /* Credits.rtf */, + ); + name = "Supporting Files"; + sourceTree = ""; + }; + 2E577CA614F952E400914F56 /* iNapiTests */ = { + isa = PBXGroup; + children = ( + 2E577CAC14F952E400914F56 /* iNapiTests.h */, + 2E577CAD14F952E400914F56 /* iNapiTests.m */, + 2E577CA714F952E400914F56 /* Supporting Files */, + ); + path = iNapiTests; + sourceTree = ""; + }; + 2E577CA714F952E400914F56 /* Supporting Files */ = { + isa = PBXGroup; + children = ( + 2E577CA814F952E400914F56 /* iNapiTests-Info.plist */, + 2E577CA914F952E400914F56 /* InfoPlist.strings */, + ); + name = "Supporting Files"; + sourceTree = ""; + }; + 2E577CCE14F95F6100914F56 /* Classes */ = { + isa = PBXGroup; + children = ( + 2E577CCF14F95F6100914F56 /* AppDelegate */, + 2E577CD314F95F6100914F56 /* Controllers */, + 2E577CD714F95F6100914F56 /* CustomViews */, + 2E577CD814F95F6100914F56 /* Helpers */, + 2E577CDF14F95F8000914F56 /* Models */, + ); + path = Classes; + sourceTree = ""; + }; + 2E577CCF14F95F6100914F56 /* AppDelegate */ = { + isa = PBXGroup; + children = ( + 2E577CD014F95F6100914F56 /* INPAppDelegate.h */, + 2E577CD114F95F6100914F56 /* INPAppDelegate.m */, + 2E577CD214F95F6100914F56 /* MainMenu.xib */, + ); + path = AppDelegate; + sourceTree = ""; + }; + 2E577CD314F95F6100914F56 /* Controllers */ = { + isa = PBXGroup; + children = ( + 2E577CE214F9620800914F56 /* INPPreferencesWindowController.h */, + 2E577CE314F9620800914F56 /* INPPreferencesWindowController.m */, + 2E577CE514F9631000914F56 /* INPPreferencesWindow.xib */, + ); + path = Controllers; + sourceTree = ""; + }; + 2E577CD714F95F6100914F56 /* CustomViews */ = { + isa = PBXGroup; + children = ( + ); + path = CustomViews; + sourceTree = ""; + }; + 2E577CD814F95F6100914F56 /* Helpers */ = { + isa = PBXGroup; + children = ( + 2E30A1EC1502845400119004 /* NSData+MD5.h */, + 2E30A1ED1502845400119004 /* NSData+MD5.m */, + 2E30A1EF150284AD00119004 /* INPURLCreator.h */, + 2E30A1F0150284AD00119004 /* INPURLCreator.m */, + 2E30A1F21502872E00119004 /* INPMovieFilter.h */, + 2E30A1F31502872E00119004 /* INPMovieFilter.m */, + 2E4847561593D23B00D1EBF4 /* INSubtitleDownloader.h */, + 2E4847571593D23B00D1EBF4 /* INSubtitleDownloader.m */, + ); + path = Helpers; + sourceTree = ""; + }; + 2E577CD914F95F6100914F56 /* Externals */ = { + isa = PBXGroup; + children = ( + ); + path = Externals; + sourceTree = ""; + }; + 2E577CDA14F95F6100914F56 /* Resources */ = { + isa = PBXGroup; + children = ( + 2E4606AA15A4B631009C6878 /* DownloadStatusImages */, + 2E577CE014F95FD000914F56 /* AppIcons */, + 2E577CE114F95FD000914F56 /* Localization */, + ); + path = Resources; + sourceTree = ""; + }; + 2E577CDF14F95F8000914F56 /* Models */ = { + isa = PBXGroup; + children = ( + 2E4606B215A4B6CF009C6878 /* INDownloadResult.h */, + 2E4606B315A4B6CF009C6878 /* INDownloadResult.m */, + ); + path = Models; + sourceTree = ""; + }; + 2E577CE014F95FD000914F56 /* AppIcons */ = { + isa = PBXGroup; + children = ( + 2E20C37715003CA800A826A7 /* AppIcon.icns */, + ); + path = AppIcons; + sourceTree = ""; + }; + 2E577CE114F95FD000914F56 /* Localization */ = { + isa = PBXGroup; + children = ( + 2E30A1E515024A8100119004 /* Localizable.strings */, + ); + path = Localization; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + 2E577C7E14F952E300914F56 /* iNapi */ = { + isa = PBXNativeTarget; + buildConfigurationList = 2E577CB114F952E400914F56 /* Build configuration list for PBXNativeTarget "iNapi" */; + buildPhases = ( + 2E577C7B14F952E300914F56 /* Sources */, + 2E577C7C14F952E300914F56 /* Frameworks */, + 2E577C7D14F952E300914F56 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = iNapi; + productName = iNapi; + productReference = 2E577C7F14F952E300914F56 /* iNapi.app */; + productType = "com.apple.product-type.application"; + }; + 2E577C9F14F952E400914F56 /* iNapiTests */ = { + isa = PBXNativeTarget; + buildConfigurationList = 2E577CB414F952E400914F56 /* Build configuration list for PBXNativeTarget "iNapiTests" */; + buildPhases = ( + 2E577C9B14F952E400914F56 /* Sources */, + 2E577C9C14F952E400914F56 /* Frameworks */, + 2E577C9D14F952E400914F56 /* Resources */, + 2E577C9E14F952E400914F56 /* ShellScript */, + ); + buildRules = ( + ); + dependencies = ( + 2E577CA514F952E400914F56 /* PBXTargetDependency */, + ); + name = iNapiTests; + productName = iNapiTests; + productReference = 2E577CA014F952E400914F56 /* iNapiTests.octest */; + productType = "com.apple.product-type.bundle"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 2E577C7614F952E300914F56 /* Project object */ = { + isa = PBXProject; + attributes = { + LastUpgradeCheck = 0420; + ORGANIZATIONNAME = Trifork; + }; + buildConfigurationList = 2E577C7914F952E300914F56 /* Build configuration list for PBXProject "iNapi" */; + compatibilityVersion = "Xcode 3.2"; + developmentRegion = English; + hasScannedForEncodings = 0; + knownRegions = ( + en, + ); + mainGroup = 2E577C7414F952E300914F56; + productRefGroup = 2E577C8014F952E300914F56 /* Products */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 2E577C7E14F952E300914F56 /* iNapi */, + 2E577C9F14F952E400914F56 /* iNapiTests */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXResourcesBuildPhase section */ + 2E577C7D14F952E300914F56 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 2E577C8E14F952E300914F56 /* InfoPlist.strings in Resources */, + 2E577C9414F952E300914F56 /* Credits.rtf in Resources */, + 2E577CDC14F95F6100914F56 /* MainMenu.xib in Resources */, + 2E577CE614F9631000914F56 /* INPPreferencesWindow.xib in Resources */, + 2E20C37815003CA800A826A7 /* AppIcon.icns in Resources */, + 2E30A1E615024A8100119004 /* Localizable.strings in Resources */, + 2E4606AE15A4B631009C6878 /* DownloadStatusFailed.png in Resources */, + 2E4606AF15A4B631009C6878 /* DownloadStatusNotFound.png in Resources */, + 2E4606B015A4B631009C6878 /* DownloadStatusSucceeded.png in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 2E577C9D14F952E400914F56 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 2E577CAB14F952E400914F56 /* InfoPlist.strings in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXShellScriptBuildPhase section */ + 2E577C9E14F952E400914F56 /* ShellScript */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputPaths = ( + ); + outputPaths = ( + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "# Run the unit tests in this test bundle.\n\"${SYSTEM_DEVELOPER_DIR}/Tools/RunUnitTests\"\n"; + }; +/* End PBXShellScriptBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 2E577C7B14F952E300914F56 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 2E577C9014F952E300914F56 /* main.m in Sources */, + 2E577CDB14F95F6100914F56 /* INPAppDelegate.m in Sources */, + 2E577CE414F9620800914F56 /* INPPreferencesWindowController.m in Sources */, + 2E30A1EE1502845400119004 /* NSData+MD5.m in Sources */, + 2E30A1F1150284AD00119004 /* INPURLCreator.m in Sources */, + 2E30A1F41502872E00119004 /* INPMovieFilter.m in Sources */, + 2E4847581593D23B00D1EBF4 /* INSubtitleDownloader.m in Sources */, + 2E4606B415A4B6CF009C6878 /* INDownloadResult.m in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 2E577C9B14F952E400914F56 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 2E577CAE14F952E400914F56 /* iNapiTests.m in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXTargetDependency section */ + 2E577CA514F952E400914F56 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = 2E577C7E14F952E300914F56 /* iNapi */; + targetProxy = 2E577CA414F952E400914F56 /* PBXContainerItemProxy */; + }; +/* End PBXTargetDependency section */ + +/* Begin PBXVariantGroup section */ + 2E577C8C14F952E300914F56 /* InfoPlist.strings */ = { + isa = PBXVariantGroup; + children = ( + 2E577C8D14F952E300914F56 /* en */, + ); + name = InfoPlist.strings; + sourceTree = ""; + }; + 2E577C9214F952E300914F56 /* Credits.rtf */ = { + isa = PBXVariantGroup; + children = ( + 2E577C9314F952E300914F56 /* en */, + ); + name = Credits.rtf; + sourceTree = ""; + }; + 2E577CA914F952E400914F56 /* InfoPlist.strings */ = { + isa = PBXVariantGroup; + children = ( + 2E577CAA14F952E400914F56 /* en */, + ); + name = InfoPlist.strings; + sourceTree = ""; + }; +/* End PBXVariantGroup section */ + +/* Begin XCBuildConfiguration section */ + 2E577CAF14F952E400914F56 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + ARCHS = "$(ARCHS_STANDARD_64_BIT)"; + CLANG_ENABLE_OBJC_ARC = YES; + COPY_PHASE_STRIP = NO; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_OBJC_EXCEPTIONS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_SYMBOLS_PRIVATE_EXTERN = NO; + GCC_VERSION = com.apple.compilers.llvm.clang.1_0; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_MISSING_PROTOTYPES = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + MACOSX_DEPLOYMENT_TARGET = 10.7; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = macosx; + }; + name = Debug; + }; + 2E577CB014F952E400914F56 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + ARCHS = "$(ARCHS_STANDARD_64_BIT)"; + CLANG_ENABLE_OBJC_ARC = YES; + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_ENABLE_OBJC_EXCEPTIONS = YES; + GCC_VERSION = com.apple.compilers.llvm.clang.1_0; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_MISSING_PROTOTYPES = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + MACOSX_DEPLOYMENT_TARGET = 10.7; + SDKROOT = macosx; + }; + name = Release; + }; + 2E577CB214F952E400914F56 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + GCC_PRECOMPILE_PREFIX_HEADER = YES; + GCC_PREFIX_HEADER = "iNapi/iNapi-Prefix.pch"; + INFOPLIST_FILE = "iNapi/iNapi-Info.plist"; + PRODUCT_NAME = "$(TARGET_NAME)"; + WRAPPER_EXTENSION = app; + }; + name = Debug; + }; + 2E577CB314F952E400914F56 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + GCC_PRECOMPILE_PREFIX_HEADER = YES; + GCC_PREFIX_HEADER = "iNapi/iNapi-Prefix.pch"; + INFOPLIST_FILE = "iNapi/iNapi-Info.plist"; + PRODUCT_NAME = "$(TARGET_NAME)"; + WRAPPER_EXTENSION = app; + }; + name = Release; + }; + 2E577CB514F952E400914F56 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + BUNDLE_LOADER = "$(BUILT_PRODUCTS_DIR)/iNapi.app/Contents/MacOS/iNapi"; + FRAMEWORK_SEARCH_PATHS = "$(DEVELOPER_LIBRARY_DIR)/Frameworks"; + GCC_PRECOMPILE_PREFIX_HEADER = YES; + GCC_PREFIX_HEADER = "iNapi/iNapi-Prefix.pch"; + INFOPLIST_FILE = "iNapiTests/iNapiTests-Info.plist"; + PRODUCT_NAME = "$(TARGET_NAME)"; + TEST_HOST = "$(BUNDLE_LOADER)"; + WRAPPER_EXTENSION = octest; + }; + name = Debug; + }; + 2E577CB614F952E400914F56 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + BUNDLE_LOADER = "$(BUILT_PRODUCTS_DIR)/iNapi.app/Contents/MacOS/iNapi"; + FRAMEWORK_SEARCH_PATHS = "$(DEVELOPER_LIBRARY_DIR)/Frameworks"; + GCC_PRECOMPILE_PREFIX_HEADER = YES; + GCC_PREFIX_HEADER = "iNapi/iNapi-Prefix.pch"; + INFOPLIST_FILE = "iNapiTests/iNapiTests-Info.plist"; + PRODUCT_NAME = "$(TARGET_NAME)"; + TEST_HOST = "$(BUNDLE_LOADER)"; + WRAPPER_EXTENSION = octest; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 2E577C7914F952E300914F56 /* Build configuration list for PBXProject "iNapi" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 2E577CAF14F952E400914F56 /* Debug */, + 2E577CB014F952E400914F56 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 2E577CB114F952E400914F56 /* Build configuration list for PBXNativeTarget "iNapi" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 2E577CB214F952E400914F56 /* Debug */, + 2E577CB314F952E400914F56 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 2E577CB414F952E400914F56 /* Build configuration list for PBXNativeTarget "iNapiTests" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 2E577CB514F952E400914F56 /* Debug */, + 2E577CB614F952E400914F56 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 2E577C7614F952E300914F56 /* Project object */; +} diff --git a/iNapi/Classes/AppDelegate/INPAppDelegate.h b/iNapi/Classes/AppDelegate/INPAppDelegate.h new file mode 100644 index 0000000..831cfef --- /dev/null +++ b/iNapi/Classes/AppDelegate/INPAppDelegate.h @@ -0,0 +1,17 @@ +// +// INPAppDelegate.h +// iNapi +// +// Created by Wojtek Nagrodzki on 25/02/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import + +@interface INPAppDelegate : NSObject + +@property (assign) IBOutlet NSWindow *window; + +- (IBAction)showPreferences:(id)sender; + +@end diff --git a/iNapi/Classes/AppDelegate/INPAppDelegate.m b/iNapi/Classes/AppDelegate/INPAppDelegate.m new file mode 100644 index 0000000..4231a1f --- /dev/null +++ b/iNapi/Classes/AppDelegate/INPAppDelegate.m @@ -0,0 +1,139 @@ +// +// INPAppDelegate.m +// iNapi +// +// Created by Wojtek Nagrodzki on 25/02/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import "INPAppDelegate.h" +#import "INPPreferencesWindowController.h" +#import "INPMovieFilter.h" +#import "INSubtitleDownloader.h" +#import "INDownloadResult.h" +#import "INPURLCreator.h" + + +@interface INPAppDelegate () + +@property (weak) IBOutlet NSArrayController *downloadResultsArrayController; + +@property (strong, nonatomic) INSubtitleDownloader * subtitleDownloader; +@property (strong, nonatomic) INPURLCreator * urlCreator; +@property (strong, nonatomic) INPMovieFilter * movieFilter; +@property (strong, nonatomic) INPPreferencesWindowController * preferencesWindowController; +@property (strong, nonatomic) NSMutableArray * downloadResults; +@property (assign, nonatomic) float downloadProgress; + +@end + + +@implementation INPAppDelegate + +- (IBAction)showPreferences:(id)sender +{ + [self.preferencesWindowController.window makeKeyAndOrderFront:self]; +} + +#pragma mark - Private + +- (INSubtitleDownloader *)subtitleDownloader +{ + if (_subtitleDownloader == nil) { + _subtitleDownloader = [[INSubtitleDownloader alloc] init]; + _subtitleDownloader.delegate = self; + } + return _subtitleDownloader; +} + +- (INPURLCreator *)urlCreator +{ + if (_urlCreator == nil) { + _urlCreator = [[INPURLCreator alloc] init]; + } + + return _urlCreator; +} + +- (INPMovieFilter *)movieFilter +{ + if (_movieFilter == nil) { + _movieFilter = [[INPMovieFilter alloc] init]; + } + + return _movieFilter; +} + +- (INPPreferencesWindowController *)preferencesWindowController +{ + if (_preferencesWindowController == nil) { + _preferencesWindowController = [[INPPreferencesWindowController alloc] initWithWindowNibName:@"INPPreferencesWindow"]; + } + + return _preferencesWindowController; +} + +- (NSMutableArray *)downloadResults +{ + if (_downloadResults == nil) { + _downloadResults = [NSMutableArray array]; + } + + return _downloadResults; +} + +#pragma mark - Notifications + +- (void)applicationDidFinishLaunching:(NSNotification *)aNotification +{ + +} + +#pragma mark - NSApplicationDelegate + +- (BOOL)applicationShouldHandleReopen:(NSApplication *)theApplication hasVisibleWindows:(BOOL)flag +{ + if (!flag) { + [self.window makeKeyAndOrderFront:self]; + return NO; + } + + return YES; +} + +- (void)application:(NSApplication *)sender openFiles:(NSArray *)filenames +{ + [self.downloadResultsArrayController removeObjects:self.downloadResults]; + + self.downloadProgress = 0; + + if ([INPPreferencesWindowController showMainWindow] == YES) { + [self.window makeKeyAndOrderFront:self]; + } + + self.movieFilter = [[INPMovieFilter alloc] init]; + NSArray * array = [self.movieFilter moviePathsAmongFilePaths:filenames]; + + for (NSString * path in array) { + NSURL * movieURL = [NSURL fileURLWithPath:path]; + NSURL * subtitlesURL = [self.urlCreator iNapiURLForMovie:path language:[INPPreferencesWindowController subtitleLanguage]]; + [self.subtitleDownloader downloadSubtitlesAtURL:subtitlesURL forMovieAtURL:movieURL completionHandler:^(NSURL *downloadedSubtitlesURL, NSError *error) { + INDownloadResult * result = [[INDownloadResult alloc] initWithDownloadedSubtitlesURL:downloadedSubtitlesURL error:error]; + [self.downloadResultsArrayController addObject:result]; + self.downloadProgress += 1.0 / array.count; + }]; + } + + if ([INPPreferencesWindowController quitINapi] == YES) { + [NSApp terminate:self]; + } +} + +#pragma mark - INSubtitleDownloaderDelegate + +- (BOOL)subtitleDownloader:(INSubtitleDownloader *)subtitleDownloader shouldArchivePreviousSubtitlesAtURL:(NSURL *)oldSubtitlesURL forMovieAtURL:(NSURL *)movieURL +{ + return [INPPreferencesWindowController archivePreviousSubtitles]; +} + +@end diff --git a/iNapi/Classes/AppDelegate/MainMenu.xib b/iNapi/Classes/AppDelegate/MainMenu.xib new file mode 100644 index 0000000..f7bb6cc --- /dev/null +++ b/iNapi/Classes/AppDelegate/MainMenu.xib @@ -0,0 +1,3678 @@ + + + + 1080 + 12A269 + 2549 + 1187 + 624.00 + + com.apple.InterfaceBuilder.CocoaPlugin + 2549 + + + NSArrayController + NSButton + NSButtonCell + NSCustomObject + NSImageCell + NSMenu + NSMenuItem + NSProgressIndicator + NSScrollView + NSScroller + NSTableColumn + NSTableView + NSTextFieldCell + NSView + NSWindowTemplate + + + com.apple.InterfaceBuilder.CocoaPlugin + + + PluginDependencyRecalculationVersion + + + + + NSApplication + + + FirstResponder + + + NSApplication + + + AMainMenu + + + + iNapi + + 1048576 + 2147483647 + + NSImage + NSMenuCheckmark + + + NSImage + NSMenuMixedState + + submenuAction: + + iNapi + + + + About iNapi + + 2147483647 + + + + + + YES + YES + + + 1048576 + 2147483647 + + + + + + Preferences… + , + 1048576 + 2147483647 + + + + + + YES + YES + + + 1048576 + 2147483647 + + + + + + Services + + 1048576 + 2147483647 + + + submenuAction: + + Services + + _NSServicesMenu + + + + + YES + YES + + + 1048576 + 2147483647 + + + + + + Hide iNapi + h + 1048576 + 2147483647 + + + + + + Hide Others + h + 1572864 + 2147483647 + + + + + + Show All + + 1048576 + 2147483647 + + + + + + YES + YES + + + 1048576 + 2147483647 + + + + + + Quit iNapi + q + 1048576 + 2147483647 + + + + + _NSAppleMenu + + + + + File + + 1048576 + 2147483647 + + + submenuAction: + + File + + + + New + n + 1048576 + 2147483647 + + + + + + Open… + o + 1048576 + 2147483647 + + + + + + Open Recent + + 1048576 + 2147483647 + + + submenuAction: + + Open Recent + + + + Clear Menu + + 1048576 + 2147483647 + + + + + _NSRecentDocumentsMenu + + + + + YES + YES + + + 1048576 + 2147483647 + + + + + + Close + w + 1048576 + 2147483647 + + + + + + Save… + s + 1048576 + 2147483647 + + + + + + Revert to Saved + + 2147483647 + + + + + + YES + YES + + + 1048576 + 2147483647 + + + + + + Page Setup... + P + 1179648 + 2147483647 + + + + + + + Print… + p + 1048576 + 2147483647 + + + + + + + + + Edit + + 1048576 + 2147483647 + + + submenuAction: + + Edit + + + + Undo + z + 1048576 + 2147483647 + + + + + + Redo + Z + 1179648 + 2147483647 + + + + + + YES + YES + + + 1048576 + 2147483647 + + + + + + Cut + x + 1048576 + 2147483647 + + + + + + Copy + c + 1048576 + 2147483647 + + + + + + Paste + v + 1048576 + 2147483647 + + + + + + Paste and Match Style + V + 1572864 + 2147483647 + + + + + + Delete + + 1048576 + 2147483647 + + + + + + Select All + a + 1048576 + 2147483647 + + + + + + YES + YES + + + 1048576 + 2147483647 + + + + + + Find + + 1048576 + 2147483647 + + + submenuAction: + + Find + + + + Find… + f + 1048576 + 2147483647 + + + 1 + + + + Find and Replace… + f + 1572864 + 2147483647 + + + 12 + + + + Find Next + g + 1048576 + 2147483647 + + + 2 + + + + Find Previous + G + 1179648 + 2147483647 + + + 3 + + + + Use Selection for Find + e + 1048576 + 2147483647 + + + 7 + + + + Jump to Selection + j + 1048576 + 2147483647 + + + + + + + + + Spelling and Grammar + + 1048576 + 2147483647 + + + submenuAction: + + Spelling and Grammar + + + + Show Spelling and Grammar + : + 1048576 + 2147483647 + + + + + + Check Document Now + ; + 1048576 + 2147483647 + + + + + + YES + YES + + + 2147483647 + + + + + + Check Spelling While Typing + + 1048576 + 2147483647 + + + + + + Check Grammar With Spelling + + 1048576 + 2147483647 + + + + + + Correct Spelling Automatically + + 2147483647 + + + + + + + + + Substitutions + + 1048576 + 2147483647 + + + submenuAction: + + Substitutions + + + + Show Substitutions + + 2147483647 + + + + + + YES + YES + + + 2147483647 + + + + + + Smart Copy/Paste + f + 1048576 + 2147483647 + + + 1 + + + + Smart Quotes + g + 1048576 + 2147483647 + + + 2 + + + + Smart Dashes + + 2147483647 + + + + + + Smart Links + G + 1179648 + 2147483647 + + + 3 + + + + Text Replacement + + 2147483647 + + + + + + + + + Transformations + + 2147483647 + + + submenuAction: + + Transformations + + + + Make Upper Case + + 2147483647 + + + + + + Make Lower Case + + 2147483647 + + + + + + Capitalize + + 2147483647 + + + + + + + + + Speech + + 1048576 + 2147483647 + + + submenuAction: + + Speech + + + + Start Speaking + + 1048576 + 2147483647 + + + + + + Stop Speaking + + 1048576 + 2147483647 + + + + + + + + + + + + Format + + 2147483647 + + + submenuAction: + + Format + + + + Font + + 2147483647 + + + submenuAction: + + Font + + + + Show Fonts + t + 1048576 + 2147483647 + + + + + + Bold + b + 1048576 + 2147483647 + + + 2 + + + + Italic + i + 1048576 + 2147483647 + + + 1 + + + + Underline + u + 1048576 + 2147483647 + + + + + + YES + YES + + + 2147483647 + + + + + + Bigger + + + 1048576 + 2147483647 + + + 3 + + + + Smaller + - + 1048576 + 2147483647 + + + 4 + + + + YES + YES + + + 2147483647 + + + + + + Kern + + 2147483647 + + + submenuAction: + + Kern + + + + Use Default + + 2147483647 + + + + + + Use None + + 2147483647 + + + + + + Tighten + + 2147483647 + + + + + + Loosen + + 2147483647 + + + + + + + + + Ligature + + 2147483647 + + + submenuAction: + + Ligature + + + + Use Default + + 2147483647 + + + + + + Use None + + 2147483647 + + + + + + Use All + + 2147483647 + + + + + + + + + Baseline + + 2147483647 + + + submenuAction: + + Baseline + + + + Use Default + + 2147483647 + + + + + + Superscript + + 2147483647 + + + + + + Subscript + + 2147483647 + + + + + + Raise + + 2147483647 + + + + + + Lower + + 2147483647 + + + + + + + + + YES + YES + + + 2147483647 + + + + + + Show Colors + C + 1048576 + 2147483647 + + + + + + YES + YES + + + 2147483647 + + + + + + Copy Style + c + 1572864 + 2147483647 + + + + + + Paste Style + v + 1572864 + 2147483647 + + + + + _NSFontMenu + + + + + Text + + 2147483647 + + + submenuAction: + + Text + + + + Align Left + { + 1048576 + 2147483647 + + + + + + Center + | + 1048576 + 2147483647 + + + + + + Justify + + 2147483647 + + + + + + Align Right + } + 1048576 + 2147483647 + + + + + + YES + YES + + + 2147483647 + + + + + + Writing Direction + + 2147483647 + + + submenuAction: + + Writing Direction + + + + YES + Paragraph + + 2147483647 + + + + + + CURlZmF1bHQ + + 2147483647 + + + + + + CUxlZnQgdG8gUmlnaHQ + + 2147483647 + + + + + + CVJpZ2h0IHRvIExlZnQ + + 2147483647 + + + + + + YES + YES + + + 2147483647 + + + + + + YES + Selection + + 2147483647 + + + + + + CURlZmF1bHQ + + 2147483647 + + + + + + CUxlZnQgdG8gUmlnaHQ + + 2147483647 + + + + + + CVJpZ2h0IHRvIExlZnQ + + 2147483647 + + + + + + + + + YES + YES + + + 2147483647 + + + + + + Show Ruler + + 2147483647 + + + + + + Copy Ruler + c + 1310720 + 2147483647 + + + + + + Paste Ruler + v + 1310720 + 2147483647 + + + + + + + + + + + + View + + 1048576 + 2147483647 + + + submenuAction: + + View + + + + Show Toolbar + t + 1572864 + 2147483647 + + + + + + Customize Toolbar… + + 1048576 + 2147483647 + + + + + + + + + Window + + 1048576 + 2147483647 + + + submenuAction: + + Window + + + + Minimize + m + 1048576 + 2147483647 + + + + + + Zoom + + 1048576 + 2147483647 + + + + + + YES + YES + + + 1048576 + 2147483647 + + + + + + Bring All to Front + + 1048576 + 2147483647 + + + + + _NSWindowsMenu + + + + + Help + + 2147483647 + + + submenuAction: + + Help + + + + iNapi Help + ? + 1048576 + 2147483647 + + + + + _NSHelpMenu + + + + _NSMainMenu + + + 15 + 2 + {{335, 390}, {400, 160}} + 1954021376 + iNapi + NSWindow + + + {400, 160} + + + 256 + + + + 274 + + + + 2304 + + + + 256 + {400, 128} + + + + _NS:1828 + YES + NO + YES + + + -2147483392 + {{224, 0}, {16, 17}} + _NS:1833 + + + + DownloadStatusImage + 25 + 25 + 25 + + 75497536 + 2048 + + + LucidaGrande + 11 + 3100 + + + 3 + MC4zMzMzMzI5ODU2AA + + + 6 + System + headerTextColor + + 3 + MAA + + + + + 134217728 + 33685504 + _NS:4001 + 0 + 0 + 0 + NO + + 3 + YES + + + + MovieFilename + 369 + 40 + 1000 + + 75497536 + 2048 + + + LucidaGrande + 11 + 16 + + + + + + 337641536 + 133120 + Text Cell + + + + 6 + System + controlBackgroundColor + + 3 + MC42NjY2NjY2NjY3AA + + + + 6 + System + controlTextColor + + + + 3 + YES + + + + 3 + 2 + + 3 + MQA + + + 6 + System + gridColor + + 3 + MC41AA + + + 14 + 1455423488 + + + 4 + 15 + 0 + YES + 0 + 1 + + + {400, 128} + + + + _NS:1826 + + + 4 + + + + -2147483392 + {{224, 17}, {15, 102}} + + + + _NS:1845 + NO + + _doScroller: + 0.99310344827586206 + + + + -2147483392 + {{0, 113}, {400, 15}} + + + + _NS:1847 + NO + 1 + + _doScroller: + 0.99750623441396513 + + + {{0, 32}, {400, 128}} + + + + _NS:1824 + 133680 + + + + QSAAAEEgAABBgAAAQYAAAA + 0.25 + 4 + 1 + + + + 1314 + {{19, 9}, {272, 12}} + + + + _NS:2352 + 16648 + 1 + + + + 289 + {{298, 7}, {82, 18}} + + + + _NS:687 + YES + + 67108864 + 134348800 + Hide + + _NS:687 + + -2038284288 + 160 + + + 200 + 25 + + NO + + + {400, 160} + + + + + {{0, 0}, {1680, 1028}} + {400, 182} + {10000000000000, 10000000000000} + MainWindow + NO + 32 + YES + + + INPAppDelegate + + + NSFontManager + + + YES + + YES + YES + YES + YES + YES + + + + + + + terminate: + + + + 449 + + + + orderFrontStandardAboutPanel: + + + + 142 + + + + delegate + + + + 495 + + + + performMiniaturize: + + + + 37 + + + + arrangeInFront: + + + + 39 + + + + print: + + + + 86 + + + + runPageLayout: + + + + 87 + + + + clearRecentDocuments: + + + + 127 + + + + performClose: + + + + 193 + + + + toggleContinuousSpellChecking: + + + + 222 + + + + undo: + + + + 223 + + + + copy: + + + + 224 + + + + checkSpelling: + + + + 225 + + + + paste: + + + + 226 + + + + stopSpeaking: + + + + 227 + + + + cut: + + + + 228 + + + + showGuessPanel: + + + + 230 + + + + redo: + + + + 231 + + + + selectAll: + + + + 232 + + + + startSpeaking: + + + + 233 + + + + delete: + + + + 235 + + + + performZoom: + + + + 240 + + + + performFindPanelAction: + + + + 241 + + + + centerSelectionInVisibleArea: + + + + 245 + + + + toggleGrammarChecking: + + + + 347 + + + + toggleSmartInsertDelete: + + + + 355 + + + + toggleAutomaticQuoteSubstitution: + + + + 356 + + + + toggleAutomaticLinkDetection: + + + + 357 + + + + saveDocument: + + + + 362 + + + + revertDocumentToSaved: + + + + 364 + + + + runToolbarCustomizationPalette: + + + + 365 + + + + toggleToolbarShown: + + + + 366 + + + + hide: + + + + 367 + + + + hideOtherApplications: + + + + 368 + + + + unhideAllApplications: + + + + 370 + + + + newDocument: + + + + 373 + + + + openDocument: + + + + 374 + + + + raiseBaseline: + + + + 426 + + + + lowerBaseline: + + + + 427 + + + + copyFont: + + + + 428 + + + + subscript: + + + + 429 + + + + superscript: + + + + 430 + + + + tightenKerning: + + + + 431 + + + + underline: + + + + 432 + + + + orderFrontColorPanel: + + + + 433 + + + + useAllLigatures: + + + + 434 + + + + loosenKerning: + + + + 435 + + + + pasteFont: + + + + 436 + + + + unscript: + + + + 437 + + + + useStandardKerning: + + + + 438 + + + + useStandardLigatures: + + + + 439 + + + + turnOffLigatures: + + + + 440 + + + + turnOffKerning: + + + + 441 + + + + toggleAutomaticSpellingCorrection: + + + + 456 + + + + orderFrontSubstitutionsPanel: + + + + 458 + + + + toggleAutomaticDashSubstitution: + + + + 461 + + + + toggleAutomaticTextReplacement: + + + + 463 + + + + uppercaseWord: + + + + 464 + + + + capitalizeWord: + + + + 467 + + + + lowercaseWord: + + + + 468 + + + + pasteAsPlainText: + + + + 486 + + + + performFindPanelAction: + + + + 487 + + + + performFindPanelAction: + + + + 488 + + + + performFindPanelAction: + + + + 489 + + + + showHelp: + + + + 493 + + + + alignCenter: + + + + 518 + + + + pasteRuler: + + + + 519 + + + + toggleRuler: + + + + 520 + + + + alignRight: + + + + 521 + + + + copyRuler: + + + + 522 + + + + alignJustified: + + + + 523 + + + + alignLeft: + + + + 524 + + + + makeBaseWritingDirectionNatural: + + + + 525 + + + + makeBaseWritingDirectionLeftToRight: + + + + 526 + + + + makeBaseWritingDirectionRightToLeft: + + + + 527 + + + + makeTextWritingDirectionNatural: + + + + 528 + + + + makeTextWritingDirectionLeftToRight: + + + + 529 + + + + makeTextWritingDirectionRightToLeft: + + + + 530 + + + + performFindPanelAction: + + + + 535 + + + + addFontTrait: + + + + 421 + + + + addFontTrait: + + + + 422 + + + + modifyFont: + + + + 423 + + + + orderFrontFontPanel: + + + + 424 + + + + modifyFont: + + + + 425 + + + + window + + + + 532 + + + + showPreferences: + + + + 553 + + + + downloadResultsArrayController + + + + 555 + + + + value: arrangedObjects.downloadResultImage + + + + + + value: arrangedObjects.downloadResultImage + value + arrangedObjects.downloadResultImage + 2 + + + 561 + + + + value: arrangedObjects.movieFileName + + + + + + value: arrangedObjects.movieFileName + value + arrangedObjects.movieFileName + 2 + + + 560 + + + + value: downloadProgress + + + + + + value: downloadProgress + value + downloadProgress + 2 + + + 562 + + + + contentArray: downloadResults + + + + + + contentArray: downloadResults + contentArray + downloadResults + 2 + + + 556 + + + + + + 0 + + + + + + -2 + + + File's Owner + + + -1 + + + First Responder + + + -3 + + + Application + + + 29 + + + + + + + + + + + + + + 19 + + + + + + + + 56 + + + + + + + + 217 + + + + + + + + 83 + + + + + + + + 81 + + + + + + + + + + + + + + + + + 75 + + + + + 78 + + + + + 72 + + + + + 82 + + + + + 124 + + + + + + + + 77 + + + + + 73 + + + + + 79 + + + + + 112 + + + + + 74 + + + + + 125 + + + + + + + + 126 + + + + + 205 + + + + + + + + + + + + + + + + + + + + + + 202 + + + + + 198 + + + + + 207 + + + + + 214 + + + + + 199 + + + + + 203 + + + + + 197 + + + + + 206 + + + + + 215 + + + + + 218 + + + + + + + + 216 + + + + + + + + 200 + + + + + + + + + + + + + 219 + + + + + 201 + + + + + 204 + + + + + 220 + + + + + + + + + + + + + 213 + + + + + 210 + + + + + 221 + + + + + 208 + + + + + 209 + + + + + 57 + + + + + + + + + + + + + + + + + + 58 + + + + + 134 + + + + + 150 + + + + + 136 + + + + + 144 + + + + + 129 + + + + + 143 + + + + + 236 + + + + + 131 + + + + + + + + 149 + + + + + 145 + + + + + 130 + + + + + 24 + + + + + + + + + + + 92 + + + + + 5 + + + + + 239 + + + + + 23 + + + + + 295 + + + + + + + + 296 + + + + + + + + + 297 + + + + + 298 + + + + + 211 + + + + + + + + 212 + + + + + + + + + 195 + + + + + 196 + + + + + 346 + + + + + 348 + + + + + + + + 349 + + + + + + + + + + + + + + 350 + + + + + 351 + + + + + 354 + + + + + 371 + + + + + + + + 372 + + + + + + + + + + 375 + + + + + + + + 376 + + + + + + + + + 377 + + + + + + + + 388 + + + + + + + + + + + + + + + + + + + + + + + 389 + + + + + 390 + + + + + 391 + + + + + 392 + + + + + 393 + + + + + 394 + + + + + 395 + + + + + 396 + + + + + 397 + + + + + + + + 398 + + + + + + + + 399 + + + + + + + + 400 + + + + + 401 + + + + + 402 + + + + + 403 + + + + + 404 + + + + + 405 + + + + + + + + + + + + 406 + + + + + 407 + + + + + 408 + + + + + 409 + + + + + 410 + + + + + 411 + + + + + + + + + + 412 + + + + + 413 + + + + + 414 + + + + + 415 + + + + + + + + + + + 416 + + + + + 417 + + + + + 418 + + + + + 419 + + + + + 420 + + + + + 450 + + + + + + + + 451 + + + + + + + + + + 452 + + + + + 453 + + + + + 454 + + + + + 457 + + + + + 459 + + + + + 460 + + + + + 462 + + + + + 465 + + + + + 466 + + + + + 485 + + + + + 490 + + + + + + + + 491 + + + + + + + + 492 + + + + + 494 + + + + + 496 + + + + + + + + 497 + + + + + + + + + + + + + + + + + 498 + + + + + 499 + + + + + 500 + + + + + 501 + + + + + 502 + + + + + 503 + + + + + + + + 504 + + + + + 505 + + + + + 506 + + + + + 507 + + + + + 508 + + + + + + + + + + + + + + + + 509 + + + + + 510 + + + + + 511 + + + + + 512 + + + + + 513 + + + + + 514 + + + + + 515 + + + + + 516 + + + + + 517 + + + + + 534 + + + + + 536 + + + + + + + + + + 537 + + + + + + + + + 538 + + + + + 540 + + + + + 541 + + + + + + + + 542 + + + + + + + + 543 + + + + + 545 + + + + + 546 + + + + + 549 + + + + + + + + 550 + + + + + 554 + + + + + + + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + {{380, 496}, {480, 360}} + + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + + + + + + 562 + + + + + INPAppDelegate + NSObject + + showPreferences: + id + + + showPreferences: + + showPreferences: + id + + + + NSArrayController + NSWindow + + + + downloadResultsArrayController + NSArrayController + + + window + NSWindow + + + + IBProjectSource + ./Classes/INPAppDelegate.h + + + + NSDocument + + id + id + id + id + id + id + + + + printDocument: + id + + + revertDocumentToSaved: + id + + + runPageLayout: + id + + + saveDocument: + id + + + saveDocumentAs: + id + + + saveDocumentTo: + id + + + + IBProjectSource + ./Classes/NSDocument.h + + + + + 0 + IBCocoaFramework + YES + 3 + + {11, 11} + {10, 3} + + + diff --git a/iNapi/Classes/Controllers/INPPreferencesWindow.xib b/iNapi/Classes/Controllers/INPPreferencesWindow.xib new file mode 100644 index 0000000..622c5be --- /dev/null +++ b/iNapi/Classes/Controllers/INPPreferencesWindow.xib @@ -0,0 +1,1106 @@ + + + + 1070 + 11D50 + 1938 + 1138.32 + 568.00 + + com.apple.InterfaceBuilder.CocoaPlugin + 1938 + + + YES + NSTextField + NSView + NSWindowTemplate + NSCustomObject + NSMenu + NSMenuItem + NSPopUpButton + NSPopUpButtonCell + NSButtonCell + NSButton + NSTextFieldCell + + + YES + com.apple.InterfaceBuilder.CocoaPlugin + + + PluginDependencyRecalculationVersion + + + + YES + + INPPreferencesWindowController + + + FirstResponder + + + NSApplication + + + 19 + 2 + {{120, 120}, {400, 190}} + -1535638528 + Preferences + NSPanel + + + + + 256 + + YES + + + 268 + {{17, 153}, {176, 17}} + + + + _NS:3944 + YES + + 68288064 + 71304192 + Language + + LucidaGrande + 13 + 1044 + + _NS:3944 + + + 6 + System + controlColor + + 3 + MC42NjY2NjY2NjY3AA + + + + 6 + System + controlTextColor + + 3 + MAA + + + + + + + 268 + {{207, 149}, {176, 22}} + + + + _NS:868 + YES + + -2076049856 + 133120 + + LucidaGrande + 11 + 3100 + + _NS:868 + + 109199615 + 129 + + + 400 + 75 + + + Item 1 + + 1048576 + 2147483647 + 1 + + NSImage + NSMenuCheckmark + + + NSImage + NSMenuMixedState + + _popUpItemAction: + + + YES + + OtherViews + + YES + + + + Item 2 + + 1048576 + 2147483647 + + + _popUpItemAction: + + + + + Item 3 + + 1048576 + 2147483647 + + + _popUpItemAction: + + + + + + 1 + YES + YES + 2 + + + + + 268 + {{17, 128}, {176, 17}} + + + + _NS:3944 + YES + + 68288064 + 71304192 + Subtitles + + _NS:3944 + + + + + + + + 268 + {{208, 127}, {174, 18}} + + + + _NS:771 + YES + + -2080244224 + 0 + Convert to UTF8 + + _NS:771 + + 1211912703 + 2 + + NSImage + NSSwitch + + + NSSwitch + + + + 200 + 25 + + + + + 268 + {{208, 107}, {174, 18}} + + + + _NS:771 + YES + + -2080244224 + 0 + Archive previous + + _NS:771 + + 1211912703 + 2 + + + + + 200 + 25 + + + + + 268 + {{208, 87}, {174, 18}} + + + + _NS:771 + YES + + -2080244224 + 0 + Create SRT copy + + _NS:771 + + 1211912703 + 2 + + + + + 200 + 25 + + + + + 268 + {{17, 20}, {176, 17}} + + + + _NS:3944 + YES + + 68288064 + 71304192 + After download + + _NS:3944 + + + + + + + + 268 + {{208, 19}, {174, 18}} + + + + _NS:771 + YES + + -2080244224 + 0 + Quit iNapi + + _NS:771 + + 1211912703 + 2 + + + + + 200 + 25 + + + + + 268 + {{17, 64}, {176, 17}} + + + + _NS:3944 + YES + + 68288064 + 71304192 + During download + + _NS:3944 + + + + + + + + 268 + {{208, 63}, {174, 18}} + + + + _NS:771 + YES + + -2080244224 + 0 + Show main window + + _NS:771 + + 1211912703 + 2 + + + + + 200 + 25 + + + + + 268 + {{208, 43}, {174, 18}} + + + + _NS:771 + YES + + -2080244224 + 0 + Use Growl + + _NS:771 + + 1211912703 + 2 + + + + + 200 + 25 + + + + {400, 190} + + + + _NS:207 + + {{0, 0}, {1280, 778}} + {10000000000000, 10000000000000} + PreferencesWindow + YES + + + + + YES + + + window + + + + 5 + + + + subtitleLanguageLabel + + + + 50 + + + + subtitlesLabel + + + + 51 + + + + archivePreviousButton + + + + 54 + + + + createSRTCopyButton + + + + 55 + + + + duringDownloadLabel + + + + 56 + + + + showMainWindowButton + + + + 57 + + + + useGrowlButton + + + + 58 + + + + afterDownloadLabel + + + + 60 + + + + quitINapiButton + + + + 61 + + + + convertToUTF8Button + + + + 53 + + + + content: languages + + + + + + content: languages + content + languages + 2 + + + 147 + + + + selectedTag: selectedLanguageIndex + + + + + + selectedTag: selectedLanguageIndex + selectedTag + selectedLanguageIndex + + 2 + + + 148 + + + + value: convertToUTF8 + + + + + + value: convertToUTF8 + value + convertToUTF8 + 2 + + + 131 + + + + value: convertToUTF8 + + + + + + value: convertToUTF8 + value + convertToUTF8 + 2 + + + 130 + + + + value: archivePreviousSubtitles + + + + + + value: archivePreviousSubtitles + value + archivePreviousSubtitles + 2 + + + 64 + + + + value: createSRTCopy + + + + + + value: createSRTCopy + value + createSRTCopy + 2 + + + 65 + + + + value: quitINapi + + + + + + value: quitINapi + value + quitINapi + 2 + + + 68 + + + + value: showMainWindow + + + + + + value: showMainWindow + value + showMainWindow + 2 + + + 66 + + + + value: useGrowl + + + + + + value: useGrowl + value + useGrowl + 2 + + + 67 + + + + + YES + + 0 + + YES + + + + + + -2 + + + File's Owner + + + -1 + + + First Responder + + + -3 + + + Application + + + 3 + + + YES + + + + + + 4 + + + YES + + + + + + + + + + + + + + + + 6 + + + YES + + + + + + 7 + + + + + 8 + + + YES + + + + + + 9 + + + YES + + + + + + 10 + + + YES + + + + + + + + 11 + + + + + 12 + + + + + 13 + + + + + 26 + + + YES + + + + + + 27 + + + + + 30 + + + YES + + + + + + 31 + + + + + 32 + + + YES + + + + + + 33 + + + + + 40 + + + YES + + + + + + 41 + + + + + 42 + + + YES + + + + + + 43 + + + + + 44 + + + YES + + + + + + 45 + + + + + 46 + + + YES + + + + + + 47 + + + + + 48 + + + YES + + + + + + 49 + + + + + 28 + + + YES + + + + + + 29 + + + + + + + YES + + YES + -1.IBPluginDependency + -2.IBPluginDependency + -3.IBPluginDependency + 10.IBPluginDependency + 11.IBPluginDependency + 12.IBPluginDependency + 13.IBPluginDependency + 26.IBPluginDependency + 27.IBPluginDependency + 28.IBPluginDependency + 29.IBPluginDependency + 3.IBPluginDependency + 3.NSWindowTemplate.visibleAtLaunch + 30.IBPluginDependency + 31.IBPluginDependency + 32.IBPluginDependency + 33.IBPluginDependency + 4.IBPluginDependency + 40.IBPluginDependency + 41.IBPluginDependency + 42.IBPluginDependency + 43.IBPluginDependency + 44.IBPluginDependency + 45.IBPluginDependency + 46.IBPluginDependency + 47.IBPluginDependency + 48.IBPluginDependency + 49.IBPluginDependency + 6.IBPluginDependency + 7.IBPluginDependency + 8.IBPluginDependency + 9.IBPluginDependency + + + YES + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + com.apple.InterfaceBuilder.CocoaPlugin + + + + YES + + + + + + YES + + + + + 148 + + + + YES + + INPPreferencesWindowController + NSWindowController + + YES + + YES + afterDownloadLabel + archivePreviousButton + convertToUTF8Button + createSRTCopyButton + duringDownloadLabel + quitINapiButton + showMainWindowButton + subtitleLanguageLabel + subtitlesLabel + useGrowlButton + + + YES + NSTextField + NSButton + NSButton + NSButton + NSTextField + NSButton + NSButton + NSTextField + NSTextField + NSButton + + + + YES + + YES + afterDownloadLabel + archivePreviousButton + convertToUTF8Button + createSRTCopyButton + duringDownloadLabel + quitINapiButton + showMainWindowButton + subtitleLanguageLabel + subtitlesLabel + useGrowlButton + + + YES + + afterDownloadLabel + NSTextField + + + archivePreviousButton + NSButton + + + convertToUTF8Button + NSButton + + + createSRTCopyButton + NSButton + + + duringDownloadLabel + NSTextField + + + quitINapiButton + NSButton + + + showMainWindowButton + NSButton + + + subtitleLanguageLabel + NSTextField + + + subtitlesLabel + NSTextField + + + useGrowlButton + NSButton + + + + + IBProjectSource + ./Classes/INPPreferencesWindowController.h + + + + + 0 + IBCocoaFramework + + com.apple.InterfaceBuilder.CocoaPlugin.InterfaceBuilder3 + + + YES + 3 + + YES + + YES + NSMenuCheckmark + NSMenuMixedState + NSSwitch + + + YES + {11, 11} + {10, 3} + {15, 15} + + + + diff --git a/iNapi/Classes/Controllers/INPPreferencesWindowController.h b/iNapi/Classes/Controllers/INPPreferencesWindowController.h new file mode 100644 index 0000000..e4abb6b --- /dev/null +++ b/iNapi/Classes/Controllers/INPPreferencesWindowController.h @@ -0,0 +1,21 @@ +// +// INPPreferencesWindowController.h +// iNapi +// +// Created by Wojtek Nagrodzki on 25/02/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import + +@interface INPPreferencesWindowController : NSWindowController + ++ (NSString *)subtitleLanguage; ++ (BOOL)convertToUTF8; ++ (BOOL)archivePreviousSubtitles; ++ (BOOL)createSRTCopy; ++ (BOOL)showMainWindow; ++ (BOOL)useGrowl; ++ (BOOL)quitINapi; + +@end diff --git a/iNapi/Classes/Controllers/INPPreferencesWindowController.m b/iNapi/Classes/Controllers/INPPreferencesWindowController.m new file mode 100644 index 0000000..f1ca00c --- /dev/null +++ b/iNapi/Classes/Controllers/INPPreferencesWindowController.m @@ -0,0 +1,220 @@ +// +// INPPreferencesWindowController.m +// iNapi +// +// Created by Wojtek Nagrodzki on 25/02/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import "INPPreferencesWindowController.h" + + +static NSString * const INPPreferencesWindowControllerConvertToUTF8Key = @"INPPreferencesWindowControllerConvertToUTF8"; +static NSString * const INPPreferencesWindowControllerArchivePreviousSubtitlesKey = @"INPPreferencesWindowControllerArchivePreviousSubtitles"; +static NSString * const INPPreferencesWindowControllerCreateSRTCopyKey = @"INPPreferencesWindowControllerCreateSRTCopy"; +static NSString * const INPPreferencesWindowControllerShowMainWindowKey = @"INPPreferencesWindowControllerShowMainWindow"; +static NSString * const INPPreferencesWindowControllerUseGrowlKey = @"INPPreferencesWindowControllerUseGrowl"; +static NSString * const INPPreferencesWindowControllerQuitINapiKey = @"INPPreferencesWindowControllerQuitINapi"; +static NSString * const INPPreferencesWindowControllerSelectedLanguageIndexKey = @"INPPreferencesWindowControllerSelectedLanguageIndexKey"; + + +@interface INPPreferencesWindowController () + +@property (assign, nonatomic) BOOL convertToUTF8; +@property (assign, nonatomic) BOOL archivePreviousSubtitles; +@property (assign, nonatomic) BOOL createSRTCopy; +@property (assign, nonatomic) BOOL showMainWindow; +@property (assign, nonatomic) BOOL useGrowl; +@property (assign, nonatomic) BOOL quitINapi; + +@property (copy, nonatomic) NSArray * languages; +@property (assign, nonatomic) NSInteger selectedLanguageIndex; + +- (void)localizeUserInterface; + +@property (weak) IBOutlet NSTextField *subtitleLanguageLabel; +@property (weak) IBOutlet NSTextField *subtitlesLabel; +@property (weak) IBOutlet NSButton *convertToUTF8Button; +@property (weak) IBOutlet NSButton *archivePreviousButton; +@property (weak) IBOutlet NSButton *createSRTCopyButton; +@property (weak) IBOutlet NSTextField *duringDownloadLabel; +@property (weak) IBOutlet NSButton *showMainWindowButton; +@property (weak) IBOutlet NSButton *useGrowlButton; +@property (weak) IBOutlet NSTextField *afterDownloadLabel; +@property (weak) IBOutlet NSButton *quitINapiButton; + +@end + + +@implementation INPPreferencesWindowController + +@synthesize subtitleLanguageLabel; +@synthesize subtitlesLabel; +@synthesize convertToUTF8Button; +@synthesize archivePreviousButton; +@synthesize createSRTCopyButton; +@synthesize duringDownloadLabel; +@synthesize showMainWindowButton; +@synthesize useGrowlButton; +@synthesize afterDownloadLabel; +@synthesize quitINapiButton; + +// Private +@synthesize convertToUTF8; +@synthesize archivePreviousSubtitles; +@synthesize createSRTCopy; +@synthesize showMainWindow; +@synthesize useGrowl; +@synthesize quitINapi; +@synthesize languages; +@synthesize selectedLanguageIndex; + +#pragma mark - Class methods + ++ (NSString *)subtitleLanguage +{ + NSInteger selectedLanguageIndex = [[NSUserDefaults standardUserDefaults] integerForKey:INPPreferencesWindowControllerSelectedLanguageIndexKey]; + NSArray * languageCodes = [NSArray arrayWithObjects:@"PL", @"EN", nil]; + + return [languageCodes objectAtIndex:selectedLanguageIndex]; +} + ++ (BOOL)convertToUTF8 +{ + return [[NSUserDefaults standardUserDefaults] boolForKey:INPPreferencesWindowControllerConvertToUTF8Key]; +} + ++ (BOOL)archivePreviousSubtitles +{ + return [[NSUserDefaults standardUserDefaults] boolForKey:INPPreferencesWindowControllerArchivePreviousSubtitlesKey]; +} + ++ (BOOL)createSRTCopy +{ + return [[NSUserDefaults standardUserDefaults] boolForKey:INPPreferencesWindowControllerCreateSRTCopyKey]; +} + ++ (BOOL)showMainWindow +{ + return [[NSUserDefaults standardUserDefaults] boolForKey:INPPreferencesWindowControllerShowMainWindowKey]; +} + ++ (BOOL)useGrowl +{ + return [[NSUserDefaults standardUserDefaults] boolForKey:INPPreferencesWindowControllerUseGrowlKey]; +} + ++ (BOOL)quitINapi +{ + return [[NSUserDefaults standardUserDefaults] boolForKey:INPPreferencesWindowControllerQuitINapiKey]; +} + +#pragma mark - + +- (id)initWithWindow:(NSWindow *)window +{ + self = [super initWithWindow:window]; + if (self) { + NSString * polish = NSLocalizedString(@"Polish", nil); + NSString * english = NSLocalizedString(@"English", nil); + self.languages = [NSArray arrayWithObjects:polish, english, nil]; + } + + return self; +} + +- (void)windowDidLoad +{ + [super windowDidLoad]; + [self localizeUserInterface]; +} + +#pragma mark - Setters/Getters + +- (void)setConvertToUTF8:(BOOL)flag +{ + [[NSUserDefaults standardUserDefaults] setBool:flag forKey:INPPreferencesWindowControllerConvertToUTF8Key]; +} + +- (BOOL)convertToUTF8 +{ + return [[self class] convertToUTF8]; +} + +- (void)setArchivePreviousSubtitles:(BOOL)flag +{ + [[NSUserDefaults standardUserDefaults] setBool:flag forKey:INPPreferencesWindowControllerArchivePreviousSubtitlesKey]; +} + +- (BOOL)archivePreviousSubtitles +{ + return [[self class] archivePreviousSubtitles]; +} + +- (void)setCreateSRTCopy:(BOOL)flag +{ + [[NSUserDefaults standardUserDefaults] setBool:flag forKey:INPPreferencesWindowControllerCreateSRTCopyKey]; +} + +- (BOOL)createSRTCopy +{ + return [[self class] createSRTCopy]; +} + +- (void)setShowMainWindow:(BOOL)flag +{ + [[NSUserDefaults standardUserDefaults] setBool:flag forKey:INPPreferencesWindowControllerShowMainWindowKey]; +} + +- (BOOL)showMainWindow +{ + return [[self class] showMainWindow]; +} + +- (void)setUseGrowl:(BOOL)flag +{ + [[NSUserDefaults standardUserDefaults] setBool:flag forKey:INPPreferencesWindowControllerUseGrowlKey]; +} + +- (BOOL)useGrowl +{ + return [[self class] useGrowl]; +} + +- (void)setQuitINapi:(BOOL)flag +{ + [[NSUserDefaults standardUserDefaults] setBool:flag forKey:INPPreferencesWindowControllerQuitINapiKey]; +} + +- (BOOL)quitINapi +{ + return [[self class] quitINapi]; +} + +- (void)setSelectedLanguageIndex:(NSInteger)newSelectedLanguageIndex +{ + [[NSUserDefaults standardUserDefaults] setInteger:newSelectedLanguageIndex forKey:INPPreferencesWindowControllerSelectedLanguageIndexKey]; +} + +- (NSInteger)selectedLanguageIndex +{ + return [[NSUserDefaults standardUserDefaults] integerForKey:INPPreferencesWindowControllerSelectedLanguageIndexKey]; +} + +#pragma mark - Private + +- (void)localizeUserInterface +{ + self.subtitleLanguageLabel.stringValue = NSLocalizedString(@"Subtitle language", nil); + self.subtitlesLabel.stringValue = NSLocalizedString(@"Subtitles", nil); + self.convertToUTF8Button.title = NSLocalizedString(@"Convert to UTF8", nil); + self.archivePreviousButton.title = NSLocalizedString(@"Archive previous", nil); + self.createSRTCopyButton.title = NSLocalizedString(@"Create SRT copy", nil); + self.duringDownloadLabel.stringValue = NSLocalizedString(@"During download", nil); + self.showMainWindowButton.title = NSLocalizedString(@"Show main window", nil); + self.useGrowlButton.title = NSLocalizedString(@"Use Growl", nil); + self.afterDownloadLabel.stringValue = NSLocalizedString(@"After download", nil); + self.quitINapiButton.title = NSLocalizedString(@"Quit iNapi", nil); +} + +@end diff --git a/iNapi/Classes/Helpers/INPMovieFilter.h b/iNapi/Classes/Helpers/INPMovieFilter.h new file mode 100644 index 0000000..500b3bc --- /dev/null +++ b/iNapi/Classes/Helpers/INPMovieFilter.h @@ -0,0 +1,15 @@ +// +// INPMovieFilter.h +// iNapi +// +// Created by Wojtek Nagrodzki on 03/03/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import + +@interface INPMovieFilter : NSObject + +- (NSArray *)moviePathsAmongFilePaths:(NSArray *)filePaths; + +@end diff --git a/iNapi/Classes/Helpers/INPMovieFilter.m b/iNapi/Classes/Helpers/INPMovieFilter.m new file mode 100644 index 0000000..82630d0 --- /dev/null +++ b/iNapi/Classes/Helpers/INPMovieFilter.m @@ -0,0 +1,100 @@ +// +// INPMovieFilter.m +// iNapi +// +// Created by Wojtek Nagrodzki on 03/03/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import "INPMovieFilter.h" + + +@interface INPMovieFilter () + +@property (strong, nonatomic) NSFileManager * fileManager; + +- (BOOL)fileConformsToMovieUTI:(NSString *)filePath; +- (NSArray *)moviePathsAtDirectory:(NSString *)directoryPath; + +@end + + +@implementation INPMovieFilter + +@synthesize fileManager; + +- (id)init +{ + self = [super init]; + if (self) { + self.fileManager = [NSFileManager defaultManager]; + } + return self; +} + +#pragma mark - Interface + +- (NSArray *)moviePathsAmongFilePaths:(NSArray *)filePaths +{ + NSMutableArray * movies = [NSMutableArray array]; + + BOOL isDirectory; + for (NSString * path in filePaths) { + [fileManager fileExistsAtPath:path isDirectory:&isDirectory]; + + if (isDirectory) { + NSArray * moviePathsAtDirectory = [self moviePathsAtDirectory:path]; + [movies addObjectsFromArray:moviePathsAtDirectory]; + } + else { + if ([self fileConformsToMovieUTI:path]) + [movies addObject:path]; + } + } + + return movies; +} + +#pragma mark - Private + +- (BOOL)fileConformsToMovieUTI:(NSString *)filePath +{ + NSString* targetFilePath_converted = [filePath stringByAddingPercentEscapesUsingEncoding: NSUTF8StringEncoding]; + CFURLRef anUrl = (__bridge CFURLRef)[NSURL URLWithString: targetFilePath_converted]; + FSRef ref; + CFURLGetFSRef(anUrl,&ref); + CFTypeRef outValue; + LSCopyItemAttribute ( + &ref, + kLSRolesAll, + kLSItemContentType, + &outValue + ); + + CFStringRef uti = (__bridge CFStringRef)[NSString stringWithString:(__bridge NSString *)outValue]; + + return UTTypeConformsTo(uti, kUTTypeMovie); +} + +- (NSArray *)moviePathsAtDirectory:(NSString *)directoryPath +{ + NSMutableArray * movies = [NSMutableArray array]; + + NSDirectoryEnumerator* enumerator = [fileManager enumeratorAtPath:directoryPath]; + BOOL isDirectory; + NSString * iPath = nil; + NSString* completeIPath = nil; + + while (iPath = [enumerator nextObject]) { + completeIPath = [[NSString stringWithString:directoryPath] stringByAppendingPathComponent:iPath]; + [fileManager fileExistsAtPath:completeIPath isDirectory: &isDirectory]; + + if (!isDirectory) + if ([self fileConformsToMovieUTI:completeIPath]) + [movies addObject:completeIPath]; + } + + return movies; +} + +@end diff --git a/iNapi/Classes/Helpers/INPURLCreator.h b/iNapi/Classes/Helpers/INPURLCreator.h new file mode 100644 index 0000000..838f24f --- /dev/null +++ b/iNapi/Classes/Helpers/INPURLCreator.h @@ -0,0 +1,15 @@ +// +// INPURLCreator.h +// iNapi +// +// Created by Wojtek Nagrodzki on 03/03/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import + +@interface INPURLCreator : NSObject + +- (NSURL *)iNapiURLForMovie:(NSString *)filePath language:(NSString *)language; + +@end diff --git a/iNapi/Classes/Helpers/INPURLCreator.m b/iNapi/Classes/Helpers/INPURLCreator.m new file mode 100644 index 0000000..09f7aad --- /dev/null +++ b/iNapi/Classes/Helpers/INPURLCreator.m @@ -0,0 +1,93 @@ +// +// INPURLCreator.m +// iNapi +// +// Created by Wojtek Nagrodzki on 03/03/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import "INPURLCreator.h" +#import "NSData+MD5.h" + + +@interface INPURLCreator () + +- (NSString *)md5HashOfFirst10MBOfFile:(NSString *)filePath; +- (NSString *)mysteriousHash:(NSString *)md5String; + +@end + + +@implementation INPURLCreator + +- (NSURL *)iNapiURLForMovie:(NSString *)filePath language:(NSString *)language +{ + NSString * md5Hash = [self md5HashOfFirst10MBOfFile:filePath]; + NSString * mysteriousHash = [self mysteriousHash:md5Hash]; + + NSString* urlString = [NSString stringWithFormat: + @"http://napiprojekt.pl/unit_napisy/dl.php?" + @"l=%@&" + @"f=%@&" + @"t=%@&" + @"v=pynapi&" + @"kolejka=false&" + @"nick=&" + @"pass=&" + @"napios=posix",language, md5Hash, mysteriousHash]; + + return [NSURL URLWithString:urlString]; +} + +- (NSString *)md5HashOfFirst10MBOfFile:(NSString *)filePath +{ + NSFileHandle * fileHandle = [NSFileHandle fileHandleForReadingAtPath:filePath]; + NSData * data = [fileHandle readDataOfLength:1024*1024*10]; + return [data md5]; +} + +- (NSString *)mysteriousHash:(NSString *)md5String +{ + if ([md5String length] != 32) { + return nil; + } + + int idx[] = {0xe, 0x3, 0x6, 0x8, 0x2}; + int mul[] = {2, 2, 5, 4, 3}; + int add[] = {0x0, 0xd, 0x10, 0xb, 0x5}; + + int t; + unsigned tmp, v; + + NSMutableString *result = [NSMutableString string]; + + for (int i = 0; i < 5; i++) { + + //hex to int + NSScanner *scanner = [NSScanner scannerWithString:[NSString stringWithFormat:@"%c", [md5String characterAtIndex:idx[i]]]]; + [scanner scanHexInt:&tmp]; + + t = add[i] + tmp; + + //hex to int + NSString *subString; + + if (t > 30) { + subString = [md5String substringFromIndex:t]; + } + else { + subString = [md5String substringWithRange:NSMakeRange(t, 2)]; + } + + scanner = [NSScanner scannerWithString:subString]; + [scanner scanHexInt:&v]; + + NSString *hexResult = [NSString stringWithFormat:@"%x", v * mul[i]]; + NSString *lastLetter = [hexResult substringFromIndex:[hexResult length] - 1]; + [result appendString:lastLetter]; + } + + return [result stringByTrimmingCharactersInSet:[NSCharacterSet newlineCharacterSet]]; +} + +@end diff --git a/iNapi/Classes/Helpers/INSubtitleDownloader.h b/iNapi/Classes/Helpers/INSubtitleDownloader.h new file mode 100644 index 0000000..b160e55 --- /dev/null +++ b/iNapi/Classes/Helpers/INSubtitleDownloader.h @@ -0,0 +1,26 @@ +// +// INSubtitleDownloader.h +// iNapi +// +// Created by Wojtek Nagrodzki on 22/06/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import + +@class INSubtitleDownloader; + +@protocol INSubtitleDownloaderDelegate + +- (BOOL)subtitleDownloader:(INSubtitleDownloader *)subtitleDownloader shouldArchivePreviousSubtitlesAtURL:(NSURL *)oldSubtitlesURL forMovieAtURL:(NSURL *)movieURL; + +@end + + +@interface INSubtitleDownloader : NSObject + +@property (weak, nonatomic) id delegate; + +-(void)downloadSubtitlesAtURL:(NSURL *)subtitlesURL forMovieAtURL:(NSURL *)movieURL completionHandler:(void (^)(NSURL * downloadedSubtitlesURL, NSError * error))completionHandler; + +@end diff --git a/iNapi/Classes/Helpers/INSubtitleDownloader.m b/iNapi/Classes/Helpers/INSubtitleDownloader.m new file mode 100644 index 0000000..abc7d18 --- /dev/null +++ b/iNapi/Classes/Helpers/INSubtitleDownloader.m @@ -0,0 +1,121 @@ +// +// INSubtitleDownloader.m +// iNapi +// +// Created by Wojtek Nagrodzki on 22/06/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import "INSubtitleDownloader.h" + + +@interface INSubtitleDownloader () + +@property (assign, nonatomic) dispatch_queue_t downloadQueue; +@property (strong, nonatomic) NSFileManager * fileManager; + +@end + + +@implementation INSubtitleDownloader + +@synthesize delegate; +// Private +@synthesize downloadQueue; +@synthesize fileManager; + ++ (INSubtitleDownloader *)sharedDownloader +{ + __strong static id _sharedObject = nil; + static dispatch_once_t onceToken = 0; + dispatch_once(&onceToken, ^{ + _sharedObject = [[self alloc] init]; + }); + return _sharedObject; +} + +- (id)init +{ + self = [super init]; + if (self) { + self.downloadQueue = dispatch_queue_create("com.izydor86.inapi.downloadSubtitles", DISPATCH_QUEUE_SERIAL); + self.fileManager = [NSFileManager defaultManager]; + } + return self; +} + +- (void)dealloc +{ + dispatch_release(downloadQueue); + self.downloadQueue = NULL; +} + +#pragma mark - Interface + +-(void)downloadSubtitlesAtURL:(NSURL *)subtitlesURL forMovieAtURL:(NSURL *)movieURL completionHandler:(void (^)(NSURL * downloadedSubtitlesURL, NSError * downloadError))completionHandler +{ + dispatch_async(self.downloadQueue, ^{ + + // download subtitles + NSError * error; + NSString * subtitles = [NSString stringWithContentsOfURL:subtitlesURL + encoding:NSWindowsCP1250StringEncoding + error:&error]; + + if (error) { + dispatch_async(dispatch_get_main_queue(), ^{ + completionHandler(nil, error); + }); + return; + } + + // check if subtitles were found, if not pass error + if ([subtitles isEqualToString:@"NPc0"]) { + error = [NSError errorWithDomain:@"com.izydor86.iNapi" code:404 userInfo:nil]; + dispatch_async(dispatch_get_main_queue(), ^{ + completionHandler(nil, error); + }); + return; + } + + // construct URL where subtitles will to be stored + NSURL * subtitlesSaveURL = [[movieURL URLByDeletingPathExtension] URLByAppendingPathExtension:@"txt"]; + + // rename existing subtitles if necessary + BOOL archivePreviousSubtitles = [self.delegate subtitleDownloader:self shouldArchivePreviousSubtitlesAtURL:subtitlesSaveURL forMovieAtURL:movieURL]; + if (archivePreviousSubtitles && [self.fileManager fileExistsAtPath:subtitlesSaveURL.path] == YES) { + NSURL * archiverSubtitlesSaveURL = [self archivedURLWithURL:subtitlesSaveURL]; + if ([self.fileManager moveItemAtURL:subtitlesSaveURL toURL:archiverSubtitlesSaveURL error:&error] == NO) { + dispatch_async(dispatch_get_main_queue(), ^{ + completionHandler(nil, error); + }); + return; + } + } + + // save subtitles + if ([subtitles writeToURL:subtitlesSaveURL atomically:YES encoding:NSWindowsCP1250StringEncoding error:&error] == NO) { + dispatch_async(dispatch_get_main_queue(), ^{ + completionHandler(nil, error); + }); + return; + } + + dispatch_async(dispatch_get_main_queue(), ^{ + completionHandler(subtitlesSaveURL, nil); + }); + }); +} + +#pragma mark - Private + +- (NSURL *)archivedURLWithURL:(NSURL *)url +{ + NSString * lastPathComponent = [url lastPathComponent]; + NSString * dateAndExtension = [NSString stringWithFormat:@"%@.txt", [NSDate date]]; + lastPathComponent = [lastPathComponent stringByReplacingOccurrencesOfString:@".txt" withString:dateAndExtension]; + + return [[url URLByDeletingLastPathComponent] URLByAppendingPathComponent:lastPathComponent]; +} + +@end diff --git a/iNapi/Classes/Helpers/NSData+MD5.h b/iNapi/Classes/Helpers/NSData+MD5.h new file mode 100644 index 0000000..fa1d203 --- /dev/null +++ b/iNapi/Classes/Helpers/NSData+MD5.h @@ -0,0 +1,16 @@ +// +// NSDataAdditions.h +// iNapi +// +// Created by Wojtek Nagrodzki on 11-02-28. +// Copyright 2011 __MyCompanyName__. All rights reserved. +// + +#import + + +@interface NSData (md5) + +- (NSString*) md5; + +@end diff --git a/iNapi/Classes/Helpers/NSData+MD5.m b/iNapi/Classes/Helpers/NSData+MD5.m new file mode 100644 index 0000000..85b1feb --- /dev/null +++ b/iNapi/Classes/Helpers/NSData+MD5.m @@ -0,0 +1,32 @@ +// +// NSDataAdditions.m +// iNapi +// +// Created by Wojtek Nagrodzki on 11-02-28. +// Copyright 2011 __MyCompanyName__. All rights reserved. +// + +#import "NSData+MD5.h" +#import + + +@implementation NSData (md5) + +- (NSString*) md5 +{ + const char *cStr = [self bytes]; + unsigned char digest[CC_MD5_DIGEST_LENGTH]; + CC_MD5( cStr, (CC_LONG)[self length], digest ); + NSString* s = [NSString stringWithFormat: @"%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x", + digest[0], digest[1], + digest[2], digest[3], + digest[4], digest[5], + digest[6], digest[7], + digest[8], digest[9], + digest[10], digest[11], + digest[12], digest[13], + digest[14], digest[15]]; + return s; +} + +@end diff --git a/iNapi/Classes/Models/INDownloadResult.h b/iNapi/Classes/Models/INDownloadResult.h new file mode 100644 index 0000000..05d82b1 --- /dev/null +++ b/iNapi/Classes/Models/INDownloadResult.h @@ -0,0 +1,18 @@ +// +// INDownloadResult.h +// iNapi +// +// Created by Wojtek Nagrodzki on 04/07/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import + +@interface INDownloadResult : NSObject + +@property (strong, nonatomic, readonly) NSString * movieFileName; +@property (strong, nonatomic, readonly) NSImage * downloadResultImage; + +- (id)initWithDownloadedSubtitlesURL:(NSURL *)downloadedSubtitlesURL error:(NSError *)error; + +@end diff --git a/iNapi/Classes/Models/INDownloadResult.m b/iNapi/Classes/Models/INDownloadResult.m new file mode 100644 index 0000000..c683843 --- /dev/null +++ b/iNapi/Classes/Models/INDownloadResult.m @@ -0,0 +1,55 @@ +// +// INDownloadResult.m +// iNapi +// +// Created by Wojtek Nagrodzki on 04/07/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import "INDownloadResult.h" + + +@interface INDownloadResult () + +@property (strong, nonatomic) NSURL * downloadedSubtitlesURL; +@property (strong, nonatomic) NSImage * downloadResultImage; + +@end + + +@implementation INDownloadResult + +@synthesize movieFileName; +@synthesize downloadResultImage; +// Private +@synthesize downloadedSubtitlesURL; + +- (id)initWithDownloadedSubtitlesURL:(NSURL *)aDownloadedSubtitlesURL error:(NSError *)error +{ + self = [super init]; + if (self) { + self.downloadedSubtitlesURL = aDownloadedSubtitlesURL; + + if (error == nil) { + self.downloadResultImage = [NSImage imageNamed:@"DownloadStatusSucceeded"]; + return self; + } + + if ([error.domain isEqualToString:@"com.izydor86.iNapi"] && error.code == 404) { + self.downloadResultImage = [NSImage imageNamed:@"DownloadStatusNotFound"]; + return self; + } + + self.downloadResultImage = [NSImage imageNamed:@"DownloadStatusFailed"]; + } + return self; +} + +#pragma mark - Interface + +- (NSString *)movieFileName +{ + return self.downloadedSubtitlesURL.path.lastPathComponent; +} + +@end diff --git a/iNapi/Resources/AppIcons/AppIcon.icns b/iNapi/Resources/AppIcons/AppIcon.icns new file mode 100644 index 0000000..c80a677 Binary files /dev/null and b/iNapi/Resources/AppIcons/AppIcon.icns differ diff --git a/iNapi/Resources/DownloadStatusImages/DownloadStatusFailed.png b/iNapi/Resources/DownloadStatusImages/DownloadStatusFailed.png new file mode 100644 index 0000000..a703f13 Binary files /dev/null and b/iNapi/Resources/DownloadStatusImages/DownloadStatusFailed.png differ diff --git a/iNapi/Resources/DownloadStatusImages/DownloadStatusNotFound.png b/iNapi/Resources/DownloadStatusImages/DownloadStatusNotFound.png new file mode 100644 index 0000000..146c28f Binary files /dev/null and b/iNapi/Resources/DownloadStatusImages/DownloadStatusNotFound.png differ diff --git a/iNapi/Resources/DownloadStatusImages/DownloadStatusSucceeded.png b/iNapi/Resources/DownloadStatusImages/DownloadStatusSucceeded.png new file mode 100644 index 0000000..f7e2b9e Binary files /dev/null and b/iNapi/Resources/DownloadStatusImages/DownloadStatusSucceeded.png differ diff --git a/iNapi/Resources/Localization/Localizable.strings b/iNapi/Resources/Localization/Localizable.strings new file mode 100644 index 0000000..88bf3bb --- /dev/null +++ b/iNapi/Resources/Localization/Localizable.strings @@ -0,0 +1,23 @@ +/* + Localizable.strings + iNapi + + Created by Wojtek Nagrodzki on 03/03/2012. + Copyright (c) 2012 Trifork. All rights reserved. +*/ + +/* INPPreferencesWindowController */ + +"Subtitle language" = "Subtitle language"; +"Subtitles" = "Subtitles"; +"Convert to UTF8" = "Convert to UTF8"; +"Archive previous" = "Archive previous"; +"Create SRT copy" = "Create SRT copy"; +"During download" = "During download"; +"Show main window" = "Show main window"; +"Use Growl" = "Use Growl"; +"After download" = "After download"; +"Quit iNapi" = "Quit iNapi"; + +"Polish" = "Polish"; +"English" = "English"; \ No newline at end of file diff --git a/iNapi/en.lproj/Credits.rtf b/iNapi/en.lproj/Credits.rtf new file mode 100644 index 0000000..46576ef --- /dev/null +++ b/iNapi/en.lproj/Credits.rtf @@ -0,0 +1,29 @@ +{\rtf0\ansi{\fonttbl\f0\fswiss Helvetica;} +{\colortbl;\red255\green255\blue255;} +\paperw9840\paperh8400 +\pard\tx560\tx1120\tx1680\tx2240\tx2800\tx3360\tx3920\tx4480\tx5040\tx5600\tx6160\tx6720\ql\qnatural + +\f0\b\fs24 \cf0 Engineering: +\b0 \ + Some people\ +\ + +\b Human Interface Design: +\b0 \ + Some other people\ +\ + +\b Testing: +\b0 \ + Hopefully not nobody\ +\ + +\b Documentation: +\b0 \ + Whoever\ +\ + +\b With special thanks to: +\b0 \ + Mom\ +} diff --git a/iNapi/en.lproj/InfoPlist.strings b/iNapi/en.lproj/InfoPlist.strings new file mode 100644 index 0000000..477b28f --- /dev/null +++ b/iNapi/en.lproj/InfoPlist.strings @@ -0,0 +1,2 @@ +/* Localized versions of Info.plist keys */ + diff --git a/iNapi/iNapi-Info.plist b/iNapi/iNapi-Info.plist new file mode 100644 index 0000000..84331bc --- /dev/null +++ b/iNapi/iNapi-Info.plist @@ -0,0 +1,148 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleDocumentTypes + + + CFBundleTypeName + Folder + CFBundleTypeRole + Viewer + LSItemContentTypes + + public.folder + + LSTypeIsPackage + + + + CFBundleTypeName + Movie + CFBundleTypeRole + Viewer + LSItemContentTypes + + public.movie + + LSTypeIsPackage + + + + CFBundleExecutable + ${EXECUTABLE_NAME} + CFBundleIconFile + AppIcon.icns + CFBundleIdentifier + com.izydor86.iNapi.${PRODUCT_NAME:rfc1034identifier} + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + ${PRODUCT_NAME} + CFBundlePackageType + APPL + CFBundleShortVersionString + 2.0 + CFBundleSignature + ???? + CFBundleVersion + 1 + LSApplicationCategoryType + public.app-category.video + LSMinimumSystemVersion + ${MACOSX_DEPLOYMENT_TARGET} + NSHumanReadableCopyright + Copyright © 2012 Trifork. All rights reserved. + NSMainNibFile + MainMenu + NSPrincipalClass + NSApplication + UTImportedTypeDeclarations + + + UTTypeConformsTo + + public.movie + + UTTypeDescription + NuppelVideo movie + UTTypeIdentifier + org.perian.nuppelvideo + UTTypeReferenceURL + http://www.mythtv.org/wiki/NuppelVideo + UTTypeTagSpecification + + public.filename-extension + + nuv + + + + + UTTypeConformsTo + + public.movie + + UTTypeDescription + Flash video + UTTypeIdentifier + org.perian.flash-video + UTTypeReferenceURL + http://www.adobe.com/devnet/flv/ + UTTypeTagSpecification + + public.filename-extension + + flv + + public.uti + + com.adobe.flash.video + com.apple.flash-video + + + + + UTTypeConformsTo + + public.movie + + UTTypeDescription + Matroska video + UTTypeIdentifier + org.perian.matroska + UTTypeReferenceURL + http://www.matroska.org/ + UTTypeTagSpecification + + public.filename-extension + + mkv + mka + + + + + UTTypeConformsTo + + public.movie + + UTTypeDescription + Ogg video + UTTypeIdentifier + org.perian.ogv + UTTypeReferenceURL + http://xiph.org/ogg/ + UTTypeTagSpecification + + public.filename-extension + + ogv + + + + + + diff --git a/iNapi/iNapi-Prefix.pch b/iNapi/iNapi-Prefix.pch new file mode 100644 index 0000000..c184111 --- /dev/null +++ b/iNapi/iNapi-Prefix.pch @@ -0,0 +1,7 @@ +// +// Prefix header for all source files of the 'iNapi' target in the 'iNapi' project +// + +#ifdef __OBJC__ + #import +#endif diff --git a/iNapi/main.m b/iNapi/main.m new file mode 100644 index 0000000..7ed188d --- /dev/null +++ b/iNapi/main.m @@ -0,0 +1,14 @@ +// +// main.m +// iNapi +// +// Created by Wojtek Nagrodzki on 25/02/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import + +int main(int argc, char *argv[]) +{ + return NSApplicationMain(argc, (const char **)argv); +} diff --git a/iNapiTests/en.lproj/InfoPlist.strings b/iNapiTests/en.lproj/InfoPlist.strings new file mode 100644 index 0000000..477b28f --- /dev/null +++ b/iNapiTests/en.lproj/InfoPlist.strings @@ -0,0 +1,2 @@ +/* Localized versions of Info.plist keys */ + diff --git a/iNapiTests/iNapiTests-Info.plist b/iNapiTests/iNapiTests-Info.plist new file mode 100644 index 0000000..f2aecf4 --- /dev/null +++ b/iNapiTests/iNapiTests-Info.plist @@ -0,0 +1,22 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleExecutable + ${EXECUTABLE_NAME} + CFBundleIdentifier + com.izydor86.iNapi.${PRODUCT_NAME:rfc1034identifier} + CFBundleInfoDictionaryVersion + 6.0 + CFBundlePackageType + BNDL + CFBundleShortVersionString + 1.0 + CFBundleSignature + ???? + CFBundleVersion + 1 + + diff --git a/iNapiTests/iNapiTests.h b/iNapiTests/iNapiTests.h new file mode 100644 index 0000000..c7e5f87 --- /dev/null +++ b/iNapiTests/iNapiTests.h @@ -0,0 +1,13 @@ +// +// iNapiTests.h +// iNapiTests +// +// Created by Wojtek Nagrodzki on 25/02/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import + +@interface iNapiTests : SenTestCase + +@end diff --git a/iNapiTests/iNapiTests.m b/iNapiTests/iNapiTests.m new file mode 100644 index 0000000..03cca0d --- /dev/null +++ b/iNapiTests/iNapiTests.m @@ -0,0 +1,32 @@ +// +// iNapiTests.m +// iNapiTests +// +// Created by Wojtek Nagrodzki on 25/02/2012. +// Copyright (c) 2012 Trifork. All rights reserved. +// + +#import "iNapiTests.h" + +@implementation iNapiTests + +- (void)setUp +{ + [super setUp]; + + // Set-up code here. +} + +- (void)tearDown +{ + // Tear-down code here. + + [super tearDown]; +} + +- (void)testExample +{ + STFail(@"Unit tests are not implemented yet in iNapiTests"); +} + +@end