The Deno Standard Library
Go to file
2023-10-11 16:21:06 +09:00
_tools chore(_tools): update status towards stabilization (#3636) 2023-09-13 22:16:05 +09:00
.devcontainer chore: add development container configuration (#1938) 2022-02-21 14:23:43 +11:00
.github chore(ci): test on stable (#3476) 2023-10-11 11:29:35 +09:00
archive fix(archive/untar.ts): cannot access symlinks in archives (#3686) 2023-10-06 15:33:36 +09:00
assert fix(assert): fix swapping of multiline str diff (#3685) 2023-10-04 10:43:58 +09:00
async chore(async): remove unused file (#3592) 2023-09-01 16:40:10 +09:00
bytes BREAKING(bytes): deprecate BytesList class (#3589) 2023-08-31 19:40:32 +09:00
collections fix(collections): accept readonly arrays in aggregateGroups, reduceGroups, zip (#3662) 2023-09-21 19:18:57 +09:00
console refactor: cleanup usage of double equals (#3566) 2023-08-25 18:04:43 +09:00
crypto refactor: remove top-level arrow sytnax use (#3687) 2023-10-11 16:19:48 +09:00
csv BREAKING(csv): deprecate error message exports (#3602) 2023-09-03 10:21:36 +09:00
datetime fix(datetime): fix dayOfYear when the timezone has DST (#3668) 2023-09-26 14:04:05 +09:00
dotenv test: make dotenv/load_test.ts less flaky (#3644) 2023-09-22 21:18:08 +09:00
encoding refactor: remove top-level arrow sytnax use (#3687) 2023-10-11 16:19:48 +09:00
flags refactor: cleanup usage of double equals (#3566) 2023-08-25 18:04:43 +09:00
fmt refactor: remove top-level arrow sytnax use (#3687) 2023-10-11 16:19:48 +09:00
front_matter BREAKING(front_matter): deprecate language-specific test functions (#3654) 2023-10-11 16:21:06 +09:00
fs refactor(_util): remove _util/os (#3564) 2023-08-25 18:07:43 +09:00
html BREAKING(testing, assert): move std/testing/asserts to std/assert (#3445) 2023-07-13 16:04:30 +09:00
http BREAKING(path): split path into per-os modules, deprecate legacy os-specific exports (#3649) 2023-09-28 19:54:53 +09:00
io BREAKING(io): deprecate io top level module (#3556) 2023-09-20 20:20:00 +09:00
json test(json): fix expectation of ConcatenatedJsonParseStream test (#3598) 2023-09-01 11:26:59 +09:00
jsonc BREAKING(testing, assert): move std/testing/asserts to std/assert (#3445) 2023-07-13 16:04:30 +09:00
log fix(log): rotating file handler sync setup and destroy (#3543) 2023-08-29 16:48:52 +09:00
media_types BREAKING(media_types): deprecate typeByExtension (#3622) 2023-09-06 11:15:00 +09:00
msgpack chore(msgpack): get rid of testing/asserts usage (#3597) 2023-09-01 11:31:43 +09:00
path BREAKING(path): split path into per-os modules, deprecate legacy os-specific exports (#3649) 2023-09-28 19:54:53 +09:00
permissions BREAKING(permissions): deprecate permissions module (#3567) 2023-08-25 17:20:02 +09:00
regexp BREAKING(testing, assert): move std/testing/asserts to std/assert (#3445) 2023-07-13 16:04:30 +09:00
semver fix(semver): add a necessary grouping, fix prerelease parsing (#3674) 2023-09-25 14:29:58 +09:00
signal refactor(_util): remove _util/os (#3564) 2023-08-25 18:07:43 +09:00
streams refactor: avoid internally using strings for numbers (#3665) 2023-09-21 19:23:28 +09:00
testing test(testing): use assert/mod.ts instead of testing/asserts.ts (#3652) 2023-09-20 13:57:44 +09:00
toml fix(toml/parse): fix edge cases (#3509) 2023-07-30 18:23:34 +09:00
ulid feat(ulid): port /x/ulid module (#3582) 2023-09-12 20:31:03 +09:00
url BREAKING(path): split path into per-os modules, deprecate legacy os-specific exports (#3649) 2023-09-28 19:54:53 +09:00
uuid BREAKING(testing, assert): move std/testing/asserts to std/assert (#3445) 2023-07-13 16:04:30 +09:00
wasi BREAKING(dotenv): fix dotenv permissions (#3578) 2023-08-29 16:36:26 +09:00
yaml refactor: remove top-level arrow sytnax use (#3687) 2023-10-11 16:19:48 +09:00
.editorconfig chore(node): add asn1.js (#1971) 2022-02-28 20:55:56 +09:00
.gitattributes Remove std/node, it was merged into Deno itself (#3206) 2023-02-22 10:28:55 -05:00
.gitignore feat(console): add unicodeWidth for TTY text layout (#3297) 2023-04-18 16:13:58 +09:00
.gitmodules chore: Setup CI and tests 2021-02-01 12:20:35 +01:00
browser-compat.tsconfig.json fix: improve type safety for browser-compatible modules (#995) 2021-07-06 11:15:37 +09:00
deno.json chore(_tools): fix type errors in _tools (#3635) 2023-09-13 22:11:01 +09:00
LICENSE chore: update copyright header (#1871) 2022-02-02 23:21:39 +09:00
README.md BREAKING(testing, assert): move std/testing/asserts to std/assert (#3445) 2023-07-13 16:04:30 +09:00
Releases.md 0.203.0 (#3678) 2023-09-27 09:33:35 +05:30
types.d.ts chore(tools): improved web-compatibility checks (#3263) 2023-03-18 21:36:00 +09:00
version.ts 0.203.0 (#3678) 2023-09-27 09:33:35 +05:30

Deno Standard Modules

codecov

These modules do not have external dependencies and they are reviewed by the Deno core team. The intention is to have a standard set of high quality code that all Deno projects can use fearlessly.

Contributions are welcome!

Releases

Standard library is currently tagged independently of Deno version. This will change once the library is stabilized.

To check compatibility of different version of standard library with Deno CLI see this list.

How to use

These modules will eventually be tagged in accordance with Deno releases but as of today we do not yet consider them stable and so we version the standard modules differently from the Deno runtime to reflect this.

It is strongly recommended that you link to tagged releases to avoid unintended updates and breaking changes.

Don't link to / import any module whose path:

  • Has a name or parent with an underscore prefix: _foo.ts, _util/bar.ts.
  • Is that of a test module or test data: test.ts, foo_test.ts, testdata/bar.txt.

Don't import any symbol with an underscore prefix: export function _baz() {}.

These elements are not considered part of the public API, thus no stability is guaranteed for them.

Documentation

To browse documentation for modules:

Contributing

NOTE: This repository was unarchived and synced on Feb, 1st, 2021. If you already had it cloned, we suggest to do a fresh clone to avoid git conflicts.

deno_std is a loose port of Go's standard library. When in doubt, simply port Go's source code, documentation, and tests. There are many times when the nature of JavaScript, TypeScript, or Deno itself justifies diverging from Go, but if possible we want to leverage the energy that went into building Go. We generally welcome direct ports of Go's code.

Please ensure the copyright headers cite the code's origin.

Follow the style guide.

Opening a pull request

After cloning don't forget to git submodule update --init.

Before opening a PR make sure to:

  • have the latest Deno version installed locally
  • add tests that cover your changes.
  • deno task test passes.
  • deno fmt --check passes.
  • deno task lint passes.
  • (optionally) check for typos with deno task typos (requires typos to be installed)

Give the PR a descriptive title.

Examples of good titles:

  • fix(http): Fix race condition in server
  • docs(fmt): Update docstrings
  • feat(log): Handle nested messages

Examples of bad titles:

  • fix #7123
  • update docs
  • fix bugs

Ensure there is a related issue and it is referenced in the PR text.

About CI checks:

We currently have 6 checks on CI. Each PR should pass all of these checks to be accepted.

  • test with Deno canary on Windows
  • test with Deno canary on Linux
  • test with Deno canary on macOS
  • lint
  • wasm crypto check
  • CLA

For maintainers:

To release a new version a tag in the form of x.y.z should be added.

Types

Deno is moving away from non-native IO functions and interfaces in favor of the Streams API. These types are to be defined here, in the Standard Library, instead of in the Deno namespace in the future. As a rule, use the following corresponding and identical types from types.d.ts:

  • Deno.Reader
  • Deno.Writer
  • Deno.ReaderSync
  • Deno.WriterSync
  • Deno.Closer

See the tracking issue here.