isowords

CI

此仓库包含 isowords 的完整源代码,这是一款在消失的立方体上玩的 iOS 单词搜索游戏。连接触摸到的字母以组成单词,越长越好,并且当第三次使用某个字母时,其立方体将被移除,从而显示更多内部的字母!

现已在 App Store 上架!

Download isowords on the App Store

isowords screenshots


关于

isowords 是一个大型且复杂的应用程序,完全使用 Swift 构建。iOS 客户端的逻辑构建于 Composable Architecture 之上,UI 主要使用 SwiftUI 构建,少量使用 SceneKit。服务器也使用 Swift 和我们实验性的 Web 服务器库构建。

我们在 Point-Free 上发布了一个包含 4 部分视频的系列,涵盖了这些主题以及更多内容。Point-Free 是一个探索函数式编程和 Swift 语言的视频系列,由 Brandon WilliamsStephen Celis 主持。

video poster image



您可能会觉得有趣的一些事情

Composable Architecture

整个应用程序都由 Composable Architecture 驱动,这是一个我们在 Point-Free 上从头开始构建的库,它提供了用于构建应用程序的工具,重点关注可组合性、模块化和可测试性。这意味着

以这种方式设计应用程序有很多好处

超模块化

该应用程序以超模块化的风格构建。在编写此 README 时,客户端和服务器被拆分为 86 个模块。这使我们能够在不构建整个应用程序的情况下开发功能,从而缩短编译时间并提高 SwiftUI 预览的稳定性。这也使我们能够轻松地发布 App Clip,其大小必须小于 10 MB未压缩,通过选择构建所需的最低限度的代码和资源。

客户端/服务器单仓库

iOS 客户端和服务器的代码都包含在这个单一的仓库中。这使得同时运行客户端和服务器变得容易,我们甚至可以同时调试它们,例如,在模拟器发出 API 请求时在服务器中设置断点。

我们还在客户端和服务器之间共享大量代码

自动化 App Store 屏幕截图和预览

我们上传到此应用的 App Store 的屏幕截图和预览视频是自动生成的。

预览应用

有时我们希望在不构建整个应用程序的情况下隔离测试某个功能。SwiftUI 预览非常适合此目的,但它们也有其局限性,例如,如果您需要使用预览不可用的 API,或者如果您需要调试更复杂的流程等等。

因此,我们创建了 迷你应用程序,它们构建了组成整个应用程序的 86+ 个模块 的一个小子集。设置这些应用程序只需要最少的工作量。您只需在 Xcode 项目中指定您需要的依赖项,然后创建一个入口点来启动该功能。

例如,这里是创建预览应用程序以隔离运行 onboarding 流程所需的所有代码。如果我们受限于完整的应用程序来测试此功能,我们将需要不断地删除和重新安装该应用程序,因为此屏幕仅在首次启动时显示。

开始使用

此仓库包含运行整个 isowords 应用程序的客户端和服务器代码,以及广泛的测试套件。要使程序运行,请执行以下操作

  1. 确保安装了 git-lfs,以便可以获取应用程序资源(图像等)。例如,使用 Homebrew

    $ brew install git-lfs  # Download and install Git LFS
    $ git lfs install       # Set up Git LFS for your user
  2. 获取代码

    git clone https://github.com/pointfreeco/isowords
    cd isowords
  3. 引导应用程序

    1. 如果您只对构建 iOS 客户端感兴趣,请运行以下引导命令
      make bootstrap-client
    2. 如果您想构建客户端和服务器,请确保已安装并运行 PostgreSQL,然后运行以下引导命令
      make bootstrap
  4. 打开 Xcode 项目 App/isowords.xcodeproj

  5. 要在本地运行客户端,请在 Xcode 中选择 isowords 目标并运行 (⌘R)。

  6. 要在本地运行服务器,请在 Xcode 中选择 server 目标并运行 (⌘R)。

了解更多

本 README 中讨论的大部分概念都在 Point-Free 上进行了深入探讨,这是一个探索函数式编程和 Swift 语言的视频系列,由 Brandon WilliamsStephen Celis 主持。

Point-Free

相关项目

此应用程序使用了许多由我们构建并在 Point-Free 上讨论的开源项目,包括

许可证

本仓库中的源代码仅可出于教育目的运行和更改,不得用于商业目的。有关更多信息,请参阅我们的完整许可证