1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-05 13:59:01 -05:00
A modern runtime for JavaScript and TypeScript. https://deno.com/
Find a file
Luca Casonato b8021744b3
feat(ext/node): properly segregate node globals (#19307)
Code run within Deno-mode and Node-mode should have access to a
slightly different set of globals. Previously this was done through a
compile time code-transform for Node-mode, but this is not ideal and has
many edge cases, for example Node's globalThis having a different
identity than Deno's globalThis.

This commit makes the `globalThis` of the entire runtime a semi-proxy.
This proxy returns a different set of globals depending on the caller's
mode. This is not a full proxy, because it is shadowed by "real"
properties on globalThis. This is done to avoid the overhead of a full
proxy for all globalThis operations.

The globals between Deno-mode and Node-mode are now properly segregated.
This means that code running in Deno-mode will not have access to Node's
globals, and vice versa. Deleting a managed global in Deno-mode will
NOT delete the corresponding global in Node-mode, and vice versa.

---------

Co-authored-by: Bartek Iwańczuk <biwanczuk@gmail.com>
Co-authored-by: Aapo Alasuutari <aapo.alasuutari@gmail.com>
2023-07-20 01:53:37 +02:00
.cargo fix: reload config files on watcher restarts (#19487) 2023-06-14 22:29:19 +00:00
.devcontainer chore: update devcontainer configuration (#15751) 2022-09-03 02:21:41 +02:00
.github chore: update to Rust 1.71 (#19822) 2023-07-20 01:53:34 +02:00
bench_util 1.35.1 (#19812) 2023-07-12 23:49:48 +02:00
cli feat(ext/node): properly segregate node globals (#19307) 2023-07-20 01:53:37 +02:00
ext feat(ext/node): properly segregate node globals (#19307) 2023-07-20 01:53:37 +02:00
runtime feat(ext/node): properly segregate node globals (#19307) 2023-07-20 01:53:37 +02:00
test_ffi chore: update to Rust 1.71 (#19822) 2023-07-20 01:53:34 +02:00
test_napi fix(node): add process.dlopen API (#19860) 2023-07-20 01:53:36 +02:00
test_util feat(lock): skip saving declaration files in the lockfile (#19447) 2023-06-26 15:53:17 -04:00
third_party@0eb5c9cbbc chore: upgrade to dprint 0.39 (#19768) 2023-07-08 18:34:08 +00:00
tools refactor: rename built-in node modules from ext:deno_node/ to node: (#19680) 2023-07-02 20:19:30 +02:00
.dlint.json chore: update dlint to v0.37.0 for GitHub Actions (#17295) 2023-01-16 17:17:18 +01:00
.dprint.json chore: upgrade to dprint 0.39 (#19768) 2023-07-08 18:34:08 +00:00
.editorconfig editorconfig: Don't insert final newline in .out files (#1686) 2019-02-07 11:31:49 -05:00
.gitattributes fix(test): support typechecking docs with CRLF line endings (#12748) 2021-11-15 09:58:04 -05:00
.gitignore chore(ext/websocket): readd autobahn|testsuite fuzzingclient (#18903) 2023-05-01 14:37:32 +02:00
.gitmodules chore: check node_compat config diff in CI (#19119) 2023-05-15 21:22:53 +09:00
.rustfmt.toml chore: update copyright year to 2023 (#17247) 2023-01-02 21:00:42 +00:00
Cargo.lock chore: update log, percent-encoding, and rusqlite (#19815) 2023-07-20 01:53:34 +02:00
Cargo.toml chore: update log, percent-encoding, and rusqlite (#19815) 2023-07-20 01:53:34 +02:00
LICENSE.md chore: update copyright year to 2023 (#17247) 2023-01-02 21:00:42 +00:00
README.md docs: use Deno.serve in README (#19805) 2023-07-20 01:53:34 +02:00
Releases.md 1.35.1 (#19812) 2023-07-12 23:49:48 +02:00
rust-toolchain.toml chore: update to Rust 1.71 (#19822) 2023-07-20 01:53:34 +02:00

Deno

Twitter badge Discord badge YouTube badge

the deno mascot dinosaur standing in the rain

Deno is a simple, modern and secure runtime for JavaScript and TypeScript that uses V8 and is built in Rust.

Features

Install

Shell (Mac, Linux):

curl -fsSL https://deno.land/install.sh | sh

PowerShell (Windows):

irm https://deno.land/install.ps1 | iex

Homebrew (Mac):

brew install deno

Chocolatey (Windows):

choco install deno

Scoop (Windows):

scoop install deno

Build and install from source using Cargo:

cargo install deno --locked

See deno_install and releases for other options.

Getting Started

Try running a simple program:

deno run https://deno.land/std/examples/welcome.ts

Or setup a simple HTTP server:

Deno.serve((_req) => new Response("Hello, World!"));

More examples.

Additional Resources

Contributing

We appreciate your help!

To contribute, please read our contributing instructions.