Please read our code of conduct, style guide and architecture guide before contributing.
- Check for existing issues before creating a new one.
- When creating an issue, be clear, provide as much detail as possible and provide examples, when possible.
- Install the Deno CLI.
- Fork and clone the repository.
- Create a new branch for your changes.
- Make your changes and ensure
deno task ok
passes successfully. - Commit your changes with clear messages.
- Submit a pull request with the package in question, and a clear title and
description, as follows:
- fix(http): fix race condition in server
- docs(fmt): update docstrings
- feat(log): handle nested messages
Tip
If creating a new package, please add the package name to the scopes
list in
the title
workflow. This must be done a pull
request that precedes the pull request that implements the new package.
-
See the deprecation policy for how deprecations work.
-
Start creating a pull request by adding a deprecation notice to the given symbol with the following format, including the removal version and links to any relevant replacement symbols or documentation:
// /sub/foo.ts /** * @deprecated This will be removed in 0.215.0. Use {@linkcode bar} instead. */ export function foo() {}
-
Submit a pull request starting with the following format:
deprecation(<package>): <symbol>
Use a test name that includes the symbol in question and the test criteria, in plain language, as follows:
- assertEquals() matches when values are equal
- ensureDirSync() creates dir if it does not exist
- Server exposes the addresses the server is listening on as addrs property
Symbols and modules are documented using the JSDoc syntax. These guidelines follow the recommendations in the blog post, How to document your JavaScript package.
Where applicable, documentation for public symbols should contain, in order:
- A short description, then any further details in new paragraph(s).
- A
@typeParam
tag for each type parameter. - A
@param
tag for each parameter. - A
@returns
tag for the return value. - At least one example code snippet using the
@example
tag and a title. For simple examples which don't need a description, "Usage" is an acceptable title. See Example code snippets below for further guidance.
See the source code within
@std/bytes
for
examples.
Once the documentation for a given package is written, add the package's entry
point(s) (usually just mod.ts
) to the ENTRY_POINTS
array in the
documentation checker tool.
Once done, run deno task lint:docs
which checks that documentation is complete
in the given entry points.
Module files, or mod.ts
files, should have the following:
- A high-level description of the package.
- One example code snippet exhibiting a few APIs within the package. Do not
include the
@example
tag. See Example code snippets below for further guidance. - A
@module
tag to declare as module documentation.
See the source code for
@std/bytes/mod.ts
as an example.
Example code snippets must:
- Be as simple yet readable as possible. When in doubt, refer to MDN's Guidelines for writing JavaScript code examples.
- Be reproducible as a copied and pasted script.
- Use an assertion from
@std/assert
, when possible. Snippets are run usingdeno eval
in the documentation checker tool and are flagged when they throw an error.
Note: To skip running a specific code snippet, add no-eval
to the starting
delimiter. E.g.
/**
* ```ts no-eval
* (code snippet will not be run)
* ```
*/