diff --git a/ElixxirDAppsSDK.xcworkspace/contents.xcworkspacedata b/ElixxirDAppsSDK.xcworkspace/contents.xcworkspacedata index 9ca22f2ec7dc6801cd91f1e2b68ae885d4abb591..ca3329e1a18abe7249c23385b288436d85ed4b75 100644 --- a/ElixxirDAppsSDK.xcworkspace/contents.xcworkspacedata +++ b/ElixxirDAppsSDK.xcworkspace/contents.xcworkspacedata @@ -4,7 +4,4 @@ <FileRef location = "group:"> </FileRef> - <FileRef - location = "group:Example/Example.xcodeproj"> - </FileRef> </Workspace> diff --git a/ElixxirDAppsSDK.xcworkspace/xcshareddata/swiftpm/Package.resolved b/ElixxirDAppsSDK.xcworkspace/xcshareddata/swiftpm/Package.resolved index 6829b18147b9023c7dac8a13beb9615666fcb45a..4dca92f3ab713290b103b3e4d345f6c391a200a9 100644 --- a/ElixxirDAppsSDK.xcworkspace/xcshareddata/swiftpm/Package.resolved +++ b/ElixxirDAppsSDK.xcworkspace/xcshareddata/swiftpm/Package.resolved @@ -1,14 +1,5 @@ { "pins" : [ - { - "identity" : "combine-schedulers", - "kind" : "remoteSourceControl", - "location" : "https://github.com/pointfreeco/combine-schedulers", - "state" : { - "revision" : "8fee20f993e64bbbf22bc3e3f444758ac2d05692", - "version" : "0.7.2" - } - }, { "identity" : "keychainaccess", "kind" : "remoteSourceControl", @@ -18,42 +9,6 @@ "version" : "4.2.2" } }, - { - "identity" : "swift-case-paths", - "kind" : "remoteSourceControl", - "location" : "https://github.com/pointfreeco/swift-case-paths", - "state" : { - "revision" : "a09839348486db8866f85a727b8550be1d671c50", - "version" : "0.9.1" - } - }, - { - "identity" : "swift-collections", - "kind" : "remoteSourceControl", - "location" : "https://github.com/apple/swift-collections", - "state" : { - "revision" : "48254824bb4248676bf7ce56014ff57b142b77eb", - "version" : "1.0.2" - } - }, - { - "identity" : "swift-composable-architecture", - "kind" : "remoteSourceControl", - "location" : "https://github.com/pointfreeco/swift-composable-architecture.git", - "state" : { - "revision" : "108e3a536fcebb16c4f247ef92c2d7326baf9fe3", - "version" : "0.39.0" - } - }, - { - "identity" : "swift-composable-presentation", - "kind" : "remoteSourceControl", - "location" : "https://github.com/darrarski/swift-composable-presentation.git", - "state" : { - "revision" : "1f4d17fae1f7ed41cbed17929083190fd9a78ee6", - "version" : "0.5.2" - } - }, { "identity" : "swift-custom-dump", "kind" : "remoteSourceControl", @@ -63,24 +18,6 @@ "version" : "0.5.0" } }, - { - "identity" : "swift-identified-collections", - "kind" : "remoteSourceControl", - "location" : "https://github.com/pointfreeco/swift-identified-collections", - "state" : { - "revision" : "2d6b7ffcc67afd9077fac5e5a29bcd6d39b71076", - "version" : "0.4.0" - } - }, - { - "identity" : "swiftui-app-icon-creator", - "kind" : "remoteSourceControl", - "location" : "https://github.com/darrarski/swiftui-app-icon-creator.git", - "state" : { - "revision" : "f0c7ba4e66d3dc8135ccf9146afc05f9dff3c4ff", - "version" : "1.2.0" - } - }, { "identity" : "xctest-dynamic-overlay", "kind" : "remoteSourceControl", diff --git a/Example/Example.xcodeproj/project.pbxproj b/Example/Example.xcodeproj/project.pbxproj deleted file mode 100644 index 6147b07eb28b1d32c4af098309f1427b4a2b2884..0000000000000000000000000000000000000000 --- a/Example/Example.xcodeproj/project.pbxproj +++ /dev/null @@ -1,344 +0,0 @@ -// !$*UTF8*$! -{ - archiveVersion = 1; - classes = { - }; - objectVersion = 55; - objects = { - -/* Begin PBXBuildFile section */ - 312C371E28475E63003E9E39 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 312C371D28475E63003E9E39 /* Assets.xcassets */; }; - 316D95EE28477B0E008475F9 /* AppFeature in Frameworks */ = {isa = PBXBuildFile; productRef = 316D95ED28477B0E008475F9 /* AppFeature */; }; -/* End PBXBuildFile section */ - -/* Begin PBXFileReference section */ - 312C371628475E62003E9E39 /* dApps Example.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "dApps Example.app"; sourceTree = BUILT_PRODUCTS_DIR; }; - 312C371D28475E63003E9E39 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; }; - 312C3728284761DC003E9E39 /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; }; - 316D95EB28477ACA008475F9 /* example-app */ = {isa = PBXFileReference; lastKnownFileType = wrapper; path = "example-app"; sourceTree = "<group>"; }; - 31B3342F2847669900865D82 /* example-app-icon */ = {isa = PBXFileReference; lastKnownFileType = wrapper; path = "example-app-icon"; sourceTree = "<group>"; }; -/* End PBXFileReference section */ - -/* Begin PBXFrameworksBuildPhase section */ - 312C371328475E62003E9E39 /* Frameworks */ = { - isa = PBXFrameworksBuildPhase; - buildActionMask = 2147483647; - files = ( - 316D95EE28477B0E008475F9 /* AppFeature in Frameworks */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; -/* End PBXFrameworksBuildPhase section */ - -/* Begin PBXGroup section */ - 312C370D28475E62003E9E39 = { - isa = PBXGroup; - children = ( - 312C3727284761C7003E9E39 /* ExampleApp (iOS) */, - 316D95EB28477ACA008475F9 /* example-app */, - 31B3342F2847669900865D82 /* example-app-icon */, - 312C371728475E62003E9E39 /* Products */, - ); - sourceTree = "<group>"; - }; - 312C371728475E62003E9E39 /* Products */ = { - isa = PBXGroup; - children = ( - 312C371628475E62003E9E39 /* dApps Example.app */, - ); - name = Products; - sourceTree = "<group>"; - }; - 312C3727284761C7003E9E39 /* ExampleApp (iOS) */ = { - isa = PBXGroup; - children = ( - 312C371D28475E63003E9E39 /* Assets.xcassets */, - 312C3728284761DC003E9E39 /* Info.plist */, - ); - path = "ExampleApp (iOS)"; - sourceTree = "<group>"; - }; -/* End PBXGroup section */ - -/* Begin PBXNativeTarget section */ - 312C371528475E62003E9E39 /* ExampleApp (iOS) */ = { - isa = PBXNativeTarget; - buildConfigurationList = 312C372428475E63003E9E39 /* Build configuration list for PBXNativeTarget "ExampleApp (iOS)" */; - buildPhases = ( - 312C371228475E62003E9E39 /* Sources */, - 312C371328475E62003E9E39 /* Frameworks */, - 312C371428475E62003E9E39 /* Resources */, - ); - buildRules = ( - ); - dependencies = ( - ); - name = "ExampleApp (iOS)"; - packageProductDependencies = ( - 316D95ED28477B0E008475F9 /* AppFeature */, - ); - productName = ExampleApp; - productReference = 312C371628475E62003E9E39 /* dApps Example.app */; - productType = "com.apple.product-type.application"; - }; -/* End PBXNativeTarget section */ - -/* Begin PBXProject section */ - 312C370E28475E62003E9E39 /* Project object */ = { - isa = PBXProject; - attributes = { - BuildIndependentTargetsInParallel = 1; - LastSwiftUpdateCheck = 1340; - LastUpgradeCheck = 1340; - TargetAttributes = { - 312C371528475E62003E9E39 = { - CreatedOnToolsVersion = 13.4; - }; - }; - }; - buildConfigurationList = 312C371128475E62003E9E39 /* Build configuration list for PBXProject "Example" */; - compatibilityVersion = "Xcode 13.0"; - developmentRegion = en; - hasScannedForEncodings = 0; - knownRegions = ( - en, - Base, - ); - mainGroup = 312C370D28475E62003E9E39; - productRefGroup = 312C371728475E62003E9E39 /* Products */; - projectDirPath = ""; - projectRoot = ""; - targets = ( - 312C371528475E62003E9E39 /* ExampleApp (iOS) */, - ); - }; -/* End PBXProject section */ - -/* Begin PBXResourcesBuildPhase section */ - 312C371428475E62003E9E39 /* Resources */ = { - isa = PBXResourcesBuildPhase; - buildActionMask = 2147483647; - files = ( - 312C371E28475E63003E9E39 /* Assets.xcassets in Resources */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; -/* End PBXResourcesBuildPhase section */ - -/* Begin PBXSourcesBuildPhase section */ - 312C371228475E62003E9E39 /* Sources */ = { - isa = PBXSourcesBuildPhase; - buildActionMask = 2147483647; - files = ( - ); - runOnlyForDeploymentPostprocessing = 0; - }; -/* End PBXSourcesBuildPhase section */ - -/* Begin XCBuildConfiguration section */ - 312C372228475E63003E9E39 /* Debug */ = { - isa = XCBuildConfiguration; - buildSettings = { - ALWAYS_SEARCH_USER_PATHS = NO; - CLANG_ANALYZER_NONNULL = YES; - CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; - CLANG_CXX_LANGUAGE_STANDARD = "gnu++17"; - CLANG_ENABLE_MODULES = YES; - CLANG_ENABLE_OBJC_ARC = YES; - CLANG_ENABLE_OBJC_WEAK = YES; - CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; - CLANG_WARN_BOOL_CONVERSION = YES; - CLANG_WARN_COMMA = YES; - CLANG_WARN_CONSTANT_CONVERSION = YES; - CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; - CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; - CLANG_WARN_DOCUMENTATION_COMMENTS = YES; - CLANG_WARN_EMPTY_BODY = YES; - CLANG_WARN_ENUM_CONVERSION = YES; - CLANG_WARN_INFINITE_RECURSION = YES; - CLANG_WARN_INT_CONVERSION = YES; - CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; - CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; - CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; - CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; - CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; - CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; - CLANG_WARN_STRICT_PROTOTYPES = YES; - CLANG_WARN_SUSPICIOUS_MOVE = YES; - CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; - CLANG_WARN_UNREACHABLE_CODE = YES; - CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; - COPY_PHASE_STRIP = NO; - DEBUG_INFORMATION_FORMAT = dwarf; - ENABLE_STRICT_OBJC_MSGSEND = YES; - ENABLE_TESTABILITY = YES; - GCC_C_LANGUAGE_STANDARD = gnu11; - GCC_DYNAMIC_NO_PIC = NO; - GCC_NO_COMMON_BLOCKS = YES; - GCC_OPTIMIZATION_LEVEL = 0; - GCC_PREPROCESSOR_DEFINITIONS = ( - "DEBUG=1", - "$(inherited)", - ); - GCC_WARN_64_TO_32_BIT_CONVERSION = YES; - GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; - GCC_WARN_UNDECLARED_SELECTOR = YES; - GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; - GCC_WARN_UNUSED_FUNCTION = YES; - GCC_WARN_UNUSED_VARIABLE = YES; - IPHONEOS_DEPLOYMENT_TARGET = 15.3; - MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE; - MTL_FAST_MATH = YES; - ONLY_ACTIVE_ARCH = YES; - SDKROOT = iphoneos; - SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG; - SWIFT_OPTIMIZATION_LEVEL = "-Onone"; - }; - name = Debug; - }; - 312C372328475E63003E9E39 /* Release */ = { - isa = XCBuildConfiguration; - buildSettings = { - ALWAYS_SEARCH_USER_PATHS = NO; - CLANG_ANALYZER_NONNULL = YES; - CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; - CLANG_CXX_LANGUAGE_STANDARD = "gnu++17"; - CLANG_ENABLE_MODULES = YES; - CLANG_ENABLE_OBJC_ARC = YES; - CLANG_ENABLE_OBJC_WEAK = YES; - CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; - CLANG_WARN_BOOL_CONVERSION = YES; - CLANG_WARN_COMMA = YES; - CLANG_WARN_CONSTANT_CONVERSION = YES; - CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; - CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; - CLANG_WARN_DOCUMENTATION_COMMENTS = YES; - CLANG_WARN_EMPTY_BODY = YES; - CLANG_WARN_ENUM_CONVERSION = YES; - CLANG_WARN_INFINITE_RECURSION = YES; - CLANG_WARN_INT_CONVERSION = YES; - CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; - CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; - CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; - CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; - CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; - CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; - CLANG_WARN_STRICT_PROTOTYPES = YES; - CLANG_WARN_SUSPICIOUS_MOVE = YES; - CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; - CLANG_WARN_UNREACHABLE_CODE = YES; - CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; - COPY_PHASE_STRIP = NO; - DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; - ENABLE_NS_ASSERTIONS = NO; - ENABLE_STRICT_OBJC_MSGSEND = YES; - GCC_C_LANGUAGE_STANDARD = gnu11; - GCC_NO_COMMON_BLOCKS = YES; - GCC_WARN_64_TO_32_BIT_CONVERSION = YES; - GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; - GCC_WARN_UNDECLARED_SELECTOR = YES; - GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; - GCC_WARN_UNUSED_FUNCTION = YES; - GCC_WARN_UNUSED_VARIABLE = YES; - IPHONEOS_DEPLOYMENT_TARGET = 15.3; - MTL_ENABLE_DEBUG_INFO = NO; - MTL_FAST_MATH = YES; - SDKROOT = iphoneos; - SWIFT_COMPILATION_MODE = wholemodule; - SWIFT_OPTIMIZATION_LEVEL = "-O"; - VALIDATE_PRODUCT = YES; - }; - name = Release; - }; - 312C372528475E63003E9E39 /* Debug */ = { - isa = XCBuildConfiguration; - buildSettings = { - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; - ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor; - CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 0; - ENABLE_PREVIEWS = YES; - GENERATE_INFOPLIST_FILE = YES; - INFOPLIST_FILE = "ExampleApp (iOS)/Info.plist"; - INFOPLIST_KEY_CFBundleDisplayName = "dApps Example"; - INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES; - INFOPLIST_KEY_UILaunchScreen_Generation = YES; - INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; - INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; - LD_RUNPATH_SEARCH_PATHS = ( - "$(inherited)", - "@executable_path/Frameworks", - ); - MARKETING_VERSION = 1.0.0; - PRODUCT_BUNDLE_IDENTIFIER = xx.network.dApps.ExampleApp; - PRODUCT_MODULE_NAME = ExampleApp; - PRODUCT_NAME = "dApps Example"; - SWIFT_EMIT_LOC_STRINGS = YES; - SWIFT_VERSION = 5.0; - TARGETED_DEVICE_FAMILY = "1,2"; - VERSIONING_SYSTEM = "apple-generic"; - }; - name = Debug; - }; - 312C372628475E63003E9E39 /* Release */ = { - isa = XCBuildConfiguration; - buildSettings = { - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; - ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor; - CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 0; - ENABLE_PREVIEWS = YES; - GENERATE_INFOPLIST_FILE = YES; - INFOPLIST_FILE = "ExampleApp (iOS)/Info.plist"; - INFOPLIST_KEY_CFBundleDisplayName = "dApps Example"; - INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES; - INFOPLIST_KEY_UILaunchScreen_Generation = YES; - INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; - INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; - LD_RUNPATH_SEARCH_PATHS = ( - "$(inherited)", - "@executable_path/Frameworks", - ); - MARKETING_VERSION = 1.0.0; - PRODUCT_BUNDLE_IDENTIFIER = xx.network.dApps.ExampleApp; - PRODUCT_MODULE_NAME = ExampleApp; - PRODUCT_NAME = "dApps Example"; - SWIFT_EMIT_LOC_STRINGS = YES; - SWIFT_VERSION = 5.0; - TARGETED_DEVICE_FAMILY = "1,2"; - VERSIONING_SYSTEM = "apple-generic"; - }; - name = Release; - }; -/* End XCBuildConfiguration section */ - -/* Begin XCConfigurationList section */ - 312C371128475E62003E9E39 /* Build configuration list for PBXProject "Example" */ = { - isa = XCConfigurationList; - buildConfigurations = ( - 312C372228475E63003E9E39 /* Debug */, - 312C372328475E63003E9E39 /* Release */, - ); - defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; - }; - 312C372428475E63003E9E39 /* Build configuration list for PBXNativeTarget "ExampleApp (iOS)" */ = { - isa = XCConfigurationList; - buildConfigurations = ( - 312C372528475E63003E9E39 /* Debug */, - 312C372628475E63003E9E39 /* Release */, - ); - defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; - }; -/* End XCConfigurationList section */ - -/* Begin XCSwiftPackageProductDependency section */ - 316D95ED28477B0E008475F9 /* AppFeature */ = { - isa = XCSwiftPackageProductDependency; - productName = AppFeature; - }; -/* End XCSwiftPackageProductDependency section */ - }; - rootObject = 312C370E28475E62003E9E39 /* Project object */; -} diff --git a/Example/Example.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/Example/Example.xcodeproj/project.xcworkspace/contents.xcworkspacedata deleted file mode 100644 index 919434a6254f0e9651f402737811be6634a03e9c..0000000000000000000000000000000000000000 --- a/Example/Example.xcodeproj/project.xcworkspace/contents.xcworkspacedata +++ /dev/null @@ -1,7 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<Workspace - version = "1.0"> - <FileRef - location = "self:"> - </FileRef> -</Workspace> diff --git a/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist deleted file mode 100644 index 18d981003d68d0546c4804ac2ff47dd97c6e7921..0000000000000000000000000000000000000000 --- a/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +++ /dev/null @@ -1,8 +0,0 @@ -<?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>IDEDidComputeMac32BitWarning</key> - <true/> -</dict> -</plist> diff --git a/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings b/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings deleted file mode 100644 index 08de0be8d3c8c1786ebe04545dd772526853eef4..0000000000000000000000000000000000000000 --- a/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings +++ /dev/null @@ -1,8 +0,0 @@ -<?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>IDEWorkspaceSharedSettings_AutocreateContextsIfNeeded</key> - <false/> -</dict> -</plist> diff --git a/Example/Example.xcodeproj/xcshareddata/xcschemes/ExampleApp (iOS).xcscheme b/Example/Example.xcodeproj/xcshareddata/xcschemes/ExampleApp (iOS).xcscheme deleted file mode 100644 index 6ae359a987e276d0151fecdeff0fc8854e31bea1..0000000000000000000000000000000000000000 --- a/Example/Example.xcodeproj/xcshareddata/xcschemes/ExampleApp (iOS).xcscheme +++ /dev/null @@ -1,119 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<Scheme - LastUpgradeVersion = "1340" - version = "1.3"> - <BuildAction - parallelizeBuildables = "YES" - buildImplicitDependencies = "YES"> - <BuildActionEntries> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "312C371528475E62003E9E39" - BuildableName = "dApps Example.app" - BlueprintName = "ExampleApp (iOS)" - ReferencedContainer = "container:Example.xcodeproj"> - </BuildableReference> - </BuildActionEntry> - </BuildActionEntries> - </BuildAction> - <TestAction - buildConfiguration = "Debug" - selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" - selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" - shouldUseLaunchSchemeArgsEnv = "YES" - codeCoverageEnabled = "YES"> - <Testables> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "AppFeatureTests" - BuildableName = "AppFeatureTests" - BlueprintName = "AppFeatureTests" - ReferencedContainer = "container:example-app"> - </BuildableReference> - </TestableReference> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "ErrorFeatureTests" - BuildableName = "ErrorFeatureTests" - BlueprintName = "ErrorFeatureTests" - ReferencedContainer = "container:example-app"> - </BuildableReference> - </TestableReference> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "LandingFeatureTests" - BuildableName = "LandingFeatureTests" - BlueprintName = "LandingFeatureTests" - ReferencedContainer = "container:example-app"> - </BuildableReference> - </TestableReference> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "SessionFeatureTests" - BuildableName = "SessionFeatureTests" - BlueprintName = "SessionFeatureTests" - ReferencedContainer = "container:example-app"> - </BuildableReference> - </TestableReference> - </Testables> - </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 = "312C371528475E62003E9E39" - BuildableName = "dApps Example.app" - BlueprintName = "ExampleApp (iOS)" - ReferencedContainer = "container:Example.xcodeproj"> - </BuildableReference> - </BuildableProductRunnable> - </LaunchAction> - <ProfileAction - buildConfiguration = "Release" - shouldUseLaunchSchemeArgsEnv = "YES" - savedToolIdentifier = "" - useCustomWorkingDirectory = "NO" - debugDocumentVersioning = "YES"> - <BuildableProductRunnable - runnableDebuggingMode = "0"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "312C371528475E62003E9E39" - BuildableName = "dApps Example.app" - BlueprintName = "ExampleApp (iOS)" - ReferencedContainer = "container:Example.xcodeproj"> - </BuildableReference> - </BuildableProductRunnable> - </ProfileAction> - <AnalyzeAction - buildConfiguration = "Debug"> - </AnalyzeAction> - <ArchiveAction - buildConfiguration = "Release" - revealArchiveInOrganizer = "YES"> - </ArchiveAction> -</Scheme> diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AccentColor.colorset/Contents.json b/Example/ExampleApp (iOS)/Assets.xcassets/AccentColor.colorset/Contents.json deleted file mode 100644 index eb8789700816459c1e1480e0b34781d9fb78a1ca..0000000000000000000000000000000000000000 --- a/Example/ExampleApp (iOS)/Assets.xcassets/AccentColor.colorset/Contents.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "colors" : [ - { - "idiom" : "universal" - } - ], - "info" : { - "author" : "xcode", - "version" : 1 - } -} diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/Contents.json b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/Contents.json deleted file mode 100644 index 84c0167b1a1045edaaee154e355e3d9362bb03c2..0000000000000000000000000000000000000000 --- a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/Contents.json +++ /dev/null @@ -1,116 +0,0 @@ -{ - "images" : [ - { - "filename" : "iPhone Notification 20pt 2x.png", - "idiom" : "iphone", - "scale" : "2x", - "size" : "20x20" - }, - { - "filename" : "iPhone Notification 20pt 3x.png", - "idiom" : "iphone", - "scale" : "3x", - "size" : "20x20" - }, - { - "filename" : "iPhone Settings 29pt 2x.png", - "idiom" : "iphone", - "scale" : "2x", - "size" : "29x29" - }, - { - "filename" : "iPhone Settings 29pt 3x.png", - "idiom" : "iphone", - "scale" : "3x", - "size" : "29x29" - }, - { - "filename" : "iPhone Spotlight 40pt 2x.png", - "idiom" : "iphone", - "scale" : "2x", - "size" : "40x40" - }, - { - "filename" : "iPhone Spotlight 40pt 3x.png", - "idiom" : "iphone", - "scale" : "3x", - "size" : "40x40" - }, - { - "filename" : "iPhone App 60pt 2x.png", - "idiom" : "iphone", - "scale" : "2x", - "size" : "60x60" - }, - { - "filename" : "iPhone App 60pt 3x.png", - "idiom" : "iphone", - "scale" : "3x", - "size" : "60x60" - }, - { - "filename" : "iPad Notification 20pt 1x.png", - "idiom" : "ipad", - "scale" : "1x", - "size" : "20x20" - }, - { - "filename" : "iPad Notification 20pt 2x.png", - "idiom" : "ipad", - "scale" : "2x", - "size" : "20x20" - }, - { - "filename" : "iPad Settings 29pt 1x.png", - "idiom" : "ipad", - "scale" : "1x", - "size" : "29x29" - }, - { - "filename" : "iPad Settings 29pt 2x.png", - "idiom" : "ipad", - "scale" : "2x", - "size" : "29x29" - }, - { - "filename" : "iPad Spotlight 40pt 1x.png", - "idiom" : "ipad", - "scale" : "1x", - "size" : "40x40" - }, - { - "filename" : "iPad Spotlight 40pt 2x.png", - "idiom" : "ipad", - "scale" : "2x", - "size" : "40x40" - }, - { - "filename" : "iPad App 76pt 1x.png", - "idiom" : "ipad", - "scale" : "1x", - "size" : "76x76" - }, - { - "filename" : "iPad App 76pt 2x.png", - "idiom" : "ipad", - "scale" : "2x", - "size" : "76x76" - }, - { - "filename" : "iPad Pro (12.9-inch) App 83.5pt 2x.png", - "idiom" : "ipad", - "scale" : "2x", - "size" : "83.5x83.5" - }, - { - "filename" : "iOS App Store 1024pt 1x.png", - "idiom" : "ios-marketing", - "scale" : "1x", - "size" : "1024x1024" - } - ], - "info" : { - "author" : "xcode", - "version" : 1 - } -} diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iOS App Store 1024pt 1x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iOS App Store 1024pt 1x.png deleted file mode 100644 index f74bafba9a74e2c0f9a075ef11c390612af07c69..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iOS App Store 1024pt 1x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 1x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 1x.png deleted file mode 100644 index 33755231d84723c6cfc3f823bad05eb5c8961ba2..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 1x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 2x.png deleted file mode 100644 index 2b5ae552b64790957d1a355d80eec642bf93d100..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 2x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 1x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 1x.png deleted file mode 100644 index ca9a346232d62f79579473062b9758afb7f8907f..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 1x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 2x.png deleted file mode 100644 index 4a5a33677bdedee2496d9f1bf25f34dc88b0a473..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 2x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Pro (12.9-inch) App 83.5pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Pro (12.9-inch) App 83.5pt 2x.png deleted file mode 100644 index 35bcfba03a28d1a7e50573e9e6438cce84e75363..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Pro (12.9-inch) App 83.5pt 2x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 1x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 1x.png deleted file mode 100644 index 907b2832c75cded4bca5e65ec9da25f3c04d572a..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 1x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 2x.png deleted file mode 100644 index 2aade831c23ada90101c8fc4cd8b07442a68fcb8..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 2x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 1x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 1x.png deleted file mode 100644 index 4a5a33677bdedee2496d9f1bf25f34dc88b0a473..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 1x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 2x.png deleted file mode 100644 index c35f34b4c2a4bea13a14c6901964057817ec0a0c..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 2x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 2x.png deleted file mode 100644 index 911a010e155c39f2a82f8dd2b472a2dfbcfa486e..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 2x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 3x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 3x.png deleted file mode 100644 index fc5a7a7ac44be361e8fb67318af7b3028630d2f0..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 3x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 2x.png deleted file mode 100644 index 4a5a33677bdedee2496d9f1bf25f34dc88b0a473..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 2x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 3x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 3x.png deleted file mode 100644 index 3561cb40fa8325368092ed54c78d8ebaa670d170..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 3x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 2x.png deleted file mode 100644 index 2aade831c23ada90101c8fc4cd8b07442a68fcb8..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 2x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 3x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 3x.png deleted file mode 100644 index 2719654ceaa888998261e08e89b94143165c1b50..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 3x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 2x.png deleted file mode 100644 index c35f34b4c2a4bea13a14c6901964057817ec0a0c..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 2x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 3x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 3x.png deleted file mode 100644 index 911a010e155c39f2a82f8dd2b472a2dfbcfa486e..0000000000000000000000000000000000000000 Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 3x.png and /dev/null differ diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/Contents.json b/Example/ExampleApp (iOS)/Assets.xcassets/Contents.json deleted file mode 100644 index 73c00596a7fca3f3d4bdd64053b69d86745f9e10..0000000000000000000000000000000000000000 --- a/Example/ExampleApp (iOS)/Assets.xcassets/Contents.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "info" : { - "author" : "xcode", - "version" : 1 - } -} diff --git a/Example/ExampleApp (iOS)/Info.plist b/Example/ExampleApp (iOS)/Info.plist deleted file mode 100644 index 669a5ca760ffe22bd5f4fec92e67939fa64476af..0000000000000000000000000000000000000000 --- a/Example/ExampleApp (iOS)/Info.plist +++ /dev/null @@ -1,13 +0,0 @@ -<?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>ITSAppUsesNonExemptEncryption</key> - <false/> - <key>UIApplicationSceneManifest</key> - <dict> - <key>UIApplicationSupportsMultipleScenes</key> - <false/> - </dict> -</dict> -</plist> diff --git a/Example/Package.swift b/Example/Package.swift deleted file mode 100644 index d0a31fe81dd861a3d33bf4eaeb4f59fb7c9f4947..0000000000000000000000000000000000000000 --- a/Example/Package.swift +++ /dev/null @@ -1,4 +0,0 @@ -// swift-tools-version:5.6 -// This file makes Xcode doesn't display this directory inside swift package. -import PackageDescription -let package = Package(name: "", products: [], targets: []) diff --git a/Example/example-app-icon/.gitignore b/Example/example-app-icon/.gitignore deleted file mode 100644 index 3b29812086f28a2b21884e57ead495ffd9434178..0000000000000000000000000000000000000000 --- a/Example/example-app-icon/.gitignore +++ /dev/null @@ -1,9 +0,0 @@ -.DS_Store -/.build -/Packages -/*.xcodeproj -xcuserdata/ -DerivedData/ -.swiftpm/config/registries.json -.swiftpm/xcode/package.xcworkspace/contents.xcworkspacedata -.netrc diff --git a/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/ExampleAppIcon.xcscheme b/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/ExampleAppIcon.xcscheme deleted file mode 100644 index 577a588463331de08076d97e67d30ddfa7eb6e70..0000000000000000000000000000000000000000 --- a/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/ExampleAppIcon.xcscheme +++ /dev/null @@ -1,67 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<Scheme - LastUpgradeVersion = "1330" - version = "1.3"> - <BuildAction - parallelizeBuildables = "YES" - buildImplicitDependencies = "YES"> - <BuildActionEntries> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "ExampleAppIcon" - BuildableName = "ExampleAppIcon" - BlueprintName = "ExampleAppIcon" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - </BuildActionEntries> - </BuildAction> - <TestAction - buildConfiguration = "Debug" - selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" - selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" - shouldUseLaunchSchemeArgsEnv = "YES"> - <Testables> - </Testables> - </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"> - </LaunchAction> - <ProfileAction - buildConfiguration = "Release" - shouldUseLaunchSchemeArgsEnv = "YES" - savedToolIdentifier = "" - useCustomWorkingDirectory = "NO" - debugDocumentVersioning = "YES"> - <MacroExpansion> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "ExampleAppIcon" - BuildableName = "ExampleAppIcon" - BlueprintName = "ExampleAppIcon" - ReferencedContainer = "container:"> - </BuildableReference> - </MacroExpansion> - </ProfileAction> - <AnalyzeAction - buildConfiguration = "Debug"> - </AnalyzeAction> - <ArchiveAction - buildConfiguration = "Release" - revealArchiveInOrganizer = "YES"> - </ArchiveAction> -</Scheme> diff --git a/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/example-app-icon-export.xcscheme b/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/example-app-icon-export.xcscheme deleted file mode 100644 index e903b8e44600283e207b4b588d9799cbd1a78f8e..0000000000000000000000000000000000000000 --- a/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/example-app-icon-export.xcscheme +++ /dev/null @@ -1,78 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<Scheme - LastUpgradeVersion = "1330" - version = "1.3"> - <BuildAction - parallelizeBuildables = "YES" - buildImplicitDependencies = "YES"> - <BuildActionEntries> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "example-app-icon-export" - BuildableName = "example-app-icon-export" - BlueprintName = "example-app-icon-export" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - </BuildActionEntries> - </BuildAction> - <TestAction - buildConfiguration = "Debug" - selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" - selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" - shouldUseLaunchSchemeArgsEnv = "YES"> - <Testables> - </Testables> - </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 = "example-app-icon-export" - BuildableName = "example-app-icon-export" - BlueprintName = "example-app-icon-export" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildableProductRunnable> - </LaunchAction> - <ProfileAction - buildConfiguration = "Release" - shouldUseLaunchSchemeArgsEnv = "YES" - savedToolIdentifier = "" - useCustomWorkingDirectory = "NO" - debugDocumentVersioning = "YES"> - <BuildableProductRunnable - runnableDebuggingMode = "0"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "example-app-icon-export" - BuildableName = "example-app-icon-export" - BlueprintName = "example-app-icon-export" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildableProductRunnable> - </ProfileAction> - <AnalyzeAction - buildConfiguration = "Debug"> - </AnalyzeAction> - <ArchiveAction - buildConfiguration = "Release" - revealArchiveInOrganizer = "YES"> - </ArchiveAction> -</Scheme> diff --git a/Example/example-app-icon/Package.swift b/Example/example-app-icon/Package.swift deleted file mode 100644 index d7a9c8bdd343f98a34609faa7f18f473c534833f..0000000000000000000000000000000000000000 --- a/Example/example-app-icon/Package.swift +++ /dev/null @@ -1,42 +0,0 @@ -// swift-tools-version: 5.6 -import PackageDescription - -let package = Package( - name: "example-app-icon", - platforms: [ - .macOS(.v12), - ], - products: [ - .library( - name: "ExampleAppIcon", - targets: ["ExampleAppIcon"] - ), - .executable( - name: "example-app-icon-export", - targets: ["ExampleAppIconExport"] - ), - ], - dependencies: [ - .package( - url: "https://github.com/darrarski/swiftui-app-icon-creator.git", - .upToNextMajor(from: "1.2.0") - ), - ], - targets: [ - .target( - name: "ExampleAppIcon", - dependencies: [ - .product( - name: "AppIconCreator", - package: "swiftui-app-icon-creator" - ), - ] - ), - .executableTarget( - name: "ExampleAppIconExport", - dependencies: [ - .target(name: "ExampleAppIcon"), - ] - ) - ] -) diff --git a/Example/example-app-icon/Sources/ExampleAppIcon/ExampleAppIcon.swift b/Example/example-app-icon/Sources/ExampleAppIcon/ExampleAppIcon.swift deleted file mode 100644 index 0c24ca0094213d7c58dc5b02361b6bc45cbf96a1..0000000000000000000000000000000000000000 --- a/Example/example-app-icon/Sources/ExampleAppIcon/ExampleAppIcon.swift +++ /dev/null @@ -1,73 +0,0 @@ -import SwiftUI -import AppIconCreator - -public struct ExampleAppIconView: View { - public init() {} - - public var body: some View { - GeometryReader { geometry in - ZStack { - Image(systemName: "cube.transparent") - .resizable() - .scaledToFit() - .foregroundColor(.black.opacity(0.2)) - .padding(geometry.size.width * 0.1) - .mask( - ZStack { - Rectangle() - - Image(systemName: "cube") - .resizable() - .scaledToFit() - .blendMode(.destinationOut) - .padding(geometry.size.width * 0.1) - - Circle() - .blendMode(.destinationOut) - .padding(geometry.size.width * 0.24) - } - ) - - Circle() - .fill(.black.opacity(0.3)) - .padding(geometry.size.width * 0.3) - .mask { - ZStack { - Rectangle() - Image(systemName: "cube") - .resizable() - .scaledToFit() - .blendMode(.destinationOut) - .padding(geometry.size.width * 0.1) - } - } - - Image(systemName: "cube") - .resizable() - .scaledToFit() - .foregroundColor(.black.opacity(0.5)) - .padding(geometry.size.width * 0.1) - } - .frame(maxWidth: .infinity, maxHeight: .infinity) - .background { - LinearGradient( - gradient: Gradient(colors: [ - Color(cgColor: CGColor(red: 0.49, green: 0.94, blue: 0.94, alpha: 1)), - Color(cgColor: CGColor(red: 0.16, green: 0.81, blue: 0.86, alpha: 1)), - ]), - startPoint: .top, - endPoint: .bottom - ) - } - } - } -} - -struct ExampleAppIconView_Previews: PreviewProvider { - static var previews: some View { - IconPreviews( - icon: ExampleAppIconView(), - configs: .iOS - ) - } -} diff --git a/Example/example-app-icon/Sources/ExampleAppIconExport/main.swift b/Example/example-app-icon/Sources/ExampleAppIconExport/main.swift deleted file mode 100644 index 87afce21a46c6c01c1d08dc08cfeed6cd11cfb87..0000000000000000000000000000000000000000 --- a/Example/example-app-icon/Sources/ExampleAppIconExport/main.swift +++ /dev/null @@ -1,24 +0,0 @@ -import AppIconCreator -import ExampleAppIcon -import Foundation - -extension URL { - func deletingLastPathComponent() -> URL { - var url = self - url.deleteLastPathComponent() - return url - } -} - -let exportURL = URL(fileURLWithPath: #file) - .deletingLastPathComponent() - .deletingLastPathComponent() - .deletingLastPathComponent() - .deletingLastPathComponent() - .appendingPathComponent("ExampleApp (iOS)") - .appendingPathComponent("Assets.xcassets") - .appendingPathComponent("AppIcon.appiconset") - -[IconImage] - .images(for: ExampleAppIconView(), with: .iOS) - .forEach { $0.save(to: exportURL) } diff --git a/Example/example-app/.gitignore b/Example/example-app/.gitignore deleted file mode 100644 index 3b29812086f28a2b21884e57ead495ffd9434178..0000000000000000000000000000000000000000 --- a/Example/example-app/.gitignore +++ /dev/null @@ -1,9 +0,0 @@ -.DS_Store -/.build -/Packages -/*.xcodeproj -xcuserdata/ -DerivedData/ -.swiftpm/config/registries.json -.swiftpm/xcode/package.xcworkspace/contents.xcworkspacedata -.netrc diff --git a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/AppFeature.xcscheme b/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/AppFeature.xcscheme deleted file mode 100644 index 076cfa82379a4f3c57008017aa6f356892754cc9..0000000000000000000000000000000000000000 --- a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/AppFeature.xcscheme +++ /dev/null @@ -1,78 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<Scheme - LastUpgradeVersion = "1340" - version = "1.3"> - <BuildAction - parallelizeBuildables = "YES" - buildImplicitDependencies = "YES"> - <BuildActionEntries> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "AppFeature" - BuildableName = "AppFeature" - BlueprintName = "AppFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - </BuildActionEntries> - </BuildAction> - <TestAction - buildConfiguration = "Debug" - selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" - selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" - shouldUseLaunchSchemeArgsEnv = "YES" - codeCoverageEnabled = "YES"> - <Testables> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "AppFeatureTests" - BuildableName = "AppFeatureTests" - BlueprintName = "AppFeatureTests" - ReferencedContainer = "container:"> - </BuildableReference> - </TestableReference> - </Testables> - </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"> - </LaunchAction> - <ProfileAction - buildConfiguration = "Release" - shouldUseLaunchSchemeArgsEnv = "YES" - savedToolIdentifier = "" - useCustomWorkingDirectory = "NO" - debugDocumentVersioning = "YES"> - <MacroExpansion> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "AppFeature" - BuildableName = "AppFeature" - BlueprintName = "AppFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </MacroExpansion> - </ProfileAction> - <AnalyzeAction - buildConfiguration = "Debug"> - </AnalyzeAction> - <ArchiveAction - buildConfiguration = "Release" - revealArchiveInOrganizer = "YES"> - </ArchiveAction> -</Scheme> diff --git a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/ErrorFeature.xcscheme b/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/ErrorFeature.xcscheme deleted file mode 100644 index 95ae136eb336e7590ebc8e1d791912f4c0393a84..0000000000000000000000000000000000000000 --- a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/ErrorFeature.xcscheme +++ /dev/null @@ -1,78 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<Scheme - LastUpgradeVersion = "1340" - version = "1.3"> - <BuildAction - parallelizeBuildables = "YES" - buildImplicitDependencies = "YES"> - <BuildActionEntries> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "ErrorFeature" - BuildableName = "ErrorFeature" - BlueprintName = "ErrorFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - </BuildActionEntries> - </BuildAction> - <TestAction - buildConfiguration = "Debug" - selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" - selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" - shouldUseLaunchSchemeArgsEnv = "YES" - codeCoverageEnabled = "YES"> - <Testables> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "ErrorFeatureTests" - BuildableName = "ErrorFeatureTests" - BlueprintName = "ErrorFeatureTests" - ReferencedContainer = "container:"> - </BuildableReference> - </TestableReference> - </Testables> - </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"> - </LaunchAction> - <ProfileAction - buildConfiguration = "Release" - shouldUseLaunchSchemeArgsEnv = "YES" - savedToolIdentifier = "" - useCustomWorkingDirectory = "NO" - debugDocumentVersioning = "YES"> - <MacroExpansion> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "ErrorFeature" - BuildableName = "ErrorFeature" - BlueprintName = "ErrorFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </MacroExpansion> - </ProfileAction> - <AnalyzeAction - buildConfiguration = "Debug"> - </AnalyzeAction> - <ArchiveAction - buildConfiguration = "Release" - revealArchiveInOrganizer = "YES"> - </ArchiveAction> -</Scheme> diff --git a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/LandingFeature.xcscheme b/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/LandingFeature.xcscheme deleted file mode 100644 index 7d203fde1b21e22854fa66dfc0b2f4253280f862..0000000000000000000000000000000000000000 --- a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/LandingFeature.xcscheme +++ /dev/null @@ -1,78 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<Scheme - LastUpgradeVersion = "1340" - version = "1.3"> - <BuildAction - parallelizeBuildables = "YES" - buildImplicitDependencies = "YES"> - <BuildActionEntries> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "LandingFeature" - BuildableName = "LandingFeature" - BlueprintName = "LandingFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - </BuildActionEntries> - </BuildAction> - <TestAction - buildConfiguration = "Debug" - selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" - selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" - shouldUseLaunchSchemeArgsEnv = "YES" - codeCoverageEnabled = "YES"> - <Testables> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "LandingFeatureTests" - BuildableName = "LandingFeatureTests" - BlueprintName = "LandingFeatureTests" - ReferencedContainer = "container:"> - </BuildableReference> - </TestableReference> - </Testables> - </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"> - </LaunchAction> - <ProfileAction - buildConfiguration = "Release" - shouldUseLaunchSchemeArgsEnv = "YES" - savedToolIdentifier = "" - useCustomWorkingDirectory = "NO" - debugDocumentVersioning = "YES"> - <MacroExpansion> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "LandingFeature" - BuildableName = "LandingFeature" - BlueprintName = "LandingFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </MacroExpansion> - </ProfileAction> - <AnalyzeAction - buildConfiguration = "Debug"> - </AnalyzeAction> - <ArchiveAction - buildConfiguration = "Release" - revealArchiveInOrganizer = "YES"> - </ArchiveAction> -</Scheme> diff --git a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/SessionFeature.xcscheme b/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/SessionFeature.xcscheme deleted file mode 100644 index 9361c5551eb399da5f095ac23edd410d6b284503..0000000000000000000000000000000000000000 --- a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/SessionFeature.xcscheme +++ /dev/null @@ -1,78 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<Scheme - LastUpgradeVersion = "1340" - version = "1.3"> - <BuildAction - parallelizeBuildables = "YES" - buildImplicitDependencies = "YES"> - <BuildActionEntries> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "SessionFeature" - BuildableName = "SessionFeature" - BlueprintName = "SessionFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - </BuildActionEntries> - </BuildAction> - <TestAction - buildConfiguration = "Debug" - selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" - selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" - shouldUseLaunchSchemeArgsEnv = "YES" - codeCoverageEnabled = "YES"> - <Testables> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "SessionFeatureTests" - BuildableName = "SessionFeatureTests" - BlueprintName = "SessionFeatureTests" - ReferencedContainer = "container:"> - </BuildableReference> - </TestableReference> - </Testables> - </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"> - </LaunchAction> - <ProfileAction - buildConfiguration = "Release" - shouldUseLaunchSchemeArgsEnv = "YES" - savedToolIdentifier = "" - useCustomWorkingDirectory = "NO" - debugDocumentVersioning = "YES"> - <MacroExpansion> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "SessionFeature" - BuildableName = "SessionFeature" - BlueprintName = "SessionFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </MacroExpansion> - </ProfileAction> - <AnalyzeAction - buildConfiguration = "Debug"> - </AnalyzeAction> - <ArchiveAction - buildConfiguration = "Release" - revealArchiveInOrganizer = "YES"> - </ArchiveAction> -</Scheme> diff --git a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/example-app.xcscheme b/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/example-app.xcscheme deleted file mode 100644 index c6edd5dda410050c40e6df64bd48b668c357afde..0000000000000000000000000000000000000000 --- a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/example-app.xcscheme +++ /dev/null @@ -1,198 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<Scheme - LastUpgradeVersion = "1340" - version = "1.3"> - <BuildAction - parallelizeBuildables = "YES" - buildImplicitDependencies = "YES"> - <BuildActionEntries> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "AppFeature" - BuildableName = "AppFeature" - BlueprintName = "AppFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "ErrorFeature" - BuildableName = "ErrorFeature" - BlueprintName = "ErrorFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "LandingFeature" - BuildableName = "LandingFeature" - BlueprintName = "LandingFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "MyContactFeature" - BuildableName = "MyContactFeature" - BlueprintName = "MyContactFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "MyIdentityFeature" - BuildableName = "MyIdentityFeature" - BlueprintName = "MyIdentityFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - <BuildActionEntry - buildForTesting = "YES" - buildForRunning = "YES" - buildForProfiling = "YES" - buildForArchiving = "YES" - buildForAnalyzing = "YES"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "SessionFeature" - BuildableName = "SessionFeature" - BlueprintName = "SessionFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </BuildActionEntry> - </BuildActionEntries> - </BuildAction> - <TestAction - buildConfiguration = "Debug" - selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" - selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" - shouldUseLaunchSchemeArgsEnv = "YES" - codeCoverageEnabled = "YES"> - <Testables> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "AppFeatureTests" - BuildableName = "AppFeatureTests" - BlueprintName = "AppFeatureTests" - ReferencedContainer = "container:"> - </BuildableReference> - </TestableReference> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "ErrorFeatureTests" - BuildableName = "ErrorFeatureTests" - BlueprintName = "ErrorFeatureTests" - ReferencedContainer = "container:"> - </BuildableReference> - </TestableReference> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "LandingFeatureTests" - BuildableName = "LandingFeatureTests" - BlueprintName = "LandingFeatureTests" - ReferencedContainer = "container:"> - </BuildableReference> - </TestableReference> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "MyContactFeatureTests" - BuildableName = "MyContactFeatureTests" - BlueprintName = "MyContactFeatureTests" - ReferencedContainer = "container:"> - </BuildableReference> - </TestableReference> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "MyIdentityFeatureTests" - BuildableName = "MyIdentityFeatureTests" - BlueprintName = "MyIdentityFeatureTests" - ReferencedContainer = "container:"> - </BuildableReference> - </TestableReference> - <TestableReference - skipped = "NO"> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "SessionFeatureTests" - BuildableName = "SessionFeatureTests" - BlueprintName = "SessionFeatureTests" - ReferencedContainer = "container:"> - </BuildableReference> - </TestableReference> - </Testables> - </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"> - </LaunchAction> - <ProfileAction - buildConfiguration = "Release" - shouldUseLaunchSchemeArgsEnv = "YES" - savedToolIdentifier = "" - useCustomWorkingDirectory = "NO" - debugDocumentVersioning = "YES"> - <MacroExpansion> - <BuildableReference - BuildableIdentifier = "primary" - BlueprintIdentifier = "AppFeature" - BuildableName = "AppFeature" - BlueprintName = "AppFeature" - ReferencedContainer = "container:"> - </BuildableReference> - </MacroExpansion> - </ProfileAction> - <AnalyzeAction - buildConfiguration = "Debug"> - </AnalyzeAction> - <ArchiveAction - buildConfiguration = "Release" - revealArchiveInOrganizer = "YES"> - </ArchiveAction> -</Scheme> diff --git a/Example/example-app/Package.swift b/Example/example-app/Package.swift deleted file mode 100644 index ec68a31a650f1ce9d1e4fc5a0282894c9e61a5b7..0000000000000000000000000000000000000000 --- a/Example/example-app/Package.swift +++ /dev/null @@ -1,121 +0,0 @@ -// swift-tools-version: 5.6 -import PackageDescription - -let swiftSettings: [SwiftSetting] = [ - .unsafeFlags( - [ - "-Xfrontend", "-debug-time-function-bodies", - "-Xfrontend", "-debug-time-expression-type-checking", - ], - .when(configuration: .debug) - ), -] - -let package = Package( - name: "example-app", - platforms: [ - .iOS(.v15), - ], - products: [ - .library(name: "AppFeature", targets: ["AppFeature"]), - .library(name: "ErrorFeature", targets: ["ErrorFeature"]), - .library(name: "LandingFeature", targets: ["LandingFeature"]), - .library(name: "SessionFeature", targets: ["SessionFeature"]), - ], - dependencies: [ - .package( - path: "../../" - ), - .package( - url: "https://github.com/pointfreeco/swift-composable-architecture.git", - .upToNextMajor(from: "0.39.0") - ), - .package( - url: "https://github.com/darrarski/swift-composable-presentation.git", - .upToNextMajor(from: "0.5.2") - ), - .package( - url: "https://github.com/kishikawakatsumi/KeychainAccess.git", - .upToNextMajor(from: "4.2.2") - ), - .package( - url: "https://github.com/pointfreeco/xctest-dynamic-overlay.git", - .upToNextMajor(from: "0.4.0") - ), - ], - targets: [ - .target( - name: "AppFeature", - dependencies: [ - .target(name: "ErrorFeature"), - .target(name: "LandingFeature"), - .target(name: "SessionFeature"), - .product(name: "ComposableArchitecture", package: "swift-composable-architecture"), - .product(name: "ComposablePresentation", package: "swift-composable-presentation"), - .product(name: "KeychainAccess", package: "KeychainAccess"), - .product(name: "XCTestDynamicOverlay", package: "xctest-dynamic-overlay"), - .product(name: "XXClient", package: "elixxir-dapps-sdk-swift"), - ], - swiftSettings: swiftSettings - ), - .testTarget( - name: "AppFeatureTests", - dependencies: [ - .target(name: "AppFeature"), - ], - swiftSettings: swiftSettings - ), - .target( - name: "ErrorFeature", - dependencies: [ - .product(name: "ComposableArchitecture", package: "swift-composable-architecture"), - .product(name: "XCTestDynamicOverlay", package: "xctest-dynamic-overlay"), - .product(name: "XXClient", package: "elixxir-dapps-sdk-swift"), - ], - swiftSettings: swiftSettings - ), - .testTarget( - name: "ErrorFeatureTests", - dependencies: [ - .target(name: "ErrorFeature"), - ], - swiftSettings: swiftSettings - ), - .target( - name: "LandingFeature", - dependencies: [ - .target(name: "ErrorFeature"), - .product(name: "ComposableArchitecture", package: "swift-composable-architecture"), - .product(name: "ComposablePresentation", package: "swift-composable-presentation"), - .product(name: "XCTestDynamicOverlay", package: "xctest-dynamic-overlay"), - .product(name: "XXClient", package: "elixxir-dapps-sdk-swift"), - ], - swiftSettings: swiftSettings - ), - .testTarget( - name: "LandingFeatureTests", - dependencies: [ - .target(name: "LandingFeature"), - ], - swiftSettings: swiftSettings - ), - .target( - name: "SessionFeature", - dependencies: [ - .target(name: "ErrorFeature"), - .product(name: "ComposableArchitecture", package: "swift-composable-architecture"), - .product(name: "ComposablePresentation", package: "swift-composable-presentation"), - .product(name: "XCTestDynamicOverlay", package: "xctest-dynamic-overlay"), - .product(name: "XXClient", package: "elixxir-dapps-sdk-swift"), - ], - swiftSettings: swiftSettings - ), - .testTarget( - name: "SessionFeatureTests", - dependencies: [ - .target(name: "SessionFeature"), - ], - swiftSettings: swiftSettings - ), - ] -) diff --git a/Example/example-app/Sources/AppFeature/App.swift b/Example/example-app/Sources/AppFeature/App.swift deleted file mode 100644 index c1fa59417c089cbf3e9371ced8a3bb80225f0b37..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/AppFeature/App.swift +++ /dev/null @@ -1,52 +0,0 @@ -import Combine -import ComposableArchitecture -import ErrorFeature -import LandingFeature -import SessionFeature -import SwiftUI -import XXClient - -@main -struct App: SwiftUI.App { - var body: some Scene { - WindowGroup { - AppView(store: Store( - initialState: AppState(), - reducer: appReducer, - environment: .live() - )) - } - } -} - -extension AppEnvironment { - static func live() -> AppEnvironment { - let cMixSubject = CurrentValueSubject<CMix?, Never>(nil) - let mainScheduler = DispatchQueue.main.eraseToAnyScheduler() - let bgScheduler = DispatchQueue( - label: "xx.network.dApps.ExampleApp.bg", - qos: .background - ).eraseToAnyScheduler() - - return AppEnvironment( - makeId: UUID.init, - hasCMix: { cMixSubject.map { $0 != nil }.eraseToAnyPublisher() }, - mainScheduler: mainScheduler, - landing: LandingEnvironment( - cMixManager: .live( - passwordStorage: .keychain - ), - setCMix: { cMixSubject.value = $0 }, - bgScheduler: bgScheduler, - mainScheduler: mainScheduler, - error: ErrorEnvironment() - ), - session: SessionEnvironment( - getCMix: { cMixSubject.value }, - bgScheduler: bgScheduler, - mainScheduler: mainScheduler, - error: ErrorEnvironment() - ) - ) - } -} diff --git a/Example/example-app/Sources/AppFeature/AppFeature.swift b/Example/example-app/Sources/AppFeature/AppFeature.swift deleted file mode 100644 index cc871972d695b8e0f35d56ba3d9b8d4d94d12a1e..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/AppFeature/AppFeature.swift +++ /dev/null @@ -1,107 +0,0 @@ -import Combine -import ComposableArchitecture -import ComposablePresentation -import LandingFeature -import SessionFeature -import XCTestDynamicOverlay - -struct AppState: Equatable { - enum Scene: Equatable { - case landing(LandingState) - case session(SessionState) - } - - var id: UUID = UUID() - var scene: Scene = .landing(LandingState(id: UUID())) -} - -extension AppState.Scene { - var asLanding: LandingState? { - get { - guard case .landing(let state) = self else { return nil } - return state - } - set { - guard let newValue = newValue else { return } - self = .landing(newValue) - } - } - - var asSession: SessionState? { - get { - guard case .session(let state) = self else { return nil } - return state - } - set { - guard let newValue = newValue else { return } - self = .session(newValue) - } - } -} - -enum AppAction: Equatable { - case viewDidLoad - case cMixDidChange(hasCMix: Bool) - case landing(LandingAction) - case session(SessionAction) -} - -struct AppEnvironment { - var makeId: () -> UUID - var hasCMix: () -> AnyPublisher<Bool, Never> - var mainScheduler: AnySchedulerOf<DispatchQueue> - var landing: LandingEnvironment - var session: SessionEnvironment -} - -let appReducer = Reducer<AppState, AppAction, AppEnvironment> -{ state, action, env in - enum HasCMixEffectId {} - - switch action { - case .viewDidLoad: - return env.hasCMix() - .removeDuplicates() - .map(AppAction.cMixDidChange(hasCMix:)) - .receive(on: env.mainScheduler) - .eraseToEffect() - .cancellable(id: HasCMixEffectId.self, cancelInFlight: true) - - case .cMixDidChange(let hasClient): - if hasClient { - let sessionState = state.scene.asSession ?? SessionState(id: env.makeId()) - state.scene = .session(sessionState) - } else { - let landingState = state.scene.asLanding ?? LandingState(id: env.makeId()) - state.scene = .landing(landingState) - } - return .none - - case .landing(_), .session(_): - return .none - } -} -.presenting( - landingReducer, - state: .keyPath(\.scene.asLanding), - id: .notNil(), - action: /AppAction.landing, - environment: \.landing -) -.presenting( - sessionReducer, - state: .keyPath(\.scene.asSession), - id: .notNil(), - action: /AppAction.session, - environment: \.session -) - -extension AppEnvironment { - static let unimplemented = AppEnvironment( - makeId: XCTUnimplemented("\(Self.self).makeId", placeholder: UUID()), - hasCMix: XCTUnimplemented("\(Self.self).hasCMix", placeholder: Empty().eraseToAnyPublisher()), - mainScheduler: .unimplemented, - landing: .unimplemented, - session: .unimplemented - ) -} diff --git a/Example/example-app/Sources/AppFeature/AppView.swift b/Example/example-app/Sources/AppFeature/AppView.swift deleted file mode 100644 index bf7bcd3d7718f938986b9d1401ef96231a212720..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/AppFeature/AppView.swift +++ /dev/null @@ -1,82 +0,0 @@ -import ComposableArchitecture -import LandingFeature -import SessionFeature -import SwiftUI - -struct AppView: View { - let store: Store<AppState, AppAction> - - struct ViewState: Equatable { - enum Scene: Equatable { - case landing - case session - } - - let scene: Scene - - init(state: AppState) { - switch state.scene { - case .landing(_): - self.scene = .landing - - case .session(_): - self.scene = .session - } - } - } - - var body: some View { - WithViewStore(store.scope(state: ViewState.init)) { viewStore in - ZStack { - SwitchStore(store.scope(state: \.scene)) { - CaseLet( - state: /AppState.Scene.landing, - action: AppAction.landing, - then: { store in - NavigationView { - LandingView(store: store) - } - .navigationViewStyle(.stack) - .transition(.asymmetric( - insertion: .move(edge: .leading), - removal: .opacity - )) - } - ) - - CaseLet( - state: /AppState.Scene.session, - action: AppAction.session, - then: { store in - NavigationView { - SessionView(store: store) - } - .navigationViewStyle(.stack) - .transition(.asymmetric( - insertion: .move(edge: .trailing), - removal: .opacity - )) - } - ) - } - .frame(maxWidth: .infinity, maxHeight: .infinity) - } - .animation(.default, value: viewStore.scene) - .task { - viewStore.send(.viewDidLoad) - } - } - } -} - -#if DEBUG -struct AppView_Previews: PreviewProvider { - static var previews: some View { - AppView(store: Store( - initialState: AppState(), - reducer: .empty, - environment: () - )) - } -} -#endif diff --git a/Example/example-app/Sources/AppFeature/PasswordStorage+Keychain.swift b/Example/example-app/Sources/AppFeature/PasswordStorage+Keychain.swift deleted file mode 100644 index 1b1a26de96c3fc947daf479a4d7eb528754aeada..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/AppFeature/PasswordStorage+Keychain.swift +++ /dev/null @@ -1,14 +0,0 @@ -import KeychainAccess -import XXClient - -extension PasswordStorage { - static let keychain: PasswordStorage = { - let keychain = KeychainAccess.Keychain( - service: "xx.network.dApps.ExampleApp" - ) - return PasswordStorage( - save: { password in keychain[data: "password"] = password}, - load: { try keychain[data: "password"] ?? { throw MissingPasswordError() }() } - ) - }() -} diff --git a/Example/example-app/Sources/ErrorFeature/ErrorFeature.swift b/Example/example-app/Sources/ErrorFeature/ErrorFeature.swift deleted file mode 100644 index eb1671e8424a7db0ee5ccb12c8fef9289d1277da..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/ErrorFeature/ErrorFeature.swift +++ /dev/null @@ -1,22 +0,0 @@ -import ComposableArchitecture -import XCTestDynamicOverlay - -public struct ErrorState: Equatable { - public init(error: NSError) { - self.error = error - } - - public var error: NSError -} - -public enum ErrorAction: Equatable {} - -public struct ErrorEnvironment { - public init() {} -} - -public let errorReducer = Reducer<ErrorState, ErrorAction, ErrorEnvironment>.empty - -extension ErrorEnvironment { - public static let unimplemented = ErrorEnvironment() -} diff --git a/Example/example-app/Sources/ErrorFeature/ErrorView.swift b/Example/example-app/Sources/ErrorFeature/ErrorView.swift deleted file mode 100644 index 35d9b84785a2906d677008ea64440a4952f84654..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/ErrorFeature/ErrorView.swift +++ /dev/null @@ -1,53 +0,0 @@ -import ComposableArchitecture -import SwiftUI - -public struct ErrorView: View { - public init(store: Store<ErrorState, ErrorAction>) { - self.store = store - } - - let store: Store<ErrorState, ErrorAction> - @Environment(\.dismiss) var dismiss - - struct ViewState: Equatable { - let error: NSError - - init(state: ErrorState) { - error = state.error - } - } - - public var body: some View { - WithViewStore(store.scope(state: ViewState.init)) { viewStore in - NavigationView { - Form { - Text("\(viewStore.error)") - } - .navigationTitle("Error") - .toolbar { - ToolbarItem(placement: .cancellationAction) { - Button { - dismiss() - } label: { - Image(systemName: "xmark") - } - } - } - } - } - } -} - -#if DEBUG -public struct ErrorView_Previews: PreviewProvider { - public static var previews: some View { - ErrorView(store: .init( - initialState: .init( - error: NSError(domain: "preview", code: 1234) - ), - reducer: .empty, - environment: () - )) - } -} -#endif diff --git a/Example/example-app/Sources/LandingFeature/LandingFeature.swift b/Example/example-app/Sources/LandingFeature/LandingFeature.swift deleted file mode 100644 index 294b53f8ed023f78dd566fd6e5e6581fe4e68e7e..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/LandingFeature/LandingFeature.swift +++ /dev/null @@ -1,145 +0,0 @@ -import Combine -import ComposableArchitecture -import ErrorFeature -import XCTestDynamicOverlay -import XXClient - -public struct LandingState: Equatable { - public init( - id: UUID, - hasStoredCMix: Bool = false, - isMakingCMix: Bool = false, - isRemovingCMix: Bool = false, - error: ErrorState? = nil - ) { - self.id = id - self.hasStoredCMix = hasStoredCMix - self.isMakingCMix = isMakingCMix - self.isRemovingCMix = isRemovingCMix - self.error = error - } - - var id: UUID - var hasStoredCMix: Bool - var isMakingCMix: Bool - var isRemovingCMix: Bool - var error: ErrorState? -} - -public enum LandingAction: Equatable { - case viewDidLoad - case makeCMix - case didMakeCMix - case didFailMakingCMix(NSError) - case removeStoredCMix - case didRemoveStoredCMix - case didFailRemovingStoredCMix(NSError) - case didDismissError - case error(ErrorAction) -} - -public struct LandingEnvironment { - public init( - cMixManager: CMixManager, - setCMix: @escaping (CMix) -> Void, - bgScheduler: AnySchedulerOf<DispatchQueue>, - mainScheduler: AnySchedulerOf<DispatchQueue>, - error: ErrorEnvironment - ) { - self.cMixManager = cMixManager - self.setCMix = setCMix - self.bgScheduler = bgScheduler - self.mainScheduler = mainScheduler - self.error = error - } - - public var cMixManager: CMixManager - public var setCMix: (CMix) -> Void - public var bgScheduler: AnySchedulerOf<DispatchQueue> - public var mainScheduler: AnySchedulerOf<DispatchQueue> - public var error: ErrorEnvironment -} - -public let landingReducer = Reducer<LandingState, LandingAction, LandingEnvironment> -{ state, action, env in - switch action { - case .viewDidLoad: - state.hasStoredCMix = env.cMixManager.hasStorage() - return .none - - case .makeCMix: - state.isMakingCMix = true - return Effect.future { fulfill in - do { - if env.cMixManager.hasStorage() { - env.setCMix(try env.cMixManager.load()) - } else { - env.setCMix(try env.cMixManager.create()) - } - fulfill(.success(.didMakeCMix)) - } catch { - fulfill(.success(.didFailMakingCMix(error as NSError))) - } - } - .subscribe(on: env.bgScheduler) - .receive(on: env.mainScheduler) - .eraseToEffect() - - case .didMakeCMix: - state.isMakingCMix = false - state.hasStoredCMix = env.cMixManager.hasStorage() - return .none - - case .didFailMakingCMix(let error): - state.isMakingCMix = false - state.hasStoredCMix = env.cMixManager.hasStorage() - state.error = ErrorState(error: error) - return .none - - case .removeStoredCMix: - state.isRemovingCMix = true - return Effect.future { fulfill in - do { - try env.cMixManager.remove() - fulfill(.success(.didRemoveStoredCMix)) - } catch { - fulfill(.success(.didFailRemovingStoredCMix(error as NSError))) - } - } - .subscribe(on: env.bgScheduler) - .receive(on: env.mainScheduler) - .eraseToEffect() - - case .didRemoveStoredCMix: - state.isRemovingCMix = false - state.hasStoredCMix = env.cMixManager.hasStorage() - return .none - - case .didFailRemovingStoredCMix(let error): - state.isRemovingCMix = false - state.hasStoredCMix = env.cMixManager.hasStorage() - state.error = ErrorState(error: error) - return .none - - case .didDismissError: - state.error = nil - return .none - } -} -.presenting( - errorReducer, - state: .keyPath(\.error), - id: .keyPath(\.?.error), - action: /LandingAction.error, - environment: \.error -) - -extension LandingEnvironment { - public static let unimplemented = LandingEnvironment( - cMixManager: .unimplemented, - setCMix: XCTUnimplemented("\(Self.self).setCMix"), - bgScheduler: .unimplemented, - mainScheduler: .unimplemented, - error: .unimplemented - ) -} diff --git a/Example/example-app/Sources/LandingFeature/LandingView.swift b/Example/example-app/Sources/LandingFeature/LandingView.swift deleted file mode 100644 index e6903c2e957a9c40913b5f3635824fa43ef93ef5..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/LandingFeature/LandingView.swift +++ /dev/null @@ -1,91 +0,0 @@ -import ComposableArchitecture -import ComposablePresentation -import ErrorFeature -import SwiftUI - -public struct LandingView: View { - public init(store: Store<LandingState, LandingAction>) { - self.store = store - } - - let store: Store<LandingState, LandingAction> - - struct ViewState: Equatable { - let hasStoredCMix: Bool - let isMakingCMix: Bool - let isRemovingCMix: Bool - - init(state: LandingState) { - hasStoredCMix = state.hasStoredCMix - isMakingCMix = state.isMakingCMix - isRemovingCMix = state.isRemovingCMix - } - - var isLoading: Bool { - isMakingCMix || - isRemovingCMix - } - } - - public var body: some View { - WithViewStore(store.scope(state: ViewState.init)) { viewStore in - Form { - Button { - viewStore.send(.makeCMix) - } label: { - HStack { - Text(viewStore.hasStoredCMix ? "Load stored cMix" : "Create new cMix") - Spacer() - if viewStore.isMakingCMix { - ProgressView() - } - } - } - - if viewStore.hasStoredCMix { - Button(role: .destructive) { - viewStore.send(.removeStoredCMix) - } label: { - HStack { - Text("Remove stored cMix") - Spacer() - if viewStore.isRemovingCMix { - ProgressView() - } - } - } - } - } - .navigationTitle("Landing") - .disabled(viewStore.isLoading) - .task { - viewStore.send(.viewDidLoad) - } - .sheet( - store.scope( - state: \.error, - action: LandingAction.error - ), - onDismiss: { - viewStore.send(.didDismissError) - }, - content: ErrorView.init(store:) - ) - } - } -} - -#if DEBUG -public struct LandingView_Previews: PreviewProvider { - public static var previews: some View { - NavigationView { - LandingView(store: .init( - initialState: .init(id: UUID()), - reducer: .empty, - environment: () - )) - } - .navigationViewStyle(.stack) - } -} -#endif diff --git a/Example/example-app/Sources/SessionFeature/NetworkFollowerStatusView.swift b/Example/example-app/Sources/SessionFeature/NetworkFollowerStatusView.swift deleted file mode 100644 index 7b478312477ca5f898952a4ab50213dd9f3c9b3f..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/SessionFeature/NetworkFollowerStatusView.swift +++ /dev/null @@ -1,40 +0,0 @@ -import SwiftUI -import XXClient - -struct NetworkFollowerStatusView: View { - var status: NetworkFollowerStatus? - - var body: some View { - switch status { - case .stopped: - Label("Stopped", systemImage: "stop.fill") - - case .running: - Label("Running", systemImage: "play.fill") - - case .stopping: - Label("Stopping...", systemImage: "stop") - - case .unknown(let code): - Label("Status \(code)", systemImage: "questionmark") - - case .none: - Label("Unknown", systemImage: "questionmark") - } - } -} - -#if DEBUG -struct NetworkFollowerStatusView_Previews: PreviewProvider { - static var previews: some View { - Group { - NetworkFollowerStatusView(status: .stopped) - NetworkFollowerStatusView(status: .running) - NetworkFollowerStatusView(status: .stopping) - NetworkFollowerStatusView(status: .unknown(code: -1)) - NetworkFollowerStatusView(status: nil) - } - .previewLayout(.sizeThatFits) - } -} -#endif diff --git a/Example/example-app/Sources/SessionFeature/NetworkHealthStatusView.swift b/Example/example-app/Sources/SessionFeature/NetworkHealthStatusView.swift deleted file mode 100644 index e13cb6fc56378fc9717b4b7e5fe3469c0b7f3162..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/SessionFeature/NetworkHealthStatusView.swift +++ /dev/null @@ -1,33 +0,0 @@ -import SwiftUI - -struct NetworkHealthStatusView: View { - var status: Bool? - - var body: some View { - switch status { - case .some(true): - Label("Healthy", systemImage: "wifi") - .foregroundColor(.green) - - case .some(false): - Label("Unhealthy", systemImage: "bolt.horizontal.fill") - .foregroundColor(.red) - - case .none: - Label("Unknown", systemImage: "questionmark") - } - } -} - -#if DEBUG -struct NetworkHealthStatusView_Previews: PreviewProvider { - static var previews: some View { - Group { - NetworkHealthStatusView(status: true) - NetworkHealthStatusView(status: false) - NetworkHealthStatusView(status: nil) - } - .previewLayout(.sizeThatFits) - } -} -#endif diff --git a/Example/example-app/Sources/SessionFeature/SessionFeature.swift b/Example/example-app/Sources/SessionFeature/SessionFeature.swift deleted file mode 100644 index 6e0931cb84253f7dba686529e2fb16f19fec99e2..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/SessionFeature/SessionFeature.swift +++ /dev/null @@ -1,155 +0,0 @@ -import Combine -import ComposableArchitecture -import ErrorFeature -import XCTestDynamicOverlay -import XXClient - -public struct SessionState: Equatable { - public init( - id: UUID, - networkFollowerStatus: NetworkFollowerStatus? = nil, - isNetworkHealthy: Bool? = nil, - error: ErrorState? = nil - ) { - self.id = id - self.networkFollowerStatus = networkFollowerStatus - self.isNetworkHealthy = isNetworkHealthy - self.error = error - } - - public var id: UUID - public var networkFollowerStatus: NetworkFollowerStatus? - public var isNetworkHealthy: Bool? - public var error: ErrorState? -} - -public enum SessionAction: Equatable { - case viewDidLoad - case updateNetworkFollowerStatus - case didUpdateNetworkFollowerStatus(NetworkFollowerStatus?) - case runNetworkFollower(Bool) - case networkFollowerDidFail(NSError) - case monitorNetworkHealth(Bool) - case didUpdateNetworkHealth(Bool?) - case didDismissError - case error(ErrorAction) -} - -public struct SessionEnvironment { - public init( - getCMix: @escaping () -> CMix?, - bgScheduler: AnySchedulerOf<DispatchQueue>, - mainScheduler: AnySchedulerOf<DispatchQueue>, - error: ErrorEnvironment - ) { - self.getCMix = getCMix - self.bgScheduler = bgScheduler - self.mainScheduler = mainScheduler - self.error = error - } - - public var getCMix: () -> CMix? - public var bgScheduler: AnySchedulerOf<DispatchQueue> - public var mainScheduler: AnySchedulerOf<DispatchQueue> - public var error: ErrorEnvironment -} - -public let sessionReducer = Reducer<SessionState, SessionAction, SessionEnvironment> -{ state, action, env in - switch action { - case .viewDidLoad: - return .merge([ - .init(value: .updateNetworkFollowerStatus), - .init(value: .monitorNetworkHealth(true)), - ]) - - case .updateNetworkFollowerStatus: - return Effect.future { fulfill in - let status = env.getCMix()?.networkFollowerStatus() - fulfill(.success(.didUpdateNetworkFollowerStatus(status))) - } - .subscribe(on: env.bgScheduler) - .receive(on: env.mainScheduler) - .eraseToEffect() - - case .didUpdateNetworkFollowerStatus(let status): - state.networkFollowerStatus = status - return .none - - case .runNetworkFollower(let start): - return Effect.run { subscriber in - do { - if start { - try env.getCMix()?.startNetworkFollower(timeoutMS: 30_000) - } else { - try env.getCMix()?.stopNetworkFollower() - } - } catch { - subscriber.send(.networkFollowerDidFail(error as NSError)) - } - let status = env.getCMix()?.networkFollowerStatus() - subscriber.send(.didUpdateNetworkFollowerStatus(status)) - subscriber.send(completion: .finished) - return AnyCancellable {} - } - .subscribe(on: env.bgScheduler) - .receive(on: env.mainScheduler) - .eraseToEffect() - - case .networkFollowerDidFail(let error): - state.error = ErrorState(error: error) - return .none - - case .monitorNetworkHealth(let start): - struct MonitorEffectId: Hashable { - var id: UUID - } - let effectId = MonitorEffectId(id: state.id) - if start { - return Effect.run { subscriber in - let callback = HealthCallback { isHealthy in - subscriber.send(.didUpdateNetworkHealth(isHealthy)) - } - let cancellable = env.getCMix()?.addHealthCallback(callback) - return AnyCancellable { - cancellable?.cancel() - } - } - .subscribe(on: env.bgScheduler) - .receive(on: env.mainScheduler) - .eraseToEffect() - .cancellable(id: effectId, cancelInFlight: true) - } else { - return Effect.cancel(id: effectId) - .subscribe(on: env.bgScheduler) - .eraseToEffect() - } - - case .didUpdateNetworkHealth(let isHealthy): - state.isNetworkHealthy = isHealthy - return .none - - case .didDismissError: - state.error = nil - return .none - - case .error(_): - return .none - } -} -.presenting( - errorReducer, - state: .keyPath(\.error), - id: .keyPath(\.?.error), - action: /SessionAction.error, - environment: \.error -) - -extension SessionEnvironment { - public static let unimplemented = SessionEnvironment( - getCMix: XCTUnimplemented("\(Self.self).getCMix"), - bgScheduler: .unimplemented, - mainScheduler: .unimplemented, - error: .unimplemented - ) -} diff --git a/Example/example-app/Sources/SessionFeature/SessionView.swift b/Example/example-app/Sources/SessionFeature/SessionView.swift deleted file mode 100644 index d095a4211a67d0e0e6b0c027a40641be66347cfb..0000000000000000000000000000000000000000 --- a/Example/example-app/Sources/SessionFeature/SessionView.swift +++ /dev/null @@ -1,81 +0,0 @@ -import ComposableArchitecture -import ComposablePresentation -import ErrorFeature -import SwiftUI -import XXClient - -public struct SessionView: View { - public init(store: Store<SessionState, SessionAction>) { - self.store = store - } - - let store: Store<SessionState, SessionAction> - - struct ViewState: Equatable { - let networkFollowerStatus: NetworkFollowerStatus? - let isNetworkHealthy: Bool? - - init(state: SessionState) { - networkFollowerStatus = state.networkFollowerStatus - isNetworkHealthy = state.isNetworkHealthy - } - } - - public var body: some View { - WithViewStore(store.scope(state: ViewState.init)) { viewStore in - Form { - Section { - NetworkFollowerStatusView(status: viewStore.networkFollowerStatus) - - Button { - viewStore.send(.runNetworkFollower(true)) - } label: { - Text("Start") - } - .disabled(viewStore.networkFollowerStatus != .stopped) - - Button { - viewStore.send(.runNetworkFollower(false)) - } label: { - Text("Stop") - } - .disabled(viewStore.networkFollowerStatus != .running) - } header: { - Text("Network follower") - } - - Section { - NetworkHealthStatusView(status: viewStore.isNetworkHealthy) - } header: { - Text("Network health") - } - } - .navigationTitle("Session") - .task { - viewStore.send(.viewDidLoad) - } - .sheet( - store.scope( - state: \.error, - action: SessionAction.error - ), - onDismiss: { - viewStore.send(.didDismissError) - }, - content: ErrorView.init(store:) - ) - } - } -} - -#if DEBUG -public struct SessionView_Previews: PreviewProvider { - public static var previews: some View { - SessionView(store: .init( - initialState: .init(id: UUID()), - reducer: .empty, - environment: () - )) - } -} -#endif diff --git a/Example/example-app/Tests/AppFeatureTests/AppFeatureTests.swift b/Example/example-app/Tests/AppFeatureTests/AppFeatureTests.swift deleted file mode 100644 index d5cd1cef41315d31db675122547d3f1f55d83525..0000000000000000000000000000000000000000 --- a/Example/example-app/Tests/AppFeatureTests/AppFeatureTests.swift +++ /dev/null @@ -1,51 +0,0 @@ -import Combine -import ComposableArchitecture -import LandingFeature -import SessionFeature -import XCTest -@testable import AppFeature - -final class AppFeatureTests: XCTestCase { - func testViewDidLoad() throws { - let newId = UUID() - let hasCMix = PassthroughSubject<Bool, Never>() - let mainScheduler = DispatchQueue.test - - let store = TestStore( - initialState: AppState(), - reducer: appReducer, - environment: .unimplemented - ) - - store.environment.makeId = { newId } - store.environment.hasCMix = { hasCMix.eraseToAnyPublisher() } - store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler() - - store.send(.viewDidLoad) - - hasCMix.send(false) - mainScheduler.advance() - - store.receive(.cMixDidChange(hasCMix: false)) - - hasCMix.send(true) - mainScheduler.advance() - - store.receive(.cMixDidChange(hasCMix: true)) { - $0.scene = .session(SessionState(id: newId)) - } - - hasCMix.send(true) - mainScheduler.advance() - - hasCMix.send(false) - mainScheduler.advance() - - store.receive(.cMixDidChange(hasCMix: false)) { - $0.scene = .landing(LandingState(id: newId)) - } - - hasCMix.send(completion: .finished) - mainScheduler.advance() - } -} diff --git a/Example/example-app/Tests/ErrorFeatureTests/ErrorFeatureTests.swift b/Example/example-app/Tests/ErrorFeatureTests/ErrorFeatureTests.swift deleted file mode 100644 index 50dabc308273fc6c77beafab3ab8733397b462bc..0000000000000000000000000000000000000000 --- a/Example/example-app/Tests/ErrorFeatureTests/ErrorFeatureTests.swift +++ /dev/null @@ -1,8 +0,0 @@ -import XCTest -@testable import ErrorFeature - -final class ErrorFeatureTests: XCTestCase { - func testExample() { - XCTAssert(true) - } -} diff --git a/Example/example-app/Tests/LandingFeatureTests/LandingFeatureTests.swift b/Example/example-app/Tests/LandingFeatureTests/LandingFeatureTests.swift deleted file mode 100644 index 9018641dbf895d99919c8234600d304a65d8f0ce..0000000000000000000000000000000000000000 --- a/Example/example-app/Tests/LandingFeatureTests/LandingFeatureTests.swift +++ /dev/null @@ -1,182 +0,0 @@ -import ComposableArchitecture -import ErrorFeature -import XCTest -@testable import LandingFeature - -final class LandingFeatureTests: XCTestCase { - func testViewDidLoad() throws { - let store = TestStore( - initialState: LandingState(id: UUID()), - reducer: landingReducer, - environment: .unimplemented - ) - - store.environment.cMixManager.hasStorage.run = { true } - - store.send(.viewDidLoad) { - $0.hasStoredCMix = true - } - } - - func testCreateCMix() { - var hasStoredCMix = false - var didSetCMix = false - let bgScheduler = DispatchQueue.test - let mainScheduler = DispatchQueue.test - - let store = TestStore( - initialState: LandingState(id: UUID()), - reducer: landingReducer, - environment: .unimplemented - ) - - store.environment.cMixManager.hasStorage.run = { hasStoredCMix } - store.environment.cMixManager.create.run = { .unimplemented } - store.environment.setCMix = { _ in didSetCMix = true } - store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler() - store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler() - - store.send(.makeCMix) { - $0.isMakingCMix = true - } - - bgScheduler.advance() - - XCTAssertTrue(didSetCMix) - - hasStoredCMix = true - mainScheduler.advance() - - store.receive(.didMakeCMix) { - $0.isMakingCMix = false - $0.hasStoredCMix = true - } - } - - func testLoadStoredCMix() { - var didSetCMix = false - let bgScheduler = DispatchQueue.test - let mainScheduler = DispatchQueue.test - - let store = TestStore( - initialState: LandingState(id: UUID()), - reducer: landingReducer, - environment: .unimplemented - ) - - store.environment.cMixManager.hasStorage.run = { true } - store.environment.cMixManager.load.run = { .unimplemented } - store.environment.setCMix = { _ in didSetCMix = true } - store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler() - store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler() - - store.send(.makeCMix) { - $0.isMakingCMix = true - } - - bgScheduler.advance() - - XCTAssertTrue(didSetCMix) - - mainScheduler.advance() - - store.receive(.didMakeCMix) { - $0.isMakingCMix = false - $0.hasStoredCMix = true - } - } - - func testMakeCMixFailure() { - let error = NSError(domain: "test", code: 1234) - let bgScheduler = DispatchQueue.test - let mainScheduler = DispatchQueue.test - - let store = TestStore( - initialState: LandingState(id: UUID()), - reducer: landingReducer, - environment: .unimplemented - ) - - store.environment.cMixManager.hasStorage.run = { false } - store.environment.cMixManager.create.run = { throw error } - store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler() - store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler() - - store.send(.makeCMix) { - $0.isMakingCMix = true - } - - bgScheduler.advance() - mainScheduler.advance() - - store.receive(.didFailMakingCMix(error)) { - $0.isMakingCMix = false - $0.hasStoredCMix = false - $0.error = ErrorState(error: error) - } - } - - func testRemoveStoredCMix() { - var hasStoredCMix = true - var didRemoveCMix = false - let bgScheduler = DispatchQueue.test - let mainScheduler = DispatchQueue.test - - let store = TestStore( - initialState: LandingState(id: UUID()), - reducer: landingReducer, - environment: .unimplemented - ) - - store.environment.cMixManager.hasStorage.run = { hasStoredCMix } - store.environment.cMixManager.remove.run = { didRemoveCMix = true } - store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler() - store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler() - - store.send(.removeStoredCMix) { - $0.isRemovingCMix = true - } - - bgScheduler.advance() - - XCTAssertTrue(didRemoveCMix) - - hasStoredCMix = false - mainScheduler.advance() - - store.receive(.didRemoveStoredCMix) { - $0.isRemovingCMix = false - $0.hasStoredCMix = false - } - } - - func testRemoveStoredCMixFailure() { - let error = NSError(domain: "test", code: 1234) - let bgScheduler = DispatchQueue.test - let mainScheduler = DispatchQueue.test - - let store = TestStore( - initialState: LandingState(id: UUID()), - reducer: landingReducer, - environment: .unimplemented - ) - - store.environment.cMixManager.hasStorage.run = { true } - store.environment.cMixManager.remove.run = { throw error } - store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler() - store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler() - - store.send(.removeStoredCMix) { - $0.isRemovingCMix = true - } - - bgScheduler.advance() - mainScheduler.advance() - - store.receive(.didFailRemovingStoredCMix(error)) { - $0.isRemovingCMix = false - $0.hasStoredCMix = true - $0.error = ErrorState(error: error) - } - } -} diff --git a/Example/example-app/Tests/SessionFeatureTests/SessionFeatureTests.swift b/Example/example-app/Tests/SessionFeatureTests/SessionFeatureTests.swift deleted file mode 100644 index 33261ec67e11aa5494103216ccc5cdfd6f135eb6..0000000000000000000000000000000000000000 --- a/Example/example-app/Tests/SessionFeatureTests/SessionFeatureTests.swift +++ /dev/null @@ -1,146 +0,0 @@ -import ComposableArchitecture -import ErrorFeature -import XCTest -import XXClient -@testable import SessionFeature - -final class SessionFeatureTests: XCTestCase { - func testViewDidLoad() { - var networkFollowerStatus: NetworkFollowerStatus! - var didStartMonitoringNetworkHealth = 0 - var didStopMonitoringNetworkHealth = 0 - var networkHealthCallback: HealthCallback! - let bgScheduler = DispatchQueue.test - let mainScheduler = DispatchQueue.test - - let store = TestStore( - initialState: SessionState(id: UUID()), - reducer: sessionReducer, - environment: .unimplemented - ) - - store.environment.getCMix = { - var cMix = CMix.unimplemented - cMix.networkFollowerStatus.run = { networkFollowerStatus } - cMix.addHealthCallback.run = { callback in - networkHealthCallback = callback - didStartMonitoringNetworkHealth += 1 - return Cancellable { - didStopMonitoringNetworkHealth += 1 - } - } - return cMix - } - store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler() - store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler() - - store.send(.viewDidLoad) - - store.receive(.updateNetworkFollowerStatus) - store.receive(.monitorNetworkHealth(true)) - - networkFollowerStatus = .stopped - bgScheduler.advance() - mainScheduler.advance() - - store.receive(.didUpdateNetworkFollowerStatus(.stopped)) { - $0.networkFollowerStatus = .stopped - } - - XCTAssertEqual(didStartMonitoringNetworkHealth, 1) - XCTAssertEqual(didStopMonitoringNetworkHealth, 0) - - networkHealthCallback.handle(true) - bgScheduler.advance() - mainScheduler.advance() - - store.receive(.didUpdateNetworkHealth(true)) { - $0.isNetworkHealthy = true - } - - store.send(.monitorNetworkHealth(false)) - - bgScheduler.advance() - - XCTAssertEqual(didStartMonitoringNetworkHealth, 1) - XCTAssertEqual(didStopMonitoringNetworkHealth, 1) - } - - func testStartStopNetworkFollower() { - var networkFollowerStatus: NetworkFollowerStatus! - var didStartNetworkFollowerWithTimeout = [Int]() - var didStopNetworkFollower = 0 - var networkFollowerStartError: NSError? - let bgScheduler = DispatchQueue.test - let mainScheduler = DispatchQueue.test - - let store = TestStore( - initialState: SessionState(id: UUID()), - reducer: sessionReducer, - environment: .unimplemented - ) - - store.environment.getCMix = { - var cMix = CMix.unimplemented - cMix.networkFollowerStatus.run = { networkFollowerStatus } - cMix.startNetworkFollower.run = { - didStartNetworkFollowerWithTimeout.append($0) - if let error = networkFollowerStartError { - throw error - } - } - cMix.stopNetworkFollower.run = { - didStopNetworkFollower += 1 - } - return cMix - } - store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler() - store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler() - - store.send(.runNetworkFollower(true)) - - networkFollowerStatus = .running - bgScheduler.advance() - mainScheduler.advance() - - XCTAssertEqual(didStartNetworkFollowerWithTimeout, [30_000]) - XCTAssertEqual(didStopNetworkFollower, 0) - - store.receive(.didUpdateNetworkFollowerStatus(.running)) { - $0.networkFollowerStatus = .running - } - - store.send(.runNetworkFollower(false)) - - networkFollowerStatus = .stopped - bgScheduler.advance() - mainScheduler.advance() - - XCTAssertEqual(didStartNetworkFollowerWithTimeout, [30_000]) - XCTAssertEqual(didStopNetworkFollower, 1) - - store.receive(.didUpdateNetworkFollowerStatus(.stopped)) { - $0.networkFollowerStatus = .stopped - } - - store.send(.runNetworkFollower(true)) - - networkFollowerStartError = NSError(domain: "test", code: 1234) - networkFollowerStatus = .stopped - bgScheduler.advance() - mainScheduler.advance() - - XCTAssertEqual(didStartNetworkFollowerWithTimeout, [30_000, 30_000]) - XCTAssertEqual(didStopNetworkFollower, 1) - - store.receive(.networkFollowerDidFail(networkFollowerStartError!)) { - $0.error = ErrorState(error: networkFollowerStartError!) - } - - store.receive(.didUpdateNetworkFollowerStatus(.stopped)) - - store.send(.didDismissError) { - $0.error = nil - } - } -}