Deno v1.28

Deno v1.28がリリースされました。 この記事では主な変更点などについて解説します。 npmパッケージサポートの安定化 Deno v1.25で実装されたnpmパッケージサポートが安定化されました。 今後は--unstableなしでnpmパッケージを読み込むことができます。 $ cat main.js import chalk from "npm:chalk@5.1.2"; console.log(chalk.green("Deno")); $ deno run --allow-read --allow-env main.js ただし、リモートモジュールの中にnpm:が含まれていた際は、従来どおり--unstableが要求されるため注意が必要そうです。 その他にも以下の改善などが実施されています。 peerDependenciesがサポート deno info --jsonでnpm:がサポート import.meta.resolveでnpm:が無効化 今後npmパッケージサポートに関して計画されている変更内容についてはロードマップを参照ください。 ロックファイルの自動適用と生成がサポート Denoにはアプリケーションが依存するサードパーティモジュールの内容を元にハッシュ値を計算し、ロックファイルと呼ばれるファイルに保存する機能があります。 アプリケーションを実行する際にサードパーティモジュールから再度ハッシュ値を計算し、ロックファイルに書き込まれたハッシュ値と比較することで、サードパーティモジュールの内容が改ざんされていないことを保証することができます。(インテグリティチェック) この挙動を有効化するには、従来では--lockと--lock-writeの指定が必要でした。 このリリースでは、deno.json(c)が存在する場合、ロックファイル(deno.lock)の生成とインテグリティチェックが自動で実施されるように挙動が変更されました。 $ ls deno.json main.js $ deno run main.js $ ls deno.json deno.lock main.js この変更に合わせて、既存のオプションやインテグリティチェックに関する挙動も一部変更されています。 --lockオプションの引数がオプショナルに変更 (デフォルトはdeno.lock) ロックファイルに列挙されていないパッケージが見つかった際に、インテグリティチェックが失敗しないように挙動が変更 新しく検出されたパッケージについては、ハッシュが自動でロックファイルに書き込まれます。そのパッケージのインテグリティチェックについては、次回以降のDenoの実行から適用されます。 また、このロックファイルの自動適用と生成を無効化するために--no-lockという新しいオプションも追加されています。 Deno.Commandの追加 Deno.CommandというDenoからサブプロセスを生成するための新しいAPIが実装されました。 利用するには--unstableと--allow-runの指定が必要です。 使用例 コマンドの実行結果の非同期での取得: const command = new Deno....

November 20, 2022

2022/11/07〜2022/11/13の最新情報

Deno v1.27.2 Deno v1.27.2がリリースされています。 peerDependenciesのサポート DenoでnpmパッケージのpeerDependenciesがサポートされました。 あるパッケージでpeerDependenciesが定義されていた場合、以下のような動作をするようです。 依存グラフの中から祖先をたどっていき、もしpeerDependenciesで指定された要件を満たすパッケージが見つからなかった場合、通常のdependenciesと同様に依存が解決されます。(npm v7と同様の挙動) optionalPeerDependenciesについては、依存グラフの祖先に指定された要件を満たすパッケージが見つかった場合のみ解決されます。 それ以外の場合は、pnpmと同様の挙動でoptionalPeerDependenciesが解決されます。 https://github.com/denoland/deno/pull/16561 その他の変更点 いくつかのバグ修正が実施されています。 data:URLに対してロックファイルのremoteエントリが作られてしまう問題が修正されています。 Deno.serveHttpで起動したHTTPサーバで圧縮が有効化された状態でストリーミングを行う際に、各チャンクが適切にフラッシュされるように修正されています。 ローカルのnode_modules内のコードでrequireによる相対パス形式での読み込みが行われた際に適切に動作するように修正されています。 https://github.com/denoland/deno/releases/tag/v1.27.2 deno_std v0.163.0 deno_std v0.163.0がリリースされています。 std/semverモジュールでinc()とdiff()が非推奨化されました。 今後は、新しく追加されているincrement()とdifference()の使用が推奨されます。 (動作はそれぞれincとdiffと同様です) https://github.com/denoland/deno_std/releases/tag/0.163.0 denoland/fresh-wordpress-themes WordPressをHeadless CMSとして使いつつ、フロントエンドをFreshで開発するためのテンプレートがDeno公式で公開されました。 https://github.com/denoland/fresh-wordpress-themes 以下の記事で使用方法などが解説されています。 Introducing Fresh WordPress Themes esm.sh v98 esm.sh v98がリリースされました。 新機能としてTree shakingのサポートが追加されています。 exportsパラメータを指定することで適用されます。 https://github.com/ije/esm.sh/releases/tag/v98

November 13, 2022

2022/10/31〜2022/11/06の最新情報

Deno v1.27.1 ロックファイルに関する機能の追加や改善などが実施されています。 ロックファイルの自動探索 ロックファイルの自動探索が実装されました。 これは、deno.json(c)と同じディレクトリにdeno.lockというファイルがあれば、それを元に自動でインテグリティチェックを実行する機能です。 現状、この機能は--unstableを指定したときのみ有効化されます。(Deno v1.28にて安定化予定のようです) また、この自動探索を無効化する目的で、--no-lockというオプションも追加されています。 これらの変更に合わせて、--lockオプションの引数がオプショナルに変更されました。(未指定の場合は、デフォルトでdeno.lockが読み込まれます) また、--lock-writeオプションを指定する際の--lockオプションの指定も不要になっています。 ロックファイルによるインテグリティチェックの挙動が変更 ロックファイルの自動探索機能の実装に合わせて、インテグリティチェックに関する挙動が変更されています。 具体的には、ロックファイルに列挙されていないパッケージが見つかったときに、インテグリティチェックが失敗しないように挙動が変更されています。 もしこのようなパッケージがあった際は、ロックファイルへ自動でハッシュが書き込まれ、次回以降からそのパッケージに対するインテグリティチェックが実施されます。 その他の変更点 deno infoコマンドでnpm:がサポートされました。 Deno.osRelease()が--unstableなしだと利用できなかった問題が解消されています。(このAPIは元々、Deno v1.27.0で安定化される予定でした) Change Array by copyに関する型定義ファイルが追加されました。 Promise.prototype.thenが上書きされても、DenoのコアAPIが影響を受けないように実装が変更されました。 WindowsでDeno.hostname()が空文字列を返すことがある問題が修正されています。 https://github.com/denoland/deno/releases/tag/v1.27.1 deno_std v0.162.0 deno_std v0.162.0がリリースされました。 std/encoding/front_matter - YAML以外のフォーマットのサポート std/encoding/front_matter/any.tsを使うと、YAML/TOML/JSONのいずれかのフォーマットで記述されたFront Matterブロックを読み込むことができます。 import { extract } from "https://deno.land/std@0.162.0/encoding/front_matter/any.ts"; // YAMLでの記述例) let { attrs, body } = extract<{ title: string, date: Date }>(`--- title: foobar date: 2022-06-12 --- Hello`); assert(attrs.title === "foobar"); assert(attrs.date instanceof Date); assert(body === "Hello"); // TOMLでの記述例) ({ attrs, body } = extract<{ title: string, date: Date }>(`---toml title='foobar' date=2022-06-12 --- Hello`)); assert(attrs....

November 6, 2022

2022/10/24〜2022/10/30の最新情報

Deno v1.27 Deno v1.27がリリースされました。 以下に変更内容をまとめたため、よろしければ参照ください。 Deno v1.27 deno_std v0.161.0 deno_std v0.161.0がリリースされました。 std/hashの削除 非推奨化されていたstd/hashモジュールが削除されています。 今後は、std/cryptoの使用が推奨されます。 std/node Deno v1.27でのNode-APIのサポートに合わせて、require()での.nodeファイルの読み込みがサポートされています。 その他には、net.Serverの"close"イベントの発火タイミングの改善やfs.openDirの互換性の向上などが実施されています。 std/fs/expand_glob expandGlobで、globstarにfalseが指定された際に、"**"が"*"として扱われるように修正されています。 https://github.com/denoland/deno_std/releases/tag/0.161.0 MongooseでのDenoサポートについて 以下のPRでMongooseでのDenoサポートが進められているようです。 Deno support (#12397) 今のところ、v6.8でのリリースを目標に作業が進められているようです。 Babel v7.20.0 @babel/preset-envで"deno"ターゲットがサポートされたようです。 "targets"オプションで対象のDenoバージョンを指定することができます。 https://babeljs.io/blog/2022/10/27/7.20.0

October 30, 2022

Deno v1.27

Deno v1.27がリリースされました。 この記事では主な変更点などについて解説します。 npmパッケージサポートの改善 Deno v1.25で追加されたnpmパッケージのサポートに関する改善が実施されています。 型チェックのサポート npm:で読み込んだnpmパッケージに対して型定義が適用されるようになりました これにより、deno checkなどのコマンドを実行した際に、npmパッケージを使用しているコードについても適切に型チェックが実行されます。 import { default as stringWidth } from "npm:string-width@5.1.2"; console.info(stringWidth("foo")); // => 3 console.info(stringWidth(123)); // => 型エラー このように、型定義ファイルを同梱したパッケージについては、自動でそれが読み込まれて適用されます。 型定義ファイルを同梱していないパッケージについては、@deno-typesを使用することで型定義を適用することができます。 // @deno-types="npm:@types/express@4.17.14" import { default as express } from "npm:express@4.18.2"; console.info(express("foo")); // => 型エラー Node-APIのサポート Deno本体にNode-APIのサポートが入りました。 Node-APIは、CやC++などを使用してネイティブアドオンを記述するためにNode.jsから提供されている仕組みです。 import { compress, uncompress } from "npm:lz4-napi@2.2.0" const data = await Deno.readFile("./deno.json"); const compressed = await compress(data); const uncompressed = await uncompress(compressed); Node-APIのサポートが入ったことにより、例えば、Prismaのクエリエンジンやnode-sqlite3などのパッケージも動かせる可能性が出てきました。...

October 30, 2022

2022/10/17〜2022/10/23の最新情報

Deno v1.26.2 Deno v1.26.2がリリースされました。 サブプロセス関連のAPIやnpmサポートの改善、fetch()の互換性の向上などが実施されています。 Deno.SpawnOptionsでwindowsRawArgumentsオプションがサポート Windows上でこのオプションにtrueを指定すると、コマンドライン引数のクォーテーションの付与とエスケープがスキップされます。 const { success, stdout } = await Deno.spawn(cmd, { args, windowsRawArguments: true, }); この機能は、後述するdeno_std v0.160.0におけるwindowsVerbatimArgumentsの実装に利用されています。 npmサポートの改善 dist-tagがサポートされています。 例) import ts from "npm:typescript@next"; その他の改善として、npmレジストリからのパッケージ情報のダウンロード処理が並列化されています。 Fetch APIの互換性の向上 Fetch Standardとの互換性の改善が実施されています。 例) Headersで不正な形式のヘッダを連続で解析すると、二度目以降の解析時にエラーが発生しない問題が修正 fetch()の呼び出し時にRangeヘッダが指定された際は、Accept-Encoding: identityが自動で設定されるように修正 ResponseやRequestに空のFormDataを渡せるように改善 Responseに設定したReadableStreamから非Uint8Array型のチャンクが読み込まれた際は、TypeErrorが発生するように修正 レスポンスボディがContent-Lengthを超過した際などにTypeErrorが発生するように修正 それ以外にもCache APIやWeb Streams APIなどでも互換性の向上が実施されています。 その他の変更点 deno taskでのスクリプト実行時にINIT_CWD環境変数が設定されるように修正 (npm runとの互換性の向上が目的のようです) deno.json(c)のimportMapオプションにリモートURLを指定できるように改善 deno lspでの補完時に、スニペットが適切に取り扱われるように修正 コンパイル対象ファイルの名前が@で始まるときに、deno compileがパニックする問題が修正 https://github.com/denoland/deno/releases/tag/v1.26.2 deno_std v0.160.0 deno_std v0.160.0がリリースされました。 このリリースではstd/nodeのNode.js互換性の向上が実施されています。 変更点: std/node/readline/promisesが実装 std/node/child_process: windowsVerbatimArgumentsオプションがサポート std/node/fs: Windowsでfs....

October 23, 2022

2022/10/10〜2022/10/16の最新情報

deno taskの安定化について deno taskコマンドを安定化することが検討されているようです。 以下のPRではdeno taskを実行した際の警告メッセージが削除されています。 feat(task): remove warning about being unstable (#16281) この変更はv1.27での導入が検討されているようです。 deno lspでtextDocument/inlayHintが実装 以下のPRでdeno lspにtextDocument/inlayHintが実装されています。 feat: support inlay hints (#16287) textDocument/inlayHintの挙動については、TypeScript公式の以下のページがわかりやすそうです。 Inlay Hints こちらについてもv1.27でのリリースが検討されているようです Bartek Iwańczuk’s “Vite Got Deno-fied” at ViteConf 2022 Bartek Iwańczuk氏によるViteConf 2022での発表内容が公開されています。 Bartek Iwańczuk’s “Vite Got Deno-fied” at ViteConf 2022 DenoでViteの開発環境をセットアップし、Deno Deployへデプロイするまでの手順が解説されています。 https://twitter.com/deno_land/status/1580356550966722560 denoland/fresh_charts Deno公式でFresh向けのチャートライブラリが公開されています。 denoland/fresh_charts チャートを描画するための<Chart>コンポーネントやハンドラ向けのユーティリティなどが提供されているようです。 Chart.jsやred-agate-svg-canvasなどを活用して作成されているようです。 https://github.com/denoland/fresh_charts

October 16, 2022

2022/10/03〜2022/10/09の最新情報

Deno v1.26.1 Deno v1.26.1がリリースされました。 Node-APIの実装 DenoでNode-APIが実装されました。 Node-APIで実装されたアドオンのrequire()での読み込みがサポートされます。 Node-APIを有効化するためには、今のところ、--allow-ffiの指定が必要なようです。 (ただし、将来的にオプションが変わる可能性はあるようです) いまのところ、lightningcssやlz4-napiなどが動作することが確認されているようです。(napi-rs/napi-rs#900) Node.js互換に関する改善 Node-APIの実装以外に関する改善として、npm:経由で読まれたパッケージの依存関係の解析結果がキャッシュされるようになりました。 これにより、キャッシュが存在する場合は、Viteの起動が3倍近く高速化されているようです。 キャッシュの仕組みはSQLiteをベースに実装されており、$DENO_DIR/node_analysis_cache_v1にデータベースが作成されます。 その他の改善として、deno cacheでのnpm:のサポートやrequire()でのJSONファイルの読み込みなどがサポートされています。 Web Cache APIのバグ修正 Deno v1.26で追加されたCache APIに関するバグ修正が実施されています。 Cache.put()に渡したResponseオブジェクトがconsumed状態にならない問題が修正 Cache.put()に渡したResponseに紐づくReadableStreamの読み込みでエラーが起きると、リソースリークが発生する問題が修正 Cache.put()で書き込みに失敗したときに、中途半端にキャッシュが保存されないように改善 その他の修正 --unstableを付けないと、Deno.hostname()がundefinedになる問題が修正 (Deno.hostname()はDeno v1.26で安定化されています) リクエストボディの読み込みが最適化 (perf(ext/fetch): consume body using ops (#16038)) 一度、Request#text()などでリクエストボディを消費したにも関わらず、再度Request.bodyを参照するとRequest.bodyUsedがfalseに戻ってしまう問題が修正 Deno.serve()で、ステータスコードが204の際はContent-Lengthが設定されないように修正 SubtleCrypto.deriveBits()でlength引数に与えられた長さが考慮されない問題が修正 https://github.com/denoland/deno/releases/tag/v1.26.1 deno_std v0.159.0 deno_std v0.159.0がリリースされました。 std/textprotoの非推奨化 以下の理由などから、std/textprotoが非推奨化されました。 現在はdeno_stdの内部で使われていないこと deno_stdの方針として、GoスタイルのAPI(Deno.Reader/Deno.Writer)からWeb Streams APIベースへ移行されていること 今後は、このモジュールの使用は避けることが推奨されます。 std/streams/conversion: iterateReaderのバグ修正 iterateReaderに長年存在していたバグが修正されています。 具体的な修正内容については、以下の記事で詳細に内容が解説されています。 Deno のめっちゃ難しいバグを修正した - Qiita また、この修正に関連してiterateReader()の実装が効率化されています。(perf(streams): memory optimizations by avoiding large buffer allocation in a loop (#2748))...

October 9, 2022

2022/09/26〜2022/10/02の最新情報

Deno v1.26 Deno v1.26がリリースされました。 以下に変更内容をまとめたため、よろしければ参照ください。 Deno v1.26 deno_std v0.158.0 deno_std v0.158.0がリリースされました。 std/node child_processパッケージでexec/execFileSync/execSyncが実装されています。 その他には、process.getuid()とprocess.getgid()が実装されています。 また、fsパッケージのread()やWriteStreamなどの互換性が向上しています。 std/http/server handlerが返却したResponseのボディがすでに消費されている場合に、500エラーが発生するように修正されています。 https://github.com/denoland/deno_std/releases/tag/0.158.0 plug v1.0.0-rc.0 Deno FFI(Deno.dlopen)のヘルパーモジュールであるplugのv1.0.0 RC版が公開されています。 このリリースでの主要な変更点として、ダイナミックライブラリを読み込むためのprepare()がdlopen()にリネームされています。 https://github.com/denosaurs/plug/releases/tag/1.0.0-rc.0

October 2, 2022

Deno v1.26

Deno v1.26がリリースされました。 この記事では主な変更点などについて解説します。 --allow-sysオプションの追加 Deno.osReleaseやDeno.systemMemoryInfoなどのシステム情報を取得するためのAPIの利用を制御するために、--allow-sysオプションが追加されました。 $ deno run --unstable --allow-sys=osRelease,systemMemoryInfo main.js 元々、これらのAPIを使うには--allow-envの指定が必要でした。 ただ、これらのAPIの利用に--allow-envを要求することの副作用として、全ての環境変数にアクセスできるようになってしまうという問題がありました。 この問題を解決するため、--allow-sysという新しいパーミッションが導入されました。 Cache APIのサポート DenoにCache APIが実装されました。 const cache = await caches.open("v1"); const req = new Request("https://example.com/"); console.assert(await cache.match(req) === undefined); const res = new Response("foobar"); await cache.put(req, res); const cachedRes = await cache.match(req); console.assert(await cachedRes?.text() === "foobar"); 挙動について localStorageなどと同様にSQLiteをベースに実装されており、利用する際は特にパーミッションなどは要求されません。 ただし、localStorageとは異なり、DENO_DIRではなく/tmp/deno_cacheにSQLiteのデータベースやキャッシュされたコンテンツなどが保存されます。 制限 現時点では、いくつかの制限があるようです。 ignoreSearchやignoreMethodなどのクエリオプションはまだサポートされてないようです。 Cache.deleteを呼んだ際に、SQLiteデータベースに保存されたメタデータは削除されるものの、キャッシュされたコンテンツは削除されないようです。 npmパッケージサポートの改善 今回のv1.26のリリースでは、--no-npmオプションが実装されています。 これにより、npm:によるnpmパッケージのimportを無効化できます。 $ deno run --no-npm main.ts また、Denoでnpmパッケージのimportがサポートされたことにより、Deno v1....

October 2, 2022