This repository has been archived by the owner on Jul 10, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
1 addition
and
120 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,120 +1 @@ | ||
# Deno wrapper | ||
|
||
🦕 Like [`./gradlew`], but for [Deno] | ||
|
||
<table align=center><td> | ||
|
||
```sh | ||
./denow --help | ||
./denow eval 'console.log(42)' | ||
./denow fmt | ||
./denow task mytask | ||
./denow compile --allow-read --allow-net app.ts | ||
./denow run -A https://examples.deno.land/http-server.ts | ||
``` | ||
|
||
</table> | ||
|
||
🦕 Downloads a pinned version of Deno \ | ||
📂 Caches Deno installation in the `.deno` folder \ | ||
🌟 Creates a `./denow` wrapper script that auto-downloads Deno \ | ||
👤 Users don't need to install `deno` globally | ||
|
||
## Installation | ||
|
||
data:image/s3,"s3://crabby-images/7df54/7df548216def8b0ca9f0de648ddb7a07e6f35049" alt="curl" | ||
data:image/s3,"s3://crabby-images/f8331/f83319631aad297bc758196cadbd5beac156c63f" alt="sh" | ||
data:image/s3,"s3://crabby-images/c223c/c223ce1d21c2c73fb0053c1a852036b068dbe547" alt="PowerShell" | ||
|
||
```sh | ||
curl -fsSL https://deno.land/x/denow/install.sh | sh | ||
``` | ||
|
||
```ps1 | ||
irm https://deno.land/x/denow/install.ps1 | iex | ||
``` | ||
|
||
**If you want to install a specific version of Deno** instead of the latest | ||
version you can use an extra argument to choose a specific version. This is the | ||
_version_ (`1.38.0`), not the _tag name_ (`v1.38.0`). | ||
|
||
```sh | ||
curl -fsSL https://deno.land/x/denow/install.sh | sh -s 1.38.0 | ||
``` | ||
|
||
```ps1 | ||
v="1.38.0"; irm https://deno.land/x/denow/install.ps1 | iex | ||
``` | ||
|
||
🛑 If you're looking to install Deno globally [check out the Deno website for an | ||
installation guide]. | ||
|
||
## Usage | ||
|
||
data:image/s3,"s3://crabby-images/53fa8/53fa83343abbaf17288113363c9bd2e5b2f34c78" alt="Terminal" | ||
data:image/s3,"s3://crabby-images/be9ac/be9acf24224a7dcda4db68322b97344fc532d27f" alt="Linux" | ||
data:image/s3,"s3://crabby-images/0cfb0/0cfb0368b773d71a8f35ca3dce7e7dc48071846b" alt="macOS" | ||
data:image/s3,"s3://crabby-images/303e0/303e00c5be991aab49fc5e311c8b10f013412708" alt="Windows" | ||
|
||
Just use `./denow` as though it were the true `deno` binary! Anyone who clones | ||
your repo won't need to install deno themselves; the `./denow` will auto-install | ||
a local copy into the `.deno` folder. | ||
|
||
⚠️ Make sure you add `.deno` to your `.gitignore`! That's where `deno` will be | ||
installed to by the wrapper. | ||
|
||
```sh | ||
./denow --help | ||
./denow eval 'console.log(42)' | ||
./denow fmt | ||
./denow task mytask | ||
./denow compile --allow-read --allow-net https://deno.land/std/http/file_server.ts | ||
./denow run --allow-net https://examples.deno.land/http-server.ts | ||
./denow run -A src/index.ts | ||
``` | ||
|
||
If you want to update the version of Deno that `./denow` downloads and invokes, | ||
you can go through the install steps (above) again to pin to a different | ||
version. Be aware that this will **overwrite** the `./denow` file. You can also | ||
inspect the generated `./denow` file to see what version of Deno they are | ||
invoking and change it manually. | ||
|
||
### Why? | ||
|
||
💡 Inspired by [The Gradle Wrapper] | ||
|
||
Sometimes (not often, but sometimes), you want to have an auto-install wrapper | ||
around a project-critical binary. In a nutshell you gain the following benefits: | ||
|
||
- Standardizes a project on a given Deno version, leading to more reliable and | ||
robust builds. | ||
|
||
- Provisioning a new Deno version to different users and execution environment | ||
(e.g. IDEs or Continuous Integration servers) is as simple as changing the | ||
Wrapper definition. | ||
|
||
For instance, GitHub Actions can be written using Deno, but how do you make sure | ||
`deno` is available on the GitHub Action runner? You can use `./denow` as a | ||
proxy! | ||
|
||
### Why not just download the `deno` binary as `./deno`? | ||
|
||
Because the Deno binary is >100MB, which is more than most version control | ||
systems want to deal with. [GitHub will even block files larger than 100MB]! | ||
|
||
## Development | ||
|
||
data:image/s3,"s3://crabby-images/0db23/0db235e82aaec8be6e5e75d04d54063722e4a7ea" alt="Bash" | ||
data:image/s3,"s3://crabby-images/f8331/f83319631aad297bc758196cadbd5beac156c63f" alt="sh" | ||
data:image/s3,"s3://crabby-images/52afe/52afe99f8b32fe6c9c1d38537dfaef8d55485c96" alt="cmd" | ||
|
||
Make sure that any changes are roughly the same in the `./denow.bat` and | ||
`./deno` wrappers as well as the `install.ps1` and `install.sh` installers. | ||
|
||
<!-- prettier-ignore-start --> | ||
[Deno]: https://deno.com/runtime | ||
[github will even block files larger than 100mb]: https://docs.github.com/en/repositories/working-with-files/managing-large-files/about-large-files-on-github | ||
[`./gradlew`]: https://github.com/gradle/gradle/blob/master/gradlew | ||
[The Gradle Wrapper]: https://docs.gradle.org/current/userguide/gradle_wrapper.html | ||
[check out the Deno website for an installation guide]: https://docs.deno.com/runtime/manual/getting_started/installation | ||
<!-- prettier-ignore-end --> | ||
# MOVED TO https://github.com/jcbhmr/denow |