This document contains information and guidelines about contributing to this project. Please read it before you start participating.
Topics
We don't use GitHub as a support forum. For any usage questions that are not specific to the project itself, please ask on Stack Overflow instead with the tag swifterswift. By doing so, you'll be more likely to quickly solve your problem, and you'll allow anyone else with the same question to find the answer. This also allows maintainers to focus on improving the project for others.
SwifterSwift is a collection of extensions found on Stack Overflow, Github, and the internet. Its in its early stages, any new idea is appreciated and welcomed, however please refer to the following rules before submitting a pull request:
- Add original place of extension source (if possile) as a comment inside extension:
public extension SomeType {
public name: SomeType {
// https://stackoverflow.com/somepage
// .. code
}
}
- All extensions should follow Swift API Design Guidelines
- Always declare extensions as public.
- All extensions names should be as clear as possible.
- All extensions should be well documented.
- Avoid using custom classes and objects the goal for this library is to extend the standards types available nativly in Swift, iOS, MacOS, WatchOS and tvOS.
- extensions could be:
- enums
- Properties & static properties
- Methods & static methods
- Initializers
- Files are named based on the type that the contained extensions extend (example: all String extensions are found in "StringExtensions.swift" file)
- extensions are ordered inside files in the following order:
// MARK: - enums
public enum {
// ...
}
// MARK: - Properties
public extension SomeType {}
// MARK: - Methods
public extension SomeType {}
// MARK: - Initializers
public extension SomeType {}
- Please add each extension in its appropriate place in the file
A great way to contribute to the project is to send a detailed issue when you encounter an problem. We always appreciate a well-written, thorough bug report.
Check that the project issues database doesn't already include that problem or suggestion before submitting an issue. If you find a match, add a quick "+1" or "I have this problem too". Doing this helps prioritize the most common problems and requests.
When reporting issues, please include the following:
- The version of Xcode you're using
- The version of iOS you're targeting
- The full output of any stack trace or compiler error
- A code snippet that reproduces the described behavior, if applicable
- Any other details that would be useful in understanding the problem
This information will help us review and fix your issue faster.