From a45ff9530d13c64a35f56d5e59ce90759540a00d Mon Sep 17 00:00:00 2001 From: Jackson Taylor Date: Fri, 9 Dec 2016 10:26:20 -0500 Subject: [PATCH] Restructure and setup Cocoapods --- .swift-version | 1 + Example/Podfile | 11 + Example/Podfile.lock | 16 + .../Pods/Local Podspecs/Spruce.podspec.json | 22 + Example/Pods/Manifest.lock | 16 + Example/Pods/Pods.xcodeproj/project.pbxproj | 824 ++++++++++++++++++ .../xcschemes/Pods-Spruce_Example.xcscheme | 71 ++ .../xcschemes/Pods-Spruce_Tests.xcscheme | 71 ++ .../xcschemes/Spruce.xcscheme | 71 ++ .../xcschemes/xcschememanagement.plist | 42 + .../Pods-Spruce_Example/Info.plist | 26 + ...s-Spruce_Example-acknowledgements.markdown | 26 + ...Pods-Spruce_Example-acknowledgements.plist | 58 ++ .../Pods-Spruce_Example-dummy.m | 5 + .../Pods-Spruce_Example-frameworks.sh | 91 ++ .../Pods-Spruce_Example-resources.sh | 96 ++ .../Pods-Spruce_Example-umbrella.h | 8 + .../Pods-Spruce_Example.debug.xcconfig | 11 + .../Pods-Spruce_Example.modulemap | 6 + .../Pods-Spruce_Example.release.xcconfig | 11 + .../Pods-Spruce_Tests/Info.plist | 26 + ...ods-Spruce_Tests-acknowledgements.markdown | 3 + .../Pods-Spruce_Tests-acknowledgements.plist | 29 + .../Pods-Spruce_Tests-dummy.m | 5 + .../Pods-Spruce_Tests-frameworks.sh | 84 ++ .../Pods-Spruce_Tests-resources.sh | 96 ++ .../Pods-Spruce_Tests-umbrella.h | 8 + .../Pods-Spruce_Tests.debug.xcconfig | 8 + .../Pods-Spruce_Tests.modulemap | 6 + .../Pods-Spruce_Tests.release.xcconfig | 8 + .../Target Support Files/Spruce/Info.plist | 26 + .../Spruce/Spruce-dummy.m | 5 + .../Spruce/Spruce-prefix.pch | 4 + .../Spruce/Spruce-umbrella.h | 8 + .../Spruce/Spruce.modulemap | 6 + .../Spruce/Spruce.xcconfig | 9 + Example/Spruce.xcodeproj/project.pbxproj | 615 +++++++++++++ .../contents.xcworkspacedata | 0 .../UserInterfaceState.xcuserstate | Bin 0 -> 5529 bytes .../xcschemes/Spruce-Example.xcscheme | 115 +++ .../xcschemes/xcschememanagement.plist | 19 + .../contents.xcworkspacedata | 10 + .../UserInterfaceState.xcuserstate | Bin 0 -> 68625 bytes Example/Spruce/AppDelegate.swift | 50 ++ Example/Spruce/Base.lproj/LaunchScreen.xib | 41 + .../AppIcon.appiconset/Contents.json | 38 + Example/Spruce/Info.plist | 37 + Example/Spruce/TableViewController.swift | 132 +++ Example/Spruce/TestCollectionVIew.swift | 82 ++ Example/Spruce/TestViewController.swift | 67 ++ Example/Spruce/TestViewController2.swift | 31 + Example/Spruce/TestViewController2Setup.swift | 27 + Example/Spruce/TestViewController3.swift | 43 + Example/Spruce/TestViewControllerSetup.swift | 28 + Example/Tests/Info.plist | 24 + Example/Tests/Tests.swift | 29 + LICENSE | 19 + Spruce.podspec | 26 + .../UserInterfaceState.xcuserstate | Bin 42651 -> 0 bytes Spruce/.gitignore | 33 + Spruce/.travis.yml | 14 + Spruce/Assets/.gitkeep | 0 Spruce/Classes/.gitkeep | 0 .../Animations/Animation.swift | 4 +- .../Animations/DefaultAnimations.swift | 2 +- .../Animations/SpringAnimation.swift | 10 +- .../Animations/StandardAnimation.swift | 10 +- .../Full View/DefaultFullViewAnimations.swift | 18 +- .../Full View/FullViewAnimation.swift | 4 +- .../Full View/SpruceViewController.swift | 8 +- .../BaseDistancedSortFunction.swift | 10 +- .../Sort Functions/CorneredSortFunction.swift | 10 +- .../Sort Functions/DefaultSortFunction.swift | 6 +- .../Sort Functions/LinearSortFunction.swift | 10 +- .../Sort Functions/NoDelaySortFunction.swift | 4 +- .../Operations/PointOperations.swift | 4 +- .../Operations/ViewOperations.swift | 4 +- .../Sort Functions/RadialSortFunction.swift | 8 +- .../Sort Functions/RandomSortFunction.swift | 6 +- .../Sort Functions/SortFunction.swift | 4 +- Spruce/{Core => Classes}/Spruce.swift | 2 +- .../UI Elements/SpruceButton.swift | 8 +- Spruce/REGFullPageErrorScreen.swift | 33 - Spruce/REGFullPageErrorScreen.xib | 160 ---- Spruce/RegalTestViewController.swift | 29 - Spruce/RegalTestViewController.xib | 56 -- .../Spruce.xcodeproj}/project.pbxproj | 0 .../contents.xcworkspacedata | 7 + .../UserInterfaceState.xcuserstate | Bin 0 -> 41661 bytes .../xcdebugger/Breakpoints_v2.xcbkptlist | 0 .../xcschemes/Spruce.xcscheme | 0 .../xcschemes/xcschememanagement.plist | 0 .../Spruce}/AppDelegate.swift | 0 .../AppIcon.appiconset/Contents.json | 0 .../Spruce}/Assets.xcassets/Contents.json | 0 .../Contents.json | 0 .../img_errorimage_birds2.png | Bin .../icX.imageset/Contents.json | 0 .../icX.imageset/ic_rewards_x.png | Bin .../icX.imageset/ic_rewards_x@2x.png | Bin .../icX.imageset/ic_rewards_x@3x.png | Bin {Spruce => Spruce_old/Spruce}/Info.plist | 0 .../Spruce}/LaunchScreen.xib | 0 .../Spruce}/TableViewController.swift | 0 .../Spruce}/TestCollectionVIew.swift | 0 .../Spruce}/TestViewController.swift | 0 .../Spruce}/TestViewController2.swift | 0 .../Spruce}/TestViewController2Setup.swift | 0 .../Spruce}/TestViewController3.swift | 0 .../Spruce}/TestViewControllerSetup.swift | 0 .../SpruceTests}/Info.plist | 0 .../SpruceTests}/SpruceTests.swift | 0 _Pods.xcodeproj | 1 + 113 files changed, 3368 insertions(+), 344 deletions(-) create mode 100644 .swift-version create mode 100644 Example/Podfile create mode 100644 Example/Podfile.lock create mode 100644 Example/Pods/Local Podspecs/Spruce.podspec.json create mode 100644 Example/Pods/Manifest.lock create mode 100644 Example/Pods/Pods.xcodeproj/project.pbxproj create mode 100644 Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Pods-Spruce_Example.xcscheme create mode 100644 Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Pods-Spruce_Tests.xcscheme create mode 100644 Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Spruce.xcscheme create mode 100644 Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Example/Info.plist create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-acknowledgements.markdown create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-acknowledgements.plist create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-dummy.m create mode 100755 Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-frameworks.sh create mode 100755 Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-resources.sh create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-umbrella.h create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.debug.xcconfig create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.modulemap create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.release.xcconfig create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Tests/Info.plist create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-acknowledgements.markdown create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-acknowledgements.plist create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-dummy.m create mode 100755 Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-frameworks.sh create mode 100755 Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-resources.sh create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-umbrella.h create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.debug.xcconfig create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.modulemap create mode 100644 Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.release.xcconfig create mode 100644 Example/Pods/Target Support Files/Spruce/Info.plist create mode 100644 Example/Pods/Target Support Files/Spruce/Spruce-dummy.m create mode 100644 Example/Pods/Target Support Files/Spruce/Spruce-prefix.pch create mode 100644 Example/Pods/Target Support Files/Spruce/Spruce-umbrella.h create mode 100644 Example/Pods/Target Support Files/Spruce/Spruce.modulemap create mode 100644 Example/Pods/Target Support Files/Spruce/Spruce.xcconfig create mode 100644 Example/Spruce.xcodeproj/project.pbxproj rename {Spruce.xcodeproj => Example/Spruce.xcodeproj}/project.xcworkspace/contents.xcworkspacedata (100%) create mode 100644 Example/Spruce.xcodeproj/project.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate create mode 100644 Example/Spruce.xcodeproj/xcshareddata/xcschemes/Spruce-Example.xcscheme create mode 100644 Example/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist create mode 100644 Example/Spruce.xcworkspace/contents.xcworkspacedata create mode 100644 Example/Spruce.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate create mode 100644 Example/Spruce/AppDelegate.swift create mode 100644 Example/Spruce/Base.lproj/LaunchScreen.xib create mode 100644 Example/Spruce/Images.xcassets/AppIcon.appiconset/Contents.json create mode 100644 Example/Spruce/Info.plist create mode 100644 Example/Spruce/TableViewController.swift create mode 100644 Example/Spruce/TestCollectionVIew.swift create mode 100644 Example/Spruce/TestViewController.swift create mode 100644 Example/Spruce/TestViewController2.swift create mode 100644 Example/Spruce/TestViewController2Setup.swift create mode 100644 Example/Spruce/TestViewController3.swift create mode 100644 Example/Spruce/TestViewControllerSetup.swift create mode 100644 Example/Tests/Info.plist create mode 100644 Example/Tests/Tests.swift create mode 100644 LICENSE create mode 100644 Spruce.podspec delete mode 100644 Spruce.xcodeproj/project.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate create mode 100644 Spruce/.gitignore create mode 100644 Spruce/.travis.yml create mode 100644 Spruce/Assets/.gitkeep create mode 100644 Spruce/Classes/.gitkeep rename Spruce/{Core => Classes}/Animations/Animation.swift (73%) rename Spruce/{Core => Classes}/Animations/DefaultAnimations.swift (97%) rename Spruce/{Core => Classes}/Animations/SpringAnimation.swift (69%) rename Spruce/{Core => Classes}/Animations/StandardAnimation.swift (64%) rename Spruce/{Core => Classes}/Full View/DefaultFullViewAnimations.swift (90%) rename Spruce/{Core => Classes}/Full View/FullViewAnimation.swift (73%) rename Spruce/{Core => Classes}/Full View/SpruceViewController.swift (85%) rename Spruce/{Core => Classes}/Sort Functions/BaseDistancedSortFunction.swift (83%) rename Spruce/{Core => Classes}/Sort Functions/CorneredSortFunction.swift (84%) rename Spruce/{Core => Classes}/Sort Functions/DefaultSortFunction.swift (79%) rename Spruce/{Core => Classes}/Sort Functions/LinearSortFunction.swift (78%) rename Spruce/{Core => Classes}/Sort Functions/NoDelaySortFunction.swift (75%) rename Spruce/{Core => Classes}/Sort Functions/Operations/PointOperations.swift (77%) rename Spruce/{Core => Classes}/Sort Functions/Operations/ViewOperations.swift (72%) rename Spruce/{Core => Classes}/Sort Functions/RadialSortFunction.swift (85%) rename Spruce/{Core => Classes}/Sort Functions/RandomSortFunction.swift (89%) rename Spruce/{Core => Classes}/Sort Functions/SortFunction.swift (81%) rename Spruce/{Core => Classes}/Spruce.swift (89%) rename Spruce/{Core => Classes}/UI Elements/SpruceButton.swift (71%) delete mode 100644 Spruce/REGFullPageErrorScreen.swift delete mode 100644 Spruce/REGFullPageErrorScreen.xib delete mode 100644 Spruce/RegalTestViewController.swift delete mode 100644 Spruce/RegalTestViewController.xib rename {Spruce.xcodeproj => Spruce_old/Spruce.xcodeproj}/project.pbxproj (100%) create mode 100644 Spruce_old/Spruce.xcodeproj/project.xcworkspace/contents.xcworkspacedata create mode 100644 Spruce_old/Spruce.xcodeproj/project.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate rename {Spruce.xcodeproj => Spruce_old/Spruce.xcodeproj}/xcuserdata/jacksontaylor.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist (100%) rename {Spruce.xcodeproj => Spruce_old/Spruce.xcodeproj}/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Spruce.xcscheme (100%) rename {Spruce.xcodeproj => Spruce_old/Spruce.xcodeproj}/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist (100%) rename {Spruce => Spruce_old/Spruce}/AppDelegate.swift (100%) rename {Spruce => Spruce_old/Spruce}/Assets.xcassets/AppIcon.appiconset/Contents.json (100%) rename {Spruce => Spruce_old/Spruce}/Assets.xcassets/Contents.json (100%) rename {Spruce => Spruce_old/Spruce}/Assets.xcassets/icTicketingErrorPaymentDeclined.imageset/Contents.json (100%) rename {Spruce => Spruce_old/Spruce}/Assets.xcassets/icTicketingErrorPaymentDeclined.imageset/img_errorimage_birds2.png (100%) rename {Spruce => Spruce_old/Spruce}/Assets.xcassets/icX.imageset/Contents.json (100%) rename {Spruce => Spruce_old/Spruce}/Assets.xcassets/icX.imageset/ic_rewards_x.png (100%) rename {Spruce => Spruce_old/Spruce}/Assets.xcassets/icX.imageset/ic_rewards_x@2x.png (100%) rename {Spruce => Spruce_old/Spruce}/Assets.xcassets/icX.imageset/ic_rewards_x@3x.png (100%) rename {Spruce => Spruce_old/Spruce}/Info.plist (100%) rename {Spruce => Spruce_old/Spruce}/LaunchScreen.xib (100%) rename {Spruce => Spruce_old/Spruce}/TableViewController.swift (100%) rename {Spruce => Spruce_old/Spruce}/TestCollectionVIew.swift (100%) rename {Spruce => Spruce_old/Spruce}/TestViewController.swift (100%) rename {Spruce => Spruce_old/Spruce}/TestViewController2.swift (100%) rename {Spruce => Spruce_old/Spruce}/TestViewController2Setup.swift (100%) rename {Spruce => Spruce_old/Spruce}/TestViewController3.swift (100%) rename {Spruce => Spruce_old/Spruce}/TestViewControllerSetup.swift (100%) rename {SpruceTests => Spruce_old/SpruceTests}/Info.plist (100%) rename {SpruceTests => Spruce_old/SpruceTests}/SpruceTests.swift (100%) create mode 120000 _Pods.xcodeproj diff --git a/.swift-version b/.swift-version new file mode 100644 index 0000000..cb2b00e --- /dev/null +++ b/.swift-version @@ -0,0 +1 @@ +3.0.1 diff --git a/Example/Podfile b/Example/Podfile new file mode 100644 index 0000000..28a44bb --- /dev/null +++ b/Example/Podfile @@ -0,0 +1,11 @@ +use_frameworks! + +target 'Spruce_Example' do + pod 'Spruce', :path => '../' + + target 'Spruce_Tests' do + inherit! :search_paths + + + end +end diff --git a/Example/Podfile.lock b/Example/Podfile.lock new file mode 100644 index 0000000..e7a3667 --- /dev/null +++ b/Example/Podfile.lock @@ -0,0 +1,16 @@ +PODS: + - Spruce (0.1.0) + +DEPENDENCIES: + - Spruce (from `../`) + +EXTERNAL SOURCES: + Spruce: + :path: ../ + +SPEC CHECKSUMS: + Spruce: a55f15c37bbfad3f9b68025305343247415db73f + +PODFILE CHECKSUM: 0682d1331d8ffa96d42f660fba6a53ca84d7b1ba + +COCOAPODS: 1.1.1 diff --git a/Example/Pods/Local Podspecs/Spruce.podspec.json b/Example/Pods/Local Podspecs/Spruce.podspec.json new file mode 100644 index 0000000..b82e2bf --- /dev/null +++ b/Example/Pods/Local Podspecs/Spruce.podspec.json @@ -0,0 +1,22 @@ +{ + "name": "Spruce", + "version": "0.1.0", + "summary": "A simple animation library that tries to do everything for you.", + "description": "Spruce is a very small, lightweight animation library that hopes to handle all of the complications of animations for you. So many developers use standard animations because they are easy and quick to use. With Spruce, developers will be able to create complex animations hopefully with just one line of code. These animations can include variations on fading, scale, spin, and many more. A key component of Spruce is that it is entirely customizable. If we don't have the exact animation you are looking to build, subclass one of our types and everything will just work.", + "homepage": "https://github.com/willowtreeapps/spruce-ios", + "license": { + "type": "MIT", + "file": "LICENSE" + }, + "authors": { + "Jackson Taylor": "jackson.taylor@willowtreeapps.com" + }, + "source": { + "git": "https://github.com/willowtreeapps/Spruce.git", + "tag": "0.1.0" + }, + "platforms": { + "ios": "8.0" + }, + "source_files": "Spruce/Classes/**/*" +} diff --git a/Example/Pods/Manifest.lock b/Example/Pods/Manifest.lock new file mode 100644 index 0000000..e7a3667 --- /dev/null +++ b/Example/Pods/Manifest.lock @@ -0,0 +1,16 @@ +PODS: + - Spruce (0.1.0) + +DEPENDENCIES: + - Spruce (from `../`) + +EXTERNAL SOURCES: + Spruce: + :path: ../ + +SPEC CHECKSUMS: + Spruce: a55f15c37bbfad3f9b68025305343247415db73f + +PODFILE CHECKSUM: 0682d1331d8ffa96d42f660fba6a53ca84d7b1ba + +COCOAPODS: 1.1.1 diff --git a/Example/Pods/Pods.xcodeproj/project.pbxproj b/Example/Pods/Pods.xcodeproj/project.pbxproj new file mode 100644 index 0000000..f396bcc --- /dev/null +++ b/Example/Pods/Pods.xcodeproj/project.pbxproj @@ -0,0 +1,824 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 46; + objects = { + +/* Begin PBXBuildFile section */ + 04259D314C64660330FC9B65A89747A7 /* RadialSortFunction.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D6AA5446A78C288383D11C1536C0C59 /* RadialSortFunction.swift */; }; + 055B5469C7C3FF860BCC9C5F4B0B7382 /* ViewOperations.swift in Sources */ = {isa = PBXBuildFile; fileRef = F1A3A1985B614FD049BC0866A944E141 /* ViewOperations.swift */; }; + 078F2691E7CDB4222B80804FF9E92A0B /* Pods-Spruce_Tests-umbrella.h in Headers */ = {isa = PBXBuildFile; fileRef = 4BF9A148D4AEDCB38BA3D05DC67413C1 /* Pods-Spruce_Tests-umbrella.h */; settings = {ATTRIBUTES = (Public, ); }; }; + 0B576018939899704AE2D280242125B1 /* StandardAnimation.swift in Sources */ = {isa = PBXBuildFile; fileRef = B762774F96DAB1753064DD6C3B7046C5 /* StandardAnimation.swift */; }; + 1180BA6FFA0D226963DDB2A705C11CFD /* Spruce.swift in Sources */ = {isa = PBXBuildFile; fileRef = A25E3312C783A916AAC807C0A7251E7D /* Spruce.swift */; }; + 16122EA4B07AB226DF90564DBD16C8F2 /* DefaultFullViewAnimations.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2A50AB2E31EACA5DDB9BEB91E36DCDD9 /* DefaultFullViewAnimations.swift */; }; + 22DF3316C67C6961621A26BBBA639DA4 /* SortFunction.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8BC066718A92797B3E685DFFC033CDE7 /* SortFunction.swift */; }; + 30BFA214C6DFF1256B6A32ECC1C0B310 /* DefaultSortFunction.swift in Sources */ = {isa = PBXBuildFile; fileRef = A5972EEF2D52B71C348D230A0E777369 /* DefaultSortFunction.swift */; }; + 389FC243005275278B89A626FD12DD2E /* SpringAnimation.swift in Sources */ = {isa = PBXBuildFile; fileRef = 558B7DA87515D3057B3B27C13ED51805 /* SpringAnimation.swift */; }; + 4D24B97E25ECA4868BC69DFAF6668EB5 /* Foundation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = CBB3DE36805AF21409EC968A9691732F /* Foundation.framework */; }; + 5A709EE7E34827F7499AEBDFE9BD7259 /* Spruce-umbrella.h in Headers */ = {isa = PBXBuildFile; fileRef = 71F792301555302C2DB7C830769A896A /* Spruce-umbrella.h */; settings = {ATTRIBUTES = (Public, ); }; }; + 5CAFC2170BBC5C93BC2D26448C7718AA /* Foundation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = CBB3DE36805AF21409EC968A9691732F /* Foundation.framework */; }; + 5DAB2EF6B59AA2CA006F11C072C244F2 /* Pods-Spruce_Example-umbrella.h in Headers */ = {isa = PBXBuildFile; fileRef = 944201B6552D4C2C2309D0E762D43C34 /* Pods-Spruce_Example-umbrella.h */; settings = {ATTRIBUTES = (Public, ); }; }; + 61BB62F324566F6B8399ED500478949E /* LinearSortFunction.swift in Sources */ = {isa = PBXBuildFile; fileRef = 85C230A0F7A7B5B1A28BD0CF472060DB /* LinearSortFunction.swift */; }; + 75739A85FC647F5AD23A2B82A79830BF /* SpruceViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = F3AAF330EE49B9E1081048682326FE80 /* SpruceViewController.swift */; }; + 7EF08D839FE38101F0B4DB51BCF031EB /* DefaultAnimations.swift in Sources */ = {isa = PBXBuildFile; fileRef = 69BF4987EFE22B77789631F91227E781 /* DefaultAnimations.swift */; }; + 7F204E75BBC011BAA3903B7943FBC63F /* Pods-Spruce_Tests-dummy.m in Sources */ = {isa = PBXBuildFile; fileRef = 9C3EAF5B8C1AD74CE465B95C5C8C3153 /* Pods-Spruce_Tests-dummy.m */; }; + 8EFEE27DE436D21BFE8FF7EED042A6FD /* NoDelaySortFunction.swift in Sources */ = {isa = PBXBuildFile; fileRef = 291957596CF4404576FE2877E13C6CEA /* NoDelaySortFunction.swift */; }; + 91832C601B289B7CFE8FE0C97A52C829 /* CorneredSortFunction.swift in Sources */ = {isa = PBXBuildFile; fileRef = 353411ADC9FE0E4916F30810ED6EABD6 /* CorneredSortFunction.swift */; }; + 982A4B31996C1F143079BE59AC4B28B7 /* PointOperations.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0DDC529F641E0529FC3437B391420856 /* PointOperations.swift */; }; + 9AF58D1A7EB58DA3B92C40E9F66D1B16 /* Spruce-dummy.m in Sources */ = {isa = PBXBuildFile; fileRef = 16A4122AB321A4174AAD98CBD009EE55 /* Spruce-dummy.m */; }; + B16549263A0E88866CCB96E761617C6F /* Pods-Spruce_Example-dummy.m in Sources */ = {isa = PBXBuildFile; fileRef = 92AD634D3FAD541D877367EDE05F0B8D /* Pods-Spruce_Example-dummy.m */; }; + B3030EE94920C08E2ED4BA6F93D0B1C4 /* Foundation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = CBB3DE36805AF21409EC968A9691732F /* Foundation.framework */; }; + B6B644C3C6C747D7CF8BEC1A1C7ED0F1 /* RandomSortFunction.swift in Sources */ = {isa = PBXBuildFile; fileRef = B7EFA568C807579D267F82D859932156 /* RandomSortFunction.swift */; }; + BA8ABCABB4A611DEAE0B6060E735FD52 /* BaseDistancedSortFunction.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7433EBBDED059A414D9C9EC496991507 /* BaseDistancedSortFunction.swift */; }; + C40B19542E178531734266FFD0A7D849 /* SpruceButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = C6AF82DFB0B553B7AC68A1E828BF7E17 /* SpruceButton.swift */; }; + DD15D53DA68DA641DB4E2537C2AC1220 /* FullViewAnimation.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09595A049ED1A8177E3A27E3E0DD17A7 /* FullViewAnimation.swift */; }; + E5A905EC8809D0D76F68D26AB746BC4D /* Animation.swift in Sources */ = {isa = PBXBuildFile; fileRef = 90CBC27EE07A3781CC6550BA4B5CBEF3 /* Animation.swift */; }; +/* End PBXBuildFile section */ + +/* Begin PBXContainerItemProxy section */ + 5C9A097675087D7AE27DA0A4AD95C7D6 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = D41D8CD98F00B204E9800998ECF8427E /* Project object */; + proxyType = 1; + remoteGlobalIDString = 889446D12CC42CF3FA024DB1A3366501; + remoteInfo = Spruce; + }; +/* End PBXContainerItemProxy section */ + +/* Begin PBXFileReference section */ + 09595A049ED1A8177E3A27E3E0DD17A7 /* FullViewAnimation.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = FullViewAnimation.swift; sourceTree = ""; }; + 0CADC92BADB3034E48F38D776995E189 /* Pods-Spruce_Example-frameworks.sh */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.script.sh; path = "Pods-Spruce_Example-frameworks.sh"; sourceTree = ""; }; + 0DDC529F641E0529FC3437B391420856 /* PointOperations.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = PointOperations.swift; sourceTree = ""; }; + 12766F2F2B7B71C85F174F8F4C923EA4 /* Info.plist */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 1369A2CFA136FAB0229E7C016D3E67F7 /* Pods-Spruce_Tests-acknowledgements.plist */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.plist.xml; path = "Pods-Spruce_Tests-acknowledgements.plist"; sourceTree = ""; }; + 16A4122AB321A4174AAD98CBD009EE55 /* Spruce-dummy.m */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.c.objc; path = "Spruce-dummy.m"; sourceTree = ""; }; + 19F7922B131E3116ADCA6BC0B3C98EEB /* Spruce.modulemap */ = {isa = PBXFileReference; includeInIndex = 1; path = Spruce.modulemap; sourceTree = ""; }; + 1A64F96EB37BE0A885651008A16F016D /* Pods-Spruce_Example-acknowledgements.plist */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.plist.xml; path = "Pods-Spruce_Example-acknowledgements.plist"; sourceTree = ""; }; + 23E7013232AB26A7CDF4F539958A88DA /* Spruce.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; path = Spruce.xcconfig; sourceTree = ""; }; + 291957596CF4404576FE2877E13C6CEA /* NoDelaySortFunction.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = NoDelaySortFunction.swift; sourceTree = ""; }; + 2A50AB2E31EACA5DDB9BEB91E36DCDD9 /* DefaultFullViewAnimations.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = DefaultFullViewAnimations.swift; sourceTree = ""; }; + 2E043D2FFC01F0C4DE42254DB8F30569 /* Pods-Spruce_Example.modulemap */ = {isa = PBXFileReference; includeInIndex = 1; path = "Pods-Spruce_Example.modulemap"; sourceTree = ""; }; + 353411ADC9FE0E4916F30810ED6EABD6 /* CorneredSortFunction.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = CorneredSortFunction.swift; sourceTree = ""; }; + 4AD054F71CF439C5BA54B2228072AEEF /* Info.plist */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 4BF9A148D4AEDCB38BA3D05DC67413C1 /* Pods-Spruce_Tests-umbrella.h */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.c.h; path = "Pods-Spruce_Tests-umbrella.h"; sourceTree = ""; }; + 55616E35201003565304A5DE3F1F1C3E /* Pods-Spruce_Tests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; path = "Pods-Spruce_Tests.debug.xcconfig"; sourceTree = ""; }; + 558B7DA87515D3057B3B27C13ED51805 /* SpringAnimation.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = SpringAnimation.swift; sourceTree = ""; }; + 57C3CA3BB49F6F52EFB79CC3738B300E /* Spruce.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; name = Spruce.framework; path = Spruce.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + 5D6AA5446A78C288383D11C1536C0C59 /* RadialSortFunction.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = RadialSortFunction.swift; sourceTree = ""; }; + 622186B9D0A15D16C664C253DFDDF343 /* Pods-Spruce_Example-resources.sh */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.script.sh; path = "Pods-Spruce_Example-resources.sh"; sourceTree = ""; }; + 69213D97DCE41DA6B2DB9BD872682DC5 /* Spruce-prefix.pch */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.c.h; path = "Spruce-prefix.pch"; sourceTree = ""; }; + 69BF4987EFE22B77789631F91227E781 /* DefaultAnimations.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = DefaultAnimations.swift; sourceTree = ""; }; + 71F792301555302C2DB7C830769A896A /* Spruce-umbrella.h */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.c.h; path = "Spruce-umbrella.h"; sourceTree = ""; }; + 7346BA1B7FBFE7D742C26AC4EFEA849E /* Pods-Spruce_Tests-resources.sh */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.script.sh; path = "Pods-Spruce_Tests-resources.sh"; sourceTree = ""; }; + 7433EBBDED059A414D9C9EC496991507 /* BaseDistancedSortFunction.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = BaseDistancedSortFunction.swift; sourceTree = ""; }; + 745C218783730A33D6B82C5E9F1CDF17 /* Info.plist */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 75BC1B05EE6AA516FFE2F32AD8DAB8BD /* Pods_Spruce_Example.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; name = Pods_Spruce_Example.framework; path = "Pods-Spruce_Example.framework"; sourceTree = BUILT_PRODUCTS_DIR; }; + 85C230A0F7A7B5B1A28BD0CF472060DB /* LinearSortFunction.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = LinearSortFunction.swift; sourceTree = ""; }; + 89BA1067F35A94869E8DD3BADD0255F1 /* Pods_Spruce_Tests.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; name = Pods_Spruce_Tests.framework; path = "Pods-Spruce_Tests.framework"; sourceTree = BUILT_PRODUCTS_DIR; }; + 89BEFCEB9618821EA82227F0316BD2EA /* Pods-Spruce_Example.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; path = "Pods-Spruce_Example.release.xcconfig"; sourceTree = ""; }; + 8BC066718A92797B3E685DFFC033CDE7 /* SortFunction.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = SortFunction.swift; sourceTree = ""; }; + 90CBC27EE07A3781CC6550BA4B5CBEF3 /* Animation.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = Animation.swift; sourceTree = ""; }; + 92AD634D3FAD541D877367EDE05F0B8D /* Pods-Spruce_Example-dummy.m */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.c.objc; path = "Pods-Spruce_Example-dummy.m"; sourceTree = ""; }; + 93A4A3777CF96A4AAC1D13BA6DCCEA73 /* Podfile */ = {isa = PBXFileReference; explicitFileType = text.script.ruby; includeInIndex = 1; lastKnownFileType = text; name = Podfile; path = ../Podfile; sourceTree = SOURCE_ROOT; xcLanguageSpecificationIdentifier = xcode.lang.ruby; }; + 944201B6552D4C2C2309D0E762D43C34 /* Pods-Spruce_Example-umbrella.h */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.c.h; path = "Pods-Spruce_Example-umbrella.h"; sourceTree = ""; }; + 986C2689F32FFD57FDF73E41131712ED /* Pods-Spruce_Tests-frameworks.sh */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.script.sh; path = "Pods-Spruce_Tests-frameworks.sh"; sourceTree = ""; }; + 9C147CDF3CF695F8EDBB22607035D46A /* Pods-Spruce_Example.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; path = "Pods-Spruce_Example.debug.xcconfig"; sourceTree = ""; }; + 9C3EAF5B8C1AD74CE465B95C5C8C3153 /* Pods-Spruce_Tests-dummy.m */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.c.objc; path = "Pods-Spruce_Tests-dummy.m"; sourceTree = ""; }; + 9CA537CEC3F170238E47E078E7C35E45 /* Pods-Spruce_Tests-acknowledgements.markdown */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text; path = "Pods-Spruce_Tests-acknowledgements.markdown"; sourceTree = ""; }; + A25E3312C783A916AAC807C0A7251E7D /* Spruce.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = Spruce.swift; sourceTree = ""; }; + A5972EEF2D52B71C348D230A0E777369 /* DefaultSortFunction.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = DefaultSortFunction.swift; sourceTree = ""; }; + B762774F96DAB1753064DD6C3B7046C5 /* StandardAnimation.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = StandardAnimation.swift; sourceTree = ""; }; + B7EFA568C807579D267F82D859932156 /* RandomSortFunction.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = RandomSortFunction.swift; sourceTree = ""; }; + C6AF82DFB0B553B7AC68A1E828BF7E17 /* SpruceButton.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = SpruceButton.swift; sourceTree = ""; }; + CB7E0533B0EC994AFC086E324A096ADF /* Pods-Spruce_Tests.modulemap */ = {isa = PBXFileReference; includeInIndex = 1; path = "Pods-Spruce_Tests.modulemap"; sourceTree = ""; }; + CBB3DE36805AF21409EC968A9691732F /* Foundation.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Foundation.framework; path = Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS10.0.sdk/System/Library/Frameworks/Foundation.framework; sourceTree = DEVELOPER_DIR; }; + D87409DAC88107B4FF98F7EF404BFC12 /* Pods-Spruce_Tests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; path = "Pods-Spruce_Tests.release.xcconfig"; sourceTree = ""; }; + E0BBEF058E73902230A3CE2EA03B1118 /* Pods-Spruce_Example-acknowledgements.markdown */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text; path = "Pods-Spruce_Example-acknowledgements.markdown"; sourceTree = ""; }; + F1A3A1985B614FD049BC0866A944E141 /* ViewOperations.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = ViewOperations.swift; sourceTree = ""; }; + F3AAF330EE49B9E1081048682326FE80 /* SpruceViewController.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; path = SpruceViewController.swift; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 4FCC6502932DD34E491A20DDEF9EAFEA /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 4D24B97E25ECA4868BC69DFAF6668EB5 /* Foundation.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + D3D3B95F3F41BAB97EE7898DB07D6440 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + B3030EE94920C08E2ED4BA6F93D0B1C4 /* Foundation.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + DF4BB24C609F7A00889E927DED43E938 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 5CAFC2170BBC5C93BC2D26448C7718AA /* Foundation.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 092F77707E4D0D7DF2C6EA21D6DEB39A /* Full View */ = { + isa = PBXGroup; + children = ( + 2A50AB2E31EACA5DDB9BEB91E36DCDD9 /* DefaultFullViewAnimations.swift */, + 09595A049ED1A8177E3A27E3E0DD17A7 /* FullViewAnimation.swift */, + F3AAF330EE49B9E1081048682326FE80 /* SpruceViewController.swift */, + ); + name = "Full View"; + path = "Full View"; + sourceTree = ""; + }; + 28C9430A8FD17088ACAB0A9D6318D53C /* UI Elements */ = { + isa = PBXGroup; + children = ( + C6AF82DFB0B553B7AC68A1E828BF7E17 /* SpruceButton.swift */, + ); + name = "UI Elements"; + path = "UI Elements"; + sourceTree = ""; + }; + 3BA638F9FF0A44F013F92F44D3372803 /* Operations */ = { + isa = PBXGroup; + children = ( + 0DDC529F641E0529FC3437B391420856 /* PointOperations.swift */, + F1A3A1985B614FD049BC0866A944E141 /* ViewOperations.swift */, + ); + name = Operations; + path = Operations; + sourceTree = ""; + }; + 7531C8F8DE19F1AA3C8A7AC97A91DC29 /* iOS */ = { + isa = PBXGroup; + children = ( + CBB3DE36805AF21409EC968A9691732F /* Foundation.framework */, + ); + name = iOS; + sourceTree = ""; + }; + 7DB346D0F39D3F0E887471402A8071AB = { + isa = PBXGroup; + children = ( + 93A4A3777CF96A4AAC1D13BA6DCCEA73 /* Podfile */, + 8B7D3866E47C6D980D5F6737C947ABBE /* Development Pods */, + BC3CA7F9E30CC8F7E2DD044DD34432FC /* Frameworks */, + 88B2AD4E6DBBF5F5B52C4429DA34E8AA /* Products */, + 8A6F285DFA5734E829CC53BF21E469B6 /* Targets Support Files */, + ); + sourceTree = ""; + }; + 88B2AD4E6DBBF5F5B52C4429DA34E8AA /* Products */ = { + isa = PBXGroup; + children = ( + 75BC1B05EE6AA516FFE2F32AD8DAB8BD /* Pods_Spruce_Example.framework */, + 89BA1067F35A94869E8DD3BADD0255F1 /* Pods_Spruce_Tests.framework */, + 57C3CA3BB49F6F52EFB79CC3738B300E /* Spruce.framework */, + ); + name = Products; + sourceTree = ""; + }; + 8A6F285DFA5734E829CC53BF21E469B6 /* Targets Support Files */ = { + isa = PBXGroup; + children = ( + FD935C59D54F063F51D5A437E6E143D1 /* Pods-Spruce_Example */, + F785331CA42358FF0DABBBD5044F5349 /* Pods-Spruce_Tests */, + ); + name = "Targets Support Files"; + sourceTree = ""; + }; + 8B7D3866E47C6D980D5F6737C947ABBE /* Development Pods */ = { + isa = PBXGroup; + children = ( + FB6FC6635344ACC99EF00E4EB8A2982E /* Spruce */, + ); + name = "Development Pods"; + sourceTree = ""; + }; + 9C95B0FBC0A62A67AFBECD8AAE5659E0 /* Classes */ = { + isa = PBXGroup; + children = ( + A25E3312C783A916AAC807C0A7251E7D /* Spruce.swift */, + DECAB41E133D7CC247A0F3723C0BA0D7 /* Animations */, + 092F77707E4D0D7DF2C6EA21D6DEB39A /* Full View */, + F0E5D028D2701ABA678E2BEB6BC6CEFB /* Sort Functions */, + 28C9430A8FD17088ACAB0A9D6318D53C /* UI Elements */, + ); + name = Classes; + path = Classes; + sourceTree = ""; + }; + BC3CA7F9E30CC8F7E2DD044DD34432FC /* Frameworks */ = { + isa = PBXGroup; + children = ( + 7531C8F8DE19F1AA3C8A7AC97A91DC29 /* iOS */, + ); + name = Frameworks; + sourceTree = ""; + }; + CDD72CBCF1B46C38E2616F1E7189AF1B /* Spruce */ = { + isa = PBXGroup; + children = ( + 9C95B0FBC0A62A67AFBECD8AAE5659E0 /* Classes */, + ); + name = Spruce; + path = Spruce; + sourceTree = ""; + }; + DECAB41E133D7CC247A0F3723C0BA0D7 /* Animations */ = { + isa = PBXGroup; + children = ( + 90CBC27EE07A3781CC6550BA4B5CBEF3 /* Animation.swift */, + 69BF4987EFE22B77789631F91227E781 /* DefaultAnimations.swift */, + 558B7DA87515D3057B3B27C13ED51805 /* SpringAnimation.swift */, + B762774F96DAB1753064DD6C3B7046C5 /* StandardAnimation.swift */, + ); + name = Animations; + path = Animations; + sourceTree = ""; + }; + F0E5D028D2701ABA678E2BEB6BC6CEFB /* Sort Functions */ = { + isa = PBXGroup; + children = ( + 7433EBBDED059A414D9C9EC496991507 /* BaseDistancedSortFunction.swift */, + 353411ADC9FE0E4916F30810ED6EABD6 /* CorneredSortFunction.swift */, + A5972EEF2D52B71C348D230A0E777369 /* DefaultSortFunction.swift */, + 85C230A0F7A7B5B1A28BD0CF472060DB /* LinearSortFunction.swift */, + 291957596CF4404576FE2877E13C6CEA /* NoDelaySortFunction.swift */, + 5D6AA5446A78C288383D11C1536C0C59 /* RadialSortFunction.swift */, + B7EFA568C807579D267F82D859932156 /* RandomSortFunction.swift */, + 8BC066718A92797B3E685DFFC033CDE7 /* SortFunction.swift */, + 3BA638F9FF0A44F013F92F44D3372803 /* Operations */, + ); + name = "Sort Functions"; + path = "Sort Functions"; + sourceTree = ""; + }; + F2470CFE7FBBB2640558CFEC75ADF05E /* Support Files */ = { + isa = PBXGroup; + children = ( + 4AD054F71CF439C5BA54B2228072AEEF /* Info.plist */, + 19F7922B131E3116ADCA6BC0B3C98EEB /* Spruce.modulemap */, + 23E7013232AB26A7CDF4F539958A88DA /* Spruce.xcconfig */, + 16A4122AB321A4174AAD98CBD009EE55 /* Spruce-dummy.m */, + 69213D97DCE41DA6B2DB9BD872682DC5 /* Spruce-prefix.pch */, + 71F792301555302C2DB7C830769A896A /* Spruce-umbrella.h */, + ); + name = "Support Files"; + path = "Example/Pods/Target Support Files/Spruce"; + sourceTree = ""; + }; + F785331CA42358FF0DABBBD5044F5349 /* Pods-Spruce_Tests */ = { + isa = PBXGroup; + children = ( + 12766F2F2B7B71C85F174F8F4C923EA4 /* Info.plist */, + CB7E0533B0EC994AFC086E324A096ADF /* Pods-Spruce_Tests.modulemap */, + 9CA537CEC3F170238E47E078E7C35E45 /* Pods-Spruce_Tests-acknowledgements.markdown */, + 1369A2CFA136FAB0229E7C016D3E67F7 /* Pods-Spruce_Tests-acknowledgements.plist */, + 9C3EAF5B8C1AD74CE465B95C5C8C3153 /* Pods-Spruce_Tests-dummy.m */, + 986C2689F32FFD57FDF73E41131712ED /* Pods-Spruce_Tests-frameworks.sh */, + 7346BA1B7FBFE7D742C26AC4EFEA849E /* Pods-Spruce_Tests-resources.sh */, + 4BF9A148D4AEDCB38BA3D05DC67413C1 /* Pods-Spruce_Tests-umbrella.h */, + 55616E35201003565304A5DE3F1F1C3E /* Pods-Spruce_Tests.debug.xcconfig */, + D87409DAC88107B4FF98F7EF404BFC12 /* Pods-Spruce_Tests.release.xcconfig */, + ); + name = "Pods-Spruce_Tests"; + path = "Target Support Files/Pods-Spruce_Tests"; + sourceTree = ""; + }; + FB6FC6635344ACC99EF00E4EB8A2982E /* Spruce */ = { + isa = PBXGroup; + children = ( + CDD72CBCF1B46C38E2616F1E7189AF1B /* Spruce */, + F2470CFE7FBBB2640558CFEC75ADF05E /* Support Files */, + ); + name = Spruce; + path = ../..; + sourceTree = ""; + }; + FD935C59D54F063F51D5A437E6E143D1 /* Pods-Spruce_Example */ = { + isa = PBXGroup; + children = ( + 745C218783730A33D6B82C5E9F1CDF17 /* Info.plist */, + 2E043D2FFC01F0C4DE42254DB8F30569 /* Pods-Spruce_Example.modulemap */, + E0BBEF058E73902230A3CE2EA03B1118 /* Pods-Spruce_Example-acknowledgements.markdown */, + 1A64F96EB37BE0A885651008A16F016D /* Pods-Spruce_Example-acknowledgements.plist */, + 92AD634D3FAD541D877367EDE05F0B8D /* Pods-Spruce_Example-dummy.m */, + 0CADC92BADB3034E48F38D776995E189 /* Pods-Spruce_Example-frameworks.sh */, + 622186B9D0A15D16C664C253DFDDF343 /* Pods-Spruce_Example-resources.sh */, + 944201B6552D4C2C2309D0E762D43C34 /* Pods-Spruce_Example-umbrella.h */, + 9C147CDF3CF695F8EDBB22607035D46A /* Pods-Spruce_Example.debug.xcconfig */, + 89BEFCEB9618821EA82227F0316BD2EA /* Pods-Spruce_Example.release.xcconfig */, + ); + name = "Pods-Spruce_Example"; + path = "Target Support Files/Pods-Spruce_Example"; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXHeadersBuildPhase section */ + 66CBDB9E81A0F8C2C858C589CDD933B0 /* Headers */ = { + isa = PBXHeadersBuildPhase; + buildActionMask = 2147483647; + files = ( + 5DAB2EF6B59AA2CA006F11C072C244F2 /* Pods-Spruce_Example-umbrella.h in Headers */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 788FA6A1C886F3C7FEAB19AB70D3D662 /* Headers */ = { + isa = PBXHeadersBuildPhase; + buildActionMask = 2147483647; + files = ( + 078F2691E7CDB4222B80804FF9E92A0B /* Pods-Spruce_Tests-umbrella.h in Headers */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + C0F6477ABA1A9E1E8A4F232728D923CB /* Headers */ = { + isa = PBXHeadersBuildPhase; + buildActionMask = 2147483647; + files = ( + 5A709EE7E34827F7499AEBDFE9BD7259 /* Spruce-umbrella.h in Headers */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXHeadersBuildPhase section */ + +/* Begin PBXNativeTarget section */ + 2B7321D1E525D2BA824577402C83D8E6 /* Pods-Spruce_Example */ = { + isa = PBXNativeTarget; + buildConfigurationList = 388BE1A2B65C1F7F2819B54E36F9535B /* Build configuration list for PBXNativeTarget "Pods-Spruce_Example" */; + buildPhases = ( + 3CF8902A520CB6681EA3D9B6520A506C /* Sources */, + D3D3B95F3F41BAB97EE7898DB07D6440 /* Frameworks */, + 66CBDB9E81A0F8C2C858C589CDD933B0 /* Headers */, + ); + buildRules = ( + ); + dependencies = ( + 5EE6379DD850C30688B01ED25CBE5F5B /* PBXTargetDependency */, + ); + name = "Pods-Spruce_Example"; + productName = "Pods-Spruce_Example"; + productReference = 75BC1B05EE6AA516FFE2F32AD8DAB8BD /* Pods_Spruce_Example.framework */; + productType = "com.apple.product-type.framework"; + }; + 889446D12CC42CF3FA024DB1A3366501 /* Spruce */ = { + isa = PBXNativeTarget; + buildConfigurationList = 06F74E89843A23C56577F38F566F4B3D /* Build configuration list for PBXNativeTarget "Spruce" */; + buildPhases = ( + 29D2ABEC44EDFFA0CAFCF69A7E7DF5CF /* Sources */, + 4FCC6502932DD34E491A20DDEF9EAFEA /* Frameworks */, + C0F6477ABA1A9E1E8A4F232728D923CB /* Headers */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = Spruce; + productName = Spruce; + productReference = 57C3CA3BB49F6F52EFB79CC3738B300E /* Spruce.framework */; + productType = "com.apple.product-type.framework"; + }; + DE2FBFC5C3EC89E291968B42F109C4D6 /* Pods-Spruce_Tests */ = { + isa = PBXNativeTarget; + buildConfigurationList = 7D25524F38FBC177AD13396670FC9E2C /* Build configuration list for PBXNativeTarget "Pods-Spruce_Tests" */; + buildPhases = ( + 2BA80353CB83DA7EFD28B1F6404176F2 /* Sources */, + DF4BB24C609F7A00889E927DED43E938 /* Frameworks */, + 788FA6A1C886F3C7FEAB19AB70D3D662 /* Headers */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = "Pods-Spruce_Tests"; + productName = "Pods-Spruce_Tests"; + productReference = 89BA1067F35A94869E8DD3BADD0255F1 /* Pods_Spruce_Tests.framework */; + productType = "com.apple.product-type.framework"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + D41D8CD98F00B204E9800998ECF8427E /* Project object */ = { + isa = PBXProject; + attributes = { + LastSwiftUpdateCheck = 0730; + LastUpgradeCheck = 0700; + }; + buildConfigurationList = 2D8E8EC45A3A1A1D94AE762CB5028504 /* Build configuration list for PBXProject "Pods" */; + compatibilityVersion = "Xcode 3.2"; + developmentRegion = English; + hasScannedForEncodings = 0; + knownRegions = ( + en, + ); + mainGroup = 7DB346D0F39D3F0E887471402A8071AB; + productRefGroup = 88B2AD4E6DBBF5F5B52C4429DA34E8AA /* Products */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 2B7321D1E525D2BA824577402C83D8E6 /* Pods-Spruce_Example */, + DE2FBFC5C3EC89E291968B42F109C4D6 /* Pods-Spruce_Tests */, + 889446D12CC42CF3FA024DB1A3366501 /* Spruce */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXSourcesBuildPhase section */ + 29D2ABEC44EDFFA0CAFCF69A7E7DF5CF /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + E5A905EC8809D0D76F68D26AB746BC4D /* Animation.swift in Sources */, + BA8ABCABB4A611DEAE0B6060E735FD52 /* BaseDistancedSortFunction.swift in Sources */, + 91832C601B289B7CFE8FE0C97A52C829 /* CorneredSortFunction.swift in Sources */, + 7EF08D839FE38101F0B4DB51BCF031EB /* DefaultAnimations.swift in Sources */, + 16122EA4B07AB226DF90564DBD16C8F2 /* DefaultFullViewAnimations.swift in Sources */, + 30BFA214C6DFF1256B6A32ECC1C0B310 /* DefaultSortFunction.swift in Sources */, + DD15D53DA68DA641DB4E2537C2AC1220 /* FullViewAnimation.swift in Sources */, + 61BB62F324566F6B8399ED500478949E /* LinearSortFunction.swift in Sources */, + 8EFEE27DE436D21BFE8FF7EED042A6FD /* NoDelaySortFunction.swift in Sources */, + 982A4B31996C1F143079BE59AC4B28B7 /* PointOperations.swift in Sources */, + 04259D314C64660330FC9B65A89747A7 /* RadialSortFunction.swift in Sources */, + B6B644C3C6C747D7CF8BEC1A1C7ED0F1 /* RandomSortFunction.swift in Sources */, + 22DF3316C67C6961621A26BBBA639DA4 /* SortFunction.swift in Sources */, + 389FC243005275278B89A626FD12DD2E /* SpringAnimation.swift in Sources */, + 9AF58D1A7EB58DA3B92C40E9F66D1B16 /* Spruce-dummy.m in Sources */, + 1180BA6FFA0D226963DDB2A705C11CFD /* Spruce.swift in Sources */, + C40B19542E178531734266FFD0A7D849 /* SpruceButton.swift in Sources */, + 75739A85FC647F5AD23A2B82A79830BF /* SpruceViewController.swift in Sources */, + 0B576018939899704AE2D280242125B1 /* StandardAnimation.swift in Sources */, + 055B5469C7C3FF860BCC9C5F4B0B7382 /* ViewOperations.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 2BA80353CB83DA7EFD28B1F6404176F2 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 7F204E75BBC011BAA3903B7943FBC63F /* Pods-Spruce_Tests-dummy.m in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 3CF8902A520CB6681EA3D9B6520A506C /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + B16549263A0E88866CCB96E761617C6F /* Pods-Spruce_Example-dummy.m in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXTargetDependency section */ + 5EE6379DD850C30688B01ED25CBE5F5B /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + name = Spruce; + target = 889446D12CC42CF3FA024DB1A3366501 /* Spruce */; + targetProxy = 5C9A097675087D7AE27DA0A4AD95C7D6 /* PBXContainerItemProxy */; + }; +/* End PBXTargetDependency section */ + +/* Begin XCBuildConfiguration section */ + 4BF1C16CA3EBF8A0A7FA0BCF8D69B0B5 /* Debug */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 9C147CDF3CF695F8EDBB22607035D46A /* Pods-Spruce_Example.debug.xcconfig */; + buildSettings = { + "CODE_SIGN_IDENTITY[sdk=appletvos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=watchos*]" = ""; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_NO_COMMON_BLOCKS = YES; + INFOPLIST_FILE = "Target Support Files/Pods-Spruce_Example/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 8.3; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + MACH_O_TYPE = staticlib; + MODULEMAP_FILE = "Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.modulemap"; + MTL_ENABLE_DEBUG_INFO = YES; + OTHER_LDFLAGS = ""; + OTHER_LIBTOOLFLAGS = ""; + PODS_ROOT = "$(SRCROOT)"; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.${PRODUCT_NAME:rfc1034identifier}"; + PRODUCT_NAME = Pods_Spruce_Example; + SDKROOT = iphoneos; + SKIP_INSTALL = YES; + SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = Debug; + }; + 5093CA52E8EC242D1E35A3CA32733501 /* Release */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = D87409DAC88107B4FF98F7EF404BFC12 /* Pods-Spruce_Tests.release.xcconfig */; + buildSettings = { + "CODE_SIGN_IDENTITY[sdk=appletvos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=watchos*]" = ""; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_NO_COMMON_BLOCKS = YES; + INFOPLIST_FILE = "Target Support Files/Pods-Spruce_Tests/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 8.3; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + MACH_O_TYPE = staticlib; + MODULEMAP_FILE = "Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.modulemap"; + MTL_ENABLE_DEBUG_INFO = NO; + OTHER_LDFLAGS = ""; + OTHER_LIBTOOLFLAGS = ""; + PODS_ROOT = "$(SRCROOT)"; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.${PRODUCT_NAME:rfc1034identifier}"; + PRODUCT_NAME = Pods_Spruce_Tests; + SDKROOT = iphoneos; + SKIP_INSTALL = YES; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = Release; + }; + 88A8939B29D108E71D6131F318669B1D /* Release */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 89BEFCEB9618821EA82227F0316BD2EA /* Pods-Spruce_Example.release.xcconfig */; + buildSettings = { + "CODE_SIGN_IDENTITY[sdk=appletvos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=watchos*]" = ""; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_NO_COMMON_BLOCKS = YES; + INFOPLIST_FILE = "Target Support Files/Pods-Spruce_Example/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 8.3; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + MACH_O_TYPE = staticlib; + MODULEMAP_FILE = "Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.modulemap"; + MTL_ENABLE_DEBUG_INFO = NO; + OTHER_LDFLAGS = ""; + OTHER_LIBTOOLFLAGS = ""; + PODS_ROOT = "$(SRCROOT)"; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.${PRODUCT_NAME:rfc1034identifier}"; + PRODUCT_NAME = Pods_Spruce_Example; + SDKROOT = iphoneos; + SKIP_INSTALL = YES; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = Release; + }; + 8DED8AD26D381A6ACFF202E5217EC498 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGNING_REQUIRED = NO; + COPY_PHASE_STRIP = YES; + ENABLE_NS_ASSERTIONS = NO; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_PREPROCESSOR_DEFINITIONS = ( + "POD_CONFIGURATION_RELEASE=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 8.3; + PROVISIONING_PROFILE_SPECIFIER = NO_SIGNING/; + STRIP_INSTALLED_PRODUCT = NO; + SYMROOT = "${SRCROOT}/../build"; + VALIDATE_PRODUCT = YES; + }; + name = Release; + }; + 9E1E4E48AF2EAB23169E611BF694090A /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGNING_REQUIRED = NO; + COPY_PHASE_STRIP = NO; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "POD_CONFIGURATION_DEBUG=1", + "DEBUG=1", + "$(inherited)", + ); + GCC_SYMBOLS_PRIVATE_EXTERN = NO; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 8.3; + ONLY_ACTIVE_ARCH = YES; + PROVISIONING_PROFILE_SPECIFIER = NO_SIGNING/; + STRIP_INSTALLED_PRODUCT = NO; + SYMROOT = "${SRCROOT}/../build"; + }; + name = Debug; + }; + A4BF9367C3FB88C4724BE8F25A720DBD /* Release */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 23E7013232AB26A7CDF4F539958A88DA /* Spruce.xcconfig */; + buildSettings = { + "CODE_SIGN_IDENTITY[sdk=appletvos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=watchos*]" = ""; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_NO_COMMON_BLOCKS = YES; + GCC_PREFIX_HEADER = "Target Support Files/Spruce/Spruce-prefix.pch"; + INFOPLIST_FILE = "Target Support Files/Spruce/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 8.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + MODULEMAP_FILE = "Target Support Files/Spruce/Spruce.modulemap"; + MTL_ENABLE_DEBUG_INFO = NO; + PRODUCT_NAME = Spruce; + SDKROOT = iphoneos; + SKIP_INSTALL = YES; + SWIFT_VERSION = 3.0; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = Release; + }; + D10DC50463C1EC394CAB605C27E963FE /* Debug */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 55616E35201003565304A5DE3F1F1C3E /* Pods-Spruce_Tests.debug.xcconfig */; + buildSettings = { + "CODE_SIGN_IDENTITY[sdk=appletvos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=watchos*]" = ""; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_NO_COMMON_BLOCKS = YES; + INFOPLIST_FILE = "Target Support Files/Pods-Spruce_Tests/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 8.3; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + MACH_O_TYPE = staticlib; + MODULEMAP_FILE = "Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.modulemap"; + MTL_ENABLE_DEBUG_INFO = YES; + OTHER_LDFLAGS = ""; + OTHER_LIBTOOLFLAGS = ""; + PODS_ROOT = "$(SRCROOT)"; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.${PRODUCT_NAME:rfc1034identifier}"; + PRODUCT_NAME = Pods_Spruce_Tests; + SDKROOT = iphoneos; + SKIP_INSTALL = YES; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = Debug; + }; + E7FD3C44AC265D64499C3822BAFE5A84 /* Debug */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 23E7013232AB26A7CDF4F539958A88DA /* Spruce.xcconfig */; + buildSettings = { + "CODE_SIGN_IDENTITY[sdk=appletvos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = ""; + "CODE_SIGN_IDENTITY[sdk=watchos*]" = ""; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_NO_COMMON_BLOCKS = YES; + GCC_PREFIX_HEADER = "Target Support Files/Spruce/Spruce-prefix.pch"; + INFOPLIST_FILE = "Target Support Files/Spruce/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 8.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + MODULEMAP_FILE = "Target Support Files/Spruce/Spruce.modulemap"; + MTL_ENABLE_DEBUG_INFO = YES; + PRODUCT_NAME = Spruce; + SDKROOT = iphoneos; + SKIP_INSTALL = YES; + SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + SWIFT_VERSION = 3.0; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = Debug; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 06F74E89843A23C56577F38F566F4B3D /* Build configuration list for PBXNativeTarget "Spruce" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + E7FD3C44AC265D64499C3822BAFE5A84 /* Debug */, + A4BF9367C3FB88C4724BE8F25A720DBD /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 2D8E8EC45A3A1A1D94AE762CB5028504 /* Build configuration list for PBXProject "Pods" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 9E1E4E48AF2EAB23169E611BF694090A /* Debug */, + 8DED8AD26D381A6ACFF202E5217EC498 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 388BE1A2B65C1F7F2819B54E36F9535B /* Build configuration list for PBXNativeTarget "Pods-Spruce_Example" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 4BF1C16CA3EBF8A0A7FA0BCF8D69B0B5 /* Debug */, + 88A8939B29D108E71D6131F318669B1D /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 7D25524F38FBC177AD13396670FC9E2C /* Build configuration list for PBXNativeTarget "Pods-Spruce_Tests" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + D10DC50463C1EC394CAB605C27E963FE /* Debug */, + 5093CA52E8EC242D1E35A3CA32733501 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = D41D8CD98F00B204E9800998ECF8427E /* Project object */; +} diff --git a/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Pods-Spruce_Example.xcscheme b/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Pods-Spruce_Example.xcscheme new file mode 100644 index 0000000..760e586 --- /dev/null +++ b/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Pods-Spruce_Example.xcscheme @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Pods-Spruce_Tests.xcscheme b/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Pods-Spruce_Tests.xcscheme new file mode 100644 index 0000000..c146e6b --- /dev/null +++ b/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Pods-Spruce_Tests.xcscheme @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Spruce.xcscheme b/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Spruce.xcscheme new file mode 100644 index 0000000..7df475b --- /dev/null +++ b/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Spruce.xcscheme @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist b/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist new file mode 100644 index 0000000..d42807b --- /dev/null +++ b/Example/Pods/Pods.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist @@ -0,0 +1,42 @@ + + + + + SchemeUserState + + Pods-Spruce_Example.xcscheme + + isShown + + + Pods-Spruce_Tests.xcscheme + + isShown + + + Spruce.xcscheme + + isShown + + + + SuppressBuildableAutocreation + + 2B7321D1E525D2BA824577402C83D8E6 + + primary + + + 889446D12CC42CF3FA024DB1A3366501 + + primary + + + DE2FBFC5C3EC89E291968B42F109C4D6 + + primary + + + + + diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Example/Info.plist b/Example/Pods/Target Support Files/Pods-Spruce_Example/Info.plist new file mode 100644 index 0000000..2243fe6 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Example/Info.plist @@ -0,0 +1,26 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleExecutable + ${EXECUTABLE_NAME} + CFBundleIdentifier + ${PRODUCT_BUNDLE_IDENTIFIER} + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + ${PRODUCT_NAME} + CFBundlePackageType + FMWK + CFBundleShortVersionString + 1.0.0 + CFBundleSignature + ???? + CFBundleVersion + ${CURRENT_PROJECT_VERSION} + NSPrincipalClass + + + diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-acknowledgements.markdown b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-acknowledgements.markdown new file mode 100644 index 0000000..de31aa8 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-acknowledgements.markdown @@ -0,0 +1,26 @@ +# Acknowledgements +This application makes use of the following third party libraries: + +## Spruce + +Copyright (c) 2016 Jackson Taylor + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. + +Generated by CocoaPods - https://cocoapods.org diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-acknowledgements.plist b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-acknowledgements.plist new file mode 100644 index 0000000..2cc940e --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-acknowledgements.plist @@ -0,0 +1,58 @@ + + + + + PreferenceSpecifiers + + + FooterText + This application makes use of the following third party libraries: + Title + Acknowledgements + Type + PSGroupSpecifier + + + FooterText + Copyright (c) 2016 Jackson Taylor <jackson.taylor@willowtreeapps.com> + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. + + License + MIT + Title + Spruce + Type + PSGroupSpecifier + + + FooterText + Generated by CocoaPods - https://cocoapods.org + Title + + Type + PSGroupSpecifier + + + StringsTable + Acknowledgements + Title + Acknowledgements + + diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-dummy.m b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-dummy.m new file mode 100644 index 0000000..d34dcee --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-dummy.m @@ -0,0 +1,5 @@ +#import +@interface PodsDummy_Pods_Spruce_Example : NSObject +@end +@implementation PodsDummy_Pods_Spruce_Example +@end diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-frameworks.sh b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-frameworks.sh new file mode 100755 index 0000000..6b4b219 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-frameworks.sh @@ -0,0 +1,91 @@ +#!/bin/sh +set -e + +echo "mkdir -p ${CONFIGURATION_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" +mkdir -p "${CONFIGURATION_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + +SWIFT_STDLIB_PATH="${DT_TOOLCHAIN_DIR}/usr/lib/swift/${PLATFORM_NAME}" + +install_framework() +{ + if [ -r "${BUILT_PRODUCTS_DIR}/$1" ]; then + local source="${BUILT_PRODUCTS_DIR}/$1" + elif [ -r "${BUILT_PRODUCTS_DIR}/$(basename "$1")" ]; then + local source="${BUILT_PRODUCTS_DIR}/$(basename "$1")" + elif [ -r "$1" ]; then + local source="$1" + fi + + local destination="${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + + if [ -L "${source}" ]; then + echo "Symlinked..." + source="$(readlink "${source}")" + fi + + # use filter instead of exclude so missing patterns dont' throw errors + echo "rsync -av --filter \"- CVS/\" --filter \"- .svn/\" --filter \"- .git/\" --filter \"- .hg/\" --filter \"- Headers\" --filter \"- PrivateHeaders\" --filter \"- Modules\" \"${source}\" \"${destination}\"" + rsync -av --filter "- CVS/" --filter "- .svn/" --filter "- .git/" --filter "- .hg/" --filter "- Headers" --filter "- PrivateHeaders" --filter "- Modules" "${source}" "${destination}" + + local basename + basename="$(basename -s .framework "$1")" + binary="${destination}/${basename}.framework/${basename}" + if ! [ -r "$binary" ]; then + binary="${destination}/${basename}" + fi + + # Strip invalid architectures so "fat" simulator / device frameworks work on device + if [[ "$(file "$binary")" == *"dynamically linked shared library"* ]]; then + strip_invalid_archs "$binary" + fi + + # Resign the code if required by the build settings to avoid unstable apps + code_sign_if_enabled "${destination}/$(basename "$1")" + + # Embed linked Swift runtime libraries. No longer necessary as of Xcode 7. + if [ "${XCODE_VERSION_MAJOR}" -lt 7 ]; then + local swift_runtime_libs + swift_runtime_libs=$(xcrun otool -LX "$binary" | grep --color=never @rpath/libswift | sed -E s/@rpath\\/\(.+dylib\).*/\\1/g | uniq -u && exit ${PIPESTATUS[0]}) + for lib in $swift_runtime_libs; do + echo "rsync -auv \"${SWIFT_STDLIB_PATH}/${lib}\" \"${destination}\"" + rsync -auv "${SWIFT_STDLIB_PATH}/${lib}" "${destination}" + code_sign_if_enabled "${destination}/${lib}" + done + fi +} + +# Signs a framework with the provided identity +code_sign_if_enabled() { + if [ -n "${EXPANDED_CODE_SIGN_IDENTITY}" -a "${CODE_SIGNING_REQUIRED}" != "NO" -a "${CODE_SIGNING_ALLOWED}" != "NO" ]; then + # Use the current code_sign_identitiy + echo "Code Signing $1 with Identity ${EXPANDED_CODE_SIGN_IDENTITY_NAME}" + echo "/usr/bin/codesign --force --sign ${EXPANDED_CODE_SIGN_IDENTITY} ${OTHER_CODE_SIGN_FLAGS} --preserve-metadata=identifier,entitlements \"$1\"" + /usr/bin/codesign --force --sign ${EXPANDED_CODE_SIGN_IDENTITY} ${OTHER_CODE_SIGN_FLAGS} --preserve-metadata=identifier,entitlements "$1" + fi +} + +# Strip invalid architectures +strip_invalid_archs() { + binary="$1" + # Get architectures for current file + archs="$(lipo -info "$binary" | rev | cut -d ':' -f1 | rev)" + stripped="" + for arch in $archs; do + if ! [[ "${VALID_ARCHS}" == *"$arch"* ]]; then + # Strip non-valid architectures in-place + lipo -remove "$arch" -output "$binary" "$binary" || exit 1 + stripped="$stripped $arch" + fi + done + if [[ "$stripped" ]]; then + echo "Stripped $binary of architectures:$stripped" + fi +} + + +if [[ "$CONFIGURATION" == "Debug" ]]; then + install_framework "$BUILT_PRODUCTS_DIR/Spruce/Spruce.framework" +fi +if [[ "$CONFIGURATION" == "Release" ]]; then + install_framework "$BUILT_PRODUCTS_DIR/Spruce/Spruce.framework" +fi diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-resources.sh b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-resources.sh new file mode 100755 index 0000000..25e9d37 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-resources.sh @@ -0,0 +1,96 @@ +#!/bin/sh +set -e + +mkdir -p "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" + +RESOURCES_TO_COPY=${PODS_ROOT}/resources-to-copy-${TARGETNAME}.txt +> "$RESOURCES_TO_COPY" + +XCASSET_FILES=() + +case "${TARGETED_DEVICE_FAMILY}" in + 1,2) + TARGET_DEVICE_ARGS="--target-device ipad --target-device iphone" + ;; + 1) + TARGET_DEVICE_ARGS="--target-device iphone" + ;; + 2) + TARGET_DEVICE_ARGS="--target-device ipad" + ;; + *) + TARGET_DEVICE_ARGS="--target-device mac" + ;; +esac + +install_resource() +{ + if [[ "$1" = /* ]] ; then + RESOURCE_PATH="$1" + else + RESOURCE_PATH="${PODS_ROOT}/$1" + fi + if [[ ! -e "$RESOURCE_PATH" ]] ; then + cat << EOM +error: Resource "$RESOURCE_PATH" not found. Run 'pod install' to update the copy resources script. +EOM + exit 1 + fi + case $RESOURCE_PATH in + *.storyboard) + echo "ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile ${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .storyboard`.storyboardc $RESOURCE_PATH --sdk ${SDKROOT} ${TARGET_DEVICE_ARGS}" + ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .storyboard`.storyboardc" "$RESOURCE_PATH" --sdk "${SDKROOT}" ${TARGET_DEVICE_ARGS} + ;; + *.xib) + echo "ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile ${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .xib`.nib $RESOURCE_PATH --sdk ${SDKROOT} ${TARGET_DEVICE_ARGS}" + ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .xib`.nib" "$RESOURCE_PATH" --sdk "${SDKROOT}" ${TARGET_DEVICE_ARGS} + ;; + *.framework) + echo "mkdir -p ${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + mkdir -p "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + echo "rsync -av $RESOURCE_PATH ${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + rsync -av "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + ;; + *.xcdatamodel) + echo "xcrun momc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH"`.mom\"" + xcrun momc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodel`.mom" + ;; + *.xcdatamodeld) + echo "xcrun momc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodeld`.momd\"" + xcrun momc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodeld`.momd" + ;; + *.xcmappingmodel) + echo "xcrun mapc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcmappingmodel`.cdm\"" + xcrun mapc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcmappingmodel`.cdm" + ;; + *.xcassets) + ABSOLUTE_XCASSET_FILE="$RESOURCE_PATH" + XCASSET_FILES+=("$ABSOLUTE_XCASSET_FILE") + ;; + *) + echo "$RESOURCE_PATH" + echo "$RESOURCE_PATH" >> "$RESOURCES_TO_COPY" + ;; + esac +} + +mkdir -p "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" +rsync -avr --copy-links --no-relative --exclude '*/.svn/*' --files-from="$RESOURCES_TO_COPY" / "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" +if [[ "${ACTION}" == "install" ]] && [[ "${SKIP_INSTALL}" == "NO" ]]; then + mkdir -p "${INSTALL_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" + rsync -avr --copy-links --no-relative --exclude '*/.svn/*' --files-from="$RESOURCES_TO_COPY" / "${INSTALL_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" +fi +rm -f "$RESOURCES_TO_COPY" + +if [[ -n "${WRAPPER_EXTENSION}" ]] && [ "`xcrun --find actool`" ] && [ -n "$XCASSET_FILES" ] +then + # Find all other xcassets (this unfortunately includes those of path pods and other targets). + OTHER_XCASSETS=$(find "$PWD" -iname "*.xcassets" -type d) + while read line; do + if [[ $line != "${PODS_ROOT}*" ]]; then + XCASSET_FILES+=("$line") + fi + done <<<"$OTHER_XCASSETS" + + printf "%s\0" "${XCASSET_FILES[@]}" | xargs -0 xcrun actool --output-format human-readable-text --notices --warnings --platform "${PLATFORM_NAME}" --minimum-deployment-target "${!DEPLOYMENT_TARGET_SETTING_NAME}" ${TARGET_DEVICE_ARGS} --compress-pngs --compile "${BUILT_PRODUCTS_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" +fi diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-umbrella.h b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-umbrella.h new file mode 100644 index 0000000..82520d4 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-umbrella.h @@ -0,0 +1,8 @@ +#ifdef __OBJC__ +#import +#endif + + +FOUNDATION_EXPORT double Pods_Spruce_ExampleVersionNumber; +FOUNDATION_EXPORT const unsigned char Pods_Spruce_ExampleVersionString[]; + diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.debug.xcconfig b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.debug.xcconfig new file mode 100644 index 0000000..7888aee --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.debug.xcconfig @@ -0,0 +1,11 @@ +ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES +EMBEDDED_CONTENT_CONTAINS_SWIFT = YES +FRAMEWORK_SEARCH_PATHS = $(inherited) "$PODS_CONFIGURATION_BUILD_DIR/Spruce" +GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1 +LD_RUNPATH_SEARCH_PATHS = $(inherited) '@executable_path/Frameworks' '@loader_path/Frameworks' +OTHER_CFLAGS = $(inherited) -iquote "$PODS_CONFIGURATION_BUILD_DIR/Spruce/Spruce.framework/Headers" +OTHER_LDFLAGS = $(inherited) -framework "Spruce" +OTHER_SWIFT_FLAGS = $(inherited) "-D" "COCOAPODS" +PODS_BUILD_DIR = $BUILD_DIR +PODS_CONFIGURATION_BUILD_DIR = $PODS_BUILD_DIR/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME) +PODS_ROOT = ${SRCROOT}/Pods diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.modulemap b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.modulemap new file mode 100644 index 0000000..ecda65c --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.modulemap @@ -0,0 +1,6 @@ +framework module Pods_Spruce_Example { + umbrella header "Pods-Spruce_Example-umbrella.h" + + export * + module * { export * } +} diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.release.xcconfig b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.release.xcconfig new file mode 100644 index 0000000..7888aee --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.release.xcconfig @@ -0,0 +1,11 @@ +ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES +EMBEDDED_CONTENT_CONTAINS_SWIFT = YES +FRAMEWORK_SEARCH_PATHS = $(inherited) "$PODS_CONFIGURATION_BUILD_DIR/Spruce" +GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1 +LD_RUNPATH_SEARCH_PATHS = $(inherited) '@executable_path/Frameworks' '@loader_path/Frameworks' +OTHER_CFLAGS = $(inherited) -iquote "$PODS_CONFIGURATION_BUILD_DIR/Spruce/Spruce.framework/Headers" +OTHER_LDFLAGS = $(inherited) -framework "Spruce" +OTHER_SWIFT_FLAGS = $(inherited) "-D" "COCOAPODS" +PODS_BUILD_DIR = $BUILD_DIR +PODS_CONFIGURATION_BUILD_DIR = $PODS_BUILD_DIR/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME) +PODS_ROOT = ${SRCROOT}/Pods diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Tests/Info.plist b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Info.plist new file mode 100644 index 0000000..2243fe6 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Info.plist @@ -0,0 +1,26 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleExecutable + ${EXECUTABLE_NAME} + CFBundleIdentifier + ${PRODUCT_BUNDLE_IDENTIFIER} + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + ${PRODUCT_NAME} + CFBundlePackageType + FMWK + CFBundleShortVersionString + 1.0.0 + CFBundleSignature + ???? + CFBundleVersion + ${CURRENT_PROJECT_VERSION} + NSPrincipalClass + + + diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-acknowledgements.markdown b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-acknowledgements.markdown new file mode 100644 index 0000000..102af75 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-acknowledgements.markdown @@ -0,0 +1,3 @@ +# Acknowledgements +This application makes use of the following third party libraries: +Generated by CocoaPods - https://cocoapods.org diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-acknowledgements.plist b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-acknowledgements.plist new file mode 100644 index 0000000..7acbad1 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-acknowledgements.plist @@ -0,0 +1,29 @@ + + + + + PreferenceSpecifiers + + + FooterText + This application makes use of the following third party libraries: + Title + Acknowledgements + Type + PSGroupSpecifier + + + FooterText + Generated by CocoaPods - https://cocoapods.org + Title + + Type + PSGroupSpecifier + + + StringsTable + Acknowledgements + Title + Acknowledgements + + diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-dummy.m b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-dummy.m new file mode 100644 index 0000000..c81acbb --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-dummy.m @@ -0,0 +1,5 @@ +#import +@interface PodsDummy_Pods_Spruce_Tests : NSObject +@end +@implementation PodsDummy_Pods_Spruce_Tests +@end diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-frameworks.sh b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-frameworks.sh new file mode 100755 index 0000000..893c16a --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-frameworks.sh @@ -0,0 +1,84 @@ +#!/bin/sh +set -e + +echo "mkdir -p ${CONFIGURATION_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" +mkdir -p "${CONFIGURATION_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + +SWIFT_STDLIB_PATH="${DT_TOOLCHAIN_DIR}/usr/lib/swift/${PLATFORM_NAME}" + +install_framework() +{ + if [ -r "${BUILT_PRODUCTS_DIR}/$1" ]; then + local source="${BUILT_PRODUCTS_DIR}/$1" + elif [ -r "${BUILT_PRODUCTS_DIR}/$(basename "$1")" ]; then + local source="${BUILT_PRODUCTS_DIR}/$(basename "$1")" + elif [ -r "$1" ]; then + local source="$1" + fi + + local destination="${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + + if [ -L "${source}" ]; then + echo "Symlinked..." + source="$(readlink "${source}")" + fi + + # use filter instead of exclude so missing patterns dont' throw errors + echo "rsync -av --filter \"- CVS/\" --filter \"- .svn/\" --filter \"- .git/\" --filter \"- .hg/\" --filter \"- Headers\" --filter \"- PrivateHeaders\" --filter \"- Modules\" \"${source}\" \"${destination}\"" + rsync -av --filter "- CVS/" --filter "- .svn/" --filter "- .git/" --filter "- .hg/" --filter "- Headers" --filter "- PrivateHeaders" --filter "- Modules" "${source}" "${destination}" + + local basename + basename="$(basename -s .framework "$1")" + binary="${destination}/${basename}.framework/${basename}" + if ! [ -r "$binary" ]; then + binary="${destination}/${basename}" + fi + + # Strip invalid architectures so "fat" simulator / device frameworks work on device + if [[ "$(file "$binary")" == *"dynamically linked shared library"* ]]; then + strip_invalid_archs "$binary" + fi + + # Resign the code if required by the build settings to avoid unstable apps + code_sign_if_enabled "${destination}/$(basename "$1")" + + # Embed linked Swift runtime libraries. No longer necessary as of Xcode 7. + if [ "${XCODE_VERSION_MAJOR}" -lt 7 ]; then + local swift_runtime_libs + swift_runtime_libs=$(xcrun otool -LX "$binary" | grep --color=never @rpath/libswift | sed -E s/@rpath\\/\(.+dylib\).*/\\1/g | uniq -u && exit ${PIPESTATUS[0]}) + for lib in $swift_runtime_libs; do + echo "rsync -auv \"${SWIFT_STDLIB_PATH}/${lib}\" \"${destination}\"" + rsync -auv "${SWIFT_STDLIB_PATH}/${lib}" "${destination}" + code_sign_if_enabled "${destination}/${lib}" + done + fi +} + +# Signs a framework with the provided identity +code_sign_if_enabled() { + if [ -n "${EXPANDED_CODE_SIGN_IDENTITY}" -a "${CODE_SIGNING_REQUIRED}" != "NO" -a "${CODE_SIGNING_ALLOWED}" != "NO" ]; then + # Use the current code_sign_identitiy + echo "Code Signing $1 with Identity ${EXPANDED_CODE_SIGN_IDENTITY_NAME}" + echo "/usr/bin/codesign --force --sign ${EXPANDED_CODE_SIGN_IDENTITY} ${OTHER_CODE_SIGN_FLAGS} --preserve-metadata=identifier,entitlements \"$1\"" + /usr/bin/codesign --force --sign ${EXPANDED_CODE_SIGN_IDENTITY} ${OTHER_CODE_SIGN_FLAGS} --preserve-metadata=identifier,entitlements "$1" + fi +} + +# Strip invalid architectures +strip_invalid_archs() { + binary="$1" + # Get architectures for current file + archs="$(lipo -info "$binary" | rev | cut -d ':' -f1 | rev)" + stripped="" + for arch in $archs; do + if ! [[ "${VALID_ARCHS}" == *"$arch"* ]]; then + # Strip non-valid architectures in-place + lipo -remove "$arch" -output "$binary" "$binary" || exit 1 + stripped="$stripped $arch" + fi + done + if [[ "$stripped" ]]; then + echo "Stripped $binary of architectures:$stripped" + fi +} + diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-resources.sh b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-resources.sh new file mode 100755 index 0000000..25e9d37 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-resources.sh @@ -0,0 +1,96 @@ +#!/bin/sh +set -e + +mkdir -p "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" + +RESOURCES_TO_COPY=${PODS_ROOT}/resources-to-copy-${TARGETNAME}.txt +> "$RESOURCES_TO_COPY" + +XCASSET_FILES=() + +case "${TARGETED_DEVICE_FAMILY}" in + 1,2) + TARGET_DEVICE_ARGS="--target-device ipad --target-device iphone" + ;; + 1) + TARGET_DEVICE_ARGS="--target-device iphone" + ;; + 2) + TARGET_DEVICE_ARGS="--target-device ipad" + ;; + *) + TARGET_DEVICE_ARGS="--target-device mac" + ;; +esac + +install_resource() +{ + if [[ "$1" = /* ]] ; then + RESOURCE_PATH="$1" + else + RESOURCE_PATH="${PODS_ROOT}/$1" + fi + if [[ ! -e "$RESOURCE_PATH" ]] ; then + cat << EOM +error: Resource "$RESOURCE_PATH" not found. Run 'pod install' to update the copy resources script. +EOM + exit 1 + fi + case $RESOURCE_PATH in + *.storyboard) + echo "ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile ${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .storyboard`.storyboardc $RESOURCE_PATH --sdk ${SDKROOT} ${TARGET_DEVICE_ARGS}" + ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .storyboard`.storyboardc" "$RESOURCE_PATH" --sdk "${SDKROOT}" ${TARGET_DEVICE_ARGS} + ;; + *.xib) + echo "ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile ${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .xib`.nib $RESOURCE_PATH --sdk ${SDKROOT} ${TARGET_DEVICE_ARGS}" + ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .xib`.nib" "$RESOURCE_PATH" --sdk "${SDKROOT}" ${TARGET_DEVICE_ARGS} + ;; + *.framework) + echo "mkdir -p ${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + mkdir -p "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + echo "rsync -av $RESOURCE_PATH ${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + rsync -av "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" + ;; + *.xcdatamodel) + echo "xcrun momc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH"`.mom\"" + xcrun momc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodel`.mom" + ;; + *.xcdatamodeld) + echo "xcrun momc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodeld`.momd\"" + xcrun momc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodeld`.momd" + ;; + *.xcmappingmodel) + echo "xcrun mapc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcmappingmodel`.cdm\"" + xcrun mapc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcmappingmodel`.cdm" + ;; + *.xcassets) + ABSOLUTE_XCASSET_FILE="$RESOURCE_PATH" + XCASSET_FILES+=("$ABSOLUTE_XCASSET_FILE") + ;; + *) + echo "$RESOURCE_PATH" + echo "$RESOURCE_PATH" >> "$RESOURCES_TO_COPY" + ;; + esac +} + +mkdir -p "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" +rsync -avr --copy-links --no-relative --exclude '*/.svn/*' --files-from="$RESOURCES_TO_COPY" / "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" +if [[ "${ACTION}" == "install" ]] && [[ "${SKIP_INSTALL}" == "NO" ]]; then + mkdir -p "${INSTALL_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" + rsync -avr --copy-links --no-relative --exclude '*/.svn/*' --files-from="$RESOURCES_TO_COPY" / "${INSTALL_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" +fi +rm -f "$RESOURCES_TO_COPY" + +if [[ -n "${WRAPPER_EXTENSION}" ]] && [ "`xcrun --find actool`" ] && [ -n "$XCASSET_FILES" ] +then + # Find all other xcassets (this unfortunately includes those of path pods and other targets). + OTHER_XCASSETS=$(find "$PWD" -iname "*.xcassets" -type d) + while read line; do + if [[ $line != "${PODS_ROOT}*" ]]; then + XCASSET_FILES+=("$line") + fi + done <<<"$OTHER_XCASSETS" + + printf "%s\0" "${XCASSET_FILES[@]}" | xargs -0 xcrun actool --output-format human-readable-text --notices --warnings --platform "${PLATFORM_NAME}" --minimum-deployment-target "${!DEPLOYMENT_TARGET_SETTING_NAME}" ${TARGET_DEVICE_ARGS} --compress-pngs --compile "${BUILT_PRODUCTS_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" +fi diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-umbrella.h b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-umbrella.h new file mode 100644 index 0000000..6411fbc --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-umbrella.h @@ -0,0 +1,8 @@ +#ifdef __OBJC__ +#import +#endif + + +FOUNDATION_EXPORT double Pods_Spruce_TestsVersionNumber; +FOUNDATION_EXPORT const unsigned char Pods_Spruce_TestsVersionString[]; + diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.debug.xcconfig b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.debug.xcconfig new file mode 100644 index 0000000..a105ee8 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.debug.xcconfig @@ -0,0 +1,8 @@ +ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = NO +FRAMEWORK_SEARCH_PATHS = $(inherited) "$PODS_CONFIGURATION_BUILD_DIR/Spruce" +GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1 +LD_RUNPATH_SEARCH_PATHS = $(inherited) '@executable_path/Frameworks' '@loader_path/Frameworks' +OTHER_CFLAGS = $(inherited) -iquote "$PODS_CONFIGURATION_BUILD_DIR/Spruce/Spruce.framework/Headers" +PODS_BUILD_DIR = $BUILD_DIR +PODS_CONFIGURATION_BUILD_DIR = $PODS_BUILD_DIR/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME) +PODS_ROOT = ${SRCROOT}/Pods diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.modulemap b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.modulemap new file mode 100644 index 0000000..d3f5b87 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.modulemap @@ -0,0 +1,6 @@ +framework module Pods_Spruce_Tests { + umbrella header "Pods-Spruce_Tests-umbrella.h" + + export * + module * { export * } +} diff --git a/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.release.xcconfig b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.release.xcconfig new file mode 100644 index 0000000..a105ee8 --- /dev/null +++ b/Example/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.release.xcconfig @@ -0,0 +1,8 @@ +ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = NO +FRAMEWORK_SEARCH_PATHS = $(inherited) "$PODS_CONFIGURATION_BUILD_DIR/Spruce" +GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1 +LD_RUNPATH_SEARCH_PATHS = $(inherited) '@executable_path/Frameworks' '@loader_path/Frameworks' +OTHER_CFLAGS = $(inherited) -iquote "$PODS_CONFIGURATION_BUILD_DIR/Spruce/Spruce.framework/Headers" +PODS_BUILD_DIR = $BUILD_DIR +PODS_CONFIGURATION_BUILD_DIR = $PODS_BUILD_DIR/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME) +PODS_ROOT = ${SRCROOT}/Pods diff --git a/Example/Pods/Target Support Files/Spruce/Info.plist b/Example/Pods/Target Support Files/Spruce/Info.plist new file mode 100644 index 0000000..161a9d3 --- /dev/null +++ b/Example/Pods/Target Support Files/Spruce/Info.plist @@ -0,0 +1,26 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleExecutable + ${EXECUTABLE_NAME} + CFBundleIdentifier + ${PRODUCT_BUNDLE_IDENTIFIER} + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + ${PRODUCT_NAME} + CFBundlePackageType + FMWK + CFBundleShortVersionString + 0.1.0 + CFBundleSignature + ???? + CFBundleVersion + ${CURRENT_PROJECT_VERSION} + NSPrincipalClass + + + diff --git a/Example/Pods/Target Support Files/Spruce/Spruce-dummy.m b/Example/Pods/Target Support Files/Spruce/Spruce-dummy.m new file mode 100644 index 0000000..dbb147c --- /dev/null +++ b/Example/Pods/Target Support Files/Spruce/Spruce-dummy.m @@ -0,0 +1,5 @@ +#import +@interface PodsDummy_Spruce : NSObject +@end +@implementation PodsDummy_Spruce +@end diff --git a/Example/Pods/Target Support Files/Spruce/Spruce-prefix.pch b/Example/Pods/Target Support Files/Spruce/Spruce-prefix.pch new file mode 100644 index 0000000..aa992a4 --- /dev/null +++ b/Example/Pods/Target Support Files/Spruce/Spruce-prefix.pch @@ -0,0 +1,4 @@ +#ifdef __OBJC__ +#import +#endif + diff --git a/Example/Pods/Target Support Files/Spruce/Spruce-umbrella.h b/Example/Pods/Target Support Files/Spruce/Spruce-umbrella.h new file mode 100644 index 0000000..0870257 --- /dev/null +++ b/Example/Pods/Target Support Files/Spruce/Spruce-umbrella.h @@ -0,0 +1,8 @@ +#ifdef __OBJC__ +#import +#endif + + +FOUNDATION_EXPORT double SpruceVersionNumber; +FOUNDATION_EXPORT const unsigned char SpruceVersionString[]; + diff --git a/Example/Pods/Target Support Files/Spruce/Spruce.modulemap b/Example/Pods/Target Support Files/Spruce/Spruce.modulemap new file mode 100644 index 0000000..2a93949 --- /dev/null +++ b/Example/Pods/Target Support Files/Spruce/Spruce.modulemap @@ -0,0 +1,6 @@ +framework module Spruce { + umbrella header "Spruce-umbrella.h" + + export * + module * { export * } +} diff --git a/Example/Pods/Target Support Files/Spruce/Spruce.xcconfig b/Example/Pods/Target Support Files/Spruce/Spruce.xcconfig new file mode 100644 index 0000000..90f971e --- /dev/null +++ b/Example/Pods/Target Support Files/Spruce/Spruce.xcconfig @@ -0,0 +1,9 @@ +CONFIGURATION_BUILD_DIR = $PODS_CONFIGURATION_BUILD_DIR/Spruce +GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1 +HEADER_SEARCH_PATHS = "${PODS_ROOT}/Headers/Private" "${PODS_ROOT}/Headers/Public" +OTHER_SWIFT_FLAGS = $(inherited) "-D" "COCOAPODS" +PODS_BUILD_DIR = $BUILD_DIR +PODS_CONFIGURATION_BUILD_DIR = $PODS_BUILD_DIR/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME) +PODS_ROOT = ${SRCROOT} +PRODUCT_BUNDLE_IDENTIFIER = org.cocoapods.${PRODUCT_NAME:rfc1034identifier} +SKIP_INSTALL = YES diff --git a/Example/Spruce.xcodeproj/project.pbxproj b/Example/Spruce.xcodeproj/project.pbxproj new file mode 100644 index 0000000..0952b44 --- /dev/null +++ b/Example/Spruce.xcodeproj/project.pbxproj @@ -0,0 +1,615 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 46; + objects = { + +/* Begin PBXBuildFile section */ + 4A43C1DAC694719AE6B7A749 /* Pods_Spruce_Tests.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 4B828A1EFFD048AD3A2E0675 /* Pods_Spruce_Tests.framework */; }; + 607FACD61AFB9204008FA782 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 607FACD51AFB9204008FA782 /* AppDelegate.swift */; }; + 607FACDD1AFB9204008FA782 /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 607FACDC1AFB9204008FA782 /* Images.xcassets */; }; + 607FACE01AFB9204008FA782 /* LaunchScreen.xib in Resources */ = {isa = PBXBuildFile; fileRef = 607FACDE1AFB9204008FA782 /* LaunchScreen.xib */; }; + 607FACEC1AFB9204008FA782 /* Tests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 607FACEB1AFB9204008FA782 /* Tests.swift */; }; + 8D0D1A6A199FC9630A10DED3 /* Pods_Spruce_Example.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = FDBE5745B9DE9B1EAB8C910C /* Pods_Spruce_Example.framework */; }; + DB9357EC1DFB026400ADC5BE /* TableViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB9357E31DFB026400ADC5BE /* TableViewController.swift */; }; + DB9357ED1DFB026400ADC5BE /* TestCollectionVIew.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB9357E41DFB026400ADC5BE /* TestCollectionVIew.swift */; }; + DB9357EE1DFB026400ADC5BE /* TestViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB9357E51DFB026400ADC5BE /* TestViewController.swift */; }; + DB9357EF1DFB026400ADC5BE /* TestViewController2.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB9357E61DFB026400ADC5BE /* TestViewController2.swift */; }; + DB9357F01DFB026400ADC5BE /* TestViewController2Setup.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB9357E71DFB026400ADC5BE /* TestViewController2Setup.swift */; }; + DB9357F11DFB026400ADC5BE /* TestViewController3.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB9357E81DFB026400ADC5BE /* TestViewController3.swift */; }; + DB9357F21DFB026400ADC5BE /* TestViewControllerSetup.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB9357E91DFB026400ADC5BE /* TestViewControllerSetup.swift */; }; +/* End PBXBuildFile section */ + +/* Begin PBXContainerItemProxy section */ + 607FACE61AFB9204008FA782 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 607FACC81AFB9204008FA782 /* Project object */; + proxyType = 1; + remoteGlobalIDString = 607FACCF1AFB9204008FA782; + remoteInfo = Spruce; + }; +/* End PBXContainerItemProxy section */ + +/* Begin PBXFileReference section */ + 180431F59A6BB6C1511A5258 /* Pods-Spruce_Example.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Spruce_Example.release.xcconfig"; path = "Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.release.xcconfig"; sourceTree = ""; }; + 1A7230AE9B3F14A5CD036320 /* README.md */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = net.daringfireball.markdown; name = README.md; path = ../README.md; sourceTree = ""; }; + 4B828A1EFFD048AD3A2E0675 /* Pods_Spruce_Tests.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Spruce_Tests.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + 607FACD01AFB9204008FA782 /* Spruce_Example.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Spruce_Example.app; sourceTree = BUILT_PRODUCTS_DIR; }; + 607FACD41AFB9204008FA782 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 607FACD51AFB9204008FA782 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; + 607FACDC1AFB9204008FA782 /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Images.xcassets; sourceTree = ""; }; + 607FACDF1AFB9204008FA782 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/LaunchScreen.xib; sourceTree = ""; }; + 607FACE51AFB9204008FA782 /* Spruce_Tests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = Spruce_Tests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; + 607FACEA1AFB9204008FA782 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 607FACEB1AFB9204008FA782 /* Tests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Tests.swift; sourceTree = ""; }; + 6C04A6F7ABEF198F183B1617 /* Pods-Spruce_Tests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Spruce_Tests.debug.xcconfig"; path = "Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.debug.xcconfig"; sourceTree = ""; }; + 6FCD75E68B76D05C1368631A /* Spruce.podspec */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text; name = Spruce.podspec; path = ../Spruce.podspec; sourceTree = ""; }; + 763FD0B1F1E8374A748D0636 /* Pods-Spruce_Tests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Spruce_Tests.release.xcconfig"; path = "Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests.release.xcconfig"; sourceTree = ""; }; + 810EF25AEB3B66AF72D6DC08 /* Pods-Spruce_Example.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Spruce_Example.debug.xcconfig"; path = "Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example.debug.xcconfig"; sourceTree = ""; }; + DB9357E31DFB026400ADC5BE /* TableViewController.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TableViewController.swift; sourceTree = ""; }; + DB9357E41DFB026400ADC5BE /* TestCollectionVIew.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TestCollectionVIew.swift; sourceTree = ""; }; + DB9357E51DFB026400ADC5BE /* TestViewController.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TestViewController.swift; sourceTree = ""; }; + DB9357E61DFB026400ADC5BE /* TestViewController2.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TestViewController2.swift; sourceTree = ""; }; + DB9357E71DFB026400ADC5BE /* TestViewController2Setup.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TestViewController2Setup.swift; sourceTree = ""; }; + DB9357E81DFB026400ADC5BE /* TestViewController3.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TestViewController3.swift; sourceTree = ""; }; + DB9357E91DFB026400ADC5BE /* TestViewControllerSetup.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TestViewControllerSetup.swift; sourceTree = ""; }; + F4D59F4B84B3E292C02F5FD8 /* LICENSE */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text; name = LICENSE; path = ../LICENSE; sourceTree = ""; }; + FDBE5745B9DE9B1EAB8C910C /* Pods_Spruce_Example.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Spruce_Example.framework; sourceTree = BUILT_PRODUCTS_DIR; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 607FACCD1AFB9204008FA782 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 8D0D1A6A199FC9630A10DED3 /* Pods_Spruce_Example.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 607FACE21AFB9204008FA782 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 4A43C1DAC694719AE6B7A749 /* Pods_Spruce_Tests.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 541F222EA2BCC4929E2C93E6 /* Pods */ = { + isa = PBXGroup; + children = ( + 810EF25AEB3B66AF72D6DC08 /* Pods-Spruce_Example.debug.xcconfig */, + 180431F59A6BB6C1511A5258 /* Pods-Spruce_Example.release.xcconfig */, + 6C04A6F7ABEF198F183B1617 /* Pods-Spruce_Tests.debug.xcconfig */, + 763FD0B1F1E8374A748D0636 /* Pods-Spruce_Tests.release.xcconfig */, + ); + name = Pods; + sourceTree = ""; + }; + 607FACC71AFB9204008FA782 = { + isa = PBXGroup; + children = ( + 607FACF51AFB993E008FA782 /* Podspec Metadata */, + 607FACD21AFB9204008FA782 /* Example for Spruce */, + 607FACE81AFB9204008FA782 /* Tests */, + 607FACD11AFB9204008FA782 /* Products */, + 541F222EA2BCC4929E2C93E6 /* Pods */, + EE518578DA1F211845F05455 /* Frameworks */, + ); + sourceTree = ""; + }; + 607FACD11AFB9204008FA782 /* Products */ = { + isa = PBXGroup; + children = ( + 607FACD01AFB9204008FA782 /* Spruce_Example.app */, + 607FACE51AFB9204008FA782 /* Spruce_Tests.xctest */, + ); + name = Products; + sourceTree = ""; + }; + 607FACD21AFB9204008FA782 /* Example for Spruce */ = { + isa = PBXGroup; + children = ( + 607FACD51AFB9204008FA782 /* AppDelegate.swift */, + DB9357E31DFB026400ADC5BE /* TableViewController.swift */, + DB9357F31DFB027800ADC5BE /* Test Controllers */, + 607FACDC1AFB9204008FA782 /* Images.xcassets */, + 607FACDE1AFB9204008FA782 /* LaunchScreen.xib */, + 607FACD31AFB9204008FA782 /* Supporting Files */, + ); + name = "Example for Spruce"; + path = Spruce; + sourceTree = ""; + }; + 607FACD31AFB9204008FA782 /* Supporting Files */ = { + isa = PBXGroup; + children = ( + 607FACD41AFB9204008FA782 /* Info.plist */, + ); + name = "Supporting Files"; + sourceTree = ""; + }; + 607FACE81AFB9204008FA782 /* Tests */ = { + isa = PBXGroup; + children = ( + 607FACEB1AFB9204008FA782 /* Tests.swift */, + 607FACE91AFB9204008FA782 /* Supporting Files */, + ); + path = Tests; + sourceTree = ""; + }; + 607FACE91AFB9204008FA782 /* Supporting Files */ = { + isa = PBXGroup; + children = ( + 607FACEA1AFB9204008FA782 /* Info.plist */, + ); + name = "Supporting Files"; + sourceTree = ""; + }; + 607FACF51AFB993E008FA782 /* Podspec Metadata */ = { + isa = PBXGroup; + children = ( + 6FCD75E68B76D05C1368631A /* Spruce.podspec */, + 1A7230AE9B3F14A5CD036320 /* README.md */, + F4D59F4B84B3E292C02F5FD8 /* LICENSE */, + ); + name = "Podspec Metadata"; + sourceTree = ""; + }; + DB9357F31DFB027800ADC5BE /* Test Controllers */ = { + isa = PBXGroup; + children = ( + DB9357E41DFB026400ADC5BE /* TestCollectionVIew.swift */, + DB9357E51DFB026400ADC5BE /* TestViewController.swift */, + DB9357E61DFB026400ADC5BE /* TestViewController2.swift */, + DB9357E71DFB026400ADC5BE /* TestViewController2Setup.swift */, + DB9357E81DFB026400ADC5BE /* TestViewController3.swift */, + DB9357E91DFB026400ADC5BE /* TestViewControllerSetup.swift */, + ); + name = "Test Controllers"; + sourceTree = ""; + }; + EE518578DA1F211845F05455 /* Frameworks */ = { + isa = PBXGroup; + children = ( + FDBE5745B9DE9B1EAB8C910C /* Pods_Spruce_Example.framework */, + 4B828A1EFFD048AD3A2E0675 /* Pods_Spruce_Tests.framework */, + ); + name = Frameworks; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + 607FACCF1AFB9204008FA782 /* Spruce_Example */ = { + isa = PBXNativeTarget; + buildConfigurationList = 607FACEF1AFB9204008FA782 /* Build configuration list for PBXNativeTarget "Spruce_Example" */; + buildPhases = ( + 7E5EF7BD0477E292EED1C40A /* [CP] Check Pods Manifest.lock */, + 607FACCC1AFB9204008FA782 /* Sources */, + 607FACCD1AFB9204008FA782 /* Frameworks */, + 607FACCE1AFB9204008FA782 /* Resources */, + C19B8AAEFD4E174686B43512 /* [CP] Embed Pods Frameworks */, + 25DC382DA6004DE75AF26E20 /* [CP] Copy Pods Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = Spruce_Example; + productName = Spruce; + productReference = 607FACD01AFB9204008FA782 /* Spruce_Example.app */; + productType = "com.apple.product-type.application"; + }; + 607FACE41AFB9204008FA782 /* Spruce_Tests */ = { + isa = PBXNativeTarget; + buildConfigurationList = 607FACF21AFB9204008FA782 /* Build configuration list for PBXNativeTarget "Spruce_Tests" */; + buildPhases = ( + A6198F741EA712B9FBA222FE /* [CP] Check Pods Manifest.lock */, + 607FACE11AFB9204008FA782 /* Sources */, + 607FACE21AFB9204008FA782 /* Frameworks */, + 607FACE31AFB9204008FA782 /* Resources */, + 8303BC710AAD4BA36B83C52A /* [CP] Embed Pods Frameworks */, + 4AFFE815B5667BCBE75D81FE /* [CP] Copy Pods Resources */, + ); + buildRules = ( + ); + dependencies = ( + 607FACE71AFB9204008FA782 /* PBXTargetDependency */, + ); + name = Spruce_Tests; + productName = Tests; + productReference = 607FACE51AFB9204008FA782 /* Spruce_Tests.xctest */; + productType = "com.apple.product-type.bundle.unit-test"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 607FACC81AFB9204008FA782 /* Project object */ = { + isa = PBXProject; + attributes = { + LastSwiftUpdateCheck = 0720; + LastUpgradeCheck = 0810; + ORGANIZATIONNAME = CocoaPods; + TargetAttributes = { + 607FACCF1AFB9204008FA782 = { + CreatedOnToolsVersion = 6.3.1; + LastSwiftMigration = 0810; + }; + 607FACE41AFB9204008FA782 = { + CreatedOnToolsVersion = 6.3.1; + LastSwiftMigration = 0810; + TestTargetID = 607FACCF1AFB9204008FA782; + }; + }; + }; + buildConfigurationList = 607FACCB1AFB9204008FA782 /* Build configuration list for PBXProject "Spruce" */; + compatibilityVersion = "Xcode 3.2"; + developmentRegion = English; + hasScannedForEncodings = 0; + knownRegions = ( + en, + Base, + ); + mainGroup = 607FACC71AFB9204008FA782; + productRefGroup = 607FACD11AFB9204008FA782 /* Products */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 607FACCF1AFB9204008FA782 /* Spruce_Example */, + 607FACE41AFB9204008FA782 /* Spruce_Tests */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXResourcesBuildPhase section */ + 607FACCE1AFB9204008FA782 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 607FACE01AFB9204008FA782 /* LaunchScreen.xib in Resources */, + 607FACDD1AFB9204008FA782 /* Images.xcassets in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 607FACE31AFB9204008FA782 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXShellScriptBuildPhase section */ + 25DC382DA6004DE75AF26E20 /* [CP] Copy Pods Resources */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputPaths = ( + ); + name = "[CP] Copy Pods Resources"; + outputPaths = ( + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "\"${SRCROOT}/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-resources.sh\"\n"; + showEnvVarsInLog = 0; + }; + 4AFFE815B5667BCBE75D81FE /* [CP] Copy Pods Resources */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputPaths = ( + ); + name = "[CP] Copy Pods Resources"; + outputPaths = ( + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "\"${SRCROOT}/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-resources.sh\"\n"; + showEnvVarsInLog = 0; + }; + 7E5EF7BD0477E292EED1C40A /* [CP] Check Pods Manifest.lock */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputPaths = ( + ); + name = "[CP] Check Pods Manifest.lock"; + outputPaths = ( + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "diff \"${PODS_ROOT}/../Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n"; + showEnvVarsInLog = 0; + }; + 8303BC710AAD4BA36B83C52A /* [CP] Embed Pods Frameworks */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputPaths = ( + ); + name = "[CP] Embed Pods Frameworks"; + outputPaths = ( + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "\"${SRCROOT}/Pods/Target Support Files/Pods-Spruce_Tests/Pods-Spruce_Tests-frameworks.sh\"\n"; + showEnvVarsInLog = 0; + }; + A6198F741EA712B9FBA222FE /* [CP] Check Pods Manifest.lock */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputPaths = ( + ); + name = "[CP] Check Pods Manifest.lock"; + outputPaths = ( + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "diff \"${PODS_ROOT}/../Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n"; + showEnvVarsInLog = 0; + }; + C19B8AAEFD4E174686B43512 /* [CP] Embed Pods Frameworks */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputPaths = ( + ); + name = "[CP] Embed Pods Frameworks"; + outputPaths = ( + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "\"${SRCROOT}/Pods/Target Support Files/Pods-Spruce_Example/Pods-Spruce_Example-frameworks.sh\"\n"; + showEnvVarsInLog = 0; + }; +/* End PBXShellScriptBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 607FACCC1AFB9204008FA782 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + DB9357F01DFB026400ADC5BE /* TestViewController2Setup.swift in Sources */, + DB9357EE1DFB026400ADC5BE /* TestViewController.swift in Sources */, + 607FACD61AFB9204008FA782 /* AppDelegate.swift in Sources */, + DB9357EC1DFB026400ADC5BE /* TableViewController.swift in Sources */, + DB9357EF1DFB026400ADC5BE /* TestViewController2.swift in Sources */, + DB9357ED1DFB026400ADC5BE /* TestCollectionVIew.swift in Sources */, + DB9357F21DFB026400ADC5BE /* TestViewControllerSetup.swift in Sources */, + DB9357F11DFB026400ADC5BE /* TestViewController3.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 607FACE11AFB9204008FA782 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 607FACEC1AFB9204008FA782 /* Tests.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXTargetDependency section */ + 607FACE71AFB9204008FA782 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = 607FACCF1AFB9204008FA782 /* Spruce_Example */; + targetProxy = 607FACE61AFB9204008FA782 /* PBXContainerItemProxy */; + }; +/* End PBXTargetDependency section */ + +/* Begin PBXVariantGroup section */ + 607FACDE1AFB9204008FA782 /* LaunchScreen.xib */ = { + isa = PBXVariantGroup; + children = ( + 607FACDF1AFB9204008FA782 /* Base */, + ); + name = LaunchScreen.xib; + sourceTree = ""; + }; +/* End PBXVariantGroup section */ + +/* Begin XCBuildConfiguration section */ + 607FACED1AFB9204008FA782 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_SYMBOLS_PRIVATE_EXTERN = NO; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 8.3; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + }; + name = Debug; + }; + 607FACEE1AFB9204008FA782 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 8.3; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + SWIFT_OPTIMIZATION_LEVEL = "-Owholemodule"; + VALIDATE_PRODUCT = YES; + }; + name = Release; + }; + 607FACF01AFB9204008FA782 /* Debug */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 810EF25AEB3B66AF72D6DC08 /* Pods-Spruce_Example.debug.xcconfig */; + buildSettings = { + ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + INFOPLIST_FILE = Spruce/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 10.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; + MODULE_NAME = ExampleApp; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.demo.$(PRODUCT_NAME:rfc1034identifier)"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 3.0; + }; + name = Debug; + }; + 607FACF11AFB9204008FA782 /* Release */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 180431F59A6BB6C1511A5258 /* Pods-Spruce_Example.release.xcconfig */; + buildSettings = { + ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + INFOPLIST_FILE = Spruce/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 10.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; + MODULE_NAME = ExampleApp; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.demo.$(PRODUCT_NAME:rfc1034identifier)"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 3.0; + }; + name = Release; + }; + 607FACF31AFB9204008FA782 /* Debug */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 6C04A6F7ABEF198F183B1617 /* Pods-Spruce_Tests.debug.xcconfig */; + buildSettings = { + FRAMEWORK_SEARCH_PATHS = ( + "$(SDKROOT)/Developer/Library/Frameworks", + "$(inherited)", + ); + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + INFOPLIST_FILE = Tests/Info.plist; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.$(PRODUCT_NAME:rfc1034identifier)"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 3.0; + }; + name = Debug; + }; + 607FACF41AFB9204008FA782 /* Release */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 763FD0B1F1E8374A748D0636 /* Pods-Spruce_Tests.release.xcconfig */; + buildSettings = { + FRAMEWORK_SEARCH_PATHS = ( + "$(SDKROOT)/Developer/Library/Frameworks", + "$(inherited)", + ); + INFOPLIST_FILE = Tests/Info.plist; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.$(PRODUCT_NAME:rfc1034identifier)"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 3.0; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 607FACCB1AFB9204008FA782 /* Build configuration list for PBXProject "Spruce" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 607FACED1AFB9204008FA782 /* Debug */, + 607FACEE1AFB9204008FA782 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 607FACEF1AFB9204008FA782 /* Build configuration list for PBXNativeTarget "Spruce_Example" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 607FACF01AFB9204008FA782 /* Debug */, + 607FACF11AFB9204008FA782 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 607FACF21AFB9204008FA782 /* Build configuration list for PBXNativeTarget "Spruce_Tests" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 607FACF31AFB9204008FA782 /* Debug */, + 607FACF41AFB9204008FA782 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 607FACC81AFB9204008FA782 /* Project object */; +} diff --git a/Spruce.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/Example/Spruce.xcodeproj/project.xcworkspace/contents.xcworkspacedata similarity index 100% rename from Spruce.xcodeproj/project.xcworkspace/contents.xcworkspacedata rename to Example/Spruce.xcodeproj/project.xcworkspace/contents.xcworkspacedata diff --git a/Example/Spruce.xcodeproj/project.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate b/Example/Spruce.xcodeproj/project.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate new file mode 100644 index 0000000000000000000000000000000000000000..0a6db910ebcf17a55c82edc117b94820d74100b7 GIT binary patch literal 5529 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 b#FVR2=A^h%ZDUJUNCvt}3 literal 0 HcmV?d00001 diff --git a/Example/Spruce.xcodeproj/xcshareddata/xcschemes/Spruce-Example.xcscheme b/Example/Spruce.xcodeproj/xcshareddata/xcschemes/Spruce-Example.xcscheme new file mode 100644 index 0000000..d1a065d --- /dev/null +++ b/Example/Spruce.xcodeproj/xcshareddata/xcschemes/Spruce-Example.xcscheme @@ -0,0 +1,115 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Example/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist b/Example/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist new file mode 100644 index 0000000..a1575db --- /dev/null +++ b/Example/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist @@ -0,0 +1,19 @@ + + + + + SuppressBuildableAutocreation + + 607FACCF1AFB9204008FA782 + + primary + + + 607FACE41AFB9204008FA782 + + primary + + + + + diff --git a/Example/Spruce.xcworkspace/contents.xcworkspacedata b/Example/Spruce.xcworkspace/contents.xcworkspacedata new file mode 100644 index 0000000..a55f430 --- /dev/null +++ b/Example/Spruce.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,10 @@ + + + + + + + diff --git a/Example/Spruce.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate b/Example/Spruce.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate new file mode 100644 index 0000000000000000000000000000000000000000..646759f921545509a94445cbc01352efa7cb41bd GIT binary patch literal 68625 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 Qw*1{9O8%o_?A79b144Kp1poj5 literal 0 HcmV?d00001 diff --git a/Example/Spruce/AppDelegate.swift b/Example/Spruce/AppDelegate.swift new file mode 100644 index 0000000..4bb185f --- /dev/null +++ b/Example/Spruce/AppDelegate.swift @@ -0,0 +1,50 @@ +// +// AppDelegate.swift +// Spruce +// +// Created by Jackson Taylor on 12/09/2016. +// Copyright (c) 2016 Jackson Taylor. All rights reserved. +// + +import UIKit + +@UIApplicationMain +class AppDelegate: UIResponder, UIApplicationDelegate { + + var window: UIWindow? + + + func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool { + let tableController = TableViewController(nibName: nil, bundle: nil) + let navController = UINavigationController(rootViewController: tableController) + + window?.rootViewController = navController + window?.makeKeyAndVisible() + return true + } + + func applicationWillResignActive(_ application: UIApplication) { + // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state. + // Use this method to pause ongoing tasks, disable timers, and throttle down OpenGL ES frame rates. Games should use this method to pause the game. + } + + func applicationDidEnterBackground(_ application: UIApplication) { + // Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later. + // If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits. + } + + func applicationWillEnterForeground(_ application: UIApplication) { + // Called as part of the transition from the background to the inactive state; here you can undo many of the changes made on entering the background. + } + + func applicationDidBecomeActive(_ application: UIApplication) { + // Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface. + } + + func applicationWillTerminate(_ application: UIApplication) { + // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:. + } + + +} + diff --git a/Example/Spruce/Base.lproj/LaunchScreen.xib b/Example/Spruce/Base.lproj/LaunchScreen.xib new file mode 100644 index 0000000..f84957a --- /dev/null +++ b/Example/Spruce/Base.lproj/LaunchScreen.xib @@ -0,0 +1,41 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Example/Spruce/Images.xcassets/AppIcon.appiconset/Contents.json b/Example/Spruce/Images.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 0000000..d3942e9 --- /dev/null +++ b/Example/Spruce/Images.xcassets/AppIcon.appiconset/Contents.json @@ -0,0 +1,38 @@ +{ + "images" : [ + { + "idiom" : "iphone", + "size" : "29x29", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "29x29", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "40x40", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "40x40", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "60x60", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "60x60", + "scale" : "3x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} diff --git a/Example/Spruce/Info.plist b/Example/Spruce/Info.plist new file mode 100644 index 0000000..04ef3d3 --- /dev/null +++ b/Example/Spruce/Info.plist @@ -0,0 +1,37 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + APPL + CFBundleShortVersionString + 1.0 + CFBundleSignature + ???? + CFBundleVersion + 1 + LSRequiresIPhoneOS + + UILaunchStoryboardName + LaunchScreen + UIRequiredDeviceCapabilities + + armv7 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + + + diff --git a/Example/Spruce/TableViewController.swift b/Example/Spruce/TableViewController.swift new file mode 100644 index 0000000..e1fc316 --- /dev/null +++ b/Example/Spruce/TableViewController.swift @@ -0,0 +1,132 @@ +// +// TableViewController.swift +// Spruce +// +// Created by Jackson Taylor on 11/15/16. +// Copyright © 2016 WillowTree Apps, Inc. All rights reserved. +// + +import UIKit + +class TableViewController: UIViewController { + let tableView = UITableView() + + override func viewDidLoad() { + super.viewDidLoad() + + tableView.frame = view.bounds + tableView.register(UITableViewCell.self, forCellReuseIdentifier: "basicCell") + tableView.delegate = self + tableView.dataSource = self + view.addSubview(tableView) + } +} + +extension TableViewController: UITableViewDataSource { + func numberOfSections(in tableView: UITableView) -> Int { + return 1 + } + + func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { + return 12 + } + + func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { + let cell = tableView.dequeueReusableCell(withIdentifier: "basicCell", for: indexPath) + + let cellText: String + switch indexPath.row { + case 0: + cellText = "Cornered Sort Function (top-left)" + case 1: + cellText = "Cornered Sort Function (bottom-right)" + case 2: + cellText = "Cornered Sort Function (top-right)" + case 3: + cellText = "Radial Sort Function" + case 4: + cellText = "Radial Sort Function (reversed)" + case 5: + cellText = "Linear Sort Function (bottom-to-top)" + case 6: + cellText = "Linear Sort Function (top-to-bottom)" + case 7: + cellText = "Linear Sort Function (left-to-right)" + case 8: + cellText = "Collection View Example" + case 9: + cellText = "Spruce Default Animation (fadeIn, expand, spin, slideUp)" + case 10: + cellText = "SpruceButton Example (grow)" + case 11: + cellText = "SpruceButton Example (grow, bounce)" + default: + cellText = "" + } + + cell.textLabel?.text = cellText + cell.textLabel?.font = UIFont(name: "HelveticaNeue-Light", size: 14.0) + return cell + } + + @objc(tableView:heightForRowAtIndexPath:) func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat { + return 50.0 + } +} + +extension TableViewController: UITableViewDelegate { + func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) { + let controller: UIViewController + switch indexPath.row { + case 0: + let tempController = TestViewController(nibName: nil, bundle: nil) + tempController.corner = .topLeft + controller = tempController + case 1: + let tempController = TestViewController(nibName: nil, bundle: nil) + tempController.corner = .bottomRight + controller = tempController + case 2: + let tempController = TestViewController(nibName: nil, bundle: nil) + tempController.corner = .topRight + controller = tempController + case 3: + let tempController = TestRadialViewController(nibName: nil, bundle: nil) + tempController.reversed = false + controller = tempController + case 4: + let tempController = TestRadialViewController(nibName: nil, bundle: nil) + tempController.reversed = true + controller = tempController + case 5: + let tempController = TestLinearViewController(nibName: nil, bundle: nil) + tempController.direction = .bottomToTop + controller = tempController + case 6: + let tempController = TestLinearViewController(nibName: nil, bundle: nil) + tempController.direction = .topToBottom + controller = tempController + case 7: + let tempController = TestLinearViewController(nibName: nil, bundle: nil) + tempController.direction = .leftToRight + controller = tempController + case 8: + let tempController = TestCollectionView(nibName: nil, bundle: nil) + controller = tempController + case 9: + let tempController = TestViewController2(nibName: nil, bundle: nil) + controller = tempController + case 10: + let tempController = TestViewController3(nibName: nil, bundle: nil) + controller = tempController + case 11: + let tempController = SpruceButtonBounceViewController(nibName: nil, bundle: nil) + controller = tempController + default: + let tempController = TestViewController(nibName: nil, bundle: nil) + controller = tempController + } + navigationController?.pushViewController(controller, animated: true) + tableView.deselectRow(at: indexPath, animated: true) + } +} diff --git a/Example/Spruce/TestCollectionVIew.swift b/Example/Spruce/TestCollectionVIew.swift new file mode 100644 index 0000000..2141fa6 --- /dev/null +++ b/Example/Spruce/TestCollectionVIew.swift @@ -0,0 +1,82 @@ +// +// TestCollectionVIew.swift +// Spruce +// +// Created by Jackson Taylor on 11/8/16. +// Copyright © 2016 WillowTree Apps, Inc. All rights reserved. +// + +import UIKit +import Spruce + +class TestCollectionView: UIViewController { + var collectionView: UICollectionView! + + override func viewDidLoad() { + super.viewDidLoad() + + let flowLayout = UICollectionViewFlowLayout() + collectionView = UICollectionView(frame: view.bounds, collectionViewLayout: flowLayout) + collectionView.dataSource = self + collectionView.delegate = self + collectionView.register(UICollectionViewCell.self, forCellWithReuseIdentifier: "cell") + view.addSubview(collectionView) + } + + override func viewDidAppear(_ animated: Bool) { + super.viewDidAppear(animated) + + /*Timer.scheduledTimer(withTimeInterval: 2.0, repeats: false) { _ in + self.callAnimation() + }*/ + callAnimation2() + } + + func callAnimation() { + let animation = SpringAnimation(duration: 0.5) { view in + view.alpha = 1.0 + view.transform = CGAffineTransform(scaleX: 1.0, y: 1.0) + } + let sortFunction = RadialSortFunction(position: .middle, interObjectDelay: 0.05) + //sortFunction.reversed = true + //let sortFunction = CorneredSortFunction(corner: .topLeft, interObjectDelay: 0.05) + //let sortFunction = LinearSortFunction(direction: .topToBottom, interObjectDelay: 0.05) + collectionView.spruceSubViews(withSortFunction: sortFunction, animation: animation) + } + + func callAnimation2() { + collectionView.spruceUp(withAnimations: [.contract(.medium), .fadeIn], duration: 0.3) + } +} + +extension TestCollectionView: UICollectionViewDelegate { + +} + +extension TestCollectionView: UICollectionViewDataSource { + func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int { + return 49 + } + + func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell { + let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "cell", for: indexPath) + cell.backgroundColor = .blue + cell.isHidden = true + return cell + } +} + +extension TestCollectionView: UICollectionViewDelegateFlowLayout { + func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize { + let viewSize = (self.view.bounds.size.width / 7.0) + return CGSize(width: viewSize, height: viewSize) + } + + func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumLineSpacingForSectionAt section: Int) -> CGFloat { + return 0.0 + } + + func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumInteritemSpacingForSectionAt section: Int) -> CGFloat { + return 0.0 + } +} diff --git a/Example/Spruce/TestViewController.swift b/Example/Spruce/TestViewController.swift new file mode 100644 index 0000000..5bd0a99 --- /dev/null +++ b/Example/Spruce/TestViewController.swift @@ -0,0 +1,67 @@ +// +// TestViewController.swift +// Spruce +// +// Created by Jackson Taylor on 11/8/16. +// Copyright © 2016 WillowTree Apps, Inc. All rights reserved. +// + +import UIKit +import Spruce + +class TestViewController: UIViewController { + + var containerView: UIView? + + var corner: SpruceCorner = .bottomRight + + override func viewDidLoad() { + super.viewDidLoad() + view.backgroundColor = UIColor.white + setup() + } + + override func viewDidAppear(_ animated: Bool) { + super.viewDidAppear(animated) + + Timer.scheduledTimer(withTimeInterval: 1.0, repeats: false) { _ in + self.callAnimation() + } + } + + func callAnimation() { + let animation = SpringAnimation(duration: 0.5) { view in + view.alpha = 1.0 + view.transform = CGAffineTransform(scaleX: 1.0, y: 1.0) + } + let sortFunction = CorneredSortFunction(corner: corner, interObjectDelay: 0.05) + containerView?.spruceSubViews(withSortFunction: sortFunction, animation: animation) + } +} + + +class TestRadialViewController: TestViewController { + var reversed: Bool = false + override func callAnimation() { + let animation = SpringAnimation(duration: 0.5) { view in + view.alpha = 1.0 + view.transform = CGAffineTransform(scaleX: 1.0, y: 1.0) + } + let sortFunction = RadialSortFunction(position: .topMiddle, interObjectDelay: 0.05) + sortFunction.reversed = reversed + containerView?.spruceSubViews(withSortFunction: sortFunction, animation: animation) + } +} + +class TestLinearViewController: TestViewController { + var direction: SpruceDirection = .topToBottom + override func callAnimation() { + let animation = SpringAnimation(duration: 0.5) { view in + view.alpha = 1.0 + view.transform = CGAffineTransform(scaleX: 1.0, y: 1.0) + } + let sortFunction = LinearSortFunction(direction: .topToBottom, interObjectDelay: 0.05) + containerView?.spruceSubViews(withSortFunction: sortFunction, animation: animation) + + } +} diff --git a/Example/Spruce/TestViewController2.swift b/Example/Spruce/TestViewController2.swift new file mode 100644 index 0000000..1a2a434 --- /dev/null +++ b/Example/Spruce/TestViewController2.swift @@ -0,0 +1,31 @@ +// +// TestViewController2.swift +// Spruce +// +// Created by Jackson Taylor on 11/15/16. +// Copyright © 2016 WillowTree Apps, Inc. All rights reserved. +// + +import UIKit +import Spruce + +class TestViewController2: UIViewController { + + var containerView: UIView? + + override func viewDidLoad() { + super.viewDidLoad() + view.backgroundColor = UIColor.white + setup() + + containerView?.hideAllSubviews() + } + + /* Where all the magic happens */ + + override func viewDidAppear(_ animated: Bool) { + super.viewDidAppear(animated) + + containerView?.spruceUp(withAnimations: [.fadeIn, .expand(.medium), .spin(.large), .slide(.up,.medium)]) + } +} diff --git a/Example/Spruce/TestViewController2Setup.swift b/Example/Spruce/TestViewController2Setup.swift new file mode 100644 index 0000000..6fe0626 --- /dev/null +++ b/Example/Spruce/TestViewController2Setup.swift @@ -0,0 +1,27 @@ +// +// TestViewController2Setup.swift +// Spruce +// +// Created by Jackson Taylor on 11/15/16. +// Copyright © 2016 WillowTree Apps, Inc. All rights reserved. +// + +import UIKit +import Spruce + + +extension TestViewController2 { + func setup() { + let viewSize = (self.view.bounds.size.width / 7.0) + + self.containerView = UIView(frame: CGRect(x: 0.0, y: 30.0, width: view.bounds.size.width, height: viewSize * 7.0)) + self.view.addSubview(self.containerView!) + for row in 0..<7 { + for col in 0..<7 { + let view = UIView(frame: CGRect(x: CGFloat(col) * viewSize, y: CGFloat(row) * viewSize, width: viewSize, height: viewSize)) + view.backgroundColor = .blue + containerView?.addSubview(view) + } + } + } +} diff --git a/Example/Spruce/TestViewController3.swift b/Example/Spruce/TestViewController3.swift new file mode 100644 index 0000000..8cd1d48 --- /dev/null +++ b/Example/Spruce/TestViewController3.swift @@ -0,0 +1,43 @@ +// +// TestViewController3.swift +// Spruce +// +// Created by Jackson Taylor on 11/30/16. +// Copyright © 2016 WillowTree Apps, Inc. All rights reserved. +// + +import UIKit +import Spruce + +class TestViewController3: UIViewController { + + override func viewDidLoad() { + super.viewDidLoad() + + view.backgroundColor = UIColor.white + + let button = SpruceButton(frame: CGRect(x: (view.frame.size.width/2.0) - 100.0, y: (view.frame.size.height/2.0) - 50.0, width: 200.0, height: 100.0)) + button.backgroundColor = UIColor.blue + button.layer.cornerRadius = 5.0 + button.clipsToBounds = true + view.addSubview(button) + } + +} + +class SpruceButtonBounceViewController: UIViewController { + + override func viewDidLoad() { + super.viewDidLoad() + + view.backgroundColor = UIColor.white + + let button = SpruceButton(frame: CGRect(x: (view.frame.size.width/2.0) - 100.0, y: (view.frame.size.height/2.0) - 50.0, width: 200.0, height: 100.0)) + button.animation = SpringAnimation(duration: 0.3) + button.backgroundColor = UIColor.blue + button.layer.cornerRadius = 5.0 + button.clipsToBounds = true + view.addSubview(button) + } + +} diff --git a/Example/Spruce/TestViewControllerSetup.swift b/Example/Spruce/TestViewControllerSetup.swift new file mode 100644 index 0000000..3652863 --- /dev/null +++ b/Example/Spruce/TestViewControllerSetup.swift @@ -0,0 +1,28 @@ +// +// TestViewControllerSetup.swift +// Spruce +// +// Created by Jackson Taylor on 11/15/16. +// Copyright © 2016 WillowTree Apps, Inc. All rights reserved. +// + +import UIKit +import Spruce + +extension TestViewController { + func setup() { + let viewSize = (self.view.bounds.size.width / 7.0) + + self.containerView = UIView(frame: CGRect(x: 0.0, y: 30.0, width: view.bounds.size.width, height: viewSize * 7.0)) + self.view.addSubview(self.containerView!) + for row in 0..<7 { + for col in 0..<7 { + let view = UIView(frame: CGRect(x: CGFloat(col) * viewSize, y: CGFloat(row) * viewSize, width: viewSize, height: viewSize)) + view.backgroundColor = .blue + view.alpha = 0.0 + view.transform = CGAffineTransform(scaleX: 0.1, y: 0.1) + containerView?.addSubview(view) + } + } + } +} diff --git a/Example/Tests/Info.plist b/Example/Tests/Info.plist new file mode 100644 index 0000000..ba72822 --- /dev/null +++ b/Example/Tests/Info.plist @@ -0,0 +1,24 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + BNDL + CFBundleShortVersionString + 1.0 + CFBundleSignature + ???? + CFBundleVersion + 1 + + diff --git a/Example/Tests/Tests.swift b/Example/Tests/Tests.swift new file mode 100644 index 0000000..ee85c0d --- /dev/null +++ b/Example/Tests/Tests.swift @@ -0,0 +1,29 @@ +import UIKit +import XCTest +import Spruce + +class Tests: XCTestCase { + + override func setUp() { + super.setUp() + // Put setup code here. This method is called before the invocation of each test method in the class. + } + + override func tearDown() { + // Put teardown code here. This method is called after the invocation of each test method in the class. + super.tearDown() + } + + func testExample() { + // This is an example of a functional test case. + XCTAssert(true, "Pass") + } + + func testPerformanceExample() { + // This is an example of a performance test case. + self.measure() { + // Put the code you want to measure the time of here. + } + } + +} diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..e93da4f --- /dev/null +++ b/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) 2016 Jackson Taylor + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/Spruce.podspec b/Spruce.podspec new file mode 100644 index 0000000..395a801 --- /dev/null +++ b/Spruce.podspec @@ -0,0 +1,26 @@ +# +# Be sure to run `pod lib lint Spruce.podspec' to ensure this is a +# valid spec before submitting. +# +# Any lines starting with a # are optional, but their use is encouraged +# To learn more about a Podspec see http://guides.cocoapods.org/syntax/podspec.html +# + +Pod::Spec.new do |s| + s.name = 'Spruce' + s.version = '0.1.0' + s.summary = 'A simple animation library that tries to do everything for you.' + + s.description = <<-DESC + Spruce is a very small, lightweight animation library that hopes to handle all of the complications of animations for you. So many developers use standard animations because they are easy and quick to use. With Spruce, developers will be able to create complex animations hopefully with just one line of code. These animations can include variations on fading, scale, spin, and many more. A key component of Spruce is that it is entirely customizable. If we don't have the exact animation you are looking to build, subclass one of our types and everything will just work. + DESC + + s.homepage = 'https://github.com/willowtreeapps/spruce-ios' + s.license = { :type => 'MIT', :file => 'LICENSE' } + s.author = { 'Jackson Taylor' => 'jackson.taylor@willowtreeapps.com' } + s.source = { :git => 'https://github.com/willowtreeapps/Spruce.git', :tag => s.version.to_s } + + s.ios.deployment_target = '8.0' + + s.source_files = 'Spruce/Classes/**/*' +end diff --git a/Spruce.xcodeproj/project.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate b/Spruce.xcodeproj/project.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate deleted file mode 100644 index c733f814050e357eb982e512ea270d5847ba9121..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 42651 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 htXWx$vb3^$%eXSD%qvU$j{!9MYwy4Q{|ulk^ Void +public typealias SpruceChangeFunction = (_ view: UIView) -> Void -protocol SpruceAnimation { +public protocol SpruceAnimation { func animate(delay: TimeInterval, view: UIView) var changeFunction: SpruceChangeFunction? { get set } diff --git a/Spruce/Core/Animations/DefaultAnimations.swift b/Spruce/Classes/Animations/DefaultAnimations.swift similarity index 97% rename from Spruce/Core/Animations/DefaultAnimations.swift rename to Spruce/Classes/Animations/DefaultAnimations.swift index 3389391..73fb57c 100644 --- a/Spruce/Core/Animations/DefaultAnimations.swift +++ b/Spruce/Classes/Animations/DefaultAnimations.swift @@ -8,7 +8,7 @@ import UIKit -enum SpruceDefaultChangeFunction { +public enum SpruceDefaultChangeFunction { case grow case shrink case fade diff --git a/Spruce/Core/Animations/SpringAnimation.swift b/Spruce/Classes/Animations/SpringAnimation.swift similarity index 69% rename from Spruce/Core/Animations/SpringAnimation.swift rename to Spruce/Classes/Animations/SpringAnimation.swift index 9fc4a80..1cd43da 100644 --- a/Spruce/Core/Animations/SpringAnimation.swift +++ b/Spruce/Classes/Animations/SpringAnimation.swift @@ -9,23 +9,23 @@ import UIKit -class SpringAnimation: SpruceAnimation { +open class SpringAnimation: SpruceAnimation { - var changeFunction: SpruceChangeFunction? + public var changeFunction: SpruceChangeFunction? let duration: TimeInterval let damping: CGFloat = 0.5 let initialVelocity: CGFloat = 0.7 - init(duration: TimeInterval) { + public init(duration: TimeInterval) { self.duration = duration } - convenience init(duration: TimeInterval, changes: @escaping SpruceChangeFunction) { + public convenience init(duration: TimeInterval, changes: @escaping SpruceChangeFunction) { self.init(duration: duration) self.changeFunction = changes } - func animate(delay: TimeInterval, view: UIView) { + open func animate(delay: TimeInterval, view: UIView) { UIView.animate(withDuration: duration, delay: delay, usingSpringWithDamping: damping, initialSpringVelocity: initialVelocity, options: [], animations: { [weak self] in self?.changeFunction?(view) }, completion: nil) diff --git a/Spruce/Core/Animations/StandardAnimation.swift b/Spruce/Classes/Animations/StandardAnimation.swift similarity index 64% rename from Spruce/Core/Animations/StandardAnimation.swift rename to Spruce/Classes/Animations/StandardAnimation.swift index 9dab5e3..493937c 100644 --- a/Spruce/Core/Animations/StandardAnimation.swift +++ b/Spruce/Classes/Animations/StandardAnimation.swift @@ -8,21 +8,21 @@ import UIKit -class StandardAnimation: SpruceAnimation { +open class StandardAnimation: SpruceAnimation { - var changeFunction: SpruceChangeFunction? + public var changeFunction: SpruceChangeFunction? let duration: TimeInterval - init(duration: TimeInterval) { + public init(duration: TimeInterval) { self.duration = duration } - convenience init(duration: TimeInterval, changes: @escaping SpruceChangeFunction) { + public convenience init(duration: TimeInterval, changes: @escaping SpruceChangeFunction) { self.init(duration: duration) self.changeFunction = changes } - func animate(delay: TimeInterval, view: UIView) { + open func animate(delay: TimeInterval, view: UIView) { UIView.animate(withDuration: duration, delay: delay, options: [.curveEaseOut], animations: { [weak self] in self?.changeFunction?(view) }, completion: nil) diff --git a/Spruce/Core/Full View/DefaultFullViewAnimations.swift b/Spruce/Classes/Full View/DefaultFullViewAnimations.swift similarity index 90% rename from Spruce/Core/Full View/DefaultFullViewAnimations.swift rename to Spruce/Classes/Full View/DefaultFullViewAnimations.swift index ad13beb..d67cdca 100644 --- a/Spruce/Core/Full View/DefaultFullViewAnimations.swift +++ b/Spruce/Classes/Full View/DefaultFullViewAnimations.swift @@ -8,20 +8,20 @@ import UIKit -enum SlideDirection { +public enum SlideDirection { case up case down case left case right } -enum SpruceSize { +public enum SpruceSize { case small case medium case large } -enum SpruceStandardAnimation { +public enum SpruceStandardAnimation { case slide(SlideDirection, SpruceSize) case fadeIn @@ -159,18 +159,18 @@ enum SpruceStandardAnimation { } } -extension UIView { - func spruceUp(withAnimations animations: [SpruceStandardAnimation], duration: TimeInterval = 0.3) { +public extension UIView { + open func spruceUp(withAnimations animations: [SpruceStandardAnimation], duration: TimeInterval = 0.3) { let animation = StandardAnimation(duration: duration) self.spruceUp(withAnimations: animations, duration: duration, animationType: animation) } - func spruceUp(withAnimations animations: [SpruceStandardAnimation], duration: TimeInterval = 0.3, animationType: SpruceAnimation) { + open func spruceUp(withAnimations animations: [SpruceStandardAnimation], duration: TimeInterval = 0.3, animationType: SpruceAnimation) { let sortFunction = LinearSortFunction(direction: .topToBottom, interObjectDelay: 0.05) self.spruceUp(withAnimations: animations, duration: duration, animationType: animationType, sortFunction: sortFunction) } - func spruceUp(withAnimations animations: [SpruceStandardAnimation], duration: TimeInterval = 0.3, animationType: SpruceAnimation, sortFunction: SortFunction, prepare: Bool = true) { + open func spruceUp(withAnimations animations: [SpruceStandardAnimation], duration: TimeInterval = 0.3, animationType: SpruceAnimation, sortFunction: SortFunction, prepare: Bool = true) { if prepare { self.sprucePrepare(withAnimations: animations) @@ -187,7 +187,7 @@ extension UIView { self.spruceSubViews(withSortFunction: sortFunction, animation: animationType) } - func sprucePrepare(withAnimations animations: [SpruceStandardAnimation]) { + open func sprucePrepare(withAnimations animations: [SpruceStandardAnimation]) { /* Reset the views to prepare for the animations */ let clearFunction: SpruceChangeFunction = { view in for animation in animations { @@ -215,7 +215,7 @@ extension UIView { } } - func hideAllSubviews() { + open func hideAllSubviews() { UIView.performWithoutAnimation { for subView in subviews { subView.isHidden = true diff --git a/Spruce/Core/Full View/FullViewAnimation.swift b/Spruce/Classes/Full View/FullViewAnimation.swift similarity index 73% rename from Spruce/Core/Full View/FullViewAnimation.swift rename to Spruce/Classes/Full View/FullViewAnimation.swift index b72c6c8..d78a231 100644 --- a/Spruce/Core/Full View/FullViewAnimation.swift +++ b/Spruce/Classes/Full View/FullViewAnimation.swift @@ -8,8 +8,8 @@ import UIKit -extension UIView { - func spruceSubViews(withSortFunction sortFunction: SortFunction, animation: SpruceAnimation) { +public extension UIView { + open func spruceSubViews(withSortFunction sortFunction: SortFunction, animation: SpruceAnimation) { let timedViews = sortFunction.getTimeOffsets(view: self) for view in timedViews { animation.animate(delay: view.timeOffset, view: view.view) diff --git a/Spruce/Core/Full View/SpruceViewController.swift b/Spruce/Classes/Full View/SpruceViewController.swift similarity index 85% rename from Spruce/Core/Full View/SpruceViewController.swift rename to Spruce/Classes/Full View/SpruceViewController.swift index 49473aa..3708cca 100644 --- a/Spruce/Core/Full View/SpruceViewController.swift +++ b/Spruce/Classes/Full View/SpruceViewController.swift @@ -8,7 +8,7 @@ import UIKit -class SpruceViewController: UIViewController { +open class SpruceViewController: UIViewController { var animations: [SpruceStandardAnimation] = [] var duration: TimeInterval = 0.3 var animationType: SpruceAnimation @@ -22,11 +22,11 @@ class SpruceViewController: UIViewController { super.init(nibName: nibNameOrNil, bundle: nibBundleOrNil) } - required init?(coder aDecoder: NSCoder) { + required public init?(coder aDecoder: NSCoder) { fatalError("init(coder:) has not been implemented") } - override func viewDidLoad() { + override open func viewDidLoad() { super.viewDidLoad() if animations.count > 0 { animationView?.hideAllSubviews() @@ -34,7 +34,7 @@ class SpruceViewController: UIViewController { } } - override func viewDidAppear(_ animated: Bool) { + override open func viewDidAppear(_ animated: Bool) { super.viewDidAppear(animated) animationView?.spruceUp(withAnimations: animations, duration: duration, animationType: animationType, sortFunction: sortFunction, prepare: false) diff --git a/Spruce/Core/Sort Functions/BaseDistancedSortFunction.swift b/Spruce/Classes/Sort Functions/BaseDistancedSortFunction.swift similarity index 83% rename from Spruce/Core/Sort Functions/BaseDistancedSortFunction.swift rename to Spruce/Classes/Sort Functions/BaseDistancedSortFunction.swift index f4e5695..2523ad0 100644 --- a/Spruce/Core/Sort Functions/BaseDistancedSortFunction.swift +++ b/Spruce/Classes/Sort Functions/BaseDistancedSortFunction.swift @@ -8,16 +8,16 @@ import UIKit -class BaseDistancedSortFunction: SortFunction { +open class BaseDistancedSortFunction: SortFunction { let interObjectDelay: TimeInterval - var reversed = false + open var reversed = false init(interObjectDelay: TimeInterval) { self.interObjectDelay = interObjectDelay } - func getTimeOffsets(view: UIView) -> [SpruceTimedView] { + open func getTimeOffsets(view: UIView) -> [SpruceTimedView] { let comparisonPoint = getDistancePoint(bounds: view.bounds) let subviews = view.subviews @@ -47,11 +47,11 @@ class BaseDistancedSortFunction: SortFunction { return timedViews } - func getDistanceBetweenPoints(left: CGPoint, right: CGPoint) -> Double { + open func getDistanceBetweenPoints(left: CGPoint, right: CGPoint) -> Double { return left.euclideanDistance(right) } - func getDistancePoint(bounds: CGRect) -> CGPoint { + open func getDistancePoint(bounds: CGRect) -> CGPoint { return CGPoint.zero } } diff --git a/Spruce/Core/Sort Functions/CorneredSortFunction.swift b/Spruce/Classes/Sort Functions/CorneredSortFunction.swift similarity index 84% rename from Spruce/Core/Sort Functions/CorneredSortFunction.swift rename to Spruce/Classes/Sort Functions/CorneredSortFunction.swift index 8ede1f8..e7917ff 100644 --- a/Spruce/Core/Sort Functions/CorneredSortFunction.swift +++ b/Spruce/Classes/Sort Functions/CorneredSortFunction.swift @@ -8,23 +8,23 @@ import UIKit -enum SpruceCorner { +public enum SpruceCorner { case topLeft case topRight case bottomLeft case bottomRight } -class CorneredSortFunction: BaseDistancedSortFunction { +open class CorneredSortFunction: BaseDistancedSortFunction { let corner: SpruceCorner - init(corner: SpruceCorner, interObjectDelay: TimeInterval) { + public init(corner: SpruceCorner, interObjectDelay: TimeInterval) { self.corner = corner super.init(interObjectDelay: interObjectDelay) } - override func getTimeOffsets(view: UIView) -> [SpruceTimedView] { + open override func getTimeOffsets(view: UIView) -> [SpruceTimedView] { let comparisonPoint = getDistancePoint(bounds: view.bounds) let subviews = view.subviews @@ -51,7 +51,7 @@ class CorneredSortFunction: BaseDistancedSortFunction { return timedViews } - override func getDistancePoint(bounds: CGRect) -> CGPoint { + open override func getDistancePoint(bounds: CGRect) -> CGPoint { switch corner { case .topLeft: return CGPoint.zero diff --git a/Spruce/Core/Sort Functions/DefaultSortFunction.swift b/Spruce/Classes/Sort Functions/DefaultSortFunction.swift similarity index 79% rename from Spruce/Core/Sort Functions/DefaultSortFunction.swift rename to Spruce/Classes/Sort Functions/DefaultSortFunction.swift index 432e73c..c13a3c2 100644 --- a/Spruce/Core/Sort Functions/DefaultSortFunction.swift +++ b/Spruce/Classes/Sort Functions/DefaultSortFunction.swift @@ -9,15 +9,15 @@ import UIKit -class DefaultSortFunction: SortFunction { +open class DefaultSortFunction: SortFunction { let interObjectDelay: TimeInterval - init(interObjectDelay: TimeInterval) { + public init(interObjectDelay: TimeInterval) { self.interObjectDelay = interObjectDelay } - func getTimeOffsets(view: UIView) -> [SpruceTimedView] { + open func getTimeOffsets(view: UIView) -> [SpruceTimedView] { var timedViews: [SpruceTimedView] = [] var currentTimeOffset: TimeInterval = 0.0 for subView in view.subviews { diff --git a/Spruce/Core/Sort Functions/LinearSortFunction.swift b/Spruce/Classes/Sort Functions/LinearSortFunction.swift similarity index 78% rename from Spruce/Core/Sort Functions/LinearSortFunction.swift rename to Spruce/Classes/Sort Functions/LinearSortFunction.swift index e3711e1..56ff3f5 100644 --- a/Spruce/Core/Sort Functions/LinearSortFunction.swift +++ b/Spruce/Classes/Sort Functions/LinearSortFunction.swift @@ -8,22 +8,22 @@ import UIKit -enum SpruceDirection { +public enum SpruceDirection { case topToBottom case bottomToTop case leftToRight case rightToLeft } -class LinearSortFunction: BaseDistancedSortFunction { +open class LinearSortFunction: BaseDistancedSortFunction { let direction: SpruceDirection - init(direction: SpruceDirection, interObjectDelay: TimeInterval) { + public init(direction: SpruceDirection, interObjectDelay: TimeInterval) { self.direction = direction super.init(interObjectDelay: interObjectDelay) } - override func getDistanceBetweenPoints(left: CGPoint, right: CGPoint) -> Double { + open override func getDistanceBetweenPoints(left: CGPoint, right: CGPoint) -> Double { var left = left var right = right switch direction { @@ -37,7 +37,7 @@ class LinearSortFunction: BaseDistancedSortFunction { return left.euclideanDistance(right) } - override func getDistancePoint(bounds: CGRect) -> CGPoint { + open override func getDistancePoint(bounds: CGRect) -> CGPoint { switch direction { case .topToBottom: return CGPoint(x: (bounds.size.width / 2.0), y: 0.0) diff --git a/Spruce/Core/Sort Functions/NoDelaySortFunction.swift b/Spruce/Classes/Sort Functions/NoDelaySortFunction.swift similarity index 75% rename from Spruce/Core/Sort Functions/NoDelaySortFunction.swift rename to Spruce/Classes/Sort Functions/NoDelaySortFunction.swift index fd618ab..0faca37 100644 --- a/Spruce/Core/Sort Functions/NoDelaySortFunction.swift +++ b/Spruce/Classes/Sort Functions/NoDelaySortFunction.swift @@ -8,8 +8,8 @@ import UIKit -class NoDelaySortFunction: SortFunction { - func getTimeOffsets(view: UIView) -> [SpruceTimedView] { +open class NoDelaySortFunction: SortFunction { + open func getTimeOffsets(view: UIView) -> [SpruceTimedView] { return view.subviews.flatMap { subView in let timedView = SpruceTimedView(view: subView, timeOffset: 0.0) return timedView diff --git a/Spruce/Core/Sort Functions/Operations/PointOperations.swift b/Spruce/Classes/Sort Functions/Operations/PointOperations.swift similarity index 77% rename from Spruce/Core/Sort Functions/Operations/PointOperations.swift rename to Spruce/Classes/Sort Functions/Operations/PointOperations.swift index 3384e7b..b9b9c71 100644 --- a/Spruce/Core/Sort Functions/Operations/PointOperations.swift +++ b/Spruce/Classes/Sort Functions/Operations/PointOperations.swift @@ -8,8 +8,8 @@ import UIKit -extension CGPoint { - func euclideanDistance(_ point: CGPoint) -> Double { +public extension CGPoint { + public func euclideanDistance(_ point: CGPoint) -> Double { let x = Double(pow(self.x - point.x, 2.0)) let y = Double(pow(self.y - point.y, 2.0)) return sqrt(x + y) diff --git a/Spruce/Core/Sort Functions/Operations/ViewOperations.swift b/Spruce/Classes/Sort Functions/Operations/ViewOperations.swift similarity index 72% rename from Spruce/Core/Sort Functions/Operations/ViewOperations.swift rename to Spruce/Classes/Sort Functions/Operations/ViewOperations.swift index 97e2b39..80b7797 100644 --- a/Spruce/Core/Sort Functions/Operations/ViewOperations.swift +++ b/Spruce/Classes/Sort Functions/Operations/ViewOperations.swift @@ -8,8 +8,8 @@ import UIKit -extension UIView { - func getOcuppiedSubBounds() -> CGRect { +public extension UIView { + public func getOcuppiedSubBounds() -> CGRect { return CGRect.zero } } diff --git a/Spruce/Core/Sort Functions/RadialSortFunction.swift b/Spruce/Classes/Sort Functions/RadialSortFunction.swift similarity index 85% rename from Spruce/Core/Sort Functions/RadialSortFunction.swift rename to Spruce/Classes/Sort Functions/RadialSortFunction.swift index 21d198e..da99b89 100644 --- a/Spruce/Core/Sort Functions/RadialSortFunction.swift +++ b/Spruce/Classes/Sort Functions/RadialSortFunction.swift @@ -8,7 +8,7 @@ import UIKit -enum SprucePosition { +public enum SprucePosition { case topLeft case topMiddle case topRight @@ -20,15 +20,15 @@ enum SprucePosition { case bottomRight } -class RadialSortFunction: BaseDistancedSortFunction { +open class RadialSortFunction: BaseDistancedSortFunction { let position: SprucePosition - init(position: SprucePosition, interObjectDelay: TimeInterval) { + public init(position: SprucePosition, interObjectDelay: TimeInterval) { self.position = position super.init(interObjectDelay: interObjectDelay) } - override func getDistancePoint(bounds: CGRect) -> CGPoint { + open override func getDistancePoint(bounds: CGRect) -> CGPoint { switch position { case .topLeft: return CGPoint.zero diff --git a/Spruce/Core/Sort Functions/RandomSortFunction.swift b/Spruce/Classes/Sort Functions/RandomSortFunction.swift similarity index 89% rename from Spruce/Core/Sort Functions/RandomSortFunction.swift rename to Spruce/Classes/Sort Functions/RandomSortFunction.swift index 419a547..cf45ee1 100644 --- a/Spruce/Core/Sort Functions/RandomSortFunction.swift +++ b/Spruce/Classes/Sort Functions/RandomSortFunction.swift @@ -8,15 +8,15 @@ import UIKit -class RandomSortFunction: SortFunction { +open class RandomSortFunction: SortFunction { let interObjectDelay: TimeInterval - init(interObjectDelay: TimeInterval) { + public init(interObjectDelay: TimeInterval) { self.interObjectDelay = interObjectDelay } - func getTimeOffsets(view: UIView) -> [SpruceTimedView] { + open func getTimeOffsets(view: UIView) -> [SpruceTimedView] { var subViews = view.subviews subViews.shuffle() diff --git a/Spruce/Core/Sort Functions/SortFunction.swift b/Spruce/Classes/Sort Functions/SortFunction.swift similarity index 81% rename from Spruce/Core/Sort Functions/SortFunction.swift rename to Spruce/Classes/Sort Functions/SortFunction.swift index 42c3fd1..39bf6d6 100644 --- a/Spruce/Core/Sort Functions/SortFunction.swift +++ b/Spruce/Classes/Sort Functions/SortFunction.swift @@ -8,11 +8,11 @@ import UIKit -struct SpruceTimedView { +public struct SpruceTimedView { let view: UIView let timeOffset: TimeInterval } -protocol SortFunction { +public protocol SortFunction { func getTimeOffsets(view: UIView) -> [SpruceTimedView] } diff --git a/Spruce/Core/Spruce.swift b/Spruce/Classes/Spruce.swift similarity index 89% rename from Spruce/Core/Spruce.swift rename to Spruce/Classes/Spruce.swift index 3bf97d7..6fcac5d 100644 --- a/Spruce/Core/Spruce.swift +++ b/Spruce/Classes/Spruce.swift @@ -8,6 +8,6 @@ import UIKit -class Spruce { +open class Spruce { } diff --git a/Spruce/Core/UI Elements/SpruceButton.swift b/Spruce/Classes/UI Elements/SpruceButton.swift similarity index 71% rename from Spruce/Core/UI Elements/SpruceButton.swift rename to Spruce/Classes/UI Elements/SpruceButton.swift index f72bb4e..86ae5b7 100644 --- a/Spruce/Core/UI Elements/SpruceButton.swift +++ b/Spruce/Classes/UI Elements/SpruceButton.swift @@ -8,12 +8,12 @@ import UIKit -class SpruceButton: UIButton { +open class SpruceButton: UIButton { - var changeFunction: SpruceDefaultChangeFunction = .grow - var animation: SpruceAnimation = StandardAnimation(duration: 0.2) + open var changeFunction: SpruceDefaultChangeFunction = .grow + open var animation: SpruceAnimation = StandardAnimation(duration: 0.2) - override var isHighlighted: Bool { + override open var isHighlighted: Bool { didSet { let function: SpruceChangeFunction if isHighlighted { diff --git a/Spruce/REGFullPageErrorScreen.swift b/Spruce/REGFullPageErrorScreen.swift deleted file mode 100644 index 54ae531..0000000 --- a/Spruce/REGFullPageErrorScreen.swift +++ /dev/null @@ -1,33 +0,0 @@ -// -// REGFullPageErrorScreen.swift -// Regal -// -// Created by Jackson Taylor on 7/19/16. -// Copyright © 2016 Regal Cinemas, Inc. All rights reserved. -// - -import UIKit - -typealias REGErrorActionCallback = (() -> Void) - -class REGFullPageErrorScreen: SpruceViewController { - - @IBOutlet weak var centerView: UIView! - - class func build(animated: Bool) -> REGFullPageErrorScreen { - let errorScreen = REGFullPageErrorScreen(nibName: "REGFullPageErrorScreen", bundle: nil) - errorScreen.animations = animated ? [.fadeIn, .slide(.up, .large), .expand(.small)] : [] - errorScreen.duration = 0.5 -// errorScreen.animationType = SpringAnimation(duration: 0.33) - return errorScreen - } - - override func viewDidLoad() { - animationView = centerView - super.viewDidLoad() - } - - @IBAction func close() { - presentingViewController?.dismiss(animated: true, completion: nil) - } -} diff --git a/Spruce/REGFullPageErrorScreen.xib b/Spruce/REGFullPageErrorScreen.xib deleted file mode 100644 index 770485d..0000000 --- a/Spruce/REGFullPageErrorScreen.xib +++ /dev/null @@ -1,160 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/Spruce/RegalTestViewController.swift b/Spruce/RegalTestViewController.swift deleted file mode 100644 index 3cb7b82..0000000 --- a/Spruce/RegalTestViewController.swift +++ /dev/null @@ -1,29 +0,0 @@ -// -// RegalTestViewController.swift -// Spruce -// -// Created by Jackson Taylor on 11/15/16. -// Copyright © 2016 WillowTree Apps, Inc. All rights reserved. -// - -import UIKit - -class RegalTestViewController: UIViewController { - class func build() -> RegalTestViewController { - return RegalTestViewController(nibName: "RegalTestViewController", bundle: nil) - } - - @IBAction func animated() { - let errorScreen = REGFullPageErrorScreen.build(animated: true) - errorScreen.modalPresentationStyle = .overCurrentContext - errorScreen.modalTransitionStyle = .crossDissolve - present(errorScreen, animated: true, completion: nil) - } - - @IBAction func notAnimated() { - let errorScreen = REGFullPageErrorScreen.build(animated: false) - errorScreen.modalPresentationStyle = .overCurrentContext - errorScreen.modalTransitionStyle = .crossDissolve - present(errorScreen, animated: true, completion: nil) - } -} diff --git a/Spruce/RegalTestViewController.xib b/Spruce/RegalTestViewController.xib deleted file mode 100644 index 0ecdd5f..0000000 --- a/Spruce/RegalTestViewController.xib +++ /dev/null @@ -1,56 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/Spruce.xcodeproj/project.pbxproj b/Spruce_old/Spruce.xcodeproj/project.pbxproj similarity index 100% rename from Spruce.xcodeproj/project.pbxproj rename to Spruce_old/Spruce.xcodeproj/project.pbxproj diff --git a/Spruce_old/Spruce.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/Spruce_old/Spruce.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100644 index 0000000..aa491bf --- /dev/null +++ b/Spruce_old/Spruce.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/Spruce_old/Spruce.xcodeproj/project.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate b/Spruce_old/Spruce.xcodeproj/project.xcworkspace/xcuserdata/jacksontaylor.xcuserdatad/UserInterfaceState.xcuserstate new file mode 100644 index 0000000000000000000000000000000000000000..58d997c92fd7a1d35c8ccb5ab7c2b6bb67bd6c94 GIT binary patch literal 41661 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 literal 0 HcmV?d00001 diff --git a/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist b/Spruce_old/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist similarity index 100% rename from Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist rename to Spruce_old/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist diff --git a/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Spruce.xcscheme b/Spruce_old/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Spruce.xcscheme similarity index 100% rename from Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Spruce.xcscheme rename to Spruce_old/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/Spruce.xcscheme diff --git a/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist b/Spruce_old/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist similarity index 100% rename from Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist rename to Spruce_old/Spruce.xcodeproj/xcuserdata/jacksontaylor.xcuserdatad/xcschemes/xcschememanagement.plist diff --git a/Spruce/AppDelegate.swift b/Spruce_old/Spruce/AppDelegate.swift similarity index 100% rename from Spruce/AppDelegate.swift rename to Spruce_old/Spruce/AppDelegate.swift diff --git a/Spruce/Assets.xcassets/AppIcon.appiconset/Contents.json b/Spruce_old/Spruce/Assets.xcassets/AppIcon.appiconset/Contents.json similarity index 100% rename from Spruce/Assets.xcassets/AppIcon.appiconset/Contents.json rename to Spruce_old/Spruce/Assets.xcassets/AppIcon.appiconset/Contents.json diff --git a/Spruce/Assets.xcassets/Contents.json b/Spruce_old/Spruce/Assets.xcassets/Contents.json similarity index 100% rename from Spruce/Assets.xcassets/Contents.json rename to Spruce_old/Spruce/Assets.xcassets/Contents.json diff --git a/Spruce/Assets.xcassets/icTicketingErrorPaymentDeclined.imageset/Contents.json b/Spruce_old/Spruce/Assets.xcassets/icTicketingErrorPaymentDeclined.imageset/Contents.json similarity index 100% rename from Spruce/Assets.xcassets/icTicketingErrorPaymentDeclined.imageset/Contents.json rename to Spruce_old/Spruce/Assets.xcassets/icTicketingErrorPaymentDeclined.imageset/Contents.json diff --git a/Spruce/Assets.xcassets/icTicketingErrorPaymentDeclined.imageset/img_errorimage_birds2.png b/Spruce_old/Spruce/Assets.xcassets/icTicketingErrorPaymentDeclined.imageset/img_errorimage_birds2.png similarity index 100% rename from Spruce/Assets.xcassets/icTicketingErrorPaymentDeclined.imageset/img_errorimage_birds2.png rename to Spruce_old/Spruce/Assets.xcassets/icTicketingErrorPaymentDeclined.imageset/img_errorimage_birds2.png diff --git a/Spruce/Assets.xcassets/icX.imageset/Contents.json b/Spruce_old/Spruce/Assets.xcassets/icX.imageset/Contents.json similarity index 100% rename from Spruce/Assets.xcassets/icX.imageset/Contents.json rename to Spruce_old/Spruce/Assets.xcassets/icX.imageset/Contents.json diff --git a/Spruce/Assets.xcassets/icX.imageset/ic_rewards_x.png b/Spruce_old/Spruce/Assets.xcassets/icX.imageset/ic_rewards_x.png similarity index 100% rename from Spruce/Assets.xcassets/icX.imageset/ic_rewards_x.png rename to Spruce_old/Spruce/Assets.xcassets/icX.imageset/ic_rewards_x.png diff --git a/Spruce/Assets.xcassets/icX.imageset/ic_rewards_x@2x.png b/Spruce_old/Spruce/Assets.xcassets/icX.imageset/ic_rewards_x@2x.png similarity index 100% rename from Spruce/Assets.xcassets/icX.imageset/ic_rewards_x@2x.png rename to Spruce_old/Spruce/Assets.xcassets/icX.imageset/ic_rewards_x@2x.png diff --git a/Spruce/Assets.xcassets/icX.imageset/ic_rewards_x@3x.png b/Spruce_old/Spruce/Assets.xcassets/icX.imageset/ic_rewards_x@3x.png similarity index 100% rename from Spruce/Assets.xcassets/icX.imageset/ic_rewards_x@3x.png rename to Spruce_old/Spruce/Assets.xcassets/icX.imageset/ic_rewards_x@3x.png diff --git a/Spruce/Info.plist b/Spruce_old/Spruce/Info.plist similarity index 100% rename from Spruce/Info.plist rename to Spruce_old/Spruce/Info.plist diff --git a/Spruce/LaunchScreen.xib b/Spruce_old/Spruce/LaunchScreen.xib similarity index 100% rename from Spruce/LaunchScreen.xib rename to Spruce_old/Spruce/LaunchScreen.xib diff --git a/Spruce/TableViewController.swift b/Spruce_old/Spruce/TableViewController.swift similarity index 100% rename from Spruce/TableViewController.swift rename to Spruce_old/Spruce/TableViewController.swift diff --git a/Spruce/TestCollectionVIew.swift b/Spruce_old/Spruce/TestCollectionVIew.swift similarity index 100% rename from Spruce/TestCollectionVIew.swift rename to Spruce_old/Spruce/TestCollectionVIew.swift diff --git a/Spruce/TestViewController.swift b/Spruce_old/Spruce/TestViewController.swift similarity index 100% rename from Spruce/TestViewController.swift rename to Spruce_old/Spruce/TestViewController.swift diff --git a/Spruce/TestViewController2.swift b/Spruce_old/Spruce/TestViewController2.swift similarity index 100% rename from Spruce/TestViewController2.swift rename to Spruce_old/Spruce/TestViewController2.swift diff --git a/Spruce/TestViewController2Setup.swift b/Spruce_old/Spruce/TestViewController2Setup.swift similarity index 100% rename from Spruce/TestViewController2Setup.swift rename to Spruce_old/Spruce/TestViewController2Setup.swift diff --git a/Spruce/TestViewController3.swift b/Spruce_old/Spruce/TestViewController3.swift similarity index 100% rename from Spruce/TestViewController3.swift rename to Spruce_old/Spruce/TestViewController3.swift diff --git a/Spruce/TestViewControllerSetup.swift b/Spruce_old/Spruce/TestViewControllerSetup.swift similarity index 100% rename from Spruce/TestViewControllerSetup.swift rename to Spruce_old/Spruce/TestViewControllerSetup.swift diff --git a/SpruceTests/Info.plist b/Spruce_old/SpruceTests/Info.plist similarity index 100% rename from SpruceTests/Info.plist rename to Spruce_old/SpruceTests/Info.plist diff --git a/SpruceTests/SpruceTests.swift b/Spruce_old/SpruceTests/SpruceTests.swift similarity index 100% rename from SpruceTests/SpruceTests.swift rename to Spruce_old/SpruceTests/SpruceTests.swift diff --git a/_Pods.xcodeproj b/_Pods.xcodeproj new file mode 120000 index 0000000..3c5a8e7 --- /dev/null +++ b/_Pods.xcodeproj @@ -0,0 +1 @@ +Example/Pods/Pods.xcodeproj \ No newline at end of file