The Deno Standard Library
Go to file
2024-05-20 17:34:47 +10:00
_tools docs(collections,internal,media-types): use @typeParam tag instead of @template (#4772) 2024-05-20 17:34:47 +10:00
.github docs: improve documentation on how to write documentation (#4771) 2024-05-20 07:22:00 +00:00
.vscode chore: add vscode settings (#4735) 2024-05-15 15:41:32 +09:00
archive chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
assert refactor(assert,internal): rename diffstr() to diffStr() (#4758) 2024-05-17 15:32:03 +10:00
async chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
bytes test(bytes): add test for negative start index for indexOfNeedle() (#4768) 2024-05-20 17:16:27 +10:00
cli chore: release 2024.05.16 (#4755) 2024-05-16 20:10:44 +09:00
collections docs(collections,internal,media-types): use @typeParam tag instead of @template (#4772) 2024-05-20 17:34:47 +10:00
crypto chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
csv docs(csv,encoding,http,json,media-types,uuid): use rfc-editor.org for RFC links (#4777) 2024-05-20 16:14:09 +09:00
data_structures chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
datetime chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
dotenv chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
encoding docs(csv,encoding,http,json,media-types,uuid): use rfc-editor.org for RFC links (#4777) 2024-05-20 16:14:09 +09:00
expect fix(expect): updated error message for toContain (#4750) 2024-05-17 14:33:05 +09:00
fmt chore(fmt,fs,path,internal): skip yanked version manually (#4753) 2024-05-16 20:04:16 +09:00
front_matter chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
fs chore(fmt,fs,path,internal): skip yanked version manually (#4753) 2024-05-16 20:04:16 +09:00
html chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
http docs(csv,encoding,http,json,media-types,uuid): use rfc-editor.org for RFC links (#4777) 2024-05-20 16:14:09 +09:00
ini chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
internal docs(collections,internal,media-types): use @typeParam tag instead of @template (#4772) 2024-05-20 17:34:47 +10:00
io chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
json docs(csv,encoding,http,json,media-types,uuid): use rfc-editor.org for RFC links (#4777) 2024-05-20 16:14:09 +09:00
jsonc chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
log chore: release 2024.05.07 (#4689) 2024-05-08 13:32:51 +09:00
media_types docs(collections,internal,media-types): use @typeParam tag instead of @template (#4772) 2024-05-20 17:34:47 +10:00
msgpack chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
net chore: release 2024.05.16 (#4755) 2024-05-16 20:10:44 +09:00
path chore(fmt,fs,path,internal): skip yanked version manually (#4753) 2024-05-16 20:04:16 +09:00
regexp chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
semver chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
streams chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
testing chore(expect): fix future no-slow-type lint errors with expando properties (#4711) 2024-05-13 08:29:05 +10:00
text chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
toml chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
ulid chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
url chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
uuid docs(csv,encoding,http,json,media-types,uuid): use rfc-editor.org for RFC links (#4777) 2024-05-20 16:14:09 +09:00
webgpu chore: release 2024.05.16 (#4755) 2024-05-16 20:10:44 +09:00
yaml chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
.editorconfig chore: update .editorconfig (#4685) 2024-05-07 16:15:29 +09:00
.gitattributes Remove std/node, it was merged into Deno itself (#3206) 2023-02-22 10:28:55 -05:00
.gitignore chore: add vscode settings (#4735) 2024-05-15 15:41:32 +09:00
badge.svg chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
browser-compat.tsconfig.json chore: switch to JSR-oriented codebase (#4650) 2024-04-29 11:57:30 +09:00
deno.json docs(internal): cleanups and documentation improvements (#4706) 2024-05-15 09:57:20 +02:00
LICENSE chore: update copyright header (#1871) 2022-02-02 23:21:39 +09:00
README.md docs: add @std/collections to stabilization schedule (#4774) 2024-05-20 17:15:11 +10:00
Releases.md chore: release 2024.05.16 (#4755) 2024-05-16 20:10:44 +09:00

Deno Standard Library

JSR @std codecov ci

High-quality APIs for Deno and the web. Use fearlessly.

Note

Newer versions of the Standard Library are now hosted on JSR. Older versions up till 0.224.0 are still available at deno.land/std.

Packages

The following list contains links to the Standard Library's packages and documentation:

Package Status Latest version
archive Unstable JSR
assert Settled JSR
async Settled JSR
bytes Settled JSR
cli Unstable JSR
collections Settled JSR
crypto Settled JSR
csv Settled JSR
data_structures Unstable JSR
datetime Unstable JSR
dotenv Unstable JSR
encoding Settled JSR
expect Unstable JSR
fmt Settled JSR
front_matter Settled JSR
fs Settled JSR
html Unstable JSR
http Unstable JSR
ini Unstable JSR
io Unstable JSR
json Settled JSR
jsonc Settled JSR
log Unstable JSR
media_types Settled JSR
msgpack Unstable JSR
net Unstable JSR
path Settled JSR
regexp Unstable JSR
semver Unstable JSR
streams Settled JSR
testing Settled JSR
text Unstable JSR
toml Settled JSR
ulid Unstable JSR
url Unstable JSR
uuid Settled JSR
webgpu Unstable JSR
yaml Settled JSR

Note: Settled status means a package is unlikely to have breaking changes, but has not yet achieved v1 status.

Stabilization

The Standard Library is now in the process of stabilizing its packages. Below is the current schedule:

Each package must go through the following steps to achieve stabilization:

  1. Publish version 1.0.0-rc.1 once meeting the following requirements:
    1. Approved by at least 2 maintainers. There must be consensus that the design, documentation and implementation of the package are good and that it is unlikely to undergo breaking changes in the future.
    2. 100% documented, passing deno doc --lint checks and adhering to the documentation guidelines.
    3. Maximum possible test coverage
    4. No open issues or pull requests that might lead to breaking changes. For example, issues that suggest new non-breaking features are fine to exist at stabilization.
  2. Allow 1 month for the community and the core team to review the package and handle any feedback. There must be consensus that the design, documentation and implementation of the package are good and that it is unlikely to undergo breaking changes in the future.
  3. If there are no remaining issues, publish version 1.0.0. If there are remaining issues, extend the waiting period to allow further time for a resolution. Then, repeat this step.

Architecture

Check out the architecture guide here.

Design

Minimal Exports

Files are structured to minimize the number of dependencies they incur and the amount of effort required to manage them, both for the maintainer and the user. In most cases, only a single function or class, alongside its related types, are exported. In other cases, functions that incur negligible dependency overhead will be grouped together in the same file.

Contributing

Check out the contributing guidelines here.

Releases

The Standard Library is versioned independently of the Deno CLI. This will change once the Standard Library is stabilized. See here for the compatibility of different versions of the Deno Standard Library and the Deno CLI.

A new minor version of the Standard Library is published at the same time as every new version of the Deno CLI (including patch versions).

Badge

Built with the Deno Standard Library

<a href="https://jsr.io/@std">
  <img
    width="135"
    height="20"
    src="https://raw.githubusercontent.com/denoland/deno_std/main/badge.svg"
    alt="Built with the Deno Standard Library"
  />
</a>
[![Built with the Deno Standard Library](https://raw.githubusercontent.com/denoland/deno_std/main/badge.svg)](https://jsr.io/@std)

Frequently Asked Questions

Check out the frequently asked questions page here.