bun init
.
terminal
enter
to accept the default answer for each prompt, or pass the -y
flag to auto-accept the defaults.
bun init
is a quick way to start a blank project with Bun. It guesses with sane defaults and is non-destructive when run multiple times.

- a
package.json
file with a name that defaults to the current directory name - a
tsconfig.json
file or ajsconfig.json
file, depending if the entry point is a TypeScript file or not - an entry point which defaults to
index.ts
unless any ofindex.{tsx, jsx, js, mts, mjs}
exist or thepackage.json
specifies amodule
ormain
field - a
README.md
file
$BUN_AGENT_RULE_DISABLED=1
):
- a
CLAUDE.md
file when Claude CLI is detected (disable withCLAUDE_CODE_AGENT_RULE_DISABLED
env var) - a
.cursor/rules/*.mdc
file to guide Cursor AI to use Bun instead of Node.js and npm when Cursor is detected
-y
or --yes
, it will assume you want to continue without asking questions.
At the end, it runs bun install
to install @types/bun
.
CLI Usage
terminal
Initialization Options
Accept all default prompts without asking questions. Alias:
-y
Only initialize type definitions (skip app scaffolding). Alias:
-m
Project Templates
Scaffold a React project. When used without a value, creates a baseline React app.
Accepts values for presets:
Accepts values for presets:
tailwind
– React app preconfigured with Tailwind CSSshadcn
– React app with@shadcn/ui
and Tailwind CSS
bun init —react bun init —react=tailwind bun init —react=shadcn
Output & Files
Initializes project files and configuration for the chosen options (e.g., creating essential config files and a starter directory structure). Exact files vary by template.
Global Configuration & Context
Run
bun init
as if started in a different working directory (useful in scripts). Help
Print this help menu. Alias:
-h
Examples
-
Accept all defaults
terminal
-
React
terminal
-
React + Tailwind CSS
terminal
-
React + @shadcn/ui
terminal