Skip to content

Commit e4a78ee

Browse files
committed
doc: add contributing guidelines
1 parent bf8ae3d commit e4a78ee

File tree

4 files changed

+138
-0
lines changed

4 files changed

+138
-0
lines changed

CHANGELOG.md

Whitespace-only changes.

CODE_OF_CONDUCT.md

Lines changed: 76 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,76 @@
1+
# Contributor Covenant Code of Conduct
2+
3+
## Our Pledge
4+
5+
In the interest of fostering an open and welcoming environment, we as
6+
contributors and maintainers pledge to making participation in our project and
7+
our community a harassment-free experience for everyone, regardless of age, body
8+
size, disability, ethnicity, sex characteristics, gender identity and expression,
9+
level of experience, education, socio-economic status, nationality, personal
10+
appearance, race, religion, or sexual identity and orientation.
11+
12+
## Our Standards
13+
14+
Examples of behavior that contributes to creating a positive environment
15+
include:
16+
17+
- Using welcoming and inclusive language
18+
- Being respectful of differing viewpoints and experiences
19+
- Gracefully accepting constructive criticism
20+
- Focusing on what is best for the community
21+
- Showing empathy towards other community members
22+
23+
Examples of unacceptable behavior by participants include:
24+
25+
- The use of sexualized language or imagery and unwelcome sexual attention or
26+
advances
27+
- Trolling, insulting/derogatory comments, and personal or political attacks
28+
- Public or private harassment
29+
- Publishing others' private information, such as a physical or electronic
30+
address, without explicit permission
31+
- Other conduct which could reasonably be considered inappropriate in a
32+
professional setting
33+
34+
## Our Responsibilities
35+
36+
Project maintainers are responsible for clarifying the standards of acceptable
37+
behavior and are expected to take appropriate and fair corrective action in
38+
response to any instances of unacceptable behavior.
39+
40+
Project maintainers have the right and responsibility to remove, edit, or
41+
reject comments, commits, code, wiki edits, issues, and other contributions
42+
that are not aligned to this Code of Conduct, or to ban temporarily or
43+
permanently any contributor for other behaviors that they deem inappropriate,
44+
threatening, offensive, or harmful.
45+
46+
## Scope
47+
48+
This Code of Conduct applies both within project spaces and in public spaces
49+
when an individual is representing the project or its community. Examples of
50+
representing a project or community include using an official project e-mail
51+
address, posting via an official social media account, or acting as an appointed
52+
representative at an online or offline event. Representation of a project may be
53+
further defined and clarified by project maintainers.
54+
55+
## Enforcement
56+
57+
Instances of abusive, harassing, or otherwise unacceptable behavior may be
58+
reported by contacting the project team at [email protected]. All
59+
complaints will be reviewed and investigated and will result in a response that
60+
is deemed necessary and appropriate to the circumstances. The project team is
61+
obligated to maintain confidentiality with regard to the reporter of an incident.
62+
Further details of specific enforcement policies may be posted separately.
63+
64+
Project maintainers who do not follow or enforce the Code of Conduct in good
65+
faith may face temporary or permanent repercussions as determined by other
66+
members of the project's leadership.
67+
68+
## Attribution
69+
70+
This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
71+
available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html
72+
73+
[homepage]: https://www.contributor-covenant.org
74+
75+
For answers to common questions about this code of conduct, see
76+
https://www.contributor-covenant.org/faq

CONTRIBUTING.md

Lines changed: 50 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,50 @@
1+
# Contributing Guidelines
2+
3+
This document contains information and guidelines about contributing to this project.
4+
Please read it before you start participating.
5+
6+
_See also: [Contributor Covenant Code of Conduct](CODE_OF_CONDUCT.md)_
7+
8+
## Submitting Pull Requests
9+
10+
You can contribute by fixing bugs or adding new features. For larger code changes, we first recommend discussing them in our [Github issues](https://github.com/SwiftyLab/AsyncObject/issues). When submitting a pull request, please add relevant tests and ensure your changes don't break any existing tests (see [Automated Tests](#automated-tests) below).
11+
12+
### Things you will need
13+
14+
* Linux, Mac OS (preferred), or Windows.
15+
* Git
16+
* [Swift](https://www.swift.org/getting-started/#installing-swift)
17+
* Optional
18+
* Xcode and [CocoaPods], to test [CocoaPods] integration
19+
* [Node], to use helper scripts in [Scripts](Scripts/) folder.
20+
21+
### Automated Tests
22+
23+
GitHub action is already setup to run tests on pull requests targeting `main` branch. However, to reduce heavy usage of GitHub runners, run the following commands in your terminal to test:
24+
25+
| Test category | With [Node] | Manually |
26+
| --- | --- | --- |
27+
| SPM integration | Run `npm run test` | Run `swift test` |
28+
| [CocoaPods] integration (Requires Xcode) | Run `npm run pod-lint` | Run `pod lib lint --no-clean --allow-warnings` |
29+
30+
## Developer's Certificate of Origin 1.1
31+
32+
By making a contribution to this project, I certify that:
33+
34+
<ol type='a'>
35+
<li id='cert-a'>
36+
The contribution was created in whole or in part by me and I have the right to submit it under the open source license indicated in the file; or
37+
</li>
38+
<li id='cert-b'>
39+
The contribution is based upon previous work that, to the best of my knowledge, is covered under an appropriate open source license and I have the right under that license to submit that work with modifications, whether created in whole or in part by me, under the same open source license (unless I am permitted to submit under a different license), as indicated in the file; or
40+
</li>
41+
<li id='cert-c'>
42+
The contribution was provided directly to me by some other person who certified <a href="#cert-a">(a)</a>, <a href="#cert-b">(b)</a> or <a href="#cert-c">(c)</a> and I have not modified it.
43+
</li>
44+
<li id='cert-d'>
45+
I understand and agree that this project and the contribution are public and that a record of the contribution (including all personal information I submit with it, including my sign-off) is maintained indefinitely and may be redistributed consistent with this project or the open source license(s) involved.
46+
</li>
47+
</ol>
48+
49+
[CocoaPods]: https://cocoapods.org/
50+
[Node]: https://nodejs.org/

README.md

Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,2 +1,14 @@
11
# AsyncObject
2+
3+
[![API Docs](http://img.shields.io/badge/Read_the-docs-2196f3.svg)](https://swiftylab.github.io/AsyncObject/documentation/asyncobject/)
4+
[![Swift Package Manager Compatible](https://img.shields.io/github/v/tag/SwiftyLab/AsyncObject?label=SPM&color=orange)](https://badge.fury.io/gh/SwiftyLab%2FAsyncObject)
5+
[![Carthage compatible](https://img.shields.io/badge/Carthage-compatible-4BC51D.svg)](https://github.com/Carthage/Carthage)
6+
[![Swift](https://img.shields.io/badge/Swift-5.5+-orange)](https://img.shields.io/badge/Swift-5-DE5D43)
7+
[![Platforms](https://img.shields.io/badge/Platforms-all-sucess)](https://img.shields.io/badge/Platforms-all-sucess)
8+
[![CI/CD](https://github.com/SwiftyLab/AsyncObject/actions/workflows/main.yml/badge.svg?event=push)](https://github.com/SwiftyLab/AsyncObject/actions/workflows/main.yml)
9+
[![CodeQL](https://github.com/SwiftyLab/AsyncObject/actions/workflows/codeql-analysis.yml/badge.svg?event=schedule)](https://github.com/SwiftyLab/AsyncObject/actions/workflows/codeql-analysis.yml)
10+
[![Maintainability](https://api.codeclimate.com/v1/badges/a489bc673af55864ff66/maintainability)](https://codeclimate.com/github/SwiftyLab/AsyncObject/maintainability)
11+
<!-- [![CocoaPods Compatible](https://img.shields.io/cocoapods/v/AsyncObject.svg?label=CocoaPods&color=C90005)](https://badge.fury.io/co/AsyncObject) -->
12+
<!-- [![codecov](https://codecov.io/gh/SwiftyLab/AsyncObject/branch/main/graph/badge.svg?token=QIM4SKWNCS)](https://codecov.io/gh/SwiftyLab/AsyncObject) -->
13+
214
Several synchronization primitives introduced to aid in modern swift concurrency. The primitives are very similar to those used in other operating systems including mutexes, condition variables, shared/exclusive locks, and semaphores.

0 commit comments

Comments
 (0)