Skip to content
Browse files

Added OS X support (fixes #11)

  • Loading branch information...
1 parent 7556211 commit 47bb85a8c95b69cb042ba07baccd876004963cb2 @joeldev joeldev committed
Showing with 2,067 additions and 49 deletions.
  1. +3 −1 .travis.yml
  2. +2 −0 {Advance → Advance-OSX}/Info.plist
  3. +28 −0 Advance-iOS/Info.plist
  4. +534 −31 Advance.xcodeproj/project.pbxproj
  5. +99 −0 Advance.xcodeproj/xcshareddata/xcschemes/Advance-OSX.xcscheme
  6. +5 −5 Advance.xcodeproj/xcshareddata/xcschemes/{Advance.xcscheme → Advance-iOS.xcscheme}
  7. +91 −0 Advance.xcodeproj/xcshareddata/xcschemes/AdvanceSample-OSX.xcscheme
  8. +5 −5 Advance.xcodeproj/xcshareddata/xcschemes/{AdvanceSample.xcscheme → AdvanceSample-iOS.xcscheme}
  9. +169 −0 Advance/Loop/DisplayLink.swift
  10. +8 −7 Advance/Loop/Loop.swift
  11. +41 −0 AdvanceSample-OSX/AppDelegate.swift
  12. +58 −0 AdvanceSample-OSX/Assets.xcassets/AppIcon.appiconset/Contents.json
  13. +756 −0 AdvanceSample-OSX/Base.lproj/MainMenu.xib
  14. +34 −0 AdvanceSample-OSX/Info.plist
  15. +70 −0 AdvanceSample-OSX/SpringContainerView.swift
  16. +62 −0 AdvanceSample-OSX/SpringView.swift
  17. 0 {AdvanceSample → AdvanceSample-iOS}/ActivityView.swift
  18. 0 {AdvanceSample → AdvanceSample-iOS}/ActivityViewController.swift
  19. 0 {AdvanceSample → AdvanceSample-iOS}/AppDelegate.swift
  20. 0 {AdvanceSample → AdvanceSample-iOS}/Assets.xcassets/AppIcon.appiconset/Contents.json
  21. 0 {AdvanceSample → AdvanceSample-iOS}/Assets.xcassets/Contents.json
  22. 0 {AdvanceSample → AdvanceSample-iOS}/Assets.xcassets/background-blurred.imageset/Contents.json
  23. 0 ...nceSample → AdvanceSample-iOS}/Assets.xcassets/background-blurred.imageset/background-blurred.jpg
  24. 0 {AdvanceSample → AdvanceSample-iOS}/Assets.xcassets/background.imageset/Contents.json
  25. 0 {AdvanceSample → AdvanceSample-iOS}/Assets.xcassets/background.imageset/background.jpg
  26. 0 {AdvanceSample → AdvanceSample-iOS}/Assets.xcassets/logo.imageset/Contents.json
  27. 0 {AdvanceSample → AdvanceSample-iOS}/Assets.xcassets/logo.imageset/logo.pdf
  28. 0 {AdvanceSample → AdvanceSample-iOS}/Base.lproj/LaunchScreen.storyboard
  29. 0 {AdvanceSample → AdvanceSample-iOS}/BrowserView.swift
  30. 0 {AdvanceSample → AdvanceSample-iOS}/BrowserViewController.swift
  31. 0 {AdvanceSample → AdvanceSample-iOS}/CoverView.swift
  32. 0 {AdvanceSample → AdvanceSample-iOS}/DemoViewController.swift
  33. 0 {AdvanceSample → AdvanceSample-iOS}/DirectManipulationGestureRecognizer.swift
  34. 0 {AdvanceSample → AdvanceSample-iOS}/GestureView.swift
  35. 0 {AdvanceSample → AdvanceSample-iOS}/GesturesViewController.swift
  36. 0 {AdvanceSample → AdvanceSample-iOS}/GravityFunction.swift
  37. 0 {AdvanceSample → AdvanceSample-iOS}/GravitySimulation.swift
  38. 0 {AdvanceSample → AdvanceSample-iOS}/GravityViewController.swift
  39. 0 {AdvanceSample → AdvanceSample-iOS}/Info.plist
  40. 0 {AdvanceSample → AdvanceSample-iOS}/SimpleTransform.swift
  41. 0 {AdvanceSample → AdvanceSample-iOS}/SpringConfigurationView.swift
  42. 0 {AdvanceSample → AdvanceSample-iOS}/SpringView.swift
  43. 0 {AdvanceSample → AdvanceSample-iOS}/SpringsViewController.swift
  44. 0 {AdvanceTests → AdvanceTests-OSX}/Info.plist
  45. 0 {AdvanceTests → AdvanceTests-iOS}/BasicAnimationTests.swift
  46. 0 {AdvanceTests → AdvanceTests-iOS}/CAMediaTimingFunctionTests.swift
  47. +78 −0 AdvanceTests-iOS/DisplayLinkTests.swift
  48. 0 {AdvanceTests → AdvanceTests-iOS}/EventTests.swift
  49. +24 −0 AdvanceTests-iOS/Info.plist
  50. 0 {AdvanceTests → AdvanceTests-iOS}/UnitBezierTests.swift
  51. 0 {AdvanceTests → AdvanceTests-iOS}/VectorConvenienceTests.swift
  52. 0 {AdvanceTests → AdvanceTests-iOS}/VectorTypeTests.swift
View
4 .travis.yml
@@ -1,3 +1,5 @@
language: objective-c
osx_image: xcode7.2
-script: xctool -project Advance.xcodeproj -scheme 'Advance' -configuration Debug -sdk iphonesimulator -arch i386 test
+script:
+ xctool -project Advance.xcodeproj -scheme 'Advance-iOS' -configuration Debug -sdk iphonesimulator -arch i386 test
+ xctool -project Advance.xcodeproj -scheme 'Advance-OSX' -configuration Debug test
View
2 Advance/Info.plist → Advance-OSX/Info.plist
@@ -20,6 +20,8 @@
<string>????</string>
<key>CFBundleVersion</key>
<string>$(CURRENT_PROJECT_VERSION)</string>
+ <key>NSHumanReadableCopyright</key>
+ <string>Copyright © 2016 Storehouse Media Inc. All rights reserved.</string>
<key>NSPrincipalClass</key>
<string></string>
</dict>
View
28 Advance-iOS/Info.plist
@@ -0,0 +1,28 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<dict>
+ <key>CFBundleDevelopmentRegion</key>
+ <string>en</string>
+ <key>CFBundleExecutable</key>
+ <string>$(EXECUTABLE_NAME)</string>
+ <key>CFBundleIdentifier</key>
+ <string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
+ <key>CFBundleInfoDictionaryVersion</key>
+ <string>6.0</string>
+ <key>CFBundleName</key>
+ <string>$(PRODUCT_NAME)</string>
+ <key>CFBundlePackageType</key>
+ <string>FMWK</string>
+ <key>CFBundleShortVersionString</key>
+ <string>0.9</string>
+ <key>CFBundleSignature</key>
+ <string>????</string>
+ <key>CFBundleVersion</key>
+ <string>$(CURRENT_PROJECT_VERSION)</string>
+ <key>NSHumanReadableCopyright</key>
+ <string>Copyright © 2016 Storehouse Media Inc. All rights reserved.</string>
+ <key>NSPrincipalClass</key>
+ <string></string>
+</dict>
+</plist>
View
565 Advance.xcodeproj/project.pbxproj
@@ -30,7 +30,50 @@
22F74AB81C76769C004C6E4C /* GesturesViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 22F74AB71C76769C004C6E4C /* GesturesViewController.swift */; };
22F74ABB1C767757004C6E4C /* GestureView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 22F74ABA1C767757004C6E4C /* GestureView.swift */; };
22F74ABC1C76778E004C6E4C /* Advance.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 5D39CEE11C6E983100DFCF86 /* Advance.framework */; };
+ 5D28A2D81C93757200E5A1E9 /* SpringView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D28A2D71C93757200E5A1E9 /* SpringView.swift */; };
+ 5D28A2DA1C9378F000E5A1E9 /* SpringContainerView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D28A2D91C9378F000E5A1E9 /* SpringContainerView.swift */; };
5D39CEEC1C6E983100DFCF86 /* Advance.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 5D39CEE11C6E983100DFCF86 /* Advance.framework */; };
+ 5D3A2F391C920C710071F08F /* Animatable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4631C876AD1000CF9EE /* Animatable.swift */; };
+ 5D3A2F3A1C920C7C0071F08F /* BasicAnimation.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4691C876AD1000CF9EE /* BasicAnimation.swift */; };
+ 5D3A2F3B1C920C7C0071F08F /* TimingFunctionType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A46A1C876AD1000CF9EE /* TimingFunctionType.swift */; };
+ 5D3A2F3C1C920C7C0071F08F /* UnitBezier.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A46B1C876AD1000CF9EE /* UnitBezier.swift */; };
+ 5D3A2F3D1C920C810071F08F /* DecayAnimation.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A46D1C876AD1000CF9EE /* DecayAnimation.swift */; };
+ 5D3A2F3E1C920C860071F08F /* SpringAnimation.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A46F1C876AD1000CF9EE /* SpringAnimation.swift */; };
+ 5D3A2F3F1C920C8C0071F08F /* AnimationType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4661C876AD1000CF9EE /* AnimationType.swift */; };
+ 5D3A2F401C920C8C0071F08F /* AnyValueAnimation.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4671C876AD1000CF9EE /* AnyValueAnimation.swift */; };
+ 5D3A2F411C920C8C0071F08F /* ValueAnimationType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4701C876AD1000CF9EE /* ValueAnimationType.swift */; };
+ 5D3A2F421C920C8C0071F08F /* Advanceable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4651C876AD1000CF9EE /* Advanceable.swift */; };
+ 5D3A2F431C920C920071F08F /* Animator.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4721C876AD1000CF9EE /* Animator.swift */; };
+ 5D3A2F441C920C920071F08F /* AnimatorContext.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4731C876AD1000CF9EE /* AnimatorContext.swift */; };
+ 5D3A2F451C920C970071F08F /* Event.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4751C876AD1000CF9EE /* Event.swift */; };
+ 5D3A2F461C920C9C0071F08F /* CAMediaTimingFunction.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4771C876AD1000CF9EE /* CAMediaTimingFunction.swift */; };
+ 5D3A2F471C920CB10071F08F /* Loop.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A47A1C876AD1000CF9EE /* Loop.swift */; };
+ 5D3A2F481C920CBC0071F08F /* DecayFunction.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A47C1C876AD1000CF9EE /* DecayFunction.swift */; };
+ 5D3A2F491C920CBC0071F08F /* DynamicFunctionType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A47D1C876AD1000CF9EE /* DynamicFunctionType.swift */; };
+ 5D3A2F4A1C920CBC0071F08F /* DynamicSolver.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A47E1C876AD1000CF9EE /* DynamicSolver.swift */; };
+ 5D3A2F4B1C920CBC0071F08F /* Spring.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A47F1C876AD1000CF9EE /* Spring.swift */; };
+ 5D3A2F4C1C920CBC0071F08F /* SpringFunction.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4801C876AD1000CF9EE /* SpringFunction.swift */; };
+ 5D3A2F4D1C920CC20071F08F /* VectorConvertible.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4881C876AD1000CF9EE /* VectorConvertible.swift */; };
+ 5D3A2F4E1C920CC20071F08F /* Double+VectorConvertible.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4871C876AD1000CF9EE /* Double+VectorConvertible.swift */; };
+ 5D3A2F4F1C920CC20071F08F /* CGFloat+VectorConvertible.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4821C876AD1000CF9EE /* CGFloat+VectorConvertible.swift */; };
+ 5D3A2F501C920CC20071F08F /* CGPoint+VectorConvertible.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4831C876AD1000CF9EE /* CGPoint+VectorConvertible.swift */; };
+ 5D3A2F511C920CC20071F08F /* CGRect+VectorConvertible.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4841C876AD1000CF9EE /* CGRect+VectorConvertible.swift */; };
+ 5D3A2F521C920CC20071F08F /* CGSize+VectorConvertible.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4851C876AD1000CF9EE /* CGSize+VectorConvertible.swift */; };
+ 5D3A2F531C920CC20071F08F /* CGVector+VectorConvertible.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4861C876AD1000CF9EE /* CGVector+VectorConvertible.swift */; };
+ 5D3A2F541C920CCA0071F08F /* Vector1.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A48B1C876AD1000CF9EE /* Vector1.swift */; };
+ 5D3A2F551C920CCA0071F08F /* Vector2.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A48C1C876AD1000CF9EE /* Vector2.swift */; };
+ 5D3A2F561C920CCA0071F08F /* Vector3.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A48D1C876AD1000CF9EE /* Vector3.swift */; };
+ 5D3A2F571C920CCA0071F08F /* Vector4.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A48E1C876AD1000CF9EE /* Vector4.swift */; };
+ 5D3A2F581C920CCA0071F08F /* VectorMathCapable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A48F1C876AD1000CF9EE /* VectorMathCapable.swift */; };
+ 5D3A2F591C920CCA0071F08F /* VectorType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4901C876AD1000CF9EE /* VectorType.swift */; };
+ 5D3A2F5A1C920CCA0071F08F /* Interpolatable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A48A1C876AD1000CF9EE /* Interpolatable.swift */; };
+ 5D3A2F5F1C922DAA0071F08F /* DisplayLink.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D3A2F5E1C922DAA0071F08F /* DisplayLink.swift */; };
+ 5D3A2F631C923ADB0071F08F /* DisplayLink.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D3A2F5E1C922DAA0071F08F /* DisplayLink.swift */; };
+ 5D3A2F6B1C92559B0071F08F /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D3A2F6A1C92559B0071F08F /* AppDelegate.swift */; };
+ 5D3A2F6D1C92559B0071F08F /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 5D3A2F6C1C92559B0071F08F /* Assets.xcassets */; };
+ 5D3A2F701C92559B0071F08F /* MainMenu.xib in Resources */ = {isa = PBXBuildFile; fileRef = 5D3A2F6E1C92559B0071F08F /* MainMenu.xib */; };
+ 5D3A2F751C9255B30071F08F /* Advance.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 5D3A2F311C9209EE0071F08F /* Advance.framework */; };
+ 5D3A2F761C9255B30071F08F /* Advance.framework in Embed Frameworks */ = {isa = PBXBuildFile; fileRef = 5D3A2F311C9209EE0071F08F /* Advance.framework */; settings = {ATTRIBUTES = (CodeSignOnCopy, RemoveHeadersOnCopy, ); }; };
5DA94F481C80DAA00039B9BB /* VectorConvenienceTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DA94F471C80DAA00039B9BB /* VectorConvenienceTests.swift */; };
5DA94F4B1C80E2700039B9BB /* UnitBezierTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DA94F4A1C80E2700039B9BB /* UnitBezierTests.swift */; };
5DA94F4D1C8112810039B9BB /* CAMediaTimingFunctionTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DA94F4C1C8112810039B9BB /* CAMediaTimingFunctionTests.swift */; };
@@ -69,6 +112,15 @@
5DB1A4B11C876AD1000CF9EE /* Vector4.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A48E1C876AD1000CF9EE /* Vector4.swift */; };
5DB1A4B21C876AD1000CF9EE /* VectorMathCapable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A48F1C876AD1000CF9EE /* VectorMathCapable.swift */; };
5DB1A4B31C876AD1000CF9EE /* VectorType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DB1A4901C876AD1000CF9EE /* VectorType.swift */; };
+ 5DE959E91C9388B9008487A8 /* DisplayLinkTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DE959E81C9388B9008487A8 /* DisplayLinkTests.swift */; };
+ 5DE959F51C9392E1008487A8 /* Advance.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 5D3A2F311C9209EE0071F08F /* Advance.framework */; };
+ 5DE959FC1C93940E008487A8 /* EventTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DA94F4E1C8114680039B9BB /* EventTests.swift */; };
+ 5DE959FD1C93940E008487A8 /* VectorTypeTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 22168B5A1C7A547300BAE519 /* VectorTypeTests.swift */; };
+ 5DE959FE1C93940E008487A8 /* VectorConvenienceTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DA94F471C80DAA00039B9BB /* VectorConvenienceTests.swift */; };
+ 5DE959FF1C93940E008487A8 /* BasicAnimationTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 22168B5C1C7A5E3500BAE519 /* BasicAnimationTests.swift */; };
+ 5DE95A001C93940E008487A8 /* UnitBezierTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DA94F4A1C80E2700039B9BB /* UnitBezierTests.swift */; };
+ 5DE95A011C93940E008487A8 /* CAMediaTimingFunctionTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DA94F4C1C8112810039B9BB /* CAMediaTimingFunctionTests.swift */; };
+ 5DE95A021C93940E008487A8 /* DisplayLinkTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DE959E81C9388B9008487A8 /* DisplayLinkTests.swift */; };
/* End PBXBuildFile section */
/* Begin PBXContainerItemProxy section */
@@ -86,6 +138,34 @@
remoteGlobalIDString = 5D39CEE01C6E983100DFCF86;
remoteInfo = Advance;
};
+ 5D3A2F771C9255B30071F08F /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 5D39CED81C6E983100DFCF86 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 5D3A2F301C9209EE0071F08F;
+ remoteInfo = "Advance-OSX";
+ };
+ 5DE959EA1C938C54008487A8 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 5D39CED81C6E983100DFCF86 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 22F74AA41C7674BB004C6E4C;
+ remoteInfo = AdvanceSample;
+ };
+ 5DE959F61C9392E1008487A8 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 5D39CED81C6E983100DFCF86 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 5D3A2F301C9209EE0071F08F;
+ remoteInfo = "Advance-OSX";
+ };
+ 5DE95A031C939427008487A8 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 5D39CED81C6E983100DFCF86 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 5D3A2F671C92559B0071F08F;
+ remoteInfo = "AdvanceSample-OSX";
+ };
/* End PBXContainerItemProxy section */
/* Begin PBXCopyFilesBuildPhase section */
@@ -99,6 +179,17 @@
);
runOnlyForDeploymentPostprocessing = 0;
};
+ 5D3A2F791C9255B30071F08F /* Embed Frameworks */ = {
+ isa = PBXCopyFilesBuildPhase;
+ buildActionMask = 2147483647;
+ dstPath = "";
+ dstSubfolderSpec = 10;
+ files = (
+ 5D3A2F761C9255B30071F08F /* Advance.framework in Embed Frameworks */,
+ );
+ name = "Embed Frameworks";
+ runOnlyForDeploymentPostprocessing = 0;
+ };
/* End PBXCopyFilesBuildPhase section */
/* Begin PBXFileReference section */
@@ -125,10 +216,19 @@
22F74AB31C7674BB004C6E4C /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
22F74AB71C76769C004C6E4C /* GesturesViewController.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = GesturesViewController.swift; sourceTree = "<group>"; };
22F74ABA1C767757004C6E4C /* GestureView.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = GestureView.swift; sourceTree = "<group>"; };
+ 5D28A2D71C93757200E5A1E9 /* SpringView.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = SpringView.swift; sourceTree = "<group>"; };
+ 5D28A2D91C9378F000E5A1E9 /* SpringContainerView.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = SpringContainerView.swift; sourceTree = "<group>"; };
5D39CEE11C6E983100DFCF86 /* Advance.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Advance.framework; sourceTree = BUILT_PRODUCTS_DIR; };
5D39CEEB1C6E983100DFCF86 /* Advance.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = Advance.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
5D39CEF21C6E983100DFCF86 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
- 5D39CF101C6E9B1F00DFCF86 /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
+ 5D3A2F311C9209EE0071F08F /* Advance.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Advance.framework; sourceTree = BUILT_PRODUCTS_DIR; };
+ 5D3A2F351C9209EE0071F08F /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
+ 5D3A2F5E1C922DAA0071F08F /* DisplayLink.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = DisplayLink.swift; sourceTree = "<group>"; };
+ 5D3A2F681C92559B0071F08F /* AdvanceSample-OSX.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "AdvanceSample-OSX.app"; sourceTree = BUILT_PRODUCTS_DIR; };
+ 5D3A2F6A1C92559B0071F08F /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
+ 5D3A2F6C1C92559B0071F08F /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
+ 5D3A2F6F1C92559B0071F08F /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/MainMenu.xib; sourceTree = "<group>"; };
+ 5D3A2F711C92559B0071F08F /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
5DA94F471C80DAA00039B9BB /* VectorConvenienceTests.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = VectorConvenienceTests.swift; sourceTree = "<group>"; };
5DA94F491C80DEEB0039B9BB /* Playground.playground */ = {isa = PBXFileReference; lastKnownFileType = file.playground; path = Playground.playground; sourceTree = "<group>"; };
5DA94F4A1C80E2700039B9BB /* UnitBezierTests.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = UnitBezierTests.swift; sourceTree = "<group>"; };
@@ -168,6 +268,10 @@
5DB1A48E1C876AD1000CF9EE /* Vector4.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Vector4.swift; sourceTree = "<group>"; };
5DB1A48F1C876AD1000CF9EE /* VectorMathCapable.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = VectorMathCapable.swift; sourceTree = "<group>"; };
5DB1A4901C876AD1000CF9EE /* VectorType.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = VectorType.swift; sourceTree = "<group>"; };
+ 5DE959E81C9388B9008487A8 /* DisplayLinkTests.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = DisplayLinkTests.swift; sourceTree = "<group>"; };
+ 5DE959F01C9392E1008487A8 /* AdvanceTests-OSX.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "AdvanceTests-OSX.xctest"; sourceTree = BUILT_PRODUCTS_DIR; };
+ 5DE959F41C9392E1008487A8 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
+ 5DE95A061C93963A008487A8 /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
/* End PBXFileReference section */
/* Begin PBXFrameworksBuildPhase section */
@@ -194,6 +298,29 @@
);
runOnlyForDeploymentPostprocessing = 0;
};
+ 5D3A2F2D1C9209EE0071F08F /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 5D3A2F651C92559B0071F08F /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 5D3A2F751C9255B30071F08F /* Advance.framework in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 5DE959ED1C9392E1008487A8 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 5DE959F51C9392E1008487A8 /* Advance.framework in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
/* End PBXFrameworksBuildPhase section */
/* Begin PBXGroup section */
@@ -226,7 +353,7 @@
name = Springs;
sourceTree = "<group>";
};
- 22F74AA61C7674BB004C6E4C /* AdvanceSample */ = {
+ 22F74AA61C7674BB004C6E4C /* AdvanceSample-iOS */ = {
isa = PBXGroup;
children = (
22142E681C810DAC000C6DEB /* Gravity */,
@@ -242,7 +369,7 @@
22F74AB01C7674BB004C6E4C /* LaunchScreen.storyboard */,
22F74AB31C7674BB004C6E4C /* Info.plist */,
);
- path = AdvanceSample;
+ path = "AdvanceSample-iOS";
sourceTree = "<group>";
};
22F74AB91C767740004C6E4C /* Gestures */ = {
@@ -262,8 +389,10 @@
5DA94F491C80DEEB0039B9BB /* Playground.playground */,
5DB1A4611C876AD1000CF9EE /* Advance */,
5D39CF281C6E9B2E00DFCF86 /* Resources */,
- 5D39CEEF1C6E983100DFCF86 /* AdvanceTests */,
- 22F74AA61C7674BB004C6E4C /* AdvanceSample */,
+ 5D39CEEF1C6E983100DFCF86 /* AdvanceTests-iOS */,
+ 5DE959F11C9392E1008487A8 /* AdvanceTests-OSX */,
+ 22F74AA61C7674BB004C6E4C /* AdvanceSample-iOS */,
+ 5D3A2F691C92559B0071F08F /* AdvanceSample-OSX */,
5D39CEE21C6E983100DFCF86 /* Products */,
);
sourceTree = "<group>";
@@ -274,11 +403,14 @@
5D39CEE11C6E983100DFCF86 /* Advance.framework */,
5D39CEEB1C6E983100DFCF86 /* Advance.xctest */,
22F74AA51C7674BB004C6E4C /* AdvanceSample.app */,
+ 5D3A2F311C9209EE0071F08F /* Advance.framework */,
+ 5D3A2F681C92559B0071F08F /* AdvanceSample-OSX.app */,
+ 5DE959F01C9392E1008487A8 /* AdvanceTests-OSX.xctest */,
);
name = Products;
sourceTree = "<group>";
};
- 5D39CEEF1C6E983100DFCF86 /* AdvanceTests */ = {
+ 5D39CEEF1C6E983100DFCF86 /* AdvanceTests-iOS */ = {
isa = PBXGroup;
children = (
5DA94F4E1C8114680039B9BB /* EventTests.swift */,
@@ -287,20 +419,43 @@
22168B5C1C7A5E3500BAE519 /* BasicAnimationTests.swift */,
5DA94F4A1C80E2700039B9BB /* UnitBezierTests.swift */,
5DA94F4C1C8112810039B9BB /* CAMediaTimingFunctionTests.swift */,
+ 5DE959E81C9388B9008487A8 /* DisplayLinkTests.swift */,
5D39CEF21C6E983100DFCF86 /* Info.plist */,
);
- path = AdvanceTests;
+ path = "AdvanceTests-iOS";
sourceTree = "<group>";
};
5D39CF281C6E9B2E00DFCF86 /* Resources */ = {
isa = PBXGroup;
children = (
- 5D39CF101C6E9B1F00DFCF86 /* Info.plist */,
+ 5DE95A051C93963A008487A8 /* Advance-iOS */,
+ 5D3A2F321C9209EE0071F08F /* Advance-OSX */,
);
name = Resources;
path = Advance;
sourceTree = "<group>";
};
+ 5D3A2F321C9209EE0071F08F /* Advance-OSX */ = {
+ isa = PBXGroup;
+ children = (
+ 5D3A2F351C9209EE0071F08F /* Info.plist */,
+ );
+ path = "Advance-OSX";
+ sourceTree = SOURCE_ROOT;
+ };
+ 5D3A2F691C92559B0071F08F /* AdvanceSample-OSX */ = {
+ isa = PBXGroup;
+ children = (
+ 5D3A2F6A1C92559B0071F08F /* AppDelegate.swift */,
+ 5D28A2D91C9378F000E5A1E9 /* SpringContainerView.swift */,
+ 5D28A2D71C93757200E5A1E9 /* SpringView.swift */,
+ 5D3A2F6C1C92559B0071F08F /* Assets.xcassets */,
+ 5D3A2F6E1C92559B0071F08F /* MainMenu.xib */,
+ 5D3A2F711C92559B0071F08F /* Info.plist */,
+ );
+ path = "AdvanceSample-OSX";
+ sourceTree = "<group>";
+ };
5DB1A4611C876AD1000CF9EE /* Advance */ = {
isa = PBXGroup;
children = (
@@ -394,6 +549,7 @@
isa = PBXGroup;
children = (
5DB1A47A1C876AD1000CF9EE /* Loop.swift */,
+ 5D3A2F5E1C922DAA0071F08F /* DisplayLink.swift */,
);
path = Loop;
sourceTree = "<group>";
@@ -439,6 +595,22 @@
path = Vectors;
sourceTree = "<group>";
};
+ 5DE959F11C9392E1008487A8 /* AdvanceTests-OSX */ = {
+ isa = PBXGroup;
+ children = (
+ 5DE959F41C9392E1008487A8 /* Info.plist */,
+ );
+ path = "AdvanceTests-OSX";
+ sourceTree = SOURCE_ROOT;
+ };
+ 5DE95A051C93963A008487A8 /* Advance-iOS */ = {
+ isa = PBXGroup;
+ children = (
+ 5DE95A061C93963A008487A8 /* Info.plist */,
+ );
+ path = "Advance-iOS";
+ sourceTree = SOURCE_ROOT;
+ };
/* End PBXGroup section */
/* Begin PBXHeadersBuildPhase section */
@@ -449,12 +621,19 @@
);
runOnlyForDeploymentPostprocessing = 0;
};
+ 5D3A2F2E1C9209EE0071F08F /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
/* End PBXHeadersBuildPhase section */
/* Begin PBXNativeTarget section */
- 22F74AA41C7674BB004C6E4C /* AdvanceSample */ = {
+ 22F74AA41C7674BB004C6E4C /* AdvanceSample-iOS */ = {
isa = PBXNativeTarget;
- buildConfigurationList = 22F74AB61C7674BB004C6E4C /* Build configuration list for PBXNativeTarget "AdvanceSample" */;
+ buildConfigurationList = 22F74AB61C7674BB004C6E4C /* Build configuration list for PBXNativeTarget "AdvanceSample-iOS" */;
buildPhases = (
22F74AA11C7674BB004C6E4C /* Sources */,
22F74AA21C7674BB004C6E4C /* Frameworks */,
@@ -466,14 +645,14 @@
dependencies = (
22F74ABE1C767797004C6E4C /* PBXTargetDependency */,
);
- name = AdvanceSample;
+ name = "AdvanceSample-iOS";
productName = AnimationSample;
productReference = 22F74AA51C7674BB004C6E4C /* AdvanceSample.app */;
productType = "com.apple.product-type.application";
};
- 5D39CEE01C6E983100DFCF86 /* Advance */ = {
+ 5D39CEE01C6E983100DFCF86 /* Advance-iOS */ = {
isa = PBXNativeTarget;
- buildConfigurationList = 5D39CEF51C6E983100DFCF86 /* Build configuration list for PBXNativeTarget "Advance" */;
+ buildConfigurationList = 5D39CEF51C6E983100DFCF86 /* Build configuration list for PBXNativeTarget "Advance-iOS" */;
buildPhases = (
5D39CEDC1C6E983100DFCF86 /* Sources */,
5D39CEDD1C6E983100DFCF86 /* Frameworks */,
@@ -484,14 +663,14 @@
);
dependencies = (
);
- name = Advance;
+ name = "Advance-iOS";
productName = Advance;
productReference = 5D39CEE11C6E983100DFCF86 /* Advance.framework */;
productType = "com.apple.product-type.framework";
};
- 5D39CEEA1C6E983100DFCF86 /* AdvanceTests */ = {
+ 5D39CEEA1C6E983100DFCF86 /* AdvanceTests-iOS */ = {
isa = PBXNativeTarget;
- buildConfigurationList = 5D39CEF81C6E983100DFCF86 /* Build configuration list for PBXNativeTarget "AdvanceTests" */;
+ buildConfigurationList = 5D39CEF81C6E983100DFCF86 /* Build configuration list for PBXNativeTarget "AdvanceTests-iOS" */;
buildPhases = (
5D39CEE71C6E983100DFCF86 /* Sources */,
5D39CEE81C6E983100DFCF86 /* Frameworks */,
@@ -501,12 +680,69 @@
);
dependencies = (
5D39CEEE1C6E983100DFCF86 /* PBXTargetDependency */,
+ 5DE959EB1C938C54008487A8 /* PBXTargetDependency */,
);
- name = AdvanceTests;
+ name = "AdvanceTests-iOS";
productName = AdvanceTests;
productReference = 5D39CEEB1C6E983100DFCF86 /* Advance.xctest */;
productType = "com.apple.product-type.bundle.unit-test";
};
+ 5D3A2F301C9209EE0071F08F /* Advance-OSX */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 5D3A2F381C9209EE0071F08F /* Build configuration list for PBXNativeTarget "Advance-OSX" */;
+ buildPhases = (
+ 5D3A2F2C1C9209EE0071F08F /* Sources */,
+ 5D3A2F2D1C9209EE0071F08F /* Frameworks */,
+ 5D3A2F2E1C9209EE0071F08F /* Headers */,
+ 5D3A2F2F1C9209EE0071F08F /* Resources */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ );
+ name = "Advance-OSX";
+ productName = "Advance-OSX";
+ productReference = 5D3A2F311C9209EE0071F08F /* Advance.framework */;
+ productType = "com.apple.product-type.framework";
+ };
+ 5D3A2F671C92559B0071F08F /* AdvanceSample-OSX */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 5D3A2F721C92559B0071F08F /* Build configuration list for PBXNativeTarget "AdvanceSample-OSX" */;
+ buildPhases = (
+ 5D3A2F641C92559B0071F08F /* Sources */,
+ 5D3A2F651C92559B0071F08F /* Frameworks */,
+ 5D3A2F661C92559B0071F08F /* Resources */,
+ 5D3A2F791C9255B30071F08F /* Embed Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 5D3A2F781C9255B30071F08F /* PBXTargetDependency */,
+ );
+ name = "AdvanceSample-OSX";
+ productName = "AdvanceSample-OSX";
+ productReference = 5D3A2F681C92559B0071F08F /* AdvanceSample-OSX.app */;
+ productType = "com.apple.product-type.application";
+ };
+ 5DE959EF1C9392E1008487A8 /* AdvanceTests-OSX */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 5DE959F81C9392E1008487A8 /* Build configuration list for PBXNativeTarget "AdvanceTests-OSX" */;
+ buildPhases = (
+ 5DE959EC1C9392E1008487A8 /* Sources */,
+ 5DE959ED1C9392E1008487A8 /* Frameworks */,
+ 5DE959EE1C9392E1008487A8 /* Resources */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 5DE959F71C9392E1008487A8 /* PBXTargetDependency */,
+ 5DE95A041C939427008487A8 /* PBXTargetDependency */,
+ );
+ name = "AdvanceTests-OSX";
+ productName = "AdvanceTests-OSX";
+ productReference = 5DE959F01C9392E1008487A8 /* AdvanceTests-OSX.xctest */;
+ productType = "com.apple.product-type.bundle.unit-test";
+ };
/* End PBXNativeTarget section */
/* Begin PBXProject section */
@@ -525,6 +761,17 @@
};
5D39CEEA1C6E983100DFCF86 = {
CreatedOnToolsVersion = 7.3;
+ TestTargetID = 22F74AA41C7674BB004C6E4C;
+ };
+ 5D3A2F301C9209EE0071F08F = {
+ CreatedOnToolsVersion = 7.2.1;
+ };
+ 5D3A2F671C92559B0071F08F = {
+ CreatedOnToolsVersion = 7.2.1;
+ };
+ 5DE959EF1C9392E1008487A8 = {
+ CreatedOnToolsVersion = 7.2.1;
+ TestTargetID = 5D3A2F671C92559B0071F08F;
};
};
};
@@ -541,9 +788,12 @@
projectDirPath = "";
projectRoot = "";
targets = (
- 5D39CEE01C6E983100DFCF86 /* Advance */,
- 5D39CEEA1C6E983100DFCF86 /* AdvanceTests */,
- 22F74AA41C7674BB004C6E4C /* AdvanceSample */,
+ 5D39CEE01C6E983100DFCF86 /* Advance-iOS */,
+ 5D3A2F301C9209EE0071F08F /* Advance-OSX */,
+ 5D39CEEA1C6E983100DFCF86 /* AdvanceTests-iOS */,
+ 5DE959EF1C9392E1008487A8 /* AdvanceTests-OSX */,
+ 22F74AA41C7674BB004C6E4C /* AdvanceSample-iOS */,
+ 5D3A2F671C92559B0071F08F /* AdvanceSample-OSX */,
);
};
/* End PBXProject section */
@@ -572,6 +822,29 @@
);
runOnlyForDeploymentPostprocessing = 0;
};
+ 5D3A2F2F1C9209EE0071F08F /* Resources */ = {
+ isa = PBXResourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 5D3A2F661C92559B0071F08F /* Resources */ = {
+ isa = PBXResourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 5D3A2F6D1C92559B0071F08F /* Assets.xcassets in Resources */,
+ 5D3A2F701C92559B0071F08F /* MainMenu.xib in Resources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 5DE959EE1C9392E1008487A8 /* Resources */ = {
+ isa = PBXResourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
/* End PBXResourcesBuildPhase section */
/* Begin PBXSourcesBuildPhase section */
@@ -613,6 +886,7 @@
5DB1A4921C876AD1000CF9EE /* Advanceable.swift in Sources */,
5DB1A4A51C876AD1000CF9EE /* SpringFunction.swift in Sources */,
5DB1A4911C876AD1000CF9EE /* Animatable.swift in Sources */,
+ 5D3A2F5F1C922DAA0071F08F /* DisplayLink.swift in Sources */,
5DB1A4951C876AD1000CF9EE /* BasicAnimation.swift in Sources */,
5DB1A49A1C876AD1000CF9EE /* ValueAnimationType.swift in Sources */,
5DB1A4A91C876AD1000CF9EE /* CGSize+VectorConvertible.swift in Sources */,
@@ -646,6 +920,7 @@
files = (
5DA94F4D1C8112810039B9BB /* CAMediaTimingFunctionTests.swift in Sources */,
5DA94F4B1C80E2700039B9BB /* UnitBezierTests.swift in Sources */,
+ 5DE959E91C9388B9008487A8 /* DisplayLinkTests.swift in Sources */,
22168B5B1C7A547300BAE519 /* VectorTypeTests.swift in Sources */,
22168B5D1C7A5E3500BAE519 /* BasicAnimationTests.swift in Sources */,
5DA94F4F1C8114680039B9BB /* EventTests.swift in Sources */,
@@ -653,19 +928,105 @@
);
runOnlyForDeploymentPostprocessing = 0;
};
+ 5D3A2F2C1C9209EE0071F08F /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 5D3A2F471C920CB10071F08F /* Loop.swift in Sources */,
+ 5D3A2F441C920C920071F08F /* AnimatorContext.swift in Sources */,
+ 5D3A2F3C1C920C7C0071F08F /* UnitBezier.swift in Sources */,
+ 5D3A2F411C920C8C0071F08F /* ValueAnimationType.swift in Sources */,
+ 5D3A2F4C1C920CBC0071F08F /* SpringFunction.swift in Sources */,
+ 5D3A2F391C920C710071F08F /* Animatable.swift in Sources */,
+ 5D3A2F3A1C920C7C0071F08F /* BasicAnimation.swift in Sources */,
+ 5D3A2F591C920CCA0071F08F /* VectorType.swift in Sources */,
+ 5D3A2F3F1C920C8C0071F08F /* AnimationType.swift in Sources */,
+ 5D3A2F4F1C920CC20071F08F /* CGFloat+VectorConvertible.swift in Sources */,
+ 5D3A2F531C920CC20071F08F /* CGVector+VectorConvertible.swift in Sources */,
+ 5D3A2F4B1C920CBC0071F08F /* Spring.swift in Sources */,
+ 5D3A2F3E1C920C860071F08F /* SpringAnimation.swift in Sources */,
+ 5D3A2F541C920CCA0071F08F /* Vector1.swift in Sources */,
+ 5D3A2F571C920CCA0071F08F /* Vector4.swift in Sources */,
+ 5D3A2F521C920CC20071F08F /* CGSize+VectorConvertible.swift in Sources */,
+ 5D3A2F421C920C8C0071F08F /* Advanceable.swift in Sources */,
+ 5D3A2F5A1C920CCA0071F08F /* Interpolatable.swift in Sources */,
+ 5D3A2F4E1C920CC20071F08F /* Double+VectorConvertible.swift in Sources */,
+ 5D3A2F3D1C920C810071F08F /* DecayAnimation.swift in Sources */,
+ 5D3A2F481C920CBC0071F08F /* DecayFunction.swift in Sources */,
+ 5D3A2F3B1C920C7C0071F08F /* TimingFunctionType.swift in Sources */,
+ 5D3A2F511C920CC20071F08F /* CGRect+VectorConvertible.swift in Sources */,
+ 5D3A2F491C920CBC0071F08F /* DynamicFunctionType.swift in Sources */,
+ 5D3A2F501C920CC20071F08F /* CGPoint+VectorConvertible.swift in Sources */,
+ 5D3A2F581C920CCA0071F08F /* VectorMathCapable.swift in Sources */,
+ 5D3A2F631C923ADB0071F08F /* DisplayLink.swift in Sources */,
+ 5D3A2F4D1C920CC20071F08F /* VectorConvertible.swift in Sources */,
+ 5D3A2F431C920C920071F08F /* Animator.swift in Sources */,
+ 5D3A2F401C920C8C0071F08F /* AnyValueAnimation.swift in Sources */,
+ 5D3A2F461C920C9C0071F08F /* CAMediaTimingFunction.swift in Sources */,
+ 5D3A2F4A1C920CBC0071F08F /* DynamicSolver.swift in Sources */,
+ 5D3A2F551C920CCA0071F08F /* Vector2.swift in Sources */,
+ 5D3A2F561C920CCA0071F08F /* Vector3.swift in Sources */,
+ 5D3A2F451C920C970071F08F /* Event.swift in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 5D3A2F641C92559B0071F08F /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 5D28A2DA1C9378F000E5A1E9 /* SpringContainerView.swift in Sources */,
+ 5D3A2F6B1C92559B0071F08F /* AppDelegate.swift in Sources */,
+ 5D28A2D81C93757200E5A1E9 /* SpringView.swift in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 5DE959EC1C9392E1008487A8 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 5DE959FE1C93940E008487A8 /* VectorConvenienceTests.swift in Sources */,
+ 5DE95A001C93940E008487A8 /* UnitBezierTests.swift in Sources */,
+ 5DE95A021C93940E008487A8 /* DisplayLinkTests.swift in Sources */,
+ 5DE95A011C93940E008487A8 /* CAMediaTimingFunctionTests.swift in Sources */,
+ 5DE959FF1C93940E008487A8 /* BasicAnimationTests.swift in Sources */,
+ 5DE959FD1C93940E008487A8 /* VectorTypeTests.swift in Sources */,
+ 5DE959FC1C93940E008487A8 /* EventTests.swift in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
/* End PBXSourcesBuildPhase section */
/* Begin PBXTargetDependency section */
22F74ABE1C767797004C6E4C /* PBXTargetDependency */ = {
isa = PBXTargetDependency;
- target = 5D39CEE01C6E983100DFCF86 /* Advance */;
+ target = 5D39CEE01C6E983100DFCF86 /* Advance-iOS */;
targetProxy = 22F74ABD1C767797004C6E4C /* PBXContainerItemProxy */;
};
5D39CEEE1C6E983100DFCF86 /* PBXTargetDependency */ = {
isa = PBXTargetDependency;
- target = 5D39CEE01C6E983100DFCF86 /* Advance */;
+ target = 5D39CEE01C6E983100DFCF86 /* Advance-iOS */;
targetProxy = 5D39CEED1C6E983100DFCF86 /* PBXContainerItemProxy */;
};
+ 5D3A2F781C9255B30071F08F /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 5D3A2F301C9209EE0071F08F /* Advance-OSX */;
+ targetProxy = 5D3A2F771C9255B30071F08F /* PBXContainerItemProxy */;
+ };
+ 5DE959EB1C938C54008487A8 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 22F74AA41C7674BB004C6E4C /* AdvanceSample-iOS */;
+ targetProxy = 5DE959EA1C938C54008487A8 /* PBXContainerItemProxy */;
+ };
+ 5DE959F71C9392E1008487A8 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 5D3A2F301C9209EE0071F08F /* Advance-OSX */;
+ targetProxy = 5DE959F61C9392E1008487A8 /* PBXContainerItemProxy */;
+ };
+ 5DE95A041C939427008487A8 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 5D3A2F671C92559B0071F08F /* AdvanceSample-OSX */;
+ targetProxy = 5DE95A031C939427008487A8 /* PBXContainerItemProxy */;
+ };
/* End PBXTargetDependency section */
/* Begin PBXVariantGroup section */
@@ -677,6 +1038,14 @@
name = LaunchScreen.storyboard;
sourceTree = "<group>";
};
+ 5D3A2F6E1C92559B0071F08F /* MainMenu.xib */ = {
+ isa = PBXVariantGroup;
+ children = (
+ 5D3A2F6F1C92559B0071F08F /* Base */,
+ );
+ name = MainMenu.xib;
+ sourceTree = "<group>";
+ };
/* End PBXVariantGroup section */
/* Begin XCBuildConfiguration section */
@@ -686,7 +1055,7 @@
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CODE_SIGN_IDENTITY = "iPhone Developer";
EMBEDDED_CONTENT_CONTAINS_SWIFT = YES;
- INFOPLIST_FILE = "$(SRCROOT)/AdvanceSample/Info.plist";
+ INFOPLIST_FILE = "$(SRCROOT)/AdvanceSample-iOS/Info.plist";
IPHONEOS_DEPLOYMENT_TARGET = 8.2;
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
PRODUCT_BUNDLE_IDENTIFIER = co.storehouse.AdvanceSample;
@@ -700,7 +1069,7 @@
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CODE_SIGN_IDENTITY = "iPhone Developer";
EMBEDDED_CONTENT_CONTAINS_SWIFT = YES;
- INFOPLIST_FILE = "$(SRCROOT)/AdvanceSample/Info.plist";
+ INFOPLIST_FILE = "$(SRCROOT)/AdvanceSample-iOS/Info.plist";
IPHONEOS_DEPLOYMENT_TARGET = 8.2;
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
PRODUCT_BUNDLE_IDENTIFIER = co.storehouse.AdvanceSample;
@@ -810,7 +1179,7 @@
DYLIB_COMPATIBILITY_VERSION = 1;
DYLIB_CURRENT_VERSION = 1;
DYLIB_INSTALL_NAME_BASE = "@rpath";
- INFOPLIST_FILE = "$(SRCROOT)/Advance/Info.plist";
+ INFOPLIST_FILE = "$(SRCROOT)/Advance-iOS/Info.plist";
INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks";
IPHONEOS_DEPLOYMENT_TARGET = 8.0;
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
@@ -831,7 +1200,7 @@
DYLIB_COMPATIBILITY_VERSION = 1;
DYLIB_CURRENT_VERSION = 1;
DYLIB_INSTALL_NAME_BASE = "@rpath";
- INFOPLIST_FILE = "$(SRCROOT)/Advance/Info.plist";
+ INFOPLIST_FILE = "$(SRCROOT)/Advance-iOS/Info.plist";
INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks";
IPHONEOS_DEPLOYMENT_TARGET = 8.0;
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
@@ -845,31 +1214,138 @@
5D39CEF91C6E983100DFCF86 /* Debug */ = {
isa = XCBuildConfiguration;
buildSettings = {
- INFOPLIST_FILE = Advance/Info.plist;
+ INFOPLIST_FILE = "AdvanceTests-iOS/Info.plist";
IPHONEOS_DEPLOYMENT_TARGET = 8.0;
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
PRODUCT_BUNDLE_IDENTIFIER = co.storehouse.Advance;
PRODUCT_MODULE_NAME = "$(PRODUCT_NAME:c99extidentifier)Tests";
PRODUCT_NAME = Advance;
+ TEST_HOST = "$(BUILT_PRODUCTS_DIR)/AdvanceSample.app/AdvanceSample";
};
name = Debug;
};
5D39CEFA1C6E983100DFCF86 /* Release */ = {
isa = XCBuildConfiguration;
buildSettings = {
- INFOPLIST_FILE = Advance/Info.plist;
+ INFOPLIST_FILE = "AdvanceTests-iOS/Info.plist";
IPHONEOS_DEPLOYMENT_TARGET = 8.0;
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
PRODUCT_BUNDLE_IDENTIFIER = co.storehouse.Advance;
PRODUCT_MODULE_NAME = "$(PRODUCT_NAME:c99extidentifier)Tests";
PRODUCT_NAME = Advance;
+ TEST_HOST = "$(BUILT_PRODUCTS_DIR)/AdvanceSample.app/AdvanceSample";
+ };
+ name = Release;
+ };
+ 5D3A2F361C9209EE0071F08F /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ COMBINE_HIDPI_IMAGES = YES;
+ DEFINES_MODULE = YES;
+ DYLIB_COMPATIBILITY_VERSION = 1;
+ DYLIB_CURRENT_VERSION = 1;
+ DYLIB_INSTALL_NAME_BASE = "@rpath";
+ FRAMEWORK_VERSION = A;
+ INFOPLIST_FILE = "Advance-OSX/Info.plist";
+ INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks";
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/Frameworks";
+ MACOSX_DEPLOYMENT_TARGET = 10.11;
+ PRODUCT_BUNDLE_IDENTIFIER = "co.storehouse.Advance-OSX";
+ PRODUCT_NAME = Advance;
+ SDKROOT = macosx;
+ SKIP_INSTALL = YES;
+ };
+ name = Debug;
+ };
+ 5D3A2F371C9209EE0071F08F /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ COMBINE_HIDPI_IMAGES = YES;
+ DEFINES_MODULE = YES;
+ DYLIB_COMPATIBILITY_VERSION = 1;
+ DYLIB_CURRENT_VERSION = 1;
+ DYLIB_INSTALL_NAME_BASE = "@rpath";
+ FRAMEWORK_VERSION = A;
+ INFOPLIST_FILE = "Advance-OSX/Info.plist";
+ INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks";
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/Frameworks";
+ MACOSX_DEPLOYMENT_TARGET = 10.11;
+ PRODUCT_BUNDLE_IDENTIFIER = "co.storehouse.Advance-OSX";
+ PRODUCT_NAME = Advance;
+ SDKROOT = macosx;
+ SKIP_INSTALL = YES;
+ SWIFT_OPTIMIZATION_LEVEL = "-Owholemodule";
+ };
+ name = Release;
+ };
+ 5D3A2F731C92559B0071F08F /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+ CODE_SIGN_IDENTITY = "-";
+ COMBINE_HIDPI_IMAGES = YES;
+ EMBEDDED_CONTENT_CONTAINS_SWIFT = YES;
+ INFOPLIST_FILE = "AdvanceSample-OSX/Info.plist";
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks";
+ MACOSX_DEPLOYMENT_TARGET = 10.11;
+ PRODUCT_BUNDLE_IDENTIFIER = "co.storehouse.AdvanceSample-OSX";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SDKROOT = macosx;
+ };
+ name = Debug;
+ };
+ 5D3A2F741C92559B0071F08F /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+ CODE_SIGN_IDENTITY = "-";
+ COMBINE_HIDPI_IMAGES = YES;
+ EMBEDDED_CONTENT_CONTAINS_SWIFT = YES;
+ INFOPLIST_FILE = "AdvanceSample-OSX/Info.plist";
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks";
+ MACOSX_DEPLOYMENT_TARGET = 10.11;
+ PRODUCT_BUNDLE_IDENTIFIER = "co.storehouse.AdvanceSample-OSX";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SDKROOT = macosx;
+ };
+ name = Release;
+ };
+ 5DE959F91C9392E1008487A8 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ COMBINE_HIDPI_IMAGES = YES;
+ INFOPLIST_FILE = "AdvanceTests-OSX/Info.plist";
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/../Frameworks";
+ MACOSX_DEPLOYMENT_TARGET = 10.11;
+ PRODUCT_BUNDLE_IDENTIFIER = "co.storehouse.AdvanceTests-OSX";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SDKROOT = macosx;
+ TEST_HOST = "$(BUILT_PRODUCTS_DIR)/AdvanceSample-OSX.app/Contents/MacOS/AdvanceSample-OSX";
+ };
+ name = Debug;
+ };
+ 5DE959FA1C9392E1008487A8 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ COMBINE_HIDPI_IMAGES = YES;
+ INFOPLIST_FILE = "AdvanceTests-OSX/Info.plist";
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/../Frameworks";
+ MACOSX_DEPLOYMENT_TARGET = 10.11;
+ PRODUCT_BUNDLE_IDENTIFIER = "co.storehouse.AdvanceTests-OSX";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SDKROOT = macosx;
+ TEST_HOST = "$(BUILT_PRODUCTS_DIR)/AdvanceSample-OSX.app/Contents/MacOS/AdvanceSample-OSX";
};
name = Release;
};
/* End XCBuildConfiguration section */
/* Begin XCConfigurationList section */
- 22F74AB61C7674BB004C6E4C /* Build configuration list for PBXNativeTarget "AdvanceSample" */ = {
+ 22F74AB61C7674BB004C6E4C /* Build configuration list for PBXNativeTarget "AdvanceSample-iOS" */ = {
isa = XCConfigurationList;
buildConfigurations = (
22F74AB41C7674BB004C6E4C /* Debug */,
@@ -887,7 +1363,7 @@
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
- 5D39CEF51C6E983100DFCF86 /* Build configuration list for PBXNativeTarget "Advance" */ = {
+ 5D39CEF51C6E983100DFCF86 /* Build configuration list for PBXNativeTarget "Advance-iOS" */ = {
isa = XCConfigurationList;
buildConfigurations = (
5D39CEF61C6E983100DFCF86 /* Debug */,
@@ -896,7 +1372,7 @@
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
- 5D39CEF81C6E983100DFCF86 /* Build configuration list for PBXNativeTarget "AdvanceTests" */ = {
+ 5D39CEF81C6E983100DFCF86 /* Build configuration list for PBXNativeTarget "AdvanceTests-iOS" */ = {
isa = XCConfigurationList;
buildConfigurations = (
5D39CEF91C6E983100DFCF86 /* Debug */,
@@ -905,6 +1381,33 @@
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
+ 5D3A2F381C9209EE0071F08F /* Build configuration list for PBXNativeTarget "Advance-OSX" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 5D3A2F361C9209EE0071F08F /* Debug */,
+ 5D3A2F371C9209EE0071F08F /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 5D3A2F721C92559B0071F08F /* Build configuration list for PBXNativeTarget "AdvanceSample-OSX" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 5D3A2F731C92559B0071F08F /* Debug */,
+ 5D3A2F741C92559B0071F08F /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 5DE959F81C9392E1008487A8 /* Build configuration list for PBXNativeTarget "AdvanceTests-OSX" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 5DE959F91C9392E1008487A8 /* Debug */,
+ 5DE959FA1C9392E1008487A8 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
/* End XCConfigurationList section */
};
rootObject = 5D39CED81C6E983100DFCF86 /* Project object */;
View
99 Advance.xcodeproj/xcshareddata/xcschemes/Advance-OSX.xcscheme
@@ -0,0 +1,99 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<Scheme
+ LastUpgradeVersion = "0720"
+ version = "1.3">
+ <BuildAction
+ parallelizeBuildables = "YES"
+ buildImplicitDependencies = "YES">
+ <BuildActionEntries>
+ <BuildActionEntry
+ buildForTesting = "YES"
+ buildForRunning = "YES"
+ buildForProfiling = "YES"
+ buildForArchiving = "YES"
+ buildForAnalyzing = "YES">
+ <BuildableReference
+ BuildableIdentifier = "primary"
+ BlueprintIdentifier = "5D3A2F301C9209EE0071F08F"
+ BuildableName = "Advance.framework"
+ BlueprintName = "Advance-OSX"
+ ReferencedContainer = "container:Advance.xcodeproj">
+ </BuildableReference>
+ </BuildActionEntry>
+ </BuildActionEntries>
+ </BuildAction>
+ <TestAction
+ buildConfiguration = "Debug"
+ selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
+ selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
+ shouldUseLaunchSchemeArgsEnv = "YES">
+ <Testables>
+ <TestableReference
+ skipped = "NO">
+ <BuildableReference
+ BuildableIdentifier = "primary"
+ BlueprintIdentifier = "5DE959EF1C9392E1008487A8"
+ BuildableName = "AdvanceTests-OSX.xctest"
+ BlueprintName = "AdvanceTests-OSX"
+ ReferencedContainer = "container:Advance.xcodeproj">
+ </BuildableReference>
+ </TestableReference>
+ </Testables>
+ <MacroExpansion>
+ <BuildableReference
+ BuildableIdentifier = "primary"
+ BlueprintIdentifier = "5D3A2F301C9209EE0071F08F"
+ BuildableName = "Advance.framework"
+ BlueprintName = "Advance-OSX"
+ ReferencedContainer = "container:Advance.xcodeproj">
+ </BuildableReference>
+ </MacroExpansion>
+ <AdditionalOptions>
+ </AdditionalOptions>
+ </TestAction>
+ <LaunchAction
+ buildConfiguration = "Debug"
+ selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
+ selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
+ launchStyle = "0"
+ useCustomWorkingDirectory = "NO"
+ ignoresPersistentStateOnLaunch = "NO"
+ debugDocumentVersioning = "YES"
+ debugServiceExtension = "internal"
+ allowLocationSimulation = "YES">
+ <MacroExpansion>
+ <BuildableReference
+ BuildableIdentifier = "primary"
+ BlueprintIdentifier = "5D3A2F301C9209EE0071F08F"
+ BuildableName = "Advance.framework"
+ BlueprintName = "Advance-OSX"
+ ReferencedContainer = "container:Advance.xcodeproj">
+ </BuildableReference>
+ </MacroExpansion>
+ <AdditionalOptions>
+ </AdditionalOptions>
+ </LaunchAction>
+ <ProfileAction
+ buildConfiguration = "Release"
+ shouldUseLaunchSchemeArgsEnv = "YES"
+ savedToolIdentifier = ""
+ useCustomWorkingDirectory = "NO"
+ debugDocumentVersioning = "YES">
+ <MacroExpansion>
+ <BuildableReference
+ BuildableIdentifier = "primary"
+ BlueprintIdentifier = "5D3A2F301C9209EE0071F08F"
+ BuildableName = "Advance.framework"
+ BlueprintName = "Advance-OSX"
+ ReferencedContainer = "container:Advance.xcodeproj">
+ </BuildableReference>
+ </MacroExpansion>
+ </ProfileAction>
+ <AnalyzeAction
+ buildConfiguration = "Debug">
+ </AnalyzeAction>
+ <ArchiveAction
+ buildConfiguration = "Release"
+ revealArchiveInOrganizer = "YES">
+ </ArchiveAction>
+</Scheme>
View
10 ...j/xcshareddata/xcschemes/Advance.xcscheme → ...shareddata/xcschemes/Advance-iOS.xcscheme
@@ -16,7 +16,7 @@
BuildableIdentifier = "primary"
BlueprintIdentifier = "5D39CEE01C6E983100DFCF86"
BuildableName = "Advance.framework"
- BlueprintName = "Advance"
+ BlueprintName = "Advance-iOS"
ReferencedContainer = "container:Advance.xcodeproj">
</BuildableReference>
</BuildActionEntry>
@@ -34,7 +34,7 @@
BuildableIdentifier = "primary"
BlueprintIdentifier = "5D39CEEA1C6E983100DFCF86"
BuildableName = "Advance.xctest"
- BlueprintName = "AdvanceTests"
+ BlueprintName = "AdvanceTests-iOS"
ReferencedContainer = "container:Advance.xcodeproj">
</BuildableReference>
</TestableReference>
@@ -44,7 +44,7 @@
BuildableIdentifier = "primary"
BlueprintIdentifier = "5D39CEE01C6E983100DFCF86"
BuildableName = "Advance.framework"
- BlueprintName = "Advance"
+ BlueprintName = "Advance-iOS"
ReferencedContainer = "container:Advance.xcodeproj">
</BuildableReference>
</MacroExpansion>
@@ -66,7 +66,7 @@
BuildableIdentifier = "primary"
BlueprintIdentifier = "5D39CEE01C6E983100DFCF86"
BuildableName = "Advance.framework"
- BlueprintName = "Advance"
+ BlueprintName = "Advance-iOS"
ReferencedContainer = "container:Advance.xcodeproj">
</BuildableReference>
</MacroExpansion>
@@ -84,7 +84,7 @@
BuildableIdentifier = "primary"
BlueprintIdentifier = "5D39CEE01C6E983100DFCF86"
BuildableName = "Advance.framework"
- BlueprintName = "Advance"
+ BlueprintName = "Advance-iOS"
ReferencedContainer = "container:Advance.xcodeproj">
</BuildableReference>
</MacroExpansion>
View
91 Advance.xcodeproj/xcshareddata/xcschemes/AdvanceSample-OSX.xcscheme
@@ -0,0 +1,91 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<Scheme
+ LastUpgradeVersion = "0720"
+ version = "1.3">
+ <BuildAction
+ parallelizeBuildables = "YES"
+ buildImplicitDependencies = "YES">
+ <BuildActionEntries>
+ <BuildActionEntry
+ buildForTesting = "YES"
+ buildForRunning = "YES"
+ buildForProfiling = "YES"
+ buildForArchiving = "YES"
+ buildForAnalyzing = "YES">
+ <BuildableReference
+ BuildableIdentifier = "primary"
+ BlueprintIdentifier = "5D3A2F671C92559B0071F08F"
+ BuildableName = "AdvanceSample-OSX.app"
+ BlueprintName = "AdvanceSample-OSX"
+ ReferencedContainer = "container:Advance.xcodeproj">
+ </BuildableReference>
+ </BuildActionEntry>
+ </BuildActionEntries>
+ </BuildAction>
+ <TestAction
+ buildConfiguration = "Debug"
+ selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
+ selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
+ shouldUseLaunchSchemeArgsEnv = "YES">
+ <Testables>
+ </Testables>
+ <MacroExpansion>
+ <BuildableReference
+ BuildableIdentifier = "primary"
+ BlueprintIdentifier = "5D3A2F671C92559B0071F08F"
+ BuildableName = "AdvanceSample-OSX.app"
+ BlueprintName = "AdvanceSample-OSX"
+ ReferencedContainer = "container:Advance.xcodeproj">
+ </BuildableReference>
+ </MacroExpansion>
+ <AdditionalOptions>
+ </AdditionalOptions>
+ </TestAction>
+ <LaunchAction
+ buildConfiguration = "Debug"
+ selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
+ selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
+ launchStyle = "0"
+ useCustomWorkingDirectory = "NO"
+ ignoresPersistentStateOnLaunch = "NO"
+ debugDocumentVersioning = "YES"
+ debugServiceExtension = "internal"
+ allowLocationSimulation = "YES">
+ <BuildableProductRunnable
+ runnableDebuggingMode = "0">
+ <BuildableReference
+ BuildableIdentifier = "primary"
+ BlueprintIdentifier = "5D3A2F671C92559B0071F08F"
+ BuildableName = "AdvanceSample-OSX.app"
+ BlueprintName = "AdvanceSample-OSX"
+ ReferencedContainer = "container:Advance.xcodeproj">
+ </BuildableReference>
+ </BuildableProductRunnable>
+ <AdditionalOptions>
+ </AdditionalOptions>
+ </LaunchAction>
+ <ProfileAction
+ buildConfiguration = "Release"
+ shouldUseLaunchSchemeArgsEnv = "YES"
+ savedToolIdentifier = ""
+ useCustomWorkingDirectory = "NO"
+ debugDocumentVersioning = "YES">
+ <BuildableProductRunnable
+ runnableDebuggingMode = "0">
+ <BuildableReference
+ BuildableIdentifier = "primary"
+ BlueprintIdentifier = "5D3A2F671C92559B0071F08F"
+ BuildableName = "AdvanceSample-OSX.app"
+ BlueprintName = "AdvanceSample-OSX"
+ ReferencedContainer = "container:Advance.xcodeproj">
+ </BuildableReference>
+ </BuildableProductRunnable>
+ </ProfileAction>
+ <AnalyzeAction
+ buildConfiguration = "Debug">
+ </AnalyzeAction>
+ <ArchiveAction
+ buildConfiguration = "Release"
+ revealArchiveInOrganizer = "YES">
+ </ArchiveAction>
+</Scheme>
View
10 ...areddata/xcschemes/AdvanceSample.xcscheme → ...data/xcschemes/AdvanceSample-iOS.xcscheme
@@ -1,7 +1,7 @@
<?xml version="1.0" encoding="UTF-8"?>
<Scheme
LastUpgradeVersion = "0720"
- version = "1.3">
+ version = "1.8">
<BuildAction
parallelizeBuildables = "YES"
buildImplicitDependencies = "YES">
@@ -17,7 +17,7 @@
BuildableIdentifier = "primary"
BlueprintIdentifier = "22F74AA41C7674BB004C6E4C"
BuildableName = "AdvanceSample.app"
- BlueprintName = "AdvanceSample"
+ BlueprintName = "AdvanceSample-iOS"
ReferencedContainer = "container:Advance.xcodeproj">
</BuildableReference>
</BuildActionEntry>
@@ -35,7 +35,7 @@
BuildableIdentifier = "primary"
BlueprintIdentifier = "22F74AA41C7674BB004C6E4C"
BuildableName = "AdvanceSample.app"
- BlueprintName = "AdvanceSample"
+ BlueprintName = "AdvanceSample-iOS"
ReferencedContainer = "container:Advance.xcodeproj">
</BuildableReference>
</MacroExpansion>
@@ -58,7 +58,7 @@
BuildableIdentifier = "primary"
BlueprintIdentifier = "22F74AA41C7674BB004C6E4C"
BuildableName = "AdvanceSample.app"
- BlueprintName = "AdvanceSample"
+ BlueprintName = "AdvanceSample-iOS"
ReferencedContainer = "container:Advance.xcodeproj">
</BuildableReference>
</BuildableProductRunnable>
@@ -77,7 +77,7 @@
BuildableIdentifier = "primary"
BlueprintIdentifier = "22F74AA41C7674BB004C6E4C"
BuildableName = "AdvanceSample.app"
- BlueprintName = "AdvanceSample"
+ BlueprintName = "AdvanceSample-iOS"
ReferencedContainer = "container:Advance.xcodeproj">
</BuildableReference>
</BuildableProductRunnable>
View
169 Advance/Loop/DisplayLink.swift
@@ -0,0 +1,169 @@
+/*
+
+Copyright (c) 2016, Storehouse Media Inc.
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without
+modification, are permitted provided that the following conditions are met:
+
+* Redistributions of source code must retain the above copyright notice, this
+list of conditions and the following disclaimer.
+
+* Redistributions in binary form must reproduce the above copyright notice,
+this list of conditions and the following disclaimer in the documentation
+and/or other materials provided with the distribution.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
+FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+*/
+
+import Foundation
+
+#if os(iOS)
+import QuartzCore
+#elseif os(OSX)
+import CoreVideo
+#endif
+
+
+extension DisplayLink {
+ /// Info about a particular frame.
+ struct Frame : Equatable {
+ /// The timestamp that the frame.
+ var timestamp: Double
+
+ /// The current duration between frames.
+ var duration: Double
+ }
+}
+
+func ==(lhs: DisplayLink.Frame, rhs: DisplayLink.Frame) -> Bool {
+ return lhs.timestamp == rhs.timestamp && lhs.duration == rhs.duration
+}
+
+
+#if os(iOS) // iOS support using CADisplayLink --------------------------------------------------------
+
+/// DisplayLink is used to hook into screen refreshes.
+internal final class DisplayLink {
+
+ /// The callback to call for each frame.
+ var callback: ((frame: Frame) -> Void)? = nil
+
+ /// If the display link is paused or not.
+ var paused: Bool {
+ get {
+ return displayLink.paused
+ }
+ set {
+ displayLink.paused = newValue
+ }
+ }
+
+ /// The CADisplayLink that powers this DisplayLink instance.
+ let displayLink: CADisplayLink
+
+ /// The target for the CADisplayLink (because CADisplayLink retains its target).
+ let target = DisplayLinkTarget()
+
+ /// Creates a new paused DisplayLink instance.
+ init() {
+ displayLink = CADisplayLink(target: target, selector: "frame:")
+ displayLink.paused = true
+ displayLink.addToRunLoop(NSRunLoop.mainRunLoop(), forMode: NSRunLoopCommonModes)
+
+ target.callback = { [unowned self] (frame) in
+ self.callback?(frame: frame)
+ }
+ }
+
+ deinit {
+ displayLink.invalidate()
+ }
+
+ /// The target for the CADisplayLink (because CADisplayLink retains its target).
+ internal final class DisplayLinkTarget {
+
+ /// The callback to call for each frame.
+ var callback: ((frame: DisplayLink.Frame) -> Void)? = nil
+
+ /// Called for each frame from the CADisplayLink.
+ dynamic func frame(displayLink: CADisplayLink) {
+ callback?(frame: Frame(timestamp: displayLink.timestamp, duration: displayLink.duration))
+ }
+ }
+}
+
+#elseif os(OSX) // OS X support using CVDisplayLink --------------------------------------------------
+
+/// DisplayLink is used to hook into screen refreshes.
+internal final class DisplayLink {
+
+ /// The callback to call for each frame.
+ var callback: ((frame: Frame) -> Void)? = nil
+
+ /// If the display link is paused or not.
+ var paused: Bool = true {
+ didSet {
+ guard paused != oldValue else { return }
+ if paused == true {
+ CVDisplayLinkStop(self.displayLink)
+ } else {
+ CVDisplayLinkStart(self.displayLink)
+ }
+ }
+ }
+
+ /// The CVDisplayLink that powers this DisplayLink instance.
+ var displayLink: CVDisplayLinkRef = {
+ var dl: CVDisplayLinkRef? = nil
+ CVDisplayLinkCreateWithActiveCGDisplays(&dl)
+ return dl!
+ }()
+
+ var lastFrame = Frame(timestamp: 0, duration: 0)
+
+ /// Creates a new paused DisplayLink instance.
+ init() {
+ func displayLinkOutputCallback(displayLink: CVDisplayLink, inNow: UnsafePointer<CVTimeStamp>, inOutputTime: UnsafePointer<CVTimeStamp>, flagsIn: CVOptionFlags, flagsOut: UnsafeMutablePointer<CVOptionFlags>, userInfo: UnsafeMutablePointer<Void>) -> CVReturn {
+ let timestamp = Double(inNow.memory.videoTime) / Double(inNow.memory.videoTimeScale) // convert to seconds
+ let dl = unsafeBitCast(userInfo, DisplayLink.self) // cast back to a pointer to self
+
+ let time = CVDisplayLinkGetNominalOutputVideoRefreshPeriod(displayLink)
+ let duration = Double(Double(time.timeValue) / Double(time.timeScale)) // convert to seconds
+ let info = Frame(timestamp: timestamp, duration: duration)
+
+ // dispatch to main - this is called from an internal CV thread
+ dispatch_async(dispatch_get_main_queue()) { () -> Void in
+ dl.frame(info) // call frame(timestamp:) on self
+ }
+ return kCVReturnSuccess
+ }
+
+ // hook up the frame output callback
+ CVDisplayLinkSetOutputCallback(self.displayLink, displayLinkOutputCallback, UnsafeMutablePointer<Void>(unsafeAddressOf(self))) // pass in self as the 'userInfo'
+ }
+
+ deinit {
+ paused = true
+ }
+
+ /// Called for each CVDisplayLink frame callback.
+ func frame(frame: Frame) {
+ guard paused == false else { return }
+ guard frame.timestamp != lastFrame.timestamp else { return }
+ callback?(frame: frame)
+ lastFrame = frame
+ }
+}
+
+#endif // ------------------------------------------------------------------------------------------
View
15 Advance/Loop/Loop.swift
@@ -38,10 +38,11 @@ public final class Loop {
private var currentAnimationTime: Double = 0.0
- private lazy var displayLink: CADisplayLink = {
- let link = CADisplayLink(target: self, selector: "displayLinkDidFire:")
- link.paused = true
- link.addToRunLoop(NSRunLoop.mainRunLoop(), forMode: NSRunLoopCommonModes)
+ private lazy var displayLink: DisplayLink = {
+ let link = DisplayLink()
+ link.callback = { [unowned self] (frame) in
+ self.displayLinkDidFire(frame)
+ }
return link
}()
@@ -88,12 +89,12 @@ public final class Loop {
displayLink.paused = true
}
- dynamic private func displayLinkDidFire(displayLink: CADisplayLink) {
+ private func displayLinkDidFire(frame: DisplayLink.Frame) {
- let timestamp = max(displayLink.timestamp, currentAnimationTime)
+ let timestamp = max(frame.timestamp, currentAnimationTime)
if currentAnimationTime == 0.0 {
- currentAnimationTime = timestamp - displayLink.duration
+ currentAnimationTime = timestamp - frame.duration
}
let elapsed = timestamp - currentAnimationTime
View
41 AdvanceSample-OSX/AppDelegate.swift
@@ -0,0 +1,41 @@
+/*
+
+Copyright (c) 2016, Storehouse Media Inc.
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without
+modification, are permitted provided that the following conditions are met:
+
+* Redistributions of source code must retain the above copyright notice, this
+list of conditions and the following disclaimer.
+
+* Redistributions in binary form must reproduce the above copyright notice,
+this list of conditions and the following disclaimer in the documentation
+and/or other materials provided with the distribution.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
+FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+*/
+
+import Cocoa
+
+
+@NSApplicationMain
+class AppDelegate: NSObject, NSApplicationDelegate {
+
+ @IBOutlet var window: NSWindow!
+
+ func applicationDidFinishLaunching(aNotification: NSNotification) {
+
+ }
+}
+
View
58 AdvanceSample-OSX/Assets.xcassets/AppIcon.appiconset/Contents.json
@@ -0,0 +1,58 @@
+{
+ "images" : [
+ {
+ "idiom" : "mac",
+ "size" : "16x16",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "mac",
+ "size" : "16x16",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "mac",
+ "size" : "32x32",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "mac",
+ "size" : "32x32",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "mac",
+ "size" : "128x128",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "mac",
+ "size" : "128x128",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "mac",
+ "size" : "256x256",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "mac",
+ "size" : "256x256",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "mac",
+ "size" : "512x512",
+ "scale" : "1x"
+ },
+ {
+ "idiom" : "mac",
+ "size" : "512x512",
+ "scale" : "2x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
View
756 AdvanceSample-OSX/Base.lproj/MainMenu.xib
@@ -0,0 +1,756 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<document type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="3.0" toolsVersion="9532" systemVersion="15D21" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES" customObjectInstantitationMethod="direct">
+ <dependencies>
+ <deployment identifier="macosx"/>
+ <plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="9532"/>
+ </dependencies>
+ <objects>
+ <customObject id="-2" userLabel="File's Owner" customClass="NSApplication">
+ <connections>
+ <outlet property="delegate" destination="Voe-Tx-rLC" id="GzC-gU-4Uq"/>
+ </connections>
+ </customObject>
+ <customObject id="-1" userLabel="First Responder" customClass="FirstResponder"/>
+ <customObject id="-3" userLabel="Application" customClass="NSObject"/>
+ <customObject id="Voe-Tx-rLC" customClass="AppDelegate" customModule="AdvanceSample_OSX" customModuleProvider="target">
+ <connections>
+ <outlet property="window" destination="QvC-M9-y7g" id="gIp-Ho-8D9"/>
+ </connections>
+ </customObject>
+ <customObject id="YLy-65-1bz" customClass="NSFontManager"/>
+ <menu title="Main Menu" systemMenu="main" id="AYu-sK-qS6">
+ <items>
+ <menuItem title="AdvanceSample-OSX" id="1Xt-HY-uBw">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="AdvanceSample-OSX" systemMenu="apple" id="uQy-DD-JDr">
+ <items>
+ <menuItem title="About AdvanceSample-OSX" id="5kV-Vb-QxS">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="orderFrontStandardAboutPanel:" target="-1" id="Exp-CZ-Vem"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="VOq-y0-SEH"/>
+ <menuItem title="Preferences…" keyEquivalent="," id="BOF-NM-1cW"/>
+ <menuItem isSeparatorItem="YES" id="wFC-TO-SCJ"/>
+ <menuItem title="Services" id="NMo-om-nkz">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Services" systemMenu="services" id="hz9-B4-Xy5"/>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="4je-JR-u6R"/>
+ <menuItem title="Hide AdvanceSample-OSX" keyEquivalent="h" id="Olw-nP-bQN">
+ <connections>
+ <action selector="hide:" target="-1" id="PnN-Uc-m68"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Hide Others" keyEquivalent="h" id="Vdr-fp-XzO">
+ <modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
+ <connections>
+ <action selector="hideOtherApplications:" target="-1" id="VT4-aY-XCT"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Show All" id="Kd2-mp-pUS">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="unhideAllApplications:" target="-1" id="Dhg-Le-xox"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="kCx-OE-vgT"/>
+ <menuItem title="Quit AdvanceSample-OSX" keyEquivalent="q" id="4sb-4s-VLi">
+ <connections>
+ <action selector="terminate:" target="-1" id="Te7-pn-YzF"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="File" id="dMs-cI-mzQ">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="File" id="bib-Uj-vzu">
+ <items>
+ <menuItem title="New" keyEquivalent="n" id="Was-JA-tGl">
+ <connections>
+ <action selector="newDocument:" target="-1" id="4Si-XN-c54"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Open…" keyEquivalent="o" id="IAo-SY-fd9">
+ <connections>
+ <action selector="openDocument:" target="-1" id="bVn-NM-KNZ"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Open Recent" id="tXI-mr-wws">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Open Recent" systemMenu="recentDocuments" id="oas-Oc-fiZ">
+ <items>
+ <menuItem title="Clear Menu" id="vNY-rz-j42">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="clearRecentDocuments:" target="-1" id="Daa-9d-B3U"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="m54-Is-iLE"/>
+ <menuItem title="Close" keyEquivalent="w" id="DVo-aG-piG">
+ <connections>
+ <action selector="performClose:" target="-1" id="HmO-Ls-i7Q"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Save…" keyEquivalent="s" id="pxx-59-PXV">
+ <connections>
+ <action selector="saveDocument:" target="-1" id="teZ-XB-qJY"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Save As…" keyEquivalent="S" id="Bw7-FT-i3A">
+ <connections>
+ <action selector="saveDocumentAs:" target="-1" id="mDf-zr-I0C"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Revert to Saved" id="KaW-ft-85H">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="revertDocumentToSaved:" target="-1" id="iJ3-Pv-kwq"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="aJh-i4-bef"/>
+ <menuItem title="Page Setup…" keyEquivalent="P" id="qIS-W8-SiK">
+ <modifierMask key="keyEquivalentModifierMask" shift="YES" command="YES"/>
+ <connections>
+ <action selector="runPageLayout:" target="-1" id="Din-rz-gC5"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Print…" keyEquivalent="p" id="aTl-1u-JFS">
+ <connections>
+ <action selector="print:" target="-1" id="qaZ-4w-aoO"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="Edit" id="5QF-Oa-p0T">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Edit" id="W48-6f-4Dl">
+ <items>
+ <menuItem title="Undo" keyEquivalent="z" id="dRJ-4n-Yzg">
+ <connections>
+ <action selector="undo:" target="-1" id="M6e-cu-g7V"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Redo" keyEquivalent="Z" id="6dh-zS-Vam">
+ <connections>
+ <action selector="redo:" target="-1" id="oIA-Rs-6OD"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="WRV-NI-Exz"/>
+ <menuItem title="Cut" keyEquivalent="x" id="uRl-iY-unG">
+ <connections>
+ <action selector="cut:" target="-1" id="YJe-68-I9s"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Copy" keyEquivalent="c" id="x3v-GG-iWU">
+ <connections>
+ <action selector="copy:" target="-1" id="G1f-GL-Joy"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Paste" keyEquivalent="v" id="gVA-U4-sdL">
+ <connections>
+ <action selector="paste:" target="-1" id="UvS-8e-Qdg"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Paste and Match Style" keyEquivalent="V" id="WeT-3V-zwk">
+ <modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
+ <connections>
+ <action selector="pasteAsPlainText:" target="-1" id="cEh-KX-wJQ"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Delete" id="pa3-QI-u2k">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="delete:" target="-1" id="0Mk-Ml-PaM"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Select All" keyEquivalent="a" id="Ruw-6m-B2m">
+ <connections>
+ <action selector="selectAll:" target="-1" id="VNm-Mi-diN"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="uyl-h8-XO2"/>
+ <menuItem title="Find" id="4EN-yA-p0u">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Find" id="1b7-l0-nxx">
+ <items>
+ <menuItem title="Find…" tag="1" keyEquivalent="f" id="Xz5-n4-O0W">
+ <connections>
+ <action selector="performFindPanelAction:" target="-1" id="cD7-Qs-BN4"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Find and Replace…" tag="12" keyEquivalent="f" id="YEy-JH-Tfz">
+ <modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
+ <connections>
+ <action selector="performFindPanelAction:" target="-1" id="WD3-Gg-5AJ"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Find Next" tag="2" keyEquivalent="g" id="q09-fT-Sye">
+ <connections>
+ <action selector="performFindPanelAction:" target="-1" id="NDo-RZ-v9R"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Find Previous" tag="3" keyEquivalent="G" id="OwM-mh-QMV">
+ <connections>
+ <action selector="performFindPanelAction:" target="-1" id="HOh-sY-3ay"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Use Selection for Find" tag="7" keyEquivalent="e" id="buJ-ug-pKt">
+ <connections>
+ <action selector="performFindPanelAction:" target="-1" id="U76-nv-p5D"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Jump to Selection" keyEquivalent="j" id="S0p-oC-mLd">
+ <connections>
+ <action selector="centerSelectionInVisibleArea:" target="-1" id="IOG-6D-g5B"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="Spelling and Grammar" id="Dv1-io-Yv7">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Spelling" id="3IN-sU-3Bg">
+ <items>
+ <menuItem title="Show Spelling and Grammar" keyEquivalent=":" id="HFo-cy-zxI">
+ <connections>
+ <action selector="showGuessPanel:" target="-1" id="vFj-Ks-hy3"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Check Document Now" keyEquivalent=";" id="hz2-CU-CR7">
+ <connections>
+ <action selector="checkSpelling:" target="-1" id="fz7-VC-reM"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="bNw-od-mp5"/>
+ <menuItem title="Check Spelling While Typing" id="rbD-Rh-wIN">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="toggleContinuousSpellChecking:" target="-1" id="7w6-Qz-0kB"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Check Grammar With Spelling" id="mK6-2p-4JG">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="toggleGrammarChecking:" target="-1" id="muD-Qn-j4w"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Correct Spelling Automatically" id="78Y-hA-62v">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="toggleAutomaticSpellingCorrection:" target="-1" id="2lM-Qi-WAP"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="Substitutions" id="9ic-FL-obx">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Substitutions" id="FeM-D8-WVr">
+ <items>
+ <menuItem title="Show Substitutions" id="z6F-FW-3nz">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="orderFrontSubstitutionsPanel:" target="-1" id="oku-mr-iSq"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="gPx-C9-uUO"/>
+ <menuItem title="Smart Copy/Paste" id="9yt-4B-nSM">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="toggleSmartInsertDelete:" target="-1" id="3IJ-Se-DZD"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Smart Quotes" id="hQb-2v-fYv">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="toggleAutomaticQuoteSubstitution:" target="-1" id="ptq-xd-QOA"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Smart Dashes" id="rgM-f4-ycn">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="toggleAutomaticDashSubstitution:" target="-1" id="oCt-pO-9gS"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Smart Links" id="cwL-P1-jid">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="toggleAutomaticLinkDetection:" target="-1" id="Gip-E3-Fov"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Data Detectors" id="tRr-pd-1PS">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="toggleAutomaticDataDetection:" target="-1" id="R1I-Nq-Kbl"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Text Replacement" id="HFQ-gK-NFA">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="toggleAutomaticTextReplacement:" target="-1" id="DvP-Fe-Py6"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="Transformations" id="2oI-Rn-ZJC">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Transformations" id="c8a-y6-VQd">
+ <items>
+ <menuItem title="Make Upper Case" id="vmV-6d-7jI">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="uppercaseWord:" target="-1" id="sPh-Tk-edu"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Make Lower Case" id="d9M-CD-aMd">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="lowercaseWord:" target="-1" id="iUZ-b5-hil"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Capitalize" id="UEZ-Bs-lqG">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="capitalizeWord:" target="-1" id="26H-TL-nsh"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="Speech" id="xrE-MZ-jX0">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Speech" id="3rS-ZA-NoH">
+ <items>
+ <menuItem title="Start Speaking" id="Ynk-f8-cLZ">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="startSpeaking:" target="-1" id="654-Ng-kyl"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Stop Speaking" id="Oyz-dy-DGm">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="stopSpeaking:" target="-1" id="dX8-6p-jy9"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="Format" id="jxT-CU-nIS">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Format" id="GEO-Iw-cKr">
+ <items>
+ <menuItem title="Font" id="Gi5-1S-RQB">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Font" systemMenu="font" id="aXa-aM-Jaq">
+ <items>
+ <menuItem title="Show Fonts" keyEquivalent="t" id="Q5e-8K-NDq">
+ <connections>
+ <action selector="orderFrontFontPanel:" target="YLy-65-1bz" id="WHr-nq-2xA"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Bold" tag="2" keyEquivalent="b" id="GB9-OM-e27">
+ <connections>
+ <action selector="addFontTrait:" target="YLy-65-1bz" id="hqk-hr-sYV"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Italic" tag="1" keyEquivalent="i" id="Vjx-xi-njq">
+ <connections>
+ <action selector="addFontTrait:" target="YLy-65-1bz" id="IHV-OB-c03"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Underline" keyEquivalent="u" id="WRG-CD-K1S">
+ <connections>
+ <action selector="underline:" target="-1" id="FYS-2b-JAY"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="5gT-KC-WSO"/>
+ <menuItem title="Bigger" tag="3" keyEquivalent="+" id="Ptp-SP-VEL">
+ <connections>
+ <action selector="modifyFont:" target="YLy-65-1bz" id="Uc7-di-UnL"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Smaller" tag="4" keyEquivalent="-" id="i1d-Er-qST">
+ <connections>
+ <action selector="modifyFont:" target="YLy-65-1bz" id="HcX-Lf-eNd"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="kx3-Dk-x3B"/>
+ <menuItem title="Kern" id="jBQ-r6-VK2">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Kern" id="tlD-Oa-oAM">
+ <items>
+ <menuItem title="Use Default" id="GUa-eO-cwY">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="useStandardKerning:" target="-1" id="6dk-9l-Ckg"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Use None" id="cDB-IK-hbR">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="turnOffKerning:" target="-1" id="U8a-gz-Maa"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Tighten" id="46P-cB-AYj">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="tightenKerning:" target="-1" id="hr7-Nz-8ro"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Loosen" id="ogc-rX-tC1">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="loosenKerning:" target="-1" id="8i4-f9-FKE"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="Ligatures" id="o6e-r0-MWq">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Ligatures" id="w0m-vy-SC9">
+ <items>
+ <menuItem title="Use Default" id="agt-UL-0e3">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="useStandardLigatures:" target="-1" id="7uR-wd-Dx6"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Use None" id="J7y-lM-qPV">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="turnOffLigatures:" target="-1" id="iX2-gA-Ilz"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Use All" id="xQD-1f-W4t">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="useAllLigatures:" target="-1" id="KcB-kA-TuK"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="Baseline" id="OaQ-X3-Vso">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Baseline" id="ijk-EB-dga">
+ <items>
+ <menuItem title="Use Default" id="3Om-Ey-2VK">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="unscript:" target="-1" id="0vZ-95-Ywn"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Superscript" id="Rqc-34-cIF">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="superscript:" target="-1" id="3qV-fo-wpU"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Subscript" id="I0S-gh-46l">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="subscript:" target="-1" id="Q6W-4W-IGz"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Raise" id="2h7-ER-AoG">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="raiseBaseline:" target="-1" id="4sk-31-7Q9"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Lower" id="1tx-W0-xDw">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="lowerBaseline:" target="-1" id="OF1-bc-KW4"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="Ndw-q3-faq"/>
+ <menuItem title="Show Colors" keyEquivalent="C" id="bgn-CT-cEk">
+ <connections>
+ <action selector="orderFrontColorPanel:" target="-1" id="mSX-Xz-DV3"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="iMs-zA-UFJ"/>
+ <menuItem title="Copy Style" keyEquivalent="c" id="5Vv-lz-BsD">
+ <modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
+ <connections>
+ <action selector="copyFont:" target="-1" id="GJO-xA-L4q"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Paste Style" keyEquivalent="v" id="vKC-jM-MkH">
+ <modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
+ <connections>
+ <action selector="pasteFont:" target="-1" id="JfD-CL-leO"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="Text" id="Fal-I4-PZk">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Text" id="d9c-me-L2H">
+ <items>
+ <menuItem title="Align Left" keyEquivalent="{" id="ZM1-6Q-yy1">
+ <connections>
+ <action selector="alignLeft:" target="-1" id="zUv-R1-uAa"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Center" keyEquivalent="|" id="VIY-Ag-zcb">
+ <connections>
+ <action selector="alignCenter:" target="-1" id="spX-mk-kcS"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Justify" id="J5U-5w-g23">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="alignJustified:" target="-1" id="ljL-7U-jND"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Align Right" keyEquivalent="}" id="wb2-vD-lq4">
+ <connections>
+ <action selector="alignRight:" target="-1" id="r48-bG-YeY"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="4s2-GY-VfK"/>
+ <menuItem title="Writing Direction" id="H1b-Si-o9J">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Writing Direction" id="8mr-sm-Yjd">
+ <items>
+ <menuItem title="Paragraph" enabled="NO" id="ZvO-Gk-QUH">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ </menuItem>
+ <menuItem id="YGs-j5-SAR">
+ <string key="title"> Default</string>
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="makeBaseWritingDirectionNatural:" target="-1" id="qtV-5e-UBP"/>
+ </connections>
+ </menuItem>
+ <menuItem id="Lbh-J2-qVU">
+ <string key="title"> Left to Right</string>
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="makeBaseWritingDirectionLeftToRight:" target="-1" id="S0X-9S-QSf"/>
+ </connections>
+ </menuItem>
+ <menuItem id="jFq-tB-4Kx">
+ <string key="title"> Right to Left</string>
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="makeBaseWritingDirectionRightToLeft:" target="-1" id="5fk-qB-AqJ"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="swp-gr-a21"/>
+ <menuItem title="Selection" enabled="NO" id="cqv-fj-IhA">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ </menuItem>
+ <menuItem id="Nop-cj-93Q">
+ <string key="title"> Default</string>
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="makeTextWritingDirectionNatural:" target="-1" id="lPI-Se-ZHp"/>
+ </connections>
+ </menuItem>
+ <menuItem id="BgM-ve-c93">
+ <string key="title"> Left to Right</string>
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="makeTextWritingDirectionLeftToRight:" target="-1" id="caW-Bv-w94"/>
+ </connections>
+ </menuItem>
+ <menuItem id="RB4-Sm-HuC">
+ <string key="title"> Right to Left</string>
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="makeTextWritingDirectionRightToLeft:" target="-1" id="EXD-6r-ZUu"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="fKy-g9-1gm"/>
+ <menuItem title="Show Ruler" id="vLm-3I-IUL">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="toggleRuler:" target="-1" id="FOx-HJ-KwY"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Copy Ruler" keyEquivalent="c" id="MkV-Pr-PK5">
+ <modifierMask key="keyEquivalentModifierMask" control="YES" command="YES"/>
+ <connections>
+ <action selector="copyRuler:" target="-1" id="71i-fW-3W2"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Paste Ruler" keyEquivalent="v" id="LVM-kO-fVI">
+ <modifierMask key="keyEquivalentModifierMask" control="YES" command="YES"/>
+ <connections>
+ <action selector="pasteRuler:" target="-1" id="cSh-wd-qM2"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="View" id="H8h-7b-M4v">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="View" id="HyV-fh-RgO">
+ <items>
+ <menuItem title="Show Toolbar" keyEquivalent="t" id="snW-S8-Cw5">
+ <modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
+ <connections>
+ <action selector="toggleToolbarShown:" target="-1" id="BXY-wc-z0C"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Customize Toolbar…" id="1UK-8n-QPP">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="runToolbarCustomizationPalette:" target="-1" id="pQI-g3-MTW"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="Window" id="aUF-d1-5bR">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Window" systemMenu="window" id="Td7-aD-5lo">
+ <items>
+ <menuItem title="Minimize" keyEquivalent="m" id="OY7-WF-poV">
+ <connections>
+ <action selector="performMiniaturize:" target="-1" id="VwT-WD-YPe"/>
+ </connections>
+ </menuItem>
+ <menuItem title="Zoom" id="R4o-n2-Eq4">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="performZoom:" target="-1" id="DIl-cC-cCs"/>
+ </connections>
+ </menuItem>
+ <menuItem isSeparatorItem="YES" id="eu3-7i-yIM"/>
+ <menuItem title="Bring All to Front" id="LE2-aR-0XJ">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <connections>
+ <action selector="arrangeInFront:" target="-1" id="DRN-fu-gQh"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ <menuItem title="Help" id="wpr-3q-Mcd">
+ <modifierMask key="keyEquivalentModifierMask"/>
+ <menu key="submenu" title="Help" systemMenu="help" id="F2S-fz-NVQ">
+ <items>
+ <menuItem title="AdvanceSample-OSX Help" keyEquivalent="?" id="FKE-Sm-Kum">
+ <connections>
+ <action selector="showHelp:" target="-1" id="y7X-2Q-9no"/>
+ </connections>
+ </menuItem>
+ </items>
+ </menu>
+ </menuItem>
+ </items>
+ </menu>
+ <window title="AdvanceSample-OSX" allowsToolTipsWhenApplicationIsInactive="NO" autorecalculatesKeyViewLoop="NO" releasedWhenClosed="NO" animationBehavior="default" id="QvC-M9-y7g">
+ <windowStyleMask key="styleMask" titled="YES" closable="YES" miniaturizable="YES" resizable="YES"/>
+ <rect key="contentRect" x="335" y="390" width="470" height="628"/>
+ <rect key="screenRect" x="0.0" y="0.0" width="2560" height="1417"/>
+ <view key="contentView" wantsLayer="YES" id="EiT-Mj-1SZ">
+ <rect key="frame" x="0.0" y="0.0" width="470" height="628"/>
+ <autoresizingMask key="autoresizingMask"/>
+ <subviews>
+ <customView translatesAutoresizingMaskIntoConstraints="NO" id="2GC-Eh-228" customClass="SpringContainerView" customModule="AdvanceSample_OSX" customModuleProvider="target">
+ <rect key="frame" x="0.0" y="0.0" width="470" height="628"/>
+ <subviews>
+ <textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="t5A-3S-zNd">
+ <rect key="frame" x="91" y="591" width="288" height="17"/>
+ <textFieldCell key="cell" scrollable="YES" lineBreakMode="clipping" sendsActionOnEndEditing="YES" title="Click anywhere to move the dot using a spring." id="mqy-JN-xV3">
+ <font key="font" metaFont="system"/>
+ <color key="textColor" name="labelColor" catalog="System" colorSpace="catalog"/>
+ <color key="backgroundColor" name="controlColor" catalog="System" colorSpace="catalog"/>
+ </textFieldCell>
+ </textField>
+ <slider verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="wyX-O9-fNI">
+ <rect key="frame" x="81" y="48" width="371" height="21"/>
+ <sliderCell key="cell" continuous="YES" state="on" alignment="left" minValue="1" maxValue="500" doubleValue="50" tickMarkPosition="above" sliderType="linear" id="cnN-NF-sqL"/>
+ <connections>
+ <action selector="tensionChanged:" target="2GC-Eh-228" id="kM1-uo-EY2"/>
+ </connections>
+ </slider>
+ <slider verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="msm-mE-zF5">
+ <rect key="frame" x="81" y="16" width="371" height="21"/>
+ <sliderCell key="cell" continuous="YES" state="on" alignment="left" minValue="0.10000000000000001" maxValue="150" doubleValue="50" tickMarkPosition="above" sliderType="linear" id="8hn-8y-v1g"/>
+ <connections>
+ <action selector="dampingSlider:" target="2GC-Eh-228" id="UUZ-c0-UfB"/>
+ </connections>
+ </slider>
+ <textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="ve5-f8-d4B">
+ <rect key="frame" x="18" y="51" width="59" height="17"/>
+ <constraints>
+ <constraint firstAttribute="width" constant="55" id="xKs-Ai-bvu"/>
+ </constraints>
+ <textFieldCell key="cell" scrollable="YES" lineBreakMode="clipping" sendsActionOnEndEditing="YES" alignment="right" title="Tension" id="sEv-Tu-sum">
+ <font key="font" metaFont="system"/>
+ <color key="textColor" name="labelColor" catalog="System" colorSpace="catalog"/>
+ <color key="backgroundColor" name="controlColor" catalog="System" colorSpace="catalog"/>
+ </textFieldCell>
+ </textField>
+ <textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="eYd-jG-Gsk">
+ <rect key="frame" x="18" y="20" width="59" height="17"/>
+ <constraints>
+ <constraint firstAttribute="width" constant="55" id="cAt-85-tBh"/>
+ </constraints>
+ <textFieldCell key="cell" scrollable="YES" lineBreakMode="clipping" sendsActionOnEndEditing="YES" title="Damping" id="wlW-hx-4ts">
+ <font key="font" metaFont="system"/>
+ <color key="textColor" name="labelColor" catalog="System" colorSpace="catalog"/>
+ <color key="backgroundColor" name="controlColor" catalog="System" colorSpace="catalog"/>
+ </textFieldCell>
+ </textField>
+ </subviews>
+ <constraints>
+ <constraint firstItem="t5A-3S-zNd" firstAttribute="centerX" secondItem="2GC-Eh-228" secondAttribute="centerX" id="4Or-jw-7dG"/>
+ <constraint firstItem="eYd-jG-Gsk" firstAttribute="top" secondItem="ve5-f8-d4B" secondAttribute="bottom" constant="14" id="JDe-SJ-mJV"/>
+ <constraint firstItem="msm-mE-zF5" firstAttribute="top" secondItem="wyX-O9-fNI" secondAttribute="bottom" constant="15" id="KNR-MF-Pfc"/>
+ <constraint firstAttribute="trailing" secondItem="msm-mE-zF5" secondAttribute="trailing" constant="20" id="KZ3-xV-Gaf"/>
+ <constraint firstItem="wyX-O9-fNI" firstAttribute="leading" secondItem="ve5-f8-d4B" secondAttribute="trailing" constant="8" id="P5o-Pm-rvf"/>
+ <constraint firstItem="t5A-3S-zNd" firstAttribute="top" secondItem="2GC-Eh-228" secondAttribute="top" constant="20" symbolic="YES" id="T8m-T7-0Ng"/>
+ <constraint firstAttribute="trailing" secondItem="wyX-O9-fNI" secondAttribute="trailing" constant="20" id="Vtn-6L-3xx"/>
+ <constraint firstAttribute="bottom" secondItem="eYd-jG-Gsk" secondAttribute="bottom" constant="20" id="VwL-Cf-M2R"/>
+ <constraint firstAttribute="bottom" secondItem="msm-mE-zF5" secondAttribute="bottom" constant="18" id="W9Z-sT-x5C"/>
+ <constraint firstItem="eYd-jG-Gsk" firstAttribute="leading" secondItem="2GC-Eh-228" secondAttribute="leading" constant="20" id="as3-37-Sdg"/>
+ <constraint firstItem="ve5-f8-d4B" firstAttribute="leading" secondItem="2GC-Eh-228" secondAttribute="leading" constant="20" id="dxd-Cp-LTT"/>
+ <constraint firstItem="msm-mE-zF5" firstAttribute="leading" secondItem="eYd-jG-Gsk" secondAttribute="trailing" constant="8" id="hRj-fK-Q5Z"/>
+ </constraints>
+ <connections>
+ <outlet property="dampingSlider" destination="msm-mE-zF5" id="4zB-Jo-8gM"/>
+ <outlet property="tensionSlider" destination="wyX-O9-fNI" id="Dei-7q-NHR"/>
+ </connections>
+ </customView>
+ </subviews>
+ <constraints>
+ <constraint firstAttribute="bottom" secondItem="2GC-Eh-228" secondAttribute="bottom" id="2OG-Rf-8kS"/>
+ <constraint firstItem="2GC-Eh-228" firstAttribute="top" secondItem="EiT-Mj-1SZ" secondAttribute="top" id="Dnm-hf-J9Q"/>
+ <constraint firstItem="2GC-Eh-228" firstAttribute="leading" secondItem="EiT-Mj-1SZ" secondAttribute="leading" id="LlQ-9v-pRI"/>
+ <constraint firstAttribute="trailing" secondItem="2GC-Eh-228" secondAttribute="trailing" id="No3-SS-91K"/>
+ </constraints>
+ </view>
+ <point key="canvasLocation" x="213" y="489"/>
+ </window>
+ </objects>
+</document>
View
34 AdvanceSample-OSX/Info.plist
@@ -0,0 +1,34 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<dict>
+ <key>CFBundleDevelopmentRegion</key>
+ <string>en</string>
+ <key>CFBundleExecutable</key>
+ <string>$(EXECUTABLE_NAME)</string>
+ <key>CFBundleIconFile</key>
+ <string></string>
+ <key>CFBundleIdentifier</key>
+ <string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
+ <key>CFBundleInfoDictionaryVersion</key>
+ <string>6.0</string>
+ <key>CFBundleName</key>
+ <string>$(PRODUCT_NAME)</string>
+ <key>CFBundlePackageType</key>
+ <string>APPL</string>
+ <key>CFBundleShortVersionString</key>
+ <string>1.0</string>
+ <key>CFBundleSignature</key>
+ <string>????</string>
+ <key>CFBundleVersion</key>
+ <string>1</string>
+ <key>LSMinimumSystemVersion</key>
+ <string>$(MACOSX_DEPLOYMENT_TARGET)</string>
+ <key>NSHumanReadableCopyright</key>
+ <string>Copyright © 2016 Storehouse Media Inc. All rights reserved.</string>
+ <key>NSMainNibFile</key>
+ <string>MainMenu</string>
+ <key>NSPrincipalClass</key>
+ <string>NSApplication</string>
+</dict>
+</plist>
View
70 AdvanceSample-OSX/SpringContainerView.swift
@@ -0,0 +1,70 @@
+/*
+
+Copyright (c) 2016, Storehouse Media Inc.
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without
+modification, are permitted provided that the following conditions are met:
+
+* Redistributions of source code must retain the above copyright notice, this
+list of conditions and the following disclaimer.
+
+* Redistributions in binary form must reproduce the above copyright notice,
+this list of conditions and the following disclaimer in the documentation
+and/or other materials provided with the distribution.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
+FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+*/
+
+import Cocoa
+import Advance
+
+
+final class SpringContainerView : NSView {
+
+ @IBOutlet var tensionSlider: NSSlider!
+ @IBOutlet var dampingSlider: NSSlider!
+
+ var springView = SpringView(frame: CGRect(x: 0.0, y: 0.0, width: 24.0, height: 24.0))
+
+ required init?(coder: NSCoder) {
+ super.init(coder: coder)
+ wantsLayer = true
+ layer?.backgroundColor = NSColor.whiteColor().CGColor
+ layer?.delegate = self
+
+ addSubview(springView)
+ springView.centerSpring.reset(CGPoint(x: bounds.midX, y: bounds.midY))
+ }
+
+ override func awakeFromNib() {
+ super.awakeFromNib()
+ tensionSlider.doubleValue = springView.centerSpring.configuration.tension
+ dampingSlider.doubleValue = springView.centerSpring.configuration.damping
+ }
+
+ override func mouseDown(theEvent: NSEvent) {
+ var point = theEvent.locationInWindow
+ point.x -= (springView.bounds.width / 2.0)
+ point.y -= (springView.bounds.height / 2.0)
+ springView.centerSpring.target = point
+ }
+
+ @IBAction func tensionChanged(sender: AnyObject) {
+ springView.centerSpring.configuration.tension = tensionSlider.doubleValue
+ }
+
+ @IBAction func dampingSlider(sender: AnyObject) {
+ springView.centerSpring.configuration.damping = dampingSlider.doubleValue
+ }
+}
View
62 AdvanceSample-OSX/SpringView.swift
@@ -0,0 +1,62 @@
+/*
+
+Copyright (c) 2016, Storehouse Media Inc.
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without
+modification, are permitted provided that the following conditions are met:
+
+* Redistributions of source code must retain the above copyright notice, this
+list of conditions and the following disclaimer.
+
+* Redistributions in binary form must reproduce the above copyright notice,
+this list of conditions and the following disclaimer in the documentation
+and/or other materials provided with the distribution.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
+FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+*/
+
+import Cocoa
+import Advance
+
+
+final class SpringView : NSView {
+ let centerSpring = Spring(value: CGPoint.zero)
+
+ override init(frame: CGRect) {
+ super.init(frame: frame)
+ wantsLayer = true
+
+ layer?.backgroundColor = NSColor(calibratedRed: 0.0, green: 196.0/255.0, blue: 1.0, alpha: 1.0).CGColor
+ layer?.delegate = self
+
+ let t = arc4random_uniform(120 - 20) + 20
+ let d = arc4random_uniform(20 - 4) + 4
+
+ centerSpring.configuration.tension = Scalar(t)
+ centerSpring.configuration.damping = Scalar(d)
+
+ centerSpring.changed.observe { [unowned self] (c) -> Void in
+ self.layer?.position = c
+ }
+ }
+
+ required init?(coder aDecoder: NSCoder) {
+ fatalError("init(coder:) has not been implemented")
+ }
+
+ override func layoutSublayersOfLayer(layer: CALayer) {
+ layer.cornerRadius = min(bounds.width, bounds.height) / 2.0
+ }
+}
+
View
0 AdvanceSample/ActivityView.swift → AdvanceSample-iOS/ActivityView.swift
File renamed without changes.
View
0 AdvanceSample/ActivityViewController.swift → ...ceSample-iOS/ActivityViewController.swift
File renamed without changes.
View
0 AdvanceSample/AppDelegate.swift → AdvanceSample-iOS/AppDelegate.swift
File renamed without changes.
View
0 ...xcassets/AppIcon.appiconset/Contents.json → ...xcassets/AppIcon.appiconset/Contents.json
File renamed without changes.
View
0 AdvanceSample/Assets.xcassets/Contents.json → ...eSample-iOS/Assets.xcassets/Contents.json
File renamed without changes.
View
0 ...background-blurred.imageset/Contents.json → ...background-blurred.imageset/Contents.json
File renamed without changes.
View
0 ...d-blurred.imageset/background-blurred.jpg → ...d-blurred.imageset/background-blurred.jpg
File renamed without changes
View
0 ...cassets/background.imageset/Contents.json → ...cassets/background.imageset/Contents.json
File renamed without changes.
View
0 ...assets/background.imageset/background.jpg → ...assets/background.imageset/background.jpg
File renamed without changes
View
0 ...sets.xcassets/logo.imageset/Contents.json → ...sets.xcassets/logo.imageset/Contents.json
File renamed without changes.
View
0 ...le/Assets.xcassets/logo.imageset/logo.pdf → ...OS/Assets.xcassets/logo.imageset/logo.pdf
File renamed without changes.
View
0 ...Sample/Base.lproj/LaunchScreen.storyboard → ...le-iOS/Base.lproj/LaunchScreen.storyboard
File renamed without changes.
View
0 AdvanceSample/BrowserView.swift → AdvanceSample-iOS/BrowserView.swift
File renamed without changes.
View
0 AdvanceSample/BrowserViewController.swift → ...nceSample-iOS/BrowserViewController.swift
File renamed without changes.
View
0 AdvanceSample/CoverView.swift → AdvanceSample-iOS/CoverView.swift
File renamed without changes.
View
0 AdvanceSample/DemoViewController.swift → AdvanceSample-iOS/DemoViewController.swift
File renamed without changes.
View
0 ...DirectManipulationGestureRecognizer.swift → ...DirectManipulationGestureRecognizer.swift
File renamed without changes.
View
0 AdvanceSample/GestureView.swift → AdvanceSample-iOS/GestureView.swift
File renamed without changes.
View
0 AdvanceSample/GesturesViewController.swift → ...ceSample-iOS/GesturesViewController.swift
File renamed without changes.
View
0 AdvanceSample/GravityFunction.swift → AdvanceSample-iOS/GravityFunction.swift
File renamed without changes.
View
0 AdvanceSample/GravitySimulation.swift → AdvanceSample-iOS/GravitySimulation.swift
File renamed without changes.
View
0 AdvanceSample/GravityViewController.swift → ...nceSample-iOS/GravityViewController.swift
File renamed without changes.
View
0 AdvanceSample/Info.plist → AdvanceSample-iOS/Info.plist
File renamed without changes.
View
0 AdvanceSample/SimpleTransform.swift → AdvanceSample-iOS/SimpleTransform.swift
File renamed without changes.
View
0 AdvanceSample/SpringConfigurationView.swift → ...eSample-iOS/SpringConfigurationView.swift
File renamed without changes.
View
0 AdvanceSample/SpringView.swift → AdvanceSample-iOS/SpringView.swift
File renamed without changes.
View
0 AdvanceSample/SpringsViewController.swift → ...nceSample-iOS/SpringsViewController.swift
File renamed without changes.
View
0 AdvanceTests/Info.plist → AdvanceTests-OSX/Info.plist
File renamed without changes.
View
0 AdvanceTests/BasicAnimationTests.swift → AdvanceTests-iOS/BasicAnimationTests.swift
File renamed without changes.
View
0 ...nceTests/CAMediaTimingFunctionTests.swift → ...ests-iOS/CAMediaTimingFunctionTests.swift
File renamed without changes.
View
78 AdvanceTests-iOS/DisplayLinkTests.swift
@@ -0,0 +1,78 @@
+import XCTest
+@testable import Advance
+
+
+class DisplayLinkTests : XCTestCase {
+
+ var displayLink: DisplayLink! = nil
+
+ override func setUp() {
+ displayLink = DisplayLink()
+ }
+
+ override func tearDown() {
+ displayLink = nil
+ }
+
+ func testCallback() {
+ let exp = expectationWithDescription("callback")
+
+ displayLink.callback = { (frame) in
+ exp.fulfill()
+ }
+
+ displayLink.paused = false
+
+ waitForExpectationsWithTimeout(0.5) { (error) -> Void in
+ guard error == nil else { XCTFail(); return }
+ }
+ }
+
+ func testPausing() {
+ displayLink.paused = false
+
+ var gotCallback = false
+
+ dispatch_after(dispatch_time(DISPATCH_TIME_NOW, Int64(0.5 * Double(NSEC_PER_SEC))), dispatch_get_main_queue()) { () -> Void in
+ self.displayLink.paused = true
+ self.displayLink.callback = { (frame) in
+ gotCallback = true
+ }
+ }
+
+ let timeoutDate = NSDate(timeIntervalSinceNow: 1.0)
+
+ repeat {
+ NSRunLoop.currentRunLoop().runMode(NSDefaultRunLoopMode, beforeDate: timeoutDate)
+ if timeoutDate.timeIntervalSinceNow <= 0.0 {
+ break
+ }
+ } while true
+
+ XCTAssertEqual(gotCallback, false)
+ }
+
+ func testTimestamp() {
+ let exp = expectationWithDescription("callback")
+
+ var callbacks = 0
+ var lastTimestamp: Double = 0
+
+ displayLink.callback = { (frame) in
+ XCTAssertTrue(frame.timestamp > lastTimestamp, "timestamp \(frame.timestamp) was not larger than \(lastTimestamp) (frame #\(callbacks))")
+ lastTimestamp = frame.timestamp
+
+ if callbacks == 10 { // test 10 frames before fulfilling
+ exp.fulfill()
+ }
+
+ callbacks += 1
+ }
+
+ displayLink.paused = false
+
+ waitForExpectationsWithTimeout(0.5) { (error) -> Void in
+ guard error == nil else { XCTFail(); return }
+ }
+ }
+}
View
0 AdvanceTests/EventTests.swift → AdvanceTests-iOS/EventTests.swift
File renamed without changes.
View
24 AdvanceTests-iOS/Info.plist
@@ -0,0 +1,24 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<dict>
+ <key>CFBundleDevelopmentRegion</key>
+ <string>en</string>
+ <key>CFBundleExecutable</key>
+ <string>$(EXECUTABLE_NAME)</string>
+ <key>CFBundleIdentifier</key>
+ <string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
+ <key>CFBundleInfoDictionaryVersion</key>
+ <string>6.0</string>
+ <key>CFBundleName</key>
+ <string>$(PRODUCT_NAME)</string>
+ <key>CFBundlePackageType</key>
+ <string>BNDL</string>
+ <key>CFBundleShortVersionString</key>
+ <string>1.0</string>
+ <key>CFBundleSignature</key>
+ <string>????</string>
+ <key>CFBundleVersion</key>
+ <string>1</string>
+</dict>
+</plist>
View
0 AdvanceTests/UnitBezierTests.swift → AdvanceTests-iOS/UnitBezierTests.swift
File renamed without changes.
View
0 AdvanceTests/VectorConvenienceTests.swift → ...nceTests-iOS/VectorConvenienceTests.swift
File renamed without changes.
View
0 AdvanceTests/VectorTypeTests.swift → AdvanceTests-iOS/VectorTypeTests.swift
File renamed without changes.

0 comments on commit 47bb85a

Please sign in to comment.
Something went wrong with that request. Please try again.