ArkType values the time of its users and contributors as much as its maintainers, so our goal is for the process to be as efficient and straightforward as possible. Whether this is your first pull request or you're a seasoned open source contributor, this guide is the perfect place to start. If you have any other questions, please don't hesitate to create an issue on GitHub or reach out on our Discord.
ArkType is a community project, so Pull Requests are always welcome, but, before working on a large change, it is best to open an issue first to discuss it with the maintainers.
When in doubt, keep your Pull Requests small. To give a Pull Request the best chance of getting accepted, don't bundle more than one feature or bug fix per Pull Request. It's often best to create two smaller Pull Requests than one big one.
-
Clone the fork to your local machine and add upstream remote:
git clone [email protected]:<yourname>/arktype.git && cd arktype && git remote add upstream [email protected]:arktypeio/arktype.git
- Synchronize your local
main
branch with the upstream one:
git checkout main
git pull upstream main
- Install dependencies and build:
If you don't have pnpm installed:
npm i -g pnpm
then:
pnpm i # install package.json dependencies
pnpm build # builds the package
Make sure you are using our repo's pinned version of TypeScript and not one that comes bundled with your editor. In VSCode, you should be automatically prompted to allow this when you open the repo, but otherwise take a look at this explanation for how it can be done from the VSCode docs.
- Create a new topic branch:
git checkout -b amazing-feature
-
Do your best to write code that is stylistically consistent with its context. The linter will help with this, but it won't catch everything. Here's a few general guidelines:
- Favor functions over classes
- Favor arrow functions outside of classes
- Favor types over interfaces
- Favor mutation over copying objects in perf-sensitive contexts
- Favor clarity in naming with the following exceptions:
- Ubiquitous variables/types. For example, use
s
overdynamicParserState
for a variable of type DynamicParserState that is used in the same way across many functions. - Ephemeral variables whose contents can be trivially inferred from context. For example, prefer
rawKeyDefinitions.map(_ => _.trim())
torawKeyDefinitions.map(rawKeyDefinition => rawKeyDefinition.trim())
.
- Ubiquitous variables/types. For example, use
We also have some unique casing rules for our TypeScript types to making writing isomorphic code easier:
-
Use
CapitalCase
for...- Non-generic types (e.g.
SomeData
) - Generic types with noun names, like
Array<t>
. As a rule of thumb, your generic should be named this way if all its parameters have defaults (unfortunately TS's builtinArray
type doesn't have a default parameter, but it should have beenunknown
!)
- Non-generic types (e.g.
-
Use
camelCase
for...- Generic types with verb names like
inferDomain<t>
. Types named this way should always have at least one required parameter. - Parameter names, e.g.
t
inArray<t>
- Generic types with verb names like
- Once you've made the changes you want to and added corresponding unit tests, run the
prChecks
command in the project root and address any problems:
pnpm prChecks
You can also run any of these commands individually:
"pnpm install && pnpm build && pnpm typecheck && pnpm lint && pnpm testRepo && pnpm docgen && pnpm buildSite"
All of these commands will run as part of our CI process and must succeed in order for us to accept your Pull Request.
- Once everything is passing, commit your changes and ensure your fork is up to date:
git push -u
- Go to the repository and make a Pull Request.
The core team is monitoring for Pull Requests. We will review your Pull Request and either merge it, request changes to it, or close it with an explanation.
Our current and planned work can always be found here. If you want to contribute but aren't sure where to get started, see if any of the issues in our backlog sound interesting! Most are not well-documented, so it usually makes sense to comment on the issue with any questions you may have before you start coding.
ArkType has adopted the Contributor Covenant as its Code of Conduct, and we expect project participants to adhere to it. Please read the full text so that you can understand what actions will and will not be tolerated.
By contributing your code to the arktypeio/arktype GitHub repository, you agree to license your contribution under the MIT license.