From db904bad121fe0b47a7217748b0bbd213da02921 Mon Sep 17 00:00:00 2001 From: ryu <114303361+ryuapp@users.noreply.github.com> Date: Thu, 10 Oct 2024 13:57:51 +0900 Subject: [PATCH] feat: support for `deno install` (#74) * feat: support for `deno install` * docs: add deno * chore: add Deno to current package manager candidates * chore: clarify a comment --- README.md | 2 +- src/hooks/dependencies.ts | 14 +++++++++++++- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 9152e75..aae6c97 100644 --- a/README.md +++ b/README.md @@ -41,7 +41,7 @@ Install dependencies after cloning template. npm create hono@latest ./my-app -- --install ``` -### `-p, --pm ` +### `-p, --pm ` Allows you to specify which package manager to use. diff --git a/src/hooks/dependencies.ts b/src/hooks/dependencies.ts index 6141aeb..3f9aab1 100644 --- a/src/hooks/dependencies.ts +++ b/src/hooks/dependencies.ts @@ -8,11 +8,12 @@ import { execa } from 'execa' import { createSpinner } from 'nanospinner' import { projectDependenciesHook } from '../hook' -type PackageManager = 'npm' | 'bun' | 'pnpm' | 'yarn' +type PackageManager = 'npm' | 'bun' | 'deno' | 'pnpm' | 'yarn' const knownPackageManagers: { [key: string]: string } = { npm: 'npm install', bun: 'bun install', + deno: 'deno install', pnpm: 'pnpm install', yarn: 'yarn', } @@ -44,6 +45,16 @@ const registerInstallationHook = ( // hide install dependencies option if no package manager is installed if (!installedPackageManagerNames.length) return + // If version 1 of Deno is installed, it will not be suggested because it doesn't have "deno install". + if (installedPackageManagerNames.includes('deno')) { + const { stdout } = await execa('deno', ['-v']) + if (stdout.split(' ')[1].split('.')[0] == '1') { + installedPackageManagerNames.splice( + installedPackageManagerNames.indexOf('deno'), + 1, + ) + } + } if (typeof installArg === 'boolean') { installDeps = installArg @@ -106,6 +117,7 @@ function getCurrentPackageManager(): PackageManager { const agent = process.env.npm_config_user_agent || 'npm' // Types say it might be undefined, just being cautious; if (agent.startsWith('bun')) return 'bun' + if (agent.startsWith('deno')) return 'deno' if (agent.startsWith('pnpm')) return 'pnpm' if (agent.startsWith('yarn')) return 'yarn'