Skip to content

Useful Swift NSOperation and NSOperationQueue subclasses

License

Notifications You must be signed in to change notification settings

orchetect/OTOperations

Repository files navigation

OTOperations

CI Build Status Platforms - macOS 10.15+ | iOS 13+ | tvOS 13+ | watchOS 6+ | visionOS 1+ Swift 5.3-6.0 Xcode 15-16 License: MIT

Useful NSOperation (Operation) and NSOperationQueue (OperationQueue) subclasses for Swift.

Scalable, thread-safe, and automatically fully progress-reporting for nested child operations.

  • Foundational
    • BasicOperation and BasicAsyncOperation
  • Closure-based
    • ClosureOperation and AsyncClosureOperation
    • InteractiveClosureOperation and InteractiveAsyncClosureOperation
  • Thread-safe atomic mutability
    • AtomicBlockOperation

Installation: Swift Package Manager (SPM)

Dependency within an Application

  1. Add the package to your Xcode project using Swift Package Manager
    • Select File → Swift Packages → Add Package Dependency
    • Add package using https://github.com/orchetect/OTOperations as the URL.
  2. Import the module in your *.swift files where needed.
    import OTOperations

Dependency within a Swift Package

  1. In your Package.swift file:

    dependencies: [
        .package(url: "https://github.com/orchetect/OTOperations", from: "2.0.0")
    ],
  2. Using internal import prevents the methods and properties in OTOperations from being exported to the consumer of your SPM package.

    internal import OTOperations

Documentation

Most methods are implemented as category methods so they are generally discoverable.

All methods have inline help explaining their purpose and basic usage examples.

Author

Coded by a bunch of 🐹 hamsters in a trenchcoat that calls itself @orchetect.

License

Licensed under the MIT license. See LICENSE for details.

Contributions

Bug fixes and improvements are welcome. Please open an issue to discuss prior to submitting PRs.