There is now a new powerful way to both write and integrate Sourcery functionality: Sourcery Pro provides a powerful Stencil editor and extends Xcode with the ability to handle live AST templates: available on Mac App Store
Sourcery is a code generator for Swift language, built on top of Apple’s own SwiftSyntax. It extends the language abstractions to allow you to generate boilerplate code automatically.
It’s used in over 40,000 projects on both iOS and macOS and it powers some of the most popular and critically-acclaimed apps you have used (including Airbnb, Bumble, New York Times). Its massive community adoption was one of the factors that pushed Apple to implement derived Equality and automatic Codable conformance. Sourcery is maintained by a growing community of contributors.
Try Sourcery for your next project or add it to an existing one – you’ll save a lot of time and be happy you did!
TL;DR
Sourcery allows you to get rid of repetitive code and create better architecture and developer workflows.
An example might be implementing Mocks for all your protocols, without Sourcery you will need to write hundreds lines of code per each protocol like this:
class MyProtocolMock: MyProtocol {
//MARK: - sayHelloWith
var sayHelloWithNameCallsCount = 0
var sayHelloWithNameCalled: Bool {
return sayHelloWithNameCallsCount > 0
}
var sayHelloWithNameReceivedName: String?
var sayHelloWithNameReceivedInvocations: [String] = []
var sayHelloWithNameClosure: ((String) -> Void)?
func sayHelloWith(name: String) {
sayHelloWithNameCallsCount += 1
sayHelloWithNameReceivedName = name
sayHelloWithNameReceivedInvocations.append(name)
sayHelloWithNameClosure?(name)
}
}
and with Sourcery ?
extension MyProtocol: AutoMockable {}
Sourcery removes the need to write any of the mocks code, how many protocols do you have in your project? Imagine how much time you’ll save, using Sourcery will also make every single mock consistent and if you refactor or add properties, the mock code will be automatically updated for you, eliminating possible human errors.
Sourcery can be applied to arbitrary problems across your codebase, if you can describe an algorithm to another human, you can automate it using Sourcery.
Add pod 'Sourcery' to your Podfile and run pod update Sourcery. This will download the latest release binary and will put it in your project’s CocoaPods path so you will run it with $PODS_ROOT/Sourcery/bin/sourcery
If you only want to install the sourcery binary, you may want to use the CLI-Only subspec: pod 'Sourcery', :subspecs => ['CLI-Only'].
Note: this command differs depending on how you installed Sourcery (see Installation)
Swift Package command
Sourcery can now be used as a Swift package command plugin. In order to do this, the package must be added as a dependency to your Swift package or Xcode project (see Installation above).
To provide a configuration for the plugin to use, place a .sourcery.yml file at the root of the target’s directory (in the sources folder rather than the root of the package).
Running from the command line
To verify the plugin can be found by SwiftPM, use:
$ swift package plugin --list
To run the code generator, you need to allow changes to the project with the --allow-writing-to-package-directory flag:
$ swift package --allow-writing-to-package-directory sourcery-command
Running in Xcode
Inside a project/package that uses this command plugin, right-click the project and select “SourceryCommand” from the “SourceryPlugins” menu group.
⚠️ Note that this is only available from Xcode 14 onwards.
Command line options
--sources - Path to a source swift files or directories. You can provide multiple paths using multiple --sources option.
--templates - Path to templates. File or Directory. You can provide multiple paths using multiple --templates options.
--force-parse - File extensions of Sourcery generated file you want to parse. You can provide multiple extension using multiple --force-parse options. (i.e. file.toparse.swift will be parsed even if generated by Sourcery if --force-parse toparse). Useful when trying to implement a multiple phases generation. --force-parse can also be used to process within a sourcery annotation. For example to process code within sourcery:inline:auto:Type.AutoCodable annotation you can use --force-parse AutoCodable
--output [default: current path] - Path to output. File or Directory.
--config [default: current path] - Path to config file. File or Directory. See Configuration file.
--args - Additional arguments to pass to templates. Each argument can have an explicit value or will have implicit true value. Arguments should be separated with , without spaces (i.e. --args arg1=value,arg2). Arguments are accessible in templates via argument.name
--watch [default: false] - Watch both code and template folders for changes and regenerate automatically.
--verbose [default: false] - Turn on verbose logging
--quiet [default: false] - Turn off any logging, only emit errors
--disableCache [default: false] - Turn off caching of parsed data
To clarify what is expected of our community, Sourcery has adopted the code of conduct defined by the Contributor Covenant. This document is used across many open source communities, and articulates my values well. For more, see the Code of Conduct.
Sponsoring
If you’d like to support Sourcery development you can do so through GitHub Sponsors or Open Collective, it’s highly appreciated 🙇
License
Sourcery is available under the MIT license. See LICENSE for more information.
There is now a new powerful way to both write and integrate Sourcery functionality: Sourcery Pro provides a powerful Stencil editor and extends Xcode with the ability to handle live AST templates: available on Mac App Store
https://user-images.githubusercontent.com/1468993/114271090-f6c19200-9a0f-11eb-9bd8-d7bb15129eb2.mp4
Learn more about Sourcery Pro
Sourcery is a code generator for Swift language, built on top of Apple’s own SwiftSyntax. It extends the language abstractions to allow you to generate boilerplate code automatically.
It’s used in over 40,000 projects on both iOS and macOS and it powers some of the most popular and critically-acclaimed apps you have used (including Airbnb, Bumble, New York Times). Its massive community adoption was one of the factors that pushed Apple to implement derived Equality and automatic Codable conformance. Sourcery is maintained by a growing community of contributors.
Try Sourcery for your next project or add it to an existing one – you’ll save a lot of time and be happy you did!
TL;DR
Sourcery allows you to get rid of repetitive code and create better architecture and developer workflows. An example might be implementing
Mocks
for all your protocols, without Sourcery you will need to write hundreds lines of code per each protocol like this:and with Sourcery ?
Sourcery removes the need to write any of the mocks code, how many protocols do you have in your project? Imagine how much time you’ll save, using Sourcery will also make every single mock consistent and if you refactor or add properties, the mock code will be automatically updated for you, eliminating possible human errors.
Sourcery can be applied to arbitrary problems across your codebase, if you can describe an algorithm to another human, you can automate it using Sourcery.
Most common uses are:
But how about more specific use-cases, like automatically generating all the UI for your app
BetaSetting
? you can use Sourcery for that tooOnce you start writing your own template and learn the power of Sourcery you won’t be able to live without it.
How To Get Started
There are plenty of tutorials for different uses of Sourcery, and you can always ask for help in our Swift Forum Category.
Quick Mocking Intro & Getting Started Video
You can also watch this quick getting started and intro to mocking video by Inside iOS Dev:
Installation
Binary form
Download the latest release with the prebuilt binary from release tab. Unzip the archive into the desired destination and run
bin/sourcery
Homebrew
brew install sourcery
CocoaPods
Add
pod 'Sourcery'
to yourPodfile
and runpod update Sourcery
. This will download the latest release binary and will put it in your project’s CocoaPods path so you will run it with$PODS_ROOT/Sourcery/bin/sourcery
If you only want to install the
sourcery
binary, you may want to use theCLI-Only
subspec:pod 'Sourcery', :subspecs => ['CLI-Only']
.Mint
mint run krzysztofzablocki/Sourcery
Building from Source
Download the latest release source code from the release tab or clone the repository and build Sourcery manually.
Building with Swift Package Manager
Run
swift build -c release
in the root folder and then copy.build/release/sourcery
to your desired destination.Building with Xcode
Run
xcodebuild -scheme sourcery -destination generic/platform=macOS -archivePath sourcery.xcarchive archive
and export the binary from the archive.SPM (for plugin use only) Add the package dependency to your
Package.swift
manifest from version1.8.3
..pre-commit-config.yaml
.Documentation
Full documentation for the latest release is available here.
Usage
Running the executable
Sourcery is a command line tool; you can either run it manually or in a custom build phase using the following command:
Swift Package command
Sourcery can now be used as a Swift package command plugin. In order to do this, the package must be added as a dependency to your Swift package or Xcode project (see Installation above).
To provide a configuration for the plugin to use, place a
.sourcery.yml
file at the root of the target’s directory (in the sources folder rather than the root of the package).Running from the command line
To verify the plugin can be found by SwiftPM, use:
To run the code generator, you need to allow changes to the project with the
--allow-writing-to-package-directory
flag:Running in Xcode
Inside a project/package that uses this command plugin, right-click the project and select “SourceryCommand” from the “SourceryPlugins” menu group.
Command line options
--sources
- Path to a source swift files or directories. You can provide multiple paths using multiple--sources
option.--templates
- Path to templates. File or Directory. You can provide multiple paths using multiple--templates
options.--force-parse
- File extensions of Sourcery generated file you want to parse. You can provide multiple extension using multiple--force-parse
options. (i.e.file.toparse.swift
will be parsed even if generated by Sourcery if--force-parse toparse
). Useful when trying to implement a multiple phases generation.--force-parse
can also be used to process within a sourcery annotation. For example to process code withinsourcery:inline:auto:Type.AutoCodable
annotation you can use--force-parse AutoCodable
--output
[default: current path] - Path to output. File or Directory.--config
[default: current path] - Path to config file. File or Directory. See Configuration file.--args
- Additional arguments to pass to templates. Each argument can have an explicit value or will have implicittrue
value. Arguments should be separated with,
without spaces (i.e.--args arg1=value,arg2
). Arguments are accessible in templates viaargument.name
--watch
[default: false] - Watch both code and template folders for changes and regenerate automatically.--verbose
[default: false] - Turn on verbose logging--quiet
[default: false] - Turn off any logging, only emit errors--disableCache
[default: false] - Turn off caching of parsed data--prune
[default: false] - Prune empty generated files--version
- Display the current version of Sourcery--help
- Display help information--cacheBasePath
- Base path to the cache directory. Can be overriden by the config file.--buildPath
- Path to directory used when building from .swifttemplate files. This defaults to system temp directoryConfiguration file
Instead of CLI arguments, you can use a
.sourcery.yml
configuration file:Read more about this configuration file here.
Issues
If you get an unverified developer warning when using binary zip distribution try:
xattr -dr com.apple.quarantine Sourcery-1.1.1
Contributing
Contributions to Sourcery are welcomed and encouraged!
It is easy to get involved. Please see the Contributing guide for more details.
A list of contributors is available through GitHub.
To clarify what is expected of our community, Sourcery has adopted the code of conduct defined by the Contributor Covenant. This document is used across many open source communities, and articulates my values well. For more, see the Code of Conduct.
Sponsoring
If you’d like to support Sourcery development you can do so through GitHub Sponsors or Open Collective, it’s highly appreciated 🙇
License
Sourcery is available under the MIT license. See LICENSE for more information.
Attributions
This tool is powered by
Thank you! to:
Other Libraries / Tools
If you want to generate code for asset related data like .xib, .storyboards etc. use SwiftGen. SwiftGen and Sourcery are complementary tools.
Make sure to check my other libraries and tools, especially:
You can follow me on Twitter for news/updates about other projects I am creating.