diff --git a/Sources/Spezi/Spezi.docc/Contributing Guide.md b/Sources/Spezi/Spezi.docc/Contributing Guide.md new file mode 100644 index 00000000..4ea332ce --- /dev/null +++ b/Sources/Spezi/Spezi.docc/Contributing Guide.md @@ -0,0 +1,62 @@ +# Contributing Guide + + + +Thank you for contributing to the Stanford Spezi open-source project; we value the time and effort you invest in the open-source project! This guide provides you with hints and guidance to contribute to a Swift-based Spezi repository. + +> Important: This Contributing guide extens the [Contributing Guidelines](https://github.com/StanfordSpezi/.github/blob/main/CONTRIBUTING.md) with Swift-specific guidelines and hints. You MUST refer to the [Contributing Guidelines](https://github.com/StanfordSpezi/.github/blob/main/CONTRIBUTING.md) for more general information on how to contribute to the Stanford Spezi open-source project. + +The keywords "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in [RFC 2119](https://www.ietf.org/rfc/rfc2119.txt). + +Spezi has a great collection of Swift Package-based modules: https://swiftpackageindex.com/StanfordSpezi. +All Swift-based Stanford Spezi repositories follow a similar setup and structure that is further described in this document. + +> Tip: This guide uses the terminology defined in the and refers to the . + +## Swift Packages + +_"Swift packages are reusable components of Swift, Objective-C, Objective-C++, C, or C++ code that developers can use in their projects."_ [[Swift Packages - Apple Documentation](https://developer.apple.com/documentation/xcode/swift-packages)]. +Contributing to Spezi requires a fundamental understanding of the structure of a Swift Package. +Please take a look at the [Creating a standalone Swift package with Xcode article by Apple](https://developer.apple.com/documentation/xcode/creating-a-standalone-swift-package-with-xcode) detailing the structure of a Swift Package. Each Spezi Module contains a Swift Package, including the `Package.swift` file at the root of the repository. + +You can open a Swift Package in Xcode by opening the Package.swift file with Xcode. +All Swift Packages are localized (learn more at [Localizing package resources - Apple Documentation](https://developer.apple.com/documentation/xcode/bundling-resources-with-a-swift-package)) and some Packages bundle resources such as JSON files and images ([Bundling resources with a Swift package - Apple Documentation](https://developer.apple.com/documentation/xcode/bundling-resources-with-a-swift-package)). + +> Tip: The [WWDC 2023 session "Discover String Catalogs"](https://developer.apple.com/wwdc23/10155) is an excellent resource for learning more about localization and resources, including their usage in Swift Packages. + +All contributions MUST use these localization features and MUST use the Swift Package Manager mechanism to bundle resources with a Swift Package. + + +## Testing + +As noted in the [Contributing Guidelines](https://github.com/StanfordSpezi/.github/blob/main/CONTRIBUTING.md), all changes MUST be properly tested. +Therefore, all Swift Spezi Modules contain a testing setup; it is essential to test all the functionality and run those tests during the development process. +You can learn more about running tests in [Xcode: Running tests and interpreting results - Apple Documentation](https://developer.apple.com/documentation/xcode/running-tests-and-interpreting-results). + +All Spezi Modules that contain user interface elements contain a UI (user interface) test application that allows us to write UI tests for the packages and test out user interfaces in a small example application. +You can find it in the `Tests/UITests` folder, and we RECOMMEND working on this project when developing a Spezi package that contains a user interface. + +> Tip: The [WWDC 2020 session "Write tests to fail"](https://developer.apple.com/wwdc20/10091) is an excellent resource for learning more about UI testing. + +All code-related changes MUST be tested using unit tests. +All user interface-related changes MUST be tested using UI tests. + + +## Documentation + +The Swift-based Stanford Spezi modules contain a [DocC-based](https://github.com/apple/swift-docc) documentation merging inline documentation, dedicated articles, and tutorials within a single documentation bundle deployed to the Swift Package Index. +The DocC documentation archives are typically found in the Swift Package target's respective sources folder. + +> Tip: The [WWDC 2021 session "Meet DocC documentation in Xcode"](https://developer.apple.com/wwdc21/10166) is an excellent resource to get started with understanding DocC documentation and how you can find, edit, and inspect it right in Xcode. + +All changes MUST by properly documented. + +You can learn more about the documentation requirements for Swift-based Spezi Packages in the . diff --git a/Sources/Spezi/Spezi.docc/Documentation Guide.md b/Sources/Spezi/Spezi.docc/Documentation Guide.md index ab7d6c6a..98f4eb21 100644 --- a/Sources/Spezi/Spezi.docc/Documentation Guide.md +++ b/Sources/Spezi/Spezi.docc/Documentation Guide.md @@ -14,7 +14,7 @@ Defines the documentation requirements for Spezi modules, including hints and ex The keywords "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in [RFC 2119](https://www.ietf.org/rfc/rfc2119.txt). -> Important: This guide uses the terminology defined in the . +> Tip: This guide uses the terminology defined in the . The module MUST conform to this guide within two months after changes have been published to be considered in conformance with this guide. diff --git a/Sources/Spezi/Spezi.docc/Spezi.md b/Sources/Spezi/Spezi.docc/Spezi.md index 28a25a27..e832692d 100644 --- a/Sources/Spezi/Spezi.docc/Spezi.md +++ b/Sources/Spezi/Spezi.docc/Spezi.md @@ -99,8 +99,6 @@ To simplify the creation of modules, a common set of functionalities typically u ### Essential Concepts -- -- - ``Spezi/Spezi`` - ``Standard`` - ``Module`` @@ -111,3 +109,9 @@ To simplify the creation of modules, a common set of functionalities typically u - ``SwiftUI/View/previewWith(simulateLifecycle:_:)`` - ``Foundation/ProcessInfo/isPreviewSimulator`` - ``LifecycleSimulationOptions`` + +### Contribute to Spezi + +- +- +-