mirror of
https://github.com/oven-sh/bun
synced 2026-02-03 15:38:46 +00:00
Compare commits
1 Commits
jarred/tim
...
jarred/sta
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
23d5b7e8c1 |
@@ -13,7 +13,7 @@ steps:
|
||||
group: ":darwin: aarch64"
|
||||
steps:
|
||||
- key: "darwin-aarch64-build-deps"
|
||||
label: "build-deps"
|
||||
label: ":darwin: aarch64 - build-deps"
|
||||
agents:
|
||||
queue: "build-darwin"
|
||||
os: "darwin"
|
||||
@@ -22,7 +22,7 @@ steps:
|
||||
- "bun run build:ci --target dependencies"
|
||||
|
||||
- key: "darwin-aarch64-build-cpp"
|
||||
label: "build-cpp"
|
||||
label: ":darwin: aarch64 - build-cpp"
|
||||
agents:
|
||||
queue: "build-darwin"
|
||||
os: "darwin"
|
||||
@@ -33,14 +33,14 @@ steps:
|
||||
- "bun run build:ci --target bun"
|
||||
|
||||
- key: "darwin-aarch64-build-zig"
|
||||
label: "build-zig"
|
||||
label: ":darwin: aarch64 - build-zig"
|
||||
agents:
|
||||
queue: "build-zig"
|
||||
command:
|
||||
- "bun run build:ci --target bun-zig --toolchain darwin-aarch64"
|
||||
|
||||
- key: "darwin-aarch64-build-bun"
|
||||
label: "build-bun"
|
||||
label: ":darwin: aarch64 - build-bun"
|
||||
agents:
|
||||
queue: "build-darwin"
|
||||
os: "darwin"
|
||||
@@ -115,7 +115,7 @@ steps:
|
||||
group: ":darwin: x64"
|
||||
steps:
|
||||
- key: "darwin-x64-build-deps"
|
||||
label: "build-deps"
|
||||
label: ":darwin: x64 - build-deps"
|
||||
agents:
|
||||
queue: "build-darwin"
|
||||
os: "darwin"
|
||||
@@ -124,7 +124,7 @@ steps:
|
||||
- "bun run build:ci --target dependencies"
|
||||
|
||||
- key: "darwin-x64-build-cpp"
|
||||
label: "build-cpp"
|
||||
label: ":darwin: x64 - build-cpp"
|
||||
agents:
|
||||
queue: "build-darwin"
|
||||
os: "darwin"
|
||||
@@ -135,14 +135,14 @@ steps:
|
||||
- "bun run build:ci --target bun"
|
||||
|
||||
- key: "darwin-x64-build-zig"
|
||||
label: "build-zig"
|
||||
label: ":darwin: x64 - build-zig"
|
||||
agents:
|
||||
queue: "build-zig"
|
||||
command:
|
||||
- "bun run build:ci --target bun-zig --toolchain darwin-x64"
|
||||
|
||||
- key: "darwin-x64-build-bun"
|
||||
label: "build-bun"
|
||||
label: ":darwin: x64 - build-bun"
|
||||
agents:
|
||||
queue: "build-darwin"
|
||||
os: "darwin"
|
||||
@@ -217,7 +217,7 @@ steps:
|
||||
group: ":linux: x64"
|
||||
steps:
|
||||
- key: "linux-x64-build-deps"
|
||||
label: "build-deps"
|
||||
label: ":linux: x64 - build-deps"
|
||||
agents:
|
||||
queue: "build-linux"
|
||||
os: "linux"
|
||||
@@ -226,7 +226,7 @@ steps:
|
||||
- "bun run build:ci --target dependencies"
|
||||
|
||||
- key: "linux-x64-build-cpp"
|
||||
label: "build-cpp"
|
||||
label: ":linux: x64 - build-cpp"
|
||||
agents:
|
||||
queue: "build-linux"
|
||||
os: "linux"
|
||||
@@ -237,14 +237,14 @@ steps:
|
||||
- "bun run build:ci --target bun"
|
||||
|
||||
- key: "linux-x64-build-zig"
|
||||
label: "build-zig"
|
||||
label: ":linux: x64 - build-zig"
|
||||
agents:
|
||||
queue: "build-zig"
|
||||
command:
|
||||
- "bun run build:ci --target bun-zig --toolchain linux-x64"
|
||||
|
||||
- key: "linux-x64-build-bun"
|
||||
label: "build-bun"
|
||||
label: ":linux: x64 - build-bun"
|
||||
agents:
|
||||
queue: "build-linux"
|
||||
os: "linux"
|
||||
@@ -350,7 +350,7 @@ steps:
|
||||
group: ":linux: x64-baseline"
|
||||
steps:
|
||||
- key: "linux-x64-baseline-build-deps"
|
||||
label: "build-deps"
|
||||
label: ":linux: x64-baseline - build-deps"
|
||||
agents:
|
||||
queue: "build-linux"
|
||||
os: "linux"
|
||||
@@ -361,7 +361,7 @@ steps:
|
||||
- "bun run build:ci --target dependencies"
|
||||
|
||||
- key: "linux-x64-baseline-build-cpp"
|
||||
label: "build-cpp"
|
||||
label: ":linux: x64-baseline - build-cpp"
|
||||
agents:
|
||||
queue: "build-linux"
|
||||
os: "linux"
|
||||
@@ -373,7 +373,7 @@ steps:
|
||||
- "bun run build:ci --target bun"
|
||||
|
||||
- key: "linux-x64-baseline-build-zig"
|
||||
label: "build-zig"
|
||||
label: ":linux: x64-baseline - build-zig"
|
||||
agents:
|
||||
queue: "build-zig"
|
||||
env:
|
||||
@@ -382,7 +382,7 @@ steps:
|
||||
- "bun run build:ci --target bun-zig --toolchain linux-x64-baseline"
|
||||
|
||||
- key: "linux-x64-baseline-build-bun"
|
||||
label: "build-bun"
|
||||
label: ":linux: x64-baseline - build-bun"
|
||||
agents:
|
||||
queue: "build-linux"
|
||||
os: "linux"
|
||||
@@ -489,7 +489,7 @@ steps:
|
||||
group: ":linux: aarch64"
|
||||
steps:
|
||||
- key: "linux-aarch64-build-deps"
|
||||
label: "build-deps"
|
||||
label: ":linux: aarch64 - build-deps"
|
||||
agents:
|
||||
queue: "build-linux"
|
||||
os: "linux"
|
||||
@@ -498,7 +498,7 @@ steps:
|
||||
- "bun run build:ci --target dependencies"
|
||||
|
||||
- key: "linux-aarch64-build-cpp"
|
||||
label: "build-cpp"
|
||||
label: ":linux: aarch64 - build-cpp"
|
||||
agents:
|
||||
queue: "build-linux"
|
||||
os: "linux"
|
||||
@@ -509,14 +509,14 @@ steps:
|
||||
- "bun run build:ci --target bun"
|
||||
|
||||
- key: "linux-aarch64-build-zig"
|
||||
label: "build-zig"
|
||||
label: ":linux: aarch64 - build-zig"
|
||||
agents:
|
||||
queue: "build-zig"
|
||||
command:
|
||||
- "bun run build:ci --target bun-zig --toolchain linux-aarch64"
|
||||
|
||||
- key: "linux-aarch64-build-bun"
|
||||
label: "build-bun"
|
||||
label: ":linux: aarch64 - build-bun"
|
||||
agents:
|
||||
queue: "build-linux"
|
||||
os: "linux"
|
||||
@@ -622,7 +622,7 @@ steps:
|
||||
group: ":windows: x64"
|
||||
steps:
|
||||
- key: "windows-x64-build-deps"
|
||||
label: "build-deps"
|
||||
label: ":windows: x64 - build-deps"
|
||||
agents:
|
||||
queue: "build-windows"
|
||||
os: "windows"
|
||||
@@ -635,7 +635,7 @@ steps:
|
||||
- "bun run build:ci --target dependencies"
|
||||
|
||||
- key: "windows-x64-build-cpp"
|
||||
label: "build-cpp"
|
||||
label: ":windows: x64 - build-cpp"
|
||||
agents:
|
||||
queue: "build-windows"
|
||||
os: "windows"
|
||||
@@ -650,14 +650,14 @@ steps:
|
||||
- "bun run build:ci --target bun"
|
||||
|
||||
- key: "windows-x64-build-zig"
|
||||
label: "build-zig"
|
||||
label: ":windows: x64 - build-zig"
|
||||
agents:
|
||||
queue: "build-zig"
|
||||
command:
|
||||
- "bun run build:ci --target bun-zig --toolchain windows-x64"
|
||||
|
||||
- key: "windows-x64-build-bun"
|
||||
label: "build-bun"
|
||||
label: ":windows: x64 - build-bun"
|
||||
agents:
|
||||
queue: "build-windows"
|
||||
os: "windows"
|
||||
@@ -705,7 +705,7 @@ steps:
|
||||
group: ":windows: x64-baseline"
|
||||
steps:
|
||||
- key: "windows-x64-baseline-build-deps"
|
||||
label: "build-deps"
|
||||
label: ":windows: x64-baseline - build-deps"
|
||||
agents:
|
||||
queue: "build-windows"
|
||||
os: "windows"
|
||||
@@ -720,7 +720,7 @@ steps:
|
||||
- "bun run build:ci --target dependencies"
|
||||
|
||||
- key: "windows-x64-baseline-build-cpp"
|
||||
label: "build-cpp"
|
||||
label: ":windows: x64-baseline - build-cpp"
|
||||
agents:
|
||||
queue: "build-windows"
|
||||
os: "windows"
|
||||
@@ -736,7 +736,7 @@ steps:
|
||||
- "bun run build:ci --target bun"
|
||||
|
||||
- key: "windows-x64-baseline-build-zig"
|
||||
label: "build-zig"
|
||||
label: ":windows: x64-baseline - build-zig"
|
||||
agents:
|
||||
queue: "build-zig"
|
||||
env:
|
||||
@@ -745,7 +745,7 @@ steps:
|
||||
- "bun run build:ci --target bun-zig --toolchain windows-x64-baseline"
|
||||
|
||||
- key: "windows-x64-baseline-build-bun"
|
||||
label: "build-bun"
|
||||
label: ":windows: x64-baseline - build-bun"
|
||||
agents:
|
||||
queue: "build-windows"
|
||||
os: "windows"
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
name: 🇹 TypeScript Type Bug Report
|
||||
description: Report an issue with TypeScript types
|
||||
labels: [bug, types]
|
||||
labels: [bug, typescript]
|
||||
body:
|
||||
- type: markdown
|
||||
attributes:
|
||||
|
||||
@@ -11,8 +11,8 @@ body:
|
||||
- type: textarea
|
||||
id: package_json
|
||||
attributes:
|
||||
label: "`package.json` file"
|
||||
description: "Can you upload your `package.json` file? This helps us reproduce the crash."
|
||||
label: `package.json` file
|
||||
description: Can you upload your `package.json` file? This helps us reproduce the crash.
|
||||
render: json
|
||||
- type: textarea
|
||||
id: repro
|
||||
|
||||
25
.github/workflows/clang-format.yml
vendored
25
.github/workflows/clang-format.yml
vendored
@@ -7,7 +7,18 @@ on:
|
||||
workflow_call:
|
||||
workflow_dispatch:
|
||||
pull_request:
|
||||
merge_group:
|
||||
paths:
|
||||
- ".github/workflows/clang-format.yml"
|
||||
- ".clang-format"
|
||||
- "package.json"
|
||||
- "scripts/**"
|
||||
- "cmake/**"
|
||||
- "src/**/*.c"
|
||||
- "src/**/*.cpp"
|
||||
- "src/**/*.h"
|
||||
- "packages/**/*.c"
|
||||
- "packages/**/*.cpp"
|
||||
- "packages/**/*.h"
|
||||
|
||||
env:
|
||||
BUN_VERSION: "1.1.27"
|
||||
@@ -22,7 +33,14 @@ jobs:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 0
|
||||
sparse-checkout: |
|
||||
.github
|
||||
.clang-format
|
||||
package.json
|
||||
scripts
|
||||
cmake
|
||||
src
|
||||
packages
|
||||
- name: Setup Bun
|
||||
uses: ./.github/actions/setup-bun
|
||||
with:
|
||||
@@ -32,9 +50,10 @@ jobs:
|
||||
curl -fsSL https://apt.llvm.org/llvm.sh | sudo bash -s -- ${{ env.LLVM_VERSION_MAJOR }} all
|
||||
- name: Clang Format
|
||||
env:
|
||||
ENABLE_CCACHE: OFF
|
||||
LLVM_VERSION: ${{ env.LLVM_VERSION }}
|
||||
run: |
|
||||
bun run clang-format
|
||||
bun run clang-format:diff
|
||||
- name: Commit
|
||||
uses: stefanzweifel/git-auto-commit-action@v5
|
||||
with:
|
||||
|
||||
23
.github/workflows/clang-tidy.yml
vendored
23
.github/workflows/clang-tidy.yml
vendored
@@ -7,7 +7,18 @@ on:
|
||||
workflow_call:
|
||||
workflow_dispatch:
|
||||
pull_request:
|
||||
merge_group:
|
||||
paths:
|
||||
- ".github/workflows/clang-tidy.yml"
|
||||
- ".clang-tidy"
|
||||
- "package.json"
|
||||
- "scripts/**"
|
||||
- "cmake/**"
|
||||
- "src/**/*.c"
|
||||
- "src/**/*.cpp"
|
||||
- "src/**/*.h"
|
||||
- "packages/**/*.c"
|
||||
- "packages/**/*.cpp"
|
||||
- "packages/**/*.h"
|
||||
|
||||
env:
|
||||
BUN_VERSION: "1.1.27"
|
||||
@@ -22,7 +33,14 @@ jobs:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 0
|
||||
sparse-checkout: |
|
||||
.github
|
||||
.clang-tidy
|
||||
package.json
|
||||
scripts
|
||||
cmake
|
||||
src
|
||||
packages
|
||||
- name: Setup Bun
|
||||
uses: ./.github/actions/setup-bun
|
||||
with:
|
||||
@@ -32,6 +50,7 @@ jobs:
|
||||
curl -fsSL https://apt.llvm.org/llvm.sh | sudo bash -s -- ${{ env.LLVM_VERSION_MAJOR }} all
|
||||
- name: Clang Tidy
|
||||
env:
|
||||
ENABLE_CCACHE: OFF
|
||||
LLVM_VERSION: ${{ env.LLVM_VERSION }}
|
||||
run: |
|
||||
bun run clang-tidy:diff
|
||||
|
||||
2
.github/workflows/labeled.yml
vendored
2
.github/workflows/labeled.yml
vendored
@@ -114,4 +114,4 @@ jobs:
|
||||
token: ${{ secrets.GITHUB_TOKEN }}
|
||||
issue-number: ${{ github.event.issue.number }}
|
||||
body: |
|
||||
Hello @${{ github.event.issue.user.login }}. Please provide a [minimal reproduction](https://stackoverflow.com/help/minimal-reproducible-example) using a GitHub repository, [Replit](https://replit.com/@replit/Bun), [CodeSandbox](https://codesandbox.io/templates/bun), or provide a bulleted list of commands to run that reproduce this issue. Issues marked with `needs repro` will be closed if they have no activity within 3 days.
|
||||
Hello @${{ github.event.issue.user.login }}. Please provide a [minimal reproduction](https://stackoverflow.com/help/minimal-reproducible-example) using a GitHub repository, [Replit](https://replit.com/@replit/Bun), or [CodeSandbox](https://codesandbox.io/templates/bun). Issues marked with `needs repro` will be closed if they have no activity within 3 days.
|
||||
|
||||
30
.github/workflows/lint-cpp.yml
vendored
Normal file
30
.github/workflows/lint-cpp.yml
vendored
Normal file
@@ -0,0 +1,30 @@
|
||||
name: lint-cpp
|
||||
|
||||
permissions:
|
||||
contents: read
|
||||
|
||||
concurrency:
|
||||
group: ${{ github.workflow }}-${{ github.event_name == 'workflow_dispatch' && inputs.run-id || github.ref }}
|
||||
cancel-in-progress: true
|
||||
|
||||
on:
|
||||
workflow_dispatch:
|
||||
inputs:
|
||||
run-id:
|
||||
type: string
|
||||
description: The workflow ID to download artifacts (skips the build step)
|
||||
# pull_request:
|
||||
# paths:
|
||||
# - ".github/workflows/lint-cpp.yml"
|
||||
# - "**/*.cpp"
|
||||
# - "vendor/**/*"
|
||||
# - "CMakeLists.txt"
|
||||
|
||||
jobs:
|
||||
lint-cpp:
|
||||
if: ${{ !inputs.run-id }}
|
||||
name: Lint C++
|
||||
uses: ./.github/workflows/run-lint-cpp.yml
|
||||
secrets: inherit
|
||||
with:
|
||||
pr-number: ${{ github.event.number }}
|
||||
18
.github/workflows/prettier-format.yml
vendored
18
.github/workflows/prettier-format.yml
vendored
@@ -7,7 +7,18 @@ on:
|
||||
workflow_call:
|
||||
workflow_dispatch:
|
||||
pull_request:
|
||||
merge_group:
|
||||
paths:
|
||||
- ".github/workflows/prettier-format.yml"
|
||||
- "package.json"
|
||||
- "scripts/**"
|
||||
- "**.yml"
|
||||
- "**.json"
|
||||
- "**.js"
|
||||
- "**.jsx"
|
||||
- "**.ts"
|
||||
- "**.tsx"
|
||||
- "**.mjs"
|
||||
- "**.cjs"
|
||||
|
||||
env:
|
||||
BUN_VERSION: "1.1.27"
|
||||
@@ -19,8 +30,6 @@ jobs:
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 0
|
||||
- name: Setup Bun
|
||||
uses: ./.github/actions/setup-bun
|
||||
with:
|
||||
@@ -29,6 +38,9 @@ jobs:
|
||||
run: |
|
||||
bun install
|
||||
- name: Prettier Format
|
||||
env:
|
||||
ENABLE_CCACHE: OFF
|
||||
SKIP_LLVM: ON
|
||||
run: |
|
||||
bun run prettier:diff
|
||||
- name: Commit
|
||||
|
||||
84
.github/workflows/run-lint-cpp.yml
vendored
Normal file
84
.github/workflows/run-lint-cpp.yml
vendored
Normal file
@@ -0,0 +1,84 @@
|
||||
name: lint-cpp
|
||||
|
||||
permissions:
|
||||
contents: read
|
||||
env:
|
||||
LLVM_VERSION: 18
|
||||
LC_CTYPE: "en_US.UTF-8"
|
||||
LC_ALL: "en_US.UTF-8"
|
||||
|
||||
on:
|
||||
workflow_call:
|
||||
inputs:
|
||||
pr-number:
|
||||
required: true
|
||||
type: number
|
||||
|
||||
jobs:
|
||||
lint-cpp:
|
||||
name: Lint C++
|
||||
runs-on: ${{ github.repository_owner == 'oven-sh' && 'macos-13-xlarge' || 'macos-13' }}
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
submodules: recursive
|
||||
- name: Setup Bun
|
||||
uses: ./.github/actions/setup-bun
|
||||
with:
|
||||
bun-version: 1.1.23
|
||||
- name: Install Dependencies
|
||||
env:
|
||||
HOMEBREW_NO_INSTALLED_DEPENDENTS_CHECK: 1
|
||||
HOMEBREW_NO_AUTO_UPDATE: 1
|
||||
HOMEBREW_NO_INSTALL_CLEANUP: 1
|
||||
run: |
|
||||
brew install \
|
||||
llvm@${{ env.LLVM_VERSION }} \
|
||||
ninja \
|
||||
coreutils \
|
||||
openssl@1.1 \
|
||||
libiconv \
|
||||
gnu-sed --force --overwrite
|
||||
echo "$(brew --prefix coreutils)/libexec/gnubin" >> $GITHUB_PATH
|
||||
echo "$(brew --prefix llvm@$LLVM_VERSION)/bin" >> $GITHUB_PATH
|
||||
brew link --overwrite llvm@$LLVM_VERSION
|
||||
- name: Bun install
|
||||
run: |
|
||||
bun install
|
||||
- name: clang-tidy
|
||||
id: format
|
||||
env:
|
||||
CPU_TARGET: native
|
||||
BUN_SILENT: 1
|
||||
run: |
|
||||
rm -f did_fail format.log
|
||||
echo "${{ inputs.pr-number }}" > pr-number.txt
|
||||
echo "pr_number=$(cat pr-number.txt)" >> $GITHUB_OUTPUT
|
||||
bun run --silent build:tidy &> >(tee -p format.log) && echo 0 > did_succeed.txt
|
||||
# Upload format.log as github artifact for the workflow
|
||||
if [ -f did_succeed.txt ]; then
|
||||
echo "0" > did_fail.txt
|
||||
else
|
||||
echo "1" > did_fail.txt
|
||||
fi
|
||||
echo "did_fail=$(cat did_fail.txt)" >> $GITHUB_OUTPUT
|
||||
|
||||
- name: Upload format.log
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: format.log
|
||||
path: format.log
|
||||
- name: Upload PR
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: pr-number.txt
|
||||
path: pr-number.txt
|
||||
- name: Upload PR
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: did_fail.txt
|
||||
path: did_fail.txt
|
||||
- name: Fail if formatting failed
|
||||
if: ${{ steps.format.outputs.did_fail == '1' }}
|
||||
run: exit 1
|
||||
18
.github/workflows/zig-format.yml
vendored
18
.github/workflows/zig-format.yml
vendored
@@ -7,7 +7,12 @@ on:
|
||||
workflow_call:
|
||||
workflow_dispatch:
|
||||
pull_request:
|
||||
merge_group:
|
||||
paths:
|
||||
- ".github/workflows/zig-format.yml"
|
||||
- "package.json"
|
||||
- "scripts/**"
|
||||
- "cmake/**"
|
||||
- "src/**/*.zig"
|
||||
|
||||
env:
|
||||
BUN_VERSION: "1.1.27"
|
||||
@@ -20,12 +25,21 @@ jobs:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 0
|
||||
sparse-checkout: |
|
||||
.github
|
||||
package.json
|
||||
scripts
|
||||
cmake
|
||||
src
|
||||
packages
|
||||
- name: Setup Bun
|
||||
uses: ./.github/actions/setup-bun
|
||||
with:
|
||||
bun-version: ${{ env.BUN_VERSION }}
|
||||
- name: Zig Format
|
||||
env:
|
||||
ENABLE_CCACHE: OFF
|
||||
SKIP_LLVM: ON
|
||||
run: |
|
||||
bun run zig-format:diff
|
||||
- name: Commit
|
||||
|
||||
72
.vscode/launch.json
generated
vendored
72
.vscode/launch.json
generated
vendored
@@ -14,7 +14,7 @@
|
||||
"name": "bun test [file]",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -29,7 +29,7 @@
|
||||
"name": "bun test [file] --only",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "--only", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -50,7 +50,7 @@
|
||||
"name": "bun test [file] (fast)",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -65,7 +65,7 @@
|
||||
"name": "bun test [file] (verbose)",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "0",
|
||||
@@ -80,7 +80,7 @@
|
||||
"name": "bun test [file] --watch",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "--watch", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -95,7 +95,7 @@
|
||||
"name": "bun test [file] --hot",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "--hot", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -110,7 +110,7 @@
|
||||
"name": "bun test [file] --inspect",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -131,7 +131,7 @@
|
||||
"name": "bun test [file] --inspect-brk",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -172,10 +172,6 @@
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
"BUN_GARBAGE_COLLECTOR_LEVEL": "0",
|
||||
"BUN_DEBUG_IncrementalGraph": "1",
|
||||
"BUN_DEBUG_Bake": "1",
|
||||
"BUN_DEBUG_reload_file_list": "1",
|
||||
"GOMAXPROCS": "1",
|
||||
},
|
||||
"console": "internalConsole",
|
||||
},
|
||||
@@ -268,7 +264,7 @@
|
||||
"name": "bun test [...]",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -283,7 +279,7 @@
|
||||
"name": "bun test [...] (fast)",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -298,7 +294,7 @@
|
||||
"name": "bun test [...] (verbose)",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -313,7 +309,7 @@
|
||||
"name": "bun test [...] --watch",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "--watch", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -328,7 +324,7 @@
|
||||
"name": "bun test [...] --hot",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "--hot", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -343,7 +339,7 @@
|
||||
"name": "bun test [...] --inspect",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -364,7 +360,7 @@
|
||||
"name": "bun test [...] --inspect-brk",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -401,7 +397,7 @@
|
||||
"name": "bun test [*]",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -415,7 +411,7 @@
|
||||
"name": "bun test [*] (fast)",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -429,7 +425,7 @@
|
||||
"name": "bun test [*] --inspect",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug",
|
||||
"args": ["test"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"env": {
|
||||
"FORCE_COLOR": "1",
|
||||
"BUN_DEBUG_QUIET_LOGS": "1",
|
||||
@@ -481,7 +477,7 @@
|
||||
"name": "Windows: bun test [file]",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -510,7 +506,7 @@
|
||||
"name": "Windows: bun test --only [file]",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "--only", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -539,7 +535,7 @@
|
||||
"name": "Windows: bun test [file] (fast)",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -568,7 +564,7 @@
|
||||
"name": "Windows: bun test [file] (verbose)",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -597,7 +593,7 @@
|
||||
"name": "Windows: bun test [file] --inspect",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -635,7 +631,7 @@
|
||||
"name": "Windows: bun test [file] --inspect-brk",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "${file}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -822,7 +818,7 @@
|
||||
"name": "Windows: bun test [...]",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -851,7 +847,7 @@
|
||||
"name": "Windows: bun test [...] (fast)",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -880,7 +876,7 @@
|
||||
"name": "Windows: bun test [...] (verbose)",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -909,7 +905,7 @@
|
||||
"name": "Windows: bun test [...] --watch",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "--watch", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -938,7 +934,7 @@
|
||||
"name": "Windows: bun test [...] --hot",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "--hot", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -967,7 +963,7 @@
|
||||
"name": "Windows: bun test [...] --inspect",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -1005,7 +1001,7 @@
|
||||
"name": "Windows: bun test [...] --inspect-brk",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test", "${input:testName}"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -1070,7 +1066,7 @@
|
||||
"name": "Windows: bun test [*]",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -1095,7 +1091,7 @@
|
||||
"name": "Windows: bun test [*] (fast)",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
@@ -1124,7 +1120,7 @@
|
||||
"name": "Windows: bun test [*] --inspect",
|
||||
"program": "${workspaceFolder}/build/debug/bun-debug.exe",
|
||||
"args": ["test"],
|
||||
"cwd": "${workspaceFolder}",
|
||||
"cwd": "${workspaceFolder}/test",
|
||||
"environment": [
|
||||
{
|
||||
"name": "FORCE_COLOR",
|
||||
|
||||
@@ -43,9 +43,7 @@ include(BuildBun)
|
||||
|
||||
# --- Analysis ---
|
||||
|
||||
if(ENABLE_ANALYSIS)
|
||||
include(RunClangFormat)
|
||||
include(RunClangTidy)
|
||||
include(RunZigFormat)
|
||||
include(RunPrettier)
|
||||
endif()
|
||||
include(RunClangFormat)
|
||||
include(RunClangTidy)
|
||||
include(RunZigFormat)
|
||||
include(RunPrettier)
|
||||
|
||||
@@ -30,7 +30,7 @@ $ sudo dnf install cargo ccache cmake git golang libtool ninja-build pkg-config
|
||||
```
|
||||
|
||||
```bash#openSUSE Tumbleweed
|
||||
$ sudo zypper install go cmake ninja automake git icu rustup && rustup toolchain install stable
|
||||
$ sudo zypper install go cmake ninja automake git rustup && rustup toolchain install stable
|
||||
```
|
||||
|
||||
{% /codetabs %}
|
||||
@@ -116,26 +116,42 @@ $ export PATH="$PATH:/usr/lib/llvm16/bin"
|
||||
|
||||
## Building Bun
|
||||
|
||||
After cloning the repository, run the following command to build. This may take a while as it will clone submodules and build dependencies.
|
||||
After cloning the repository, run the following command to run the first build. This may take a while as it will clone submodules and build dependencies.
|
||||
|
||||
```bash
|
||||
$ bun setup
|
||||
```
|
||||
|
||||
The binary will be located at `./build/bun-debug`. It is recommended to add this to your `$PATH`. To verify the build worked, let's print the version number on the development build of Bun.
|
||||
|
||||
```bash
|
||||
$ build/bun-debug --version
|
||||
x.y.z_debug
|
||||
```
|
||||
|
||||
To rebuild, you can invoke `bun run build`
|
||||
|
||||
```bash
|
||||
$ bun run build
|
||||
```
|
||||
|
||||
The binary will be located at `./build/debug/bun-debug`. It is recommended to add this to your `$PATH`. To verify the build worked, let's print the version number on the development build of Bun.
|
||||
These two scripts, `setup` and `build`, are aliases to do roughly the following:
|
||||
|
||||
```bash
|
||||
$ build/debug/bun-debug --version
|
||||
x.y.z_debug
|
||||
$ ./scripts/setup.sh
|
||||
$ cmake -S . -B build -G Ninja -DCMAKE_BUILD_TYPE=Debug
|
||||
$ ninja -C build # 'bun run build' runs just this
|
||||
```
|
||||
|
||||
Advanced users can pass CMake flags to customize the build.
|
||||
|
||||
## VSCode
|
||||
|
||||
VSCode is the recommended IDE for working on Bun, as it has been configured. Once opening, you can run `Extensions: Show Recommended Extensions` to install the recommended extensions for Zig and C++. ZLS is automatically configured.
|
||||
|
||||
If you use a different editor, make sure that you tell ZLS to use the automatically installed Zig compiler, which is located at `./vendor/zig/zig.exe`. The filename is `zig.exe` so that it works as expected on Windows, but it still works on macOS/Linux (it just has a surprising file extension).
|
||||
If you use a different editor, make sure that you tell ZLS to use the automatically installed Zig compiler, which is located at `./.cache/zig/zig.exe`. The filename is `zig.exe` so that it works as expected on Windows, but it still works on macOS/Linux (it just has a surprising file extension).
|
||||
|
||||
We recommend adding `./build/debug` to your `$PATH` so that you can run `bun-debug` in your terminal:
|
||||
We recommend adding `./build` to your `$PATH` so that you can run `bun-debug` in your terminal:
|
||||
|
||||
```sh
|
||||
$ bun-debug
|
||||
@@ -164,7 +180,7 @@ To compile a release build of Bun, run:
|
||||
$ bun run build:release
|
||||
```
|
||||
|
||||
The binary will be located at `./build/release/bun` and `./build/release/bun-profile`.
|
||||
The binary will be located at `./build-release/bun` and `./build-release/bun-profile`.
|
||||
|
||||
### Download release build from pull requests
|
||||
|
||||
@@ -173,8 +189,8 @@ To save you time spent building a release build locally, we provide a way to run
|
||||
To run a release build from a pull request, you can use the `bun-pr` npm package:
|
||||
|
||||
```sh
|
||||
bunx bun-pr <pr-number>
|
||||
bunx bun-pr <branch-name>
|
||||
bunx bun-pr pr-number
|
||||
bunx bun-pr branch/branch-name
|
||||
bunx bun-pr "https://github.com/oven-sh/bun/pull/1234566"
|
||||
```
|
||||
|
||||
@@ -206,18 +222,24 @@ $ valgrind --fair-sched=try --track-origins=yes bun-debug <args>
|
||||
|
||||
## Building WebKit locally + Debug mode of JSC
|
||||
|
||||
{% callout %}
|
||||
|
||||
**TODO**: This is out of date. TLDR is pass `-DUSE_DEBUG_JSC=1` or `-DWEBKIT_DIR=...` to CMake. it will probably need more fiddling. ask @paperdave if you need this.
|
||||
|
||||
{% /callout %}
|
||||
|
||||
WebKit is not cloned by default (to save time and disk space). To clone and build WebKit locally, run:
|
||||
|
||||
```bash
|
||||
# Clone WebKit into ./vendor/WebKit
|
||||
$ git clone https://github.com/oven-sh/WebKit vendor/WebKit
|
||||
|
||||
# Make a debug build of JSC. This will output build artifacts in ./vendor/WebKit/WebKitBuild/Debug
|
||||
# Optionally, you can use `make jsc` for a release build
|
||||
$ make jsc-debug
|
||||
|
||||
# Build bun with the local JSC build
|
||||
$ bun run build:local
|
||||
# once you run this, `make submodule` can be used to automatically
|
||||
# update WebKit and the other submodules
|
||||
$ git submodule update --init --depth 1 --checkout src/bun.js/WebKit
|
||||
# to make a jsc release build
|
||||
$ make jsc
|
||||
# JSC debug build does not work perfectly with Bun yet, this is actively being
|
||||
# worked on and will eventually become the default.
|
||||
$ make jsc-build-linux-compile-debug cpp
|
||||
$ make jsc-build-mac-compile-debug cpp
|
||||
```
|
||||
|
||||
Note that the WebKit folder, including build artifacts, is 8GB+ in size.
|
||||
|
||||
27
Makefile
27
Makefile
@@ -77,7 +77,7 @@ BUN_RELEASE_BIN = $(PACKAGE_DIR)/bun
|
||||
PRETTIER ?= $(shell which prettier 2>/dev/null || echo "./node_modules/.bin/prettier")
|
||||
ESBUILD = "$(shell which esbuild 2>/dev/null || echo "./node_modules/.bin/esbuild")"
|
||||
DSYMUTIL ?= $(shell which dsymutil 2>/dev/null || which dsymutil-15 2>/dev/null)
|
||||
WEBKIT_DIR ?= $(realpath vendor/WebKit)
|
||||
WEBKIT_DIR ?= $(realpath src/bun.js/WebKit)
|
||||
WEBKIT_RELEASE_DIR ?= $(WEBKIT_DIR)/WebKitBuild/Release
|
||||
WEBKIT_DEBUG_DIR ?= $(WEBKIT_DIR)/WebKitBuild/Debug
|
||||
WEBKIT_RELEASE_DIR_LTO ?= $(WEBKIT_DIR)/WebKitBuild/ReleaseLTO
|
||||
@@ -138,8 +138,8 @@ endif
|
||||
SED = $(shell which gsed 2>/dev/null || which sed 2>/dev/null)
|
||||
|
||||
BUN_DIR ?= $(shell dirname $(realpath $(firstword $(MAKEFILE_LIST))))
|
||||
BUN_DEPS_DIR ?= $(shell pwd)/vendor
|
||||
BUN_DEPS_OUT_DIR ?= $(shell pwd)/build/release
|
||||
BUN_DEPS_DIR ?= $(shell pwd)/src/deps
|
||||
BUN_DEPS_OUT_DIR ?= $(shell pwd)/build/bun-deps
|
||||
CPU_COUNT = 2
|
||||
ifeq ($(OS_NAME),darwin)
|
||||
CPU_COUNT = $(shell sysctl -n hw.logicalcpu)
|
||||
@@ -689,10 +689,19 @@ assert-deps:
|
||||
@test $(shell cargo --version | awk '{print $$2}' | cut -d. -f2) -gt 57 || (echo -e "ERROR: cargo version must be at least 1.57."; exit 1)
|
||||
@echo "You have the dependencies installed! Woo"
|
||||
|
||||
# the following allows you to run `make submodule` to update or init submodules. but we will exclude webkit
|
||||
# unless you explicitly clone it yourself (a huge download)
|
||||
SUBMODULE_NAMES=$(shell cat .gitmodules | grep 'path = ' | awk '{print $$3}')
|
||||
ifeq ("$(wildcard src/bun.js/WebKit/.git)", "")
|
||||
SUBMODULE_NAMES := $(filter-out src/bun.js/WebKit, $(SUBMODULE_NAMES))
|
||||
endif
|
||||
|
||||
.PHONY: init-submodules
|
||||
init-submodules: submodule # (backwards-compatibility alias)
|
||||
|
||||
.PHONY: submodule
|
||||
submodule: ## to init or update all submodules
|
||||
git submodule update --init --recursive --progress --depth=1 --checkout $(SUBMODULE_NAMES)
|
||||
|
||||
.PHONY: build-obj
|
||||
build-obj:
|
||||
@@ -795,7 +804,7 @@ cls:
|
||||
@echo -e "\n\n---\n\n"
|
||||
|
||||
jsc-check:
|
||||
@ls $(JSC_BASE_DIR) >/dev/null 2>&1 || (echo -e "Failed to access WebKit build. Please compile the WebKit submodule using the Dockerfile at $(shell pwd)/src/javascript/WebKit/Dockerfile and then copy from /output in the Docker container to $(JSC_BASE_DIR). You can override the directory via JSC_BASE_DIR. \n\n DOCKER_BUILDKIT=1 docker build -t bun-webkit $(shell pwd)/vendor/WebKit -f $(shell pwd)/vendor/WebKit/Dockerfile --progress=plain\n\n docker container create bun-webkit\n\n # Get the container ID\n docker container ls\n\n docker cp DOCKER_CONTAINER_ID_YOU_JUST_FOUND:/output $(JSC_BASE_DIR)" && exit 1)
|
||||
@ls $(JSC_BASE_DIR) >/dev/null 2>&1 || (echo -e "Failed to access WebKit build. Please compile the WebKit submodule using the Dockerfile at $(shell pwd)/src/javascript/WebKit/Dockerfile and then copy from /output in the Docker container to $(JSC_BASE_DIR). You can override the directory via JSC_BASE_DIR. \n\n DOCKER_BUILDKIT=1 docker build -t bun-webkit $(shell pwd)/src/bun.js/WebKit -f $(shell pwd)/src/bun.js/WebKit/Dockerfile --progress=plain\n\n docker container create bun-webkit\n\n # Get the container ID\n docker container ls\n\n docker cp DOCKER_CONTAINER_ID_YOU_JUST_FOUND:/output $(JSC_BASE_DIR)" && exit 1)
|
||||
@ls $(JSC_INCLUDE_DIR) >/dev/null 2>&1 || (echo "Failed to access WebKit include directory at $(JSC_INCLUDE_DIR)." && exit 1)
|
||||
@ls $(JSC_LIB) >/dev/null 2>&1 || (echo "Failed to access WebKit lib directory at $(JSC_LIB)." && exit 1)
|
||||
|
||||
@@ -936,7 +945,7 @@ jsc-bindings: headers bindings
|
||||
|
||||
.PHONY: clone-submodules
|
||||
clone-submodules:
|
||||
git -c submodule."vendor/WebKit".update=none submodule update --init --recursive --depth=1 --progress
|
||||
git -c submodule."src/bun.js/WebKit".update=none submodule update --init --recursive --depth=1 --progress
|
||||
|
||||
|
||||
.PHONY: headers
|
||||
@@ -1256,7 +1265,7 @@ jsc-build-mac-compile:
|
||||
-DENABLE_STATIC_JSC=ON \
|
||||
-DENABLE_SINGLE_THREADED_VM_ENTRY_SCOPE=ON \
|
||||
-DALLOW_LINE_AND_COLUMN_NUMBER_IN_BUILTINS=ON \
|
||||
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
|
||||
-DCMAKE_BUILD_TYPE=Release \
|
||||
-DUSE_THIN_ARCHIVES=OFF \
|
||||
-DBUN_FAST_TLS=ON \
|
||||
-DENABLE_FTL_JIT=ON \
|
||||
@@ -1268,7 +1277,7 @@ jsc-build-mac-compile:
|
||||
$(WEBKIT_DIR) \
|
||||
$(WEBKIT_RELEASE_DIR) && \
|
||||
CFLAGS="$(CFLAGS) -ffat-lto-objects" CXXFLAGS="$(CXXFLAGS) -ffat-lto-objects" \
|
||||
cmake --build $(WEBKIT_RELEASE_DIR) --config RelWithDebInfo --target jsc
|
||||
cmake --build $(WEBKIT_RELEASE_DIR) --config Release --target jsc
|
||||
|
||||
.PHONY: jsc-build-mac-compile-lto
|
||||
jsc-build-mac-compile-lto:
|
||||
@@ -1370,7 +1379,7 @@ jsc-build-linux-compile-config-debug:
|
||||
$(WEBKIT_DEBUG_DIR)
|
||||
|
||||
# If you get "Error: could not load cache"
|
||||
# run rm -rf vendor/WebKit/CMakeCache.txt
|
||||
# run rm -rf src/bun.js/WebKit/CMakeCache.txt
|
||||
.PHONY: jsc-build-linux-compile-build
|
||||
jsc-build-linux-compile-build:
|
||||
mkdir -p $(WEBKIT_RELEASE_DIR) && \
|
||||
@@ -1405,7 +1414,7 @@ jsc-build-copy-debug:
|
||||
cp $(WEBKIT_DEBUG_DIR)/lib/libbmalloc.a $(BUN_DEPS_OUT_DIR)/libbmalloc.a
|
||||
|
||||
clean-jsc:
|
||||
cd vendor/WebKit && rm -rf **/CMakeCache.txt **/CMakeFiles && rm -rf vendor/WebKit/WebKitBuild
|
||||
cd src/bun.js/WebKit && rm -rf **/CMakeCache.txt **/CMakeFiles && rm -rf src/bun.js/WebKit/WebKitBuild
|
||||
clean-bindings:
|
||||
rm -rf $(OBJ_DIR)/*.o $(DEBUG_OBJ_DIR)/*.o $(DEBUG_OBJ_DIR)/webcore/*.o $(DEBUG_BINDINGS_OBJ) $(OBJ_DIR)/webcore/*.o $(BINDINGS_OBJ) $(OBJ_DIR)/*.d $(DEBUG_OBJ_DIR)/*.d
|
||||
|
||||
|
||||
@@ -3,9 +3,9 @@
|
||||
"scripts": {
|
||||
"deps": "exit 0",
|
||||
"build": "exit 0",
|
||||
"bench:bun": "bun bun.js",
|
||||
"bench:node": "node node.mjs",
|
||||
"bench:deno": "deno run -A --unstable deno.js",
|
||||
"bench:bun": "$BUN bun.js",
|
||||
"bench:node": "$NODE node.mjs",
|
||||
"bench:deno": "$DENO run -A --unstable deno.js",
|
||||
"bench": "bun run bench:bun && bun run bench:node && bun run bench:deno"
|
||||
}
|
||||
}
|
||||
|
||||
BIN
bench/bun.lockb
BIN
bench/bun.lockb
Binary file not shown.
@@ -1,11 +1,11 @@
|
||||
{
|
||||
"name": "bench",
|
||||
"scripts": {
|
||||
"bench:bun": "bun bun.js",
|
||||
"bench:node": "node node.mjs",
|
||||
"bench:bun": "$BUN bun.js",
|
||||
"bench:node": "$NODE node.mjs",
|
||||
"deps": "cd src && bun run deps",
|
||||
"build": "cd src && bun run build",
|
||||
"bench:deno": "deno run -A --unstable deno.js",
|
||||
"bench:deno": "$DENO run -A --unstable deno.js",
|
||||
"bench": "bun run bench:bun && bun run bench:node && bun run bench:deno"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,14 +0,0 @@
|
||||
syntax = "proto3";
|
||||
package benchmark;
|
||||
|
||||
service BenchmarkService {
|
||||
rpc Ping(Request) returns (Response);
|
||||
}
|
||||
|
||||
message Request {
|
||||
string message = 1;
|
||||
}
|
||||
|
||||
message Response {
|
||||
string message = 1;
|
||||
}
|
||||
@@ -1,33 +0,0 @@
|
||||
-----BEGIN CERTIFICATE-----
|
||||
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
|
||||
-----END CERTIFICATE-----
|
||||
@@ -1,31 +0,0 @@
|
||||
const grpc = require("@grpc/grpc-js");
|
||||
const protoLoader = require("@grpc/proto-loader");
|
||||
const packageDefinition = protoLoader.loadSync("benchmark.proto", {});
|
||||
const proto = grpc.loadPackageDefinition(packageDefinition).benchmark;
|
||||
const fs = require("fs");
|
||||
|
||||
function ping(call, callback) {
|
||||
callback(null, { message: "Hello, World" });
|
||||
}
|
||||
|
||||
function main() {
|
||||
const server = new grpc.Server();
|
||||
server.addService(proto.BenchmarkService.service, { ping: ping });
|
||||
const tls = !!process.env.TLS && (process.env.TLS === "1" || process.env.TLS === "true");
|
||||
const port = process.env.PORT || 50051;
|
||||
const host = process.env.HOST || "localhost";
|
||||
let credentials;
|
||||
if (tls) {
|
||||
const ca = fs.readFileSync("./cert.pem");
|
||||
const key = fs.readFileSync("./key.pem");
|
||||
const cert = fs.readFileSync("./cert.pem");
|
||||
credentials = grpc.ServerCredentials.createSsl(ca, [{ private_key: key, cert_chain: cert }]);
|
||||
} else {
|
||||
credentials = grpc.ServerCredentials.createInsecure();
|
||||
}
|
||||
server.bindAsync(`${host}:${port}`, credentials, () => {
|
||||
console.log(`Server running at ${tls ? "https" : "http"}://${host}:${port}`);
|
||||
});
|
||||
}
|
||||
|
||||
main();
|
||||
@@ -1,52 +0,0 @@
|
||||
-----BEGIN PRIVATE KEY-----
|
||||
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
|
||||
z/cCLOrUJfealezimyd8SKPWPeHhrA==
|
||||
-----END PRIVATE KEY-----
|
||||
@@ -1,15 +0,0 @@
|
||||
{
|
||||
"name": "bench",
|
||||
"scripts": {
|
||||
"deps": "exit 0",
|
||||
"build": "exit 0",
|
||||
"bun:server": "TLS=1 PORT=50051 bun ./index.js",
|
||||
"node:server": "TLS=1 PORT=50051 node ./index.js",
|
||||
"bench": "ghz --cacert ./cert.pem --proto ./benchmark.proto --call benchmark.BenchmarkService.Ping -d '{\"message\": \"Hello\"}' --total=100000 localhost:50051",
|
||||
"bench:insecure": "ghz --insecure --proto ./benchmark.proto --call benchmark.BenchmarkService.Ping -d '{\"message\": \"Hello\"}' --total=100000 localhost:50051"
|
||||
},
|
||||
"dependencies": {
|
||||
"@grpc/grpc-js": "1.12.0",
|
||||
"@grpc/proto-loader": "0.7.10"
|
||||
}
|
||||
}
|
||||
@@ -3,9 +3,9 @@
|
||||
"scripts": {
|
||||
"deps": "exit 0",
|
||||
"build": "exit 0",
|
||||
"bench:bun": "bun bun.js",
|
||||
"bench:node": "node node.mjs",
|
||||
"bench:deno": "deno run -A --unstable deno.js",
|
||||
"bench:bun": "$BUN bun.js",
|
||||
"bench:node": "$NODE node.mjs",
|
||||
"bench:deno": "$DENO run -A --unstable deno.js",
|
||||
"bench": "bun run bench:bun && bun run bench:node && bun run bench:deno"
|
||||
},
|
||||
"dependencies": {
|
||||
|
||||
@@ -3,9 +3,9 @@
|
||||
"scripts": {
|
||||
"deps": "exit 0",
|
||||
"build": "exit 0",
|
||||
"bench:bun": "bun bun.js | grep iter",
|
||||
"bench:node": "node node.mjs | grep iter",
|
||||
"bench:deno": "deno run -A --unstable deno.mjs | grep iter",
|
||||
"bench:bun": "$BUN bun.js | grep iter",
|
||||
"bench:node": "$NODE node.mjs | grep iter",
|
||||
"bench:deno": "$DENO run -A --unstable deno.mjs | grep iter",
|
||||
"bench": "bun run bench:bun && bun run bench:node && bun run bench:deno"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,8 +3,8 @@
|
||||
"scripts": {
|
||||
"deps": "exit 0",
|
||||
"build": "exit 0",
|
||||
"bench:bun": "bun bun.js",
|
||||
"bench:node": "node node.mjs",
|
||||
"bench:bun": "$BUN bun.js",
|
||||
"bench:node": "$NODE node.mjs",
|
||||
"bench": "bun run bench:bun && bun run bench:node"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -7,7 +7,6 @@
|
||||
"@swc/core": "^1.2.133",
|
||||
"benchmark": "^2.1.4",
|
||||
"braces": "^3.0.2",
|
||||
"color": "^4.2.3",
|
||||
"esbuild": "^0.14.12",
|
||||
"eventemitter3": "^5.0.0",
|
||||
"execa": "^8.0.1",
|
||||
@@ -15,7 +14,6 @@
|
||||
"fdir": "^6.1.0",
|
||||
"mitata": "^0.1.6",
|
||||
"string-width": "7.1.0",
|
||||
"tinycolor2": "^1.6.0",
|
||||
"zx": "^7.2.3"
|
||||
},
|
||||
"scripts": {
|
||||
|
||||
@@ -1,15 +0,0 @@
|
||||
import { bench, run } from "./runner.mjs";
|
||||
|
||||
for (let size of [32, 2048, 1024 * 16, 1024 * 1024 * 2, 1024 * 1024 * 16]) {
|
||||
for (let fillSize of [4, 8, 16, 11]) {
|
||||
const buffer = Buffer.allocUnsafe(size);
|
||||
|
||||
const pattern = "x".repeat(fillSize);
|
||||
|
||||
bench(`Buffer.fill ${size} bytes with ${fillSize} byte value`, () => {
|
||||
buffer.fill(pattern);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
await run();
|
||||
@@ -1,25 +0,0 @@
|
||||
import Color from "color";
|
||||
import tinycolor from "tinycolor2";
|
||||
import { bench, group, run } from "./runner.mjs";
|
||||
|
||||
const inputs = ["#f00", "rgb(255, 0, 0)", "rgba(255, 0, 0, 1)", "hsl(0, 100%, 50%)"];
|
||||
|
||||
for (const input of inputs) {
|
||||
group(`${input}`, () => {
|
||||
if (typeof Bun !== "undefined") {
|
||||
bench("Bun.color()", () => {
|
||||
Bun.color(input, "css");
|
||||
});
|
||||
}
|
||||
|
||||
bench("color", () => {
|
||||
Color(input).hex();
|
||||
});
|
||||
|
||||
bench("'tinycolor2'", () => {
|
||||
tinycolor(input).toHexString();
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
await run();
|
||||
@@ -5,10 +5,10 @@
|
||||
},
|
||||
"scripts": {
|
||||
"build": "exit 0",
|
||||
"bench:bun": "bun bun.js",
|
||||
"bench:node": "node node.mjs",
|
||||
"bench:bun": "$BUN bun.js",
|
||||
"bench:node": "$NODE node.mjs",
|
||||
"deps": "npm install && bash src/download.sh",
|
||||
"bench:deno": "deno run -A --unstable-ffi deno.js",
|
||||
"bench:deno": "$DENO run -A --unstable-ffi deno.js",
|
||||
"bench": "bun run bench:bun && bun run bench:node && bun run bench:deno"
|
||||
}
|
||||
}
|
||||
|
||||
70
build.zig
70
build.zig
@@ -52,14 +52,14 @@ const BunBuildOptions = struct {
|
||||
/// instead of at compile time. This is disabled in release or if this flag
|
||||
/// is set (to allow CI to build a portable executable). Affected files:
|
||||
///
|
||||
/// - src/bake/runtime.ts (bundled)
|
||||
/// - src/kit/runtime.ts (bundled)
|
||||
/// - src/bun.js/api/FFI.h
|
||||
///
|
||||
/// A similar technique is used in C++ code for JavaScript builtins
|
||||
codegen_embed: bool = false,
|
||||
force_embed_code: bool = false,
|
||||
|
||||
/// `./build/codegen` or equivalent
|
||||
codegen_path: []const u8,
|
||||
generated_code_dir: []const u8,
|
||||
no_llvm: bool,
|
||||
|
||||
cached_options_module: ?*Module = null,
|
||||
@@ -71,7 +71,7 @@ const BunBuildOptions = struct {
|
||||
}
|
||||
|
||||
pub fn shouldEmbedCode(opts: *const BunBuildOptions) bool {
|
||||
return opts.optimize != .Debug or opts.codegen_embed;
|
||||
return opts.optimize != .Debug or opts.force_embed_code;
|
||||
}
|
||||
|
||||
pub fn buildOptionsModule(this: *BunBuildOptions, b: *Build) *Module {
|
||||
@@ -83,10 +83,10 @@ const BunBuildOptions = struct {
|
||||
opts.addOption([]const u8, "base_path", b.pathFromRoot("."));
|
||||
opts.addOption([]const u8, "codegen_path", std.fs.path.resolve(b.graph.arena, &.{
|
||||
b.build_root.path.?,
|
||||
this.codegen_path,
|
||||
this.generated_code_dir,
|
||||
}) catch @panic("OOM"));
|
||||
|
||||
opts.addOption(bool, "codegen_embed", this.shouldEmbedCode());
|
||||
opts.addOption(bool, "embed_code", this.shouldEmbedCode());
|
||||
opts.addOption(u32, "canary_revision", this.canary_revision orelse 0);
|
||||
opts.addOption(bool, "is_canary", this.canary_revision != null);
|
||||
opts.addOption(Version, "version", this.version);
|
||||
@@ -157,7 +157,7 @@ pub fn build(b: *Build) !void {
|
||||
|
||||
// TODO: Upgrade path for 0.14.0
|
||||
// b.graph.zig_lib_directory = brk: {
|
||||
// const sub_path = "vendor/zig/lib";
|
||||
// const sub_path = "src/deps/zig/lib";
|
||||
// const dir = try b.build_root.handle.openDir(sub_path, .{});
|
||||
// break :brk .{ .handle = dir, .path = try b.build_root.join(b.graph.arena, &.{sub_path}) };
|
||||
// };
|
||||
@@ -195,13 +195,12 @@ pub fn build(b: *Build) !void {
|
||||
|
||||
const target = b.resolveTargetQuery(target_query);
|
||||
|
||||
const codegen_path = b.pathFromRoot(
|
||||
b.option([]const u8, "codegen_path", "Set the generated code directory") orelse
|
||||
const generated_code_dir = b.pathFromRoot(
|
||||
b.option([]const u8, "generated-code", "Set the generated code directory") orelse
|
||||
"build/debug/codegen",
|
||||
);
|
||||
const codegen_embed = b.option(bool, "codegen_embed", "If codegen files should be embedded in the binary") orelse false;
|
||||
|
||||
const bun_version = b.option([]const u8, "version", "Value of `Bun.version`") orelse "0.0.0";
|
||||
const force_embed_js_code = b.option(bool, "force_embed_js_code", "Always embed JavaScript builtins") orelse false;
|
||||
|
||||
b.reference_trace = ref_trace: {
|
||||
const trace = b.option(u32, "reference-trace", "Set the reference trace") orelse 16;
|
||||
@@ -219,8 +218,8 @@ pub fn build(b: *Build) !void {
|
||||
.os = os,
|
||||
.arch = arch,
|
||||
|
||||
.codegen_path = codegen_path,
|
||||
.codegen_embed = codegen_embed,
|
||||
.generated_code_dir = generated_code_dir,
|
||||
.force_embed_code = force_embed_js_code,
|
||||
.no_llvm = no_llvm,
|
||||
|
||||
.version = try Version.parse(bun_version),
|
||||
@@ -296,7 +295,7 @@ pub fn build(b: *Build) !void {
|
||||
bun_check_obj.generated_bin = null;
|
||||
step.dependOn(&bun_check_obj.step);
|
||||
|
||||
// The default install step will run zig build check. This is so ZLS
|
||||
// The default install step will run zig build check This is so ZLS
|
||||
// identifies the codebase, as well as performs checking if build on
|
||||
// save is enabled.
|
||||
|
||||
@@ -352,7 +351,7 @@ pub inline fn addMultiCheck(
|
||||
.tracy_callstack_depth = root_build_options.tracy_callstack_depth,
|
||||
.version = root_build_options.version,
|
||||
.reported_nodejs_version = root_build_options.reported_nodejs_version,
|
||||
.codegen_path = root_build_options.codegen_path,
|
||||
.generated_code_dir = root_build_options.generated_code_dir,
|
||||
.no_llvm = root_build_options.no_llvm,
|
||||
};
|
||||
|
||||
@@ -369,7 +368,6 @@ pub fn addBunObject(b: *Build, opts: *BunBuildOptions) *Compile {
|
||||
.root_source_file = switch (opts.os) {
|
||||
.wasm => b.path("root_wasm.zig"),
|
||||
else => b.path("root.zig"),
|
||||
// else => b.path("root_css.zig"),
|
||||
},
|
||||
.target = opts.target,
|
||||
.optimize = opts.optimize,
|
||||
@@ -476,45 +474,13 @@ fn addInternalPackages(b: *Build, obj: *Compile, opts: *BunBuildOptions) void {
|
||||
.{ .file = "ZigGeneratedClasses.zig", .import = "ZigGeneratedClasses" },
|
||||
.{ .file = "ResolvedSourceTag.zig", .import = "ResolvedSourceTag" },
|
||||
.{ .file = "ErrorCode.zig", .import = "ErrorCode" },
|
||||
.{ .file = "runtime.out.js" },
|
||||
.{ .file = "bake.client.js", .import = "bake-codegen/bake.client.js", .enable = opts.shouldEmbedCode() },
|
||||
.{ .file = "bake.error.js", .import = "bake-codegen/bake.error.js", .enable = opts.shouldEmbedCode() },
|
||||
.{ .file = "bake.server.js", .import = "bake-codegen/bake.server.js", .enable = opts.shouldEmbedCode() },
|
||||
.{ .file = "bun-error/index.js", .enable = opts.shouldEmbedCode() },
|
||||
.{ .file = "bun-error/bun-error.css", .enable = opts.shouldEmbedCode() },
|
||||
.{ .file = "fallback-decoder.js", .enable = opts.shouldEmbedCode() },
|
||||
.{ .file = "node-fallbacks/assert.js" },
|
||||
.{ .file = "node-fallbacks/buffer.js" },
|
||||
.{ .file = "node-fallbacks/console.js" },
|
||||
.{ .file = "node-fallbacks/constants.js" },
|
||||
.{ .file = "node-fallbacks/crypto.js" },
|
||||
.{ .file = "node-fallbacks/domain.js" },
|
||||
.{ .file = "node-fallbacks/events.js" },
|
||||
.{ .file = "node-fallbacks/http.js" },
|
||||
.{ .file = "node-fallbacks/https.js" },
|
||||
.{ .file = "node-fallbacks/net.js" },
|
||||
.{ .file = "node-fallbacks/os.js" },
|
||||
.{ .file = "node-fallbacks/path.js" },
|
||||
.{ .file = "node-fallbacks/process.js" },
|
||||
.{ .file = "node-fallbacks/punycode.js" },
|
||||
.{ .file = "node-fallbacks/querystring.js" },
|
||||
.{ .file = "node-fallbacks/stream.js" },
|
||||
.{ .file = "node-fallbacks/string_decoder.js" },
|
||||
.{ .file = "node-fallbacks/sys.js" },
|
||||
.{ .file = "node-fallbacks/timers.js" },
|
||||
.{ .file = "node-fallbacks/tty.js" },
|
||||
.{ .file = "node-fallbacks/url.js" },
|
||||
.{ .file = "node-fallbacks/util.js" },
|
||||
.{ .file = "node-fallbacks/zlib.js" },
|
||||
.{ .file = "kit.client.js", .import = "kit-codegen/kit.client.js", .enable = opts.shouldEmbedCode() },
|
||||
.{ .file = "kit.server.js", .import = "kit-codegen/kit.server.js", .enable = opts.shouldEmbedCode() },
|
||||
}) |entry| {
|
||||
if (!@hasField(@TypeOf(entry), "enable") or entry.enable) {
|
||||
const path = b.pathJoin(&.{ opts.codegen_path, entry.file });
|
||||
const path = b.pathJoin(&.{ opts.generated_code_dir, entry.file });
|
||||
validateGeneratedPath(path);
|
||||
const import_path = if (@hasField(@TypeOf(entry), "import"))
|
||||
entry.import
|
||||
else
|
||||
entry.file;
|
||||
obj.root_module.addAnonymousImport(import_path, .{
|
||||
obj.root_module.addAnonymousImport(entry.import, .{
|
||||
.root_source_file = .{ .cwd_relative = path },
|
||||
});
|
||||
}
|
||||
|
||||
@@ -30,10 +30,6 @@ macro(optionx variable type description)
|
||||
set(multiValueArgs)
|
||||
cmake_parse_arguments(${variable} "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
||||
|
||||
if(DEFINED ${variable})
|
||||
set(${variable}_VALUE ${${variable}})
|
||||
endif()
|
||||
|
||||
if(NOT ${type} MATCHES "^(BOOL|STRING|FILEPATH|PATH|INTERNAL)$")
|
||||
set(${variable}_REGEX ${type})
|
||||
set(${variable}_TYPE STRING)
|
||||
@@ -69,9 +65,7 @@ macro(optionx variable type description)
|
||||
message(FATAL_ERROR "Invalid ${${variable}_SOURCE}: ${${variable}_PREVIEW}=\"${${variable}}\", please use ${${variable}_PREVIEW}=<${${variable}_REGEX}>")
|
||||
endif()
|
||||
|
||||
if(NOT ${variable}_VALUE STREQUAL ${variable})
|
||||
message(STATUS "Set ${variable}: ${${variable}}")
|
||||
endif()
|
||||
message(STATUS "Set ${variable}: ${${variable}}")
|
||||
endmacro()
|
||||
|
||||
# unsupported()
|
||||
@@ -128,7 +122,6 @@ optionx(CACHE_PATH FILEPATH "The path to the cache directory" DEFAULT ${BUILD_PA
|
||||
optionx(CACHE_STRATEGY "read-write|read-only|write-only|none" "The strategy to use for caching" DEFAULT "read-write")
|
||||
|
||||
optionx(CI BOOL "If CI is enabled" DEFAULT OFF)
|
||||
optionx(ENABLE_ANALYSIS BOOL "If static analysis targets should be enabled" DEFAULT OFF)
|
||||
|
||||
if(CI)
|
||||
set(WARNING FATAL_ERROR)
|
||||
@@ -146,8 +139,24 @@ endif()
|
||||
optionx(VENDOR_PATH FILEPATH "The path to the vendor directory" DEFAULT ${CWD}/vendor)
|
||||
optionx(TMP_PATH FILEPATH "The path to the temporary directory" DEFAULT ${BUILD_PATH}/tmp)
|
||||
|
||||
optionx(FRESH BOOL "Set when --fresh is used" DEFAULT OFF)
|
||||
optionx(CLEAN BOOL "Set when --clean is used" DEFAULT OFF)
|
||||
|
||||
# --- Helper functions ---
|
||||
|
||||
function(parse_semver value variable)
|
||||
string(REGEX MATCH "([0-9]+)\\.([0-9]+)\\.([0-9]+)" match "${value}")
|
||||
|
||||
if(NOT match)
|
||||
message(FATAL_ERROR "Invalid semver: \"${value}\"")
|
||||
endif()
|
||||
|
||||
set(${variable}_VERSION "${CMAKE_MATCH_1}.${CMAKE_MATCH_2}.${CMAKE_MATCH_3}" PARENT_SCOPE)
|
||||
set(${variable}_VERSION_MAJOR "${CMAKE_MATCH_1}" PARENT_SCOPE)
|
||||
set(${variable}_VERSION_MINOR "${CMAKE_MATCH_2}" PARENT_SCOPE)
|
||||
set(${variable}_VERSION_PATCH "${CMAKE_MATCH_3}" PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
# setenv()
|
||||
# Description:
|
||||
# Sets an environment variable during the build step, and writes it to a .env file.
|
||||
@@ -185,154 +194,102 @@ function(setenv variable value)
|
||||
message(STATUS "Set ENV ${variable}: ${value}")
|
||||
endfunction()
|
||||
|
||||
# satisfies_range()
|
||||
# check_command()
|
||||
# Description:
|
||||
# Check if a version satisfies a version range
|
||||
# Checks if a command is available, used by `find_command()` as a validator.
|
||||
# Arguments:
|
||||
# version string - The version to check (e.g. "1.2.3")
|
||||
# range string - The range to check against (e.g. ">=1.2.3")
|
||||
# variable string - The variable to store the result in
|
||||
function(satisfies_range version range variable)
|
||||
if(range STREQUAL "ignore")
|
||||
set(${variable} ON PARENT_SCOPE)
|
||||
return()
|
||||
endif()
|
||||
# FOUND bool - The variable to set to true if the version is found
|
||||
# CMD string - The executable to check the version of
|
||||
function(check_command FOUND CMD)
|
||||
set(${FOUND} OFF PARENT_SCOPE)
|
||||
|
||||
set(${variable} OFF PARENT_SCOPE)
|
||||
|
||||
string(REGEX MATCH "([0-9]+)\\.([0-9]+)\\.([0-9]+)" match "${version}")
|
||||
if(NOT match)
|
||||
return()
|
||||
endif()
|
||||
set(version ${CMAKE_MATCH_1}.${CMAKE_MATCH_2}.${CMAKE_MATCH_3})
|
||||
|
||||
string(REGEX MATCH "(>=|<=|>|<)?([0-9]+)\\.([0-9]+)\\.([0-9]+)" match "${range}")
|
||||
if(NOT match)
|
||||
return()
|
||||
endif()
|
||||
set(comparator ${CMAKE_MATCH_1})
|
||||
set(range ${CMAKE_MATCH_2}.${CMAKE_MATCH_3}.${CMAKE_MATCH_4})
|
||||
|
||||
if(comparator STREQUAL ">=")
|
||||
set(comparator VERSION_GREATER_EQUAL)
|
||||
elseif(comparator STREQUAL ">")
|
||||
set(comparator VERSION_GREATER)
|
||||
elseif(comparator STREQUAL "<=")
|
||||
set(comparator VERSION_LESS_EQUAL)
|
||||
elseif(comparator STREQUAL "<")
|
||||
set(comparator VERSION_LESS)
|
||||
if(${CMD} MATCHES "zig")
|
||||
set(CHECK_COMMAND ${CMD} version)
|
||||
else()
|
||||
set(comparator VERSION_EQUAL)
|
||||
set(CHECK_COMMAND ${CMD} --version)
|
||||
endif()
|
||||
|
||||
if(version ${comparator} ${range})
|
||||
set(${variable} ON PARENT_SCOPE)
|
||||
execute_process(
|
||||
COMMAND ${CHECK_COMMAND}
|
||||
RESULT_VARIABLE RESULT
|
||||
OUTPUT_VARIABLE OUTPUT
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||
)
|
||||
|
||||
if(NOT RESULT EQUAL 0 OR NOT OUTPUT)
|
||||
message(DEBUG "${CHECK_COMMAND}, exited with code ${RESULT}")
|
||||
return()
|
||||
endif()
|
||||
|
||||
parse_semver(${OUTPUT} CMD)
|
||||
parse_semver(${CHECK_COMMAND_VERSION} CHECK)
|
||||
|
||||
if(CHECK_COMMAND_VERSION MATCHES ">=")
|
||||
if(NOT CMD_VERSION VERSION_GREATER_EQUAL ${CHECK_VERSION})
|
||||
message(DEBUG "${CHECK_COMMAND}, actual: ${CMD_VERSION}, expected: ${CHECK_COMMAND_VERSION}")
|
||||
return()
|
||||
endif()
|
||||
elseif(CHECK_COMMAND_VERSION MATCHES ">")
|
||||
if(NOT CMD_VERSION VERSION_GREATER ${CHECK_VERSION})
|
||||
message(DEBUG "${CHECK_COMMAND}, actual: ${CMD_VERSION}, expected: ${CHECK_COMMAND_VERSION}")
|
||||
return()
|
||||
endif()
|
||||
else()
|
||||
if(NOT CMD_VERSION VERSION_EQUAL ${CHECK_VERSION})
|
||||
message(DEBUG "${CHECK_COMMAND}, actual: ${CMD_VERSION}, expected: =${CHECK_COMMAND_VERSION}")
|
||||
return()
|
||||
endif()
|
||||
endif()
|
||||
|
||||
set(${FOUND} TRUE PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
# find_command()
|
||||
# Description:
|
||||
# Finds a command, similar to `find_program()`, but allows for version checking.
|
||||
# Arguments:
|
||||
# VARIABLE string - The variable to set
|
||||
# VERSION_VARIABLE string - The variable to check for the version
|
||||
# COMMAND string[] - The names of the command to find
|
||||
# PATHS string[] - The paths to search for the command
|
||||
# REQUIRED bool - If false, the command is optional
|
||||
# VERSION string - The version of the command to find (e.g. "1.2.3" or ">1.2.3")
|
||||
# VARIABLE string - The variable to set
|
||||
# COMMAND string[] - The names of the command to find
|
||||
# PATHS string[] - The paths to search for the command
|
||||
# REQUIRED bool - If false, the command is optional
|
||||
# VERSION string - The version of the command to find (e.g. "1.2.3" or ">1.2.3")
|
||||
function(find_command)
|
||||
set(args VARIABLE VERSION_VARIABLE REQUIRED VERSION)
|
||||
set(options)
|
||||
set(args VARIABLE VERSION MIN_VERSION REQUIRED)
|
||||
set(multiArgs COMMAND PATHS)
|
||||
cmake_parse_arguments(FIND "" "${args}" "${multiArgs}" ${ARGN})
|
||||
cmake_parse_arguments(CMD "${options}" "${args}" "${multiArgs}" ${ARGN})
|
||||
|
||||
if(NOT FIND_VARIABLE OR NOT FIND_COMMAND)
|
||||
message(FATAL_ERROR "${CMAKE_CURRENT_FUNCTION}: VARIABLE and COMMAND are required")
|
||||
if(NOT CMD_VARIABLE)
|
||||
message(FATAL_ERROR "find_command: VARIABLE is required")
|
||||
endif()
|
||||
|
||||
if(NOT FIND_VERSION_VARIABLE)
|
||||
set(FIND_VERSION_VARIABLE ${FIND_VARIABLE}_VERSION)
|
||||
if(NOT CMD_COMMAND)
|
||||
message(FATAL_ERROR "find_command: COMMAND is required")
|
||||
endif()
|
||||
|
||||
list(GET FIND_COMMAND 0 FIND_NAME)
|
||||
if(FIND_VERSION)
|
||||
optionx(${FIND_VERSION_VARIABLE} STRING "The version of ${FIND_NAME} to find" DEFAULT "${FIND_VERSION}")
|
||||
|
||||
function(find_command_version variable exe)
|
||||
set(${variable} OFF PARENT_SCOPE)
|
||||
|
||||
if(${exe} MATCHES "(go|zig)(\.exe)?$")
|
||||
set(command ${exe} version)
|
||||
else()
|
||||
set(command ${exe} --version)
|
||||
endif()
|
||||
|
||||
execute_process(
|
||||
COMMAND ${command}
|
||||
RESULT_VARIABLE result
|
||||
OUTPUT_VARIABLE output
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||
ERROR_QUIET
|
||||
)
|
||||
|
||||
if(NOT result EQUAL 0)
|
||||
set(reason "exited with ${result}")
|
||||
elseif(NOT output)
|
||||
set(reason "no output")
|
||||
else()
|
||||
string(REGEX MATCH "([0-9]+)\\.([0-9]+)\\.([0-9]+)" match "${output}")
|
||||
if(match)
|
||||
set(version ${CMAKE_MATCH_1}.${CMAKE_MATCH_2}.${CMAKE_MATCH_3})
|
||||
set(reason "\"${version}\"")
|
||||
else()
|
||||
set(reason "no version")
|
||||
endif()
|
||||
endif()
|
||||
|
||||
set_property(GLOBAL PROPERTY ${FIND_NAME} "${exe}: ${reason}" APPEND)
|
||||
|
||||
if(version)
|
||||
satisfies_range(${version} ${${FIND_VERSION_VARIABLE}} ${variable})
|
||||
set(${variable} ${${variable}} PARENT_SCOPE)
|
||||
endif()
|
||||
endfunction()
|
||||
|
||||
set(FIND_VALIDATOR VALIDATOR find_command_version)
|
||||
if(CMD_VERSION)
|
||||
set(CHECK_COMMAND_VERSION ${CMD_VERSION}) # special global variable
|
||||
set(CMD_VALIDATOR VALIDATOR check_command)
|
||||
endif()
|
||||
|
||||
find_program(
|
||||
${FIND_VARIABLE}
|
||||
NAMES ${FIND_COMMAND}
|
||||
PATHS ${FIND_PATHS}
|
||||
${FIND_VALIDATOR}
|
||||
${CMD_VARIABLE}
|
||||
NAMES ${CMD_COMMAND}
|
||||
PATHS ${CMD_PATHS}
|
||||
${CMD_VALIDATOR}
|
||||
)
|
||||
|
||||
if(NOT FIND_REQUIRED STREQUAL "OFF" AND ${FIND_VARIABLE} MATCHES "NOTFOUND")
|
||||
set(error "Command not found: \"${FIND_NAME}\"")
|
||||
|
||||
if(FIND_VERSION)
|
||||
set(error "${error} that satisfies version \"${${FIND_VERSION_VARIABLE}}\"")
|
||||
if(NOT CMD_REQUIRED STREQUAL "OFF" AND ${CMD_VARIABLE} MATCHES "NOTFOUND")
|
||||
if(CMD_VERSION)
|
||||
message(FATAL_ERROR "Command not found: \"${CMD_COMMAND}\" that matches version \"${CHECK_COMMAND_VERSION}\"")
|
||||
endif()
|
||||
|
||||
get_property(FIND_RESULTS GLOBAL PROPERTY ${FIND_NAME})
|
||||
if(NOT FIND_RESULTS MATCHES "NOTFOUND")
|
||||
set(error "${error}\nThe following commands did not satisfy the requirement:")
|
||||
foreach(result ${FIND_RESULTS})
|
||||
set(error "${error}\n ${result}")
|
||||
endforeach()
|
||||
endif()
|
||||
|
||||
set(error "${error}\nTo fix this, either:
|
||||
1. Install ${FIND_NAME} ${${FIND_VERSION_VARIABLE}}
|
||||
2. Set -D${FIND_VERSION_VARIABLE}=<version> to require a different version
|
||||
3. Set -D${FIND_VERSION_VARIABLE}=ignore to allow any version
|
||||
")
|
||||
message(FATAL_ERROR ${error})
|
||||
message(FATAL_ERROR "Command not found: \"${CMD_COMMAND}\"")
|
||||
endif()
|
||||
|
||||
if(${FIND_VARIABLE} MATCHES "NOTFOUND")
|
||||
unset(${FIND_VARIABLE} PARENT_SCOPE)
|
||||
if(${CMD_VARIABLE} MATCHES "NOTFOUND")
|
||||
unset(${CMD_VARIABLE} PARENT_SCOPE)
|
||||
else()
|
||||
setx(${FIND_VARIABLE} ${${FIND_VARIABLE}} PARENT_SCOPE)
|
||||
setx(${CMD_VARIABLE} ${${CMD_VARIABLE}} PARENT_SCOPE)
|
||||
endif()
|
||||
endfunction()
|
||||
|
||||
|
||||
@@ -91,8 +91,6 @@ if(LINUX)
|
||||
optionx(ENABLE_VALGRIND BOOL "If Valgrind support should be enabled" DEFAULT OFF)
|
||||
endif()
|
||||
|
||||
optionx(ENABLE_PRETTIER BOOL "If prettier should be ran" DEFAULT OFF)
|
||||
|
||||
if(USE_VALGRIND AND NOT USE_BASELINE)
|
||||
message(WARNING "If valgrind is enabled, baseline must also be enabled")
|
||||
setx(USE_BASELINE ON)
|
||||
|
||||
@@ -1,11 +1,15 @@
|
||||
# https://clang.llvm.org/docs/ClangFormat.html
|
||||
|
||||
file(GLOB BUN_H_SOURCES LIST_DIRECTORIES false ${CONFIGURE_DEPENDS}
|
||||
${CWD}/src/bun.js/bindings/*.h
|
||||
${CWD}/src/bun.js/modules/*.h
|
||||
find_command(
|
||||
VARIABLE
|
||||
CLANG_FORMAT_PROGRAM
|
||||
COMMAND
|
||||
clang-format
|
||||
REQUIRED
|
||||
OFF
|
||||
)
|
||||
|
||||
set(CLANG_FORMAT_SOURCES ${BUN_C_SOURCES} ${BUN_CXX_SOURCES} ${BUN_H_SOURCES})
|
||||
set(CLANG_FORMAT_SOURCES ${BUN_C_SOURCES} ${BUN_CXX_SOURCES})
|
||||
|
||||
register_command(
|
||||
TARGET
|
||||
|
||||
@@ -1,5 +1,16 @@
|
||||
# https://clang.llvm.org/extra/clang-tidy/
|
||||
|
||||
find_command(
|
||||
VARIABLE
|
||||
CLANG_TIDY_PROGRAM
|
||||
COMMAND
|
||||
clang-tidy
|
||||
VERSION
|
||||
${LLVM_VERSION}
|
||||
REQUIRED
|
||||
OFF
|
||||
)
|
||||
|
||||
set(CLANG_TIDY_SOURCES ${BUN_C_SOURCES} ${BUN_CXX_SOURCES})
|
||||
|
||||
set(CLANG_TIDY_COMMAND ${CLANG_TIDY_PROGRAM}
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
# IWYU = "Include What You Use"
|
||||
# https://include-what-you-use.org/
|
||||
|
||||
setx(IWYU_SOURCE_PATH ${CACHE_PATH}/iwyu-${LLVM_VERSION})
|
||||
setx(IWYU_SOURCE_PATH ${CACHE_PATH}/iwyu-${LLVM_VERSION_MAJOR})
|
||||
setx(IWYU_BUILD_PATH ${IWYU_SOURCE_PATH}/build)
|
||||
setx(IWYU_PROGRAM ${IWYU_BUILD_PATH}/bin/include-what-you-use)
|
||||
|
||||
@@ -11,7 +11,7 @@ register_repository(
|
||||
REPOSITORY
|
||||
include-what-you-use/include-what-you-use
|
||||
BRANCH
|
||||
clang_${LLVM_VERSION}
|
||||
clang_${LLVM_VERSION_MAJOR}
|
||||
PATH
|
||||
${IWYU_SOURCE_PATH}
|
||||
)
|
||||
|
||||
@@ -95,7 +95,7 @@ register_command(
|
||||
if(GIT_CHANGED_SOURCES)
|
||||
set(PRETTIER_CHANGED_SOURCES)
|
||||
foreach(source ${PRETTIER_SOURCES})
|
||||
list(FIND GIT_CHANGED_SOURCES ${source} index)
|
||||
list(FIND PRETTIER_CHANGED_SOURCES ${source} index)
|
||||
if(NOT ${index} EQUAL -1)
|
||||
list(APPEND PRETTIER_CHANGED_SOURCES ${source})
|
||||
endif()
|
||||
|
||||
@@ -21,16 +21,10 @@ else()
|
||||
set(buns ${bun})
|
||||
endif()
|
||||
|
||||
# Some commands use this path, and some do not.
|
||||
# In the future, change those commands so that generated files are written to this path.
|
||||
optionx(CODEGEN_PATH FILEPATH "Path to the codegen directory" DEFAULT ${BUILD_PATH}/codegen)
|
||||
|
||||
if(RELEASE OR CI)
|
||||
set(DEFAULT_CODEGEN_EMBED ON)
|
||||
else()
|
||||
set(DEFAULT_CODEGEN_EMBED OFF)
|
||||
endif()
|
||||
|
||||
optionx(CODEGEN_EMBED BOOL "If codegen files should be embedded in the binary" DEFAULT ${DEFAULT_CODEGEN_EMBED})
|
||||
|
||||
if((NOT DEFINED CONFIGURE_DEPENDS AND NOT CI) OR CONFIGURE_DEPENDS)
|
||||
set(CONFIGURE_DEPENDS "CONFIGURE_DEPENDS")
|
||||
else()
|
||||
@@ -39,6 +33,39 @@ endif()
|
||||
|
||||
# --- Codegen ---
|
||||
|
||||
set(BUN_ZIG_IDENTIFIER_SOURCE ${CWD}/src/js_lexer)
|
||||
set(BUN_ZIG_IDENTIFIER_SCRIPT ${BUN_ZIG_IDENTIFIER_SOURCE}/identifier_data.zig)
|
||||
|
||||
file(GLOB BUN_ZIG_IDENTIFIER_SOURCES ${CONFIGURE_DEPENDS}
|
||||
${BUN_ZIG_IDENTIFIER_SCRIPT}
|
||||
${BUN_ZIG_IDENTIFIER_SOURCE}/*.zig
|
||||
)
|
||||
|
||||
set(BUN_ZIG_IDENTIFIER_OUTPUTS
|
||||
${BUN_ZIG_IDENTIFIER_SOURCE}/id_continue_bitset.blob
|
||||
${BUN_ZIG_IDENTIFIER_SOURCE}/id_continue_bitset.meta.blob
|
||||
${BUN_ZIG_IDENTIFIER_SOURCE}/id_start_bitset.blob
|
||||
${BUN_ZIG_IDENTIFIER_SOURCE}/id_start_bitset.meta.blob
|
||||
)
|
||||
|
||||
register_command(
|
||||
TARGET
|
||||
bun-identifier-data
|
||||
COMMENT
|
||||
"Generating src/js_lexer/*.blob"
|
||||
COMMAND
|
||||
${ZIG_EXECUTABLE}
|
||||
run
|
||||
${CMAKE_ZIG_FLAGS}
|
||||
${BUN_ZIG_IDENTIFIER_SCRIPT}
|
||||
SOURCES
|
||||
${BUN_ZIG_IDENTIFIER_SOURCES}
|
||||
TARGETS
|
||||
clone-zig
|
||||
OUTPUTS
|
||||
${BUN_ZIG_IDENTIFIER_OUTPUTS}
|
||||
)
|
||||
|
||||
set(BUN_ERROR_SOURCE ${CWD}/packages/bun-error)
|
||||
|
||||
file(GLOB BUN_ERROR_SOURCES ${CONFIGURE_DEPENDS}
|
||||
@@ -49,7 +76,7 @@ file(GLOB BUN_ERROR_SOURCES ${CONFIGURE_DEPENDS}
|
||||
${BUN_ERROR_SOURCE}/img/*
|
||||
)
|
||||
|
||||
set(BUN_ERROR_OUTPUT ${CODEGEN_PATH}/bun-error)
|
||||
set(BUN_ERROR_OUTPUT ${BUN_ERROR_SOURCE}/dist)
|
||||
set(BUN_ERROR_OUTPUTS
|
||||
${BUN_ERROR_OUTPUT}/index.js
|
||||
${BUN_ERROR_OUTPUT}/bun-error.css
|
||||
@@ -87,13 +114,13 @@ register_command(
|
||||
)
|
||||
|
||||
set(BUN_FALLBACK_DECODER_SOURCE ${CWD}/src/fallback.ts)
|
||||
set(BUN_FALLBACK_DECODER_OUTPUT ${CODEGEN_PATH}/fallback-decoder.js)
|
||||
set(BUN_FALLBACK_DECODER_OUTPUT ${CWD}/src/fallback.out.js)
|
||||
|
||||
register_command(
|
||||
TARGET
|
||||
bun-fallback-decoder
|
||||
COMMENT
|
||||
"Building fallback-decoder.js"
|
||||
"Building src/fallback.out.js"
|
||||
COMMAND
|
||||
${ESBUILD_EXECUTABLE} ${ESBUILD_ARGS}
|
||||
${BUN_FALLBACK_DECODER_SOURCE}
|
||||
@@ -110,7 +137,7 @@ register_command(
|
||||
)
|
||||
|
||||
set(BUN_RUNTIME_JS_SOURCE ${CWD}/src/runtime.bun.js)
|
||||
set(BUN_RUNTIME_JS_OUTPUT ${CODEGEN_PATH}/runtime.out.js)
|
||||
set(BUN_RUNTIME_JS_OUTPUT ${CWD}/src/runtime.out.js)
|
||||
|
||||
register_command(
|
||||
TARGET
|
||||
@@ -140,7 +167,7 @@ file(GLOB BUN_NODE_FALLBACKS_SOURCES ${CONFIGURE_DEPENDS}
|
||||
${BUN_NODE_FALLBACKS_SOURCE}/*.js
|
||||
)
|
||||
|
||||
set(BUN_NODE_FALLBACKS_OUTPUT ${CODEGEN_PATH}/node-fallbacks)
|
||||
set(BUN_NODE_FALLBACKS_OUTPUT ${BUN_NODE_FALLBACKS_SOURCE}/out)
|
||||
set(BUN_NODE_FALLBACKS_OUTPUTS)
|
||||
foreach(source ${BUN_NODE_FALLBACKS_SOURCES})
|
||||
get_filename_component(filename ${source} NAME)
|
||||
@@ -160,7 +187,7 @@ register_command(
|
||||
TARGET
|
||||
bun-node-fallbacks
|
||||
COMMENT
|
||||
"Building node-fallbacks/*.js"
|
||||
"Building src/node-fallbacks/*.js"
|
||||
CWD
|
||||
${BUN_NODE_FALLBACKS_SOURCE}
|
||||
COMMAND
|
||||
@@ -297,41 +324,40 @@ register_command(
|
||||
${BUN_JAVASCRIPT_OUTPUTS}
|
||||
)
|
||||
|
||||
set(BUN_BAKE_RUNTIME_CODEGEN_SCRIPT ${CWD}/src/codegen/bake-codegen.ts)
|
||||
set(BUN_KIT_RUNTIME_CODEGEN_SCRIPT ${CWD}/src/codegen/kit-codegen.ts)
|
||||
|
||||
file(GLOB_RECURSE BUN_BAKE_RUNTIME_SOURCES ${CONFIGURE_DEPENDS}
|
||||
${CWD}/src/bake/*.ts
|
||||
${CWD}/src/bake/*/*.ts
|
||||
${CWD}/src/bake/*/*.css
|
||||
file(GLOB_RECURSE BUN_KIT_RUNTIME_SOURCES ${CONFIGURE_DEPENDS}
|
||||
${CWD}/src/kit/*.ts
|
||||
${CWD}/src/kit/*/*.ts
|
||||
)
|
||||
|
||||
list(APPEND BUN_BAKE_RUNTIME_CODEGEN_SOURCES
|
||||
list(APPEND BUN_KIT_RUNTIME_CODEGEN_SOURCES
|
||||
${CWD}/src/bun.js/bindings/InternalModuleRegistry.cpp
|
||||
)
|
||||
|
||||
set(BUN_BAKE_RUNTIME_OUTPUTS
|
||||
${CODEGEN_PATH}/bake.client.js
|
||||
${CODEGEN_PATH}/bake.server.js
|
||||
set(BUN_KIT_RUNTIME_OUTPUTS
|
||||
${CODEGEN_PATH}/kit_empty_file
|
||||
${CODEGEN_PATH}/kit.client.js
|
||||
${CODEGEN_PATH}/kit.server.js
|
||||
)
|
||||
|
||||
register_command(
|
||||
TARGET
|
||||
bun-bake-codegen
|
||||
bun-kit-codegen
|
||||
COMMENT
|
||||
"Bundling Kit Runtime"
|
||||
COMMAND
|
||||
${BUN_EXECUTABLE}
|
||||
run
|
||||
${BUN_BAKE_RUNTIME_CODEGEN_SCRIPT}
|
||||
${BUN_KIT_RUNTIME_CODEGEN_SCRIPT}
|
||||
--debug=${DEBUG}
|
||||
--codegen_root=${CODEGEN_PATH}
|
||||
SOURCES
|
||||
${BUN_BAKE_RUNTIME_SOURCES}
|
||||
${BUN_BAKE_RUNTIME_CODEGEN_SOURCES}
|
||||
${BUN_BAKE_RUNTIME_CODEGEN_SCRIPT}
|
||||
${BUN_KIT_RUNTIME_SOURCES}
|
||||
${BUN_KIT_RUNTIME_CODEGEN_SOURCES}
|
||||
${BUN_KIT_RUNTIME_CODEGEN_SCRIPT}
|
||||
OUTPUTS
|
||||
${CODEGEN_PATH}/bake_empty_file
|
||||
${BUN_BAKE_RUNTIME_OUTPUTS}
|
||||
${BUN_KIT_RUNTIME_OUTPUTS}
|
||||
)
|
||||
|
||||
set(BUN_JS_SINK_SCRIPT ${CWD}/src/codegen/generate-jssink.ts)
|
||||
@@ -372,7 +398,6 @@ set(BUN_OBJECT_LUT_SOURCES
|
||||
${CWD}/src/bun.js/bindings/BunProcess.cpp
|
||||
${CWD}/src/bun.js/bindings/ProcessBindingConstants.cpp
|
||||
${CWD}/src/bun.js/bindings/ProcessBindingNatives.cpp
|
||||
${CWD}/src/bun.js/modules/NodeModuleModule.cpp
|
||||
)
|
||||
|
||||
set(BUN_OBJECT_LUT_OUTPUTS
|
||||
@@ -382,10 +407,8 @@ set(BUN_OBJECT_LUT_OUTPUTS
|
||||
${CODEGEN_PATH}/BunProcess.lut.h
|
||||
${CODEGEN_PATH}/ProcessBindingConstants.lut.h
|
||||
${CODEGEN_PATH}/ProcessBindingNatives.lut.h
|
||||
${CODEGEN_PATH}/NodeModuleModule.lut.h
|
||||
)
|
||||
|
||||
|
||||
macro(WEBKIT_ADD_SOURCE_DEPENDENCIES _source _deps)
|
||||
set(_tmp)
|
||||
get_source_file_property(_tmp ${_source} OBJECT_DEPENDS)
|
||||
@@ -464,6 +487,7 @@ list(APPEND BUN_ZIG_SOURCES
|
||||
)
|
||||
|
||||
set(BUN_ZIG_GENERATED_SOURCES
|
||||
${BUN_ZIG_IDENTIFIER_OUTPUTS}
|
||||
${BUN_ERROR_OUTPUTS}
|
||||
${BUN_FALLBACK_DECODER_OUTPUT}
|
||||
${BUN_RUNTIME_JS_OUTPUT}
|
||||
@@ -475,9 +499,9 @@ set(BUN_ZIG_GENERATED_SOURCES
|
||||
|
||||
# In debug builds, these are not embedded, but rather referenced at runtime.
|
||||
if (DEBUG)
|
||||
list(APPEND BUN_ZIG_GENERATED_SOURCES ${CODEGEN_PATH}/bake_empty_file)
|
||||
list(APPEND BUN_ZIG_GENERATED_SOURCES ${CODEGEN_PATH}/kit_empty_file)
|
||||
else()
|
||||
list(APPEND BUN_ZIG_GENERATED_SOURCES ${BUN_BAKE_RUNTIME_OUTPUTS})
|
||||
list(APPEND BUN_ZIG_GENERATED_SOURCES ${BUN_KIT_RUNTIME_OUTPUTS})
|
||||
endif()
|
||||
|
||||
set(BUN_ZIG_OUTPUT ${BUILD_PATH}/bun-zig.o)
|
||||
@@ -519,8 +543,7 @@ register_command(
|
||||
-Dsha=${REVISION}
|
||||
-Dreported_nodejs_version=${NODEJS_VERSION}
|
||||
-Dcanary=${CANARY_REVISION}
|
||||
-Dcodegen_path=${CODEGEN_PATH}
|
||||
-Dcodegen_embed=$<IF:$<BOOL:${CODEGEN_EMBED}>,true,false>
|
||||
-Dgenerated-code=${CODEGEN_PATH}
|
||||
ARTIFACTS
|
||||
${BUN_ZIG_OUTPUT}
|
||||
TARGETS
|
||||
@@ -546,8 +569,7 @@ file(GLOB BUN_CXX_SOURCES ${CONFIGURE_DEPENDS}
|
||||
${CWD}/src/bun.js/bindings/webcrypto/*.cpp
|
||||
${CWD}/src/bun.js/bindings/webcrypto/*/*.cpp
|
||||
${CWD}/src/bun.js/bindings/v8/*.cpp
|
||||
${CWD}/src/bun.js/bindings/v8/shim/*.cpp
|
||||
${CWD}/src/bake/*.cpp
|
||||
${CWD}/src/kit/*.cpp
|
||||
${CWD}/src/deps/*.cpp
|
||||
${BUN_USOCKETS_SOURCE}/src/crypto/*.cpp
|
||||
)
|
||||
@@ -594,7 +616,6 @@ list(APPEND BUN_CPP_SOURCES
|
||||
${BUN_C_SOURCES}
|
||||
${BUN_CXX_SOURCES}
|
||||
${VENDOR_PATH}/picohttpparser/picohttpparser.c
|
||||
${NODEJS_HEADERS_PATH}/include/node/node_version.h
|
||||
${BUN_ZIG_GENERATED_CLASSES_OUTPUTS}
|
||||
${BUN_JS_SINK_OUTPUTS}
|
||||
${BUN_JAVASCRIPT_OUTPUTS}
|
||||
@@ -672,7 +693,6 @@ target_include_directories(${bun} PRIVATE
|
||||
${CWD}/src/bun.js/bindings/webcore
|
||||
${CWD}/src/bun.js/bindings/webcrypto
|
||||
${CWD}/src/bun.js/bindings/sqlite
|
||||
${CWD}/src/bun.js/bindings/v8
|
||||
${CWD}/src/bun.js/modules
|
||||
${CWD}/src/js/builtins
|
||||
${CWD}/src/napi
|
||||
@@ -680,7 +700,6 @@ target_include_directories(${bun} PRIVATE
|
||||
${CODEGEN_PATH}
|
||||
${VENDOR_PATH}
|
||||
${VENDOR_PATH}/picohttpparser
|
||||
${NODEJS_HEADERS_PATH}/include
|
||||
)
|
||||
|
||||
# --- C/C++ Definitions ---
|
||||
@@ -856,33 +875,26 @@ else()
|
||||
-Wl,--as-needed
|
||||
-Wl,--gc-sections
|
||||
-Wl,-z,stack-size=12800000
|
||||
-Wl,--wrap=cosf
|
||||
-Wl,--wrap=exp
|
||||
-Wl,--wrap=expf
|
||||
-Wl,--wrap=fcntl
|
||||
-Wl,--wrap=fcntl64
|
||||
-Wl,--wrap=fmod
|
||||
-Wl,--wrap=fmodf
|
||||
-Wl,--wrap=fstat
|
||||
-Wl,--wrap=fstat64
|
||||
-Wl,--wrap=fstatat
|
||||
-Wl,--wrap=fstatat64
|
||||
-Wl,--wrap=stat64
|
||||
-Wl,--wrap=pow
|
||||
-Wl,--wrap=exp
|
||||
-Wl,--wrap=expf
|
||||
-Wl,--wrap=log
|
||||
-Wl,--wrap=log10f
|
||||
-Wl,--wrap=log2
|
||||
-Wl,--wrap=log2f
|
||||
-Wl,--wrap=logf
|
||||
-Wl,--wrap=lstat
|
||||
-Wl,--wrap=stat64
|
||||
-Wl,--wrap=stat
|
||||
-Wl,--wrap=fstat
|
||||
-Wl,--wrap=fstatat
|
||||
-Wl,--wrap=lstat64
|
||||
-Wl,--wrap=fstat64
|
||||
-Wl,--wrap=fstatat64
|
||||
-Wl,--wrap=mknod
|
||||
-Wl,--wrap=mknodat
|
||||
-Wl,--wrap=pow
|
||||
-Wl,--wrap=sincosf
|
||||
-Wl,--wrap=sinf
|
||||
-Wl,--wrap=stat
|
||||
-Wl,--wrap=stat64
|
||||
-Wl,--wrap=statx
|
||||
-Wl,--wrap=tanf
|
||||
-Wl,--wrap=fmod
|
||||
-Wl,--compress-debug-sections=zlib
|
||||
-Wl,-z,lazy
|
||||
-Wl,-z,norelro
|
||||
|
||||
@@ -18,7 +18,6 @@ register_cmake_command(
|
||||
-DCMAKE_POSITION_INDEPENDENT_CODE=ON
|
||||
-DCARES_SHARED=OFF
|
||||
-DCARES_BUILD_TOOLS=OFF # this was set to ON?
|
||||
-DCMAKE_INSTALL_LIBDIR=lib
|
||||
LIB_PATH
|
||||
lib
|
||||
LIBRARIES
|
||||
|
||||
@@ -11,13 +11,9 @@ find_command(
|
||||
COMMAND
|
||||
ccache
|
||||
REQUIRED
|
||||
${CI}
|
||||
ON
|
||||
)
|
||||
|
||||
if(NOT CCACHE_PROGRAM)
|
||||
return()
|
||||
endif()
|
||||
|
||||
set(CCACHE_ARGS CMAKE_C_COMPILER_LAUNCHER CMAKE_CXX_COMPILER_LAUNCHER)
|
||||
foreach(arg ${CCACHE_ARGS})
|
||||
setx(${arg} ${CCACHE_PROGRAM})
|
||||
|
||||
@@ -11,7 +11,7 @@ if(NOT GIT_PROGRAM)
|
||||
return()
|
||||
endif()
|
||||
|
||||
set(GIT_DIFF_COMMAND ${GIT_PROGRAM} diff --no-color --name-only --diff-filter=AMCR origin/main HEAD)
|
||||
set(GIT_DIFF_COMMAND ${GIT_PROGRAM} diff --no-color --name-only --diff-filter=AMCR)
|
||||
|
||||
execute_process(
|
||||
COMMAND
|
||||
@@ -34,10 +34,5 @@ if(NOT GIT_DIFF_RESULT EQUAL 0)
|
||||
endif()
|
||||
|
||||
string(REPLACE "\n" ";" GIT_CHANGED_SOURCES "${GIT_DIFF}")
|
||||
|
||||
if(CI)
|
||||
setx(GIT_CHANGED_SOURCES ${GIT_CHANGED_SOURCES})
|
||||
endif()
|
||||
|
||||
list(TRANSFORM GIT_CHANGED_SOURCES PREPEND ${CWD}/)
|
||||
list(LENGTH GIT_CHANGED_SOURCES GIT_CHANGED_SOURCES_COUNT)
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
optionx(ENABLE_LLVM BOOL "If LLVM should be used for compilation" DEFAULT ON)
|
||||
optionx(SKIP_LLVM BOOL "If LLVM setup should be skipped" DEFAULT OFF)
|
||||
|
||||
if(NOT ENABLE_LLVM)
|
||||
if(SKIP_LLVM)
|
||||
return()
|
||||
endif()
|
||||
|
||||
@@ -11,90 +11,45 @@ else()
|
||||
endif()
|
||||
|
||||
optionx(LLVM_VERSION STRING "The version of LLVM to use" DEFAULT ${DEFAULT_LLVM_VERSION})
|
||||
|
||||
string(REGEX MATCH "([0-9]+)\\.([0-9]+)\\.([0-9]+)" USE_LLVM_VERSION ${LLVM_VERSION})
|
||||
if(USE_LLVM_VERSION)
|
||||
set(LLVM_VERSION_MAJOR ${CMAKE_MATCH_1})
|
||||
set(LLVM_VERSION_MINOR ${CMAKE_MATCH_2})
|
||||
set(LLVM_VERSION_PATCH ${CMAKE_MATCH_3})
|
||||
endif()
|
||||
|
||||
set(LLVM_PATHS)
|
||||
parse_semver(${LLVM_VERSION} LLVM)
|
||||
|
||||
if(APPLE)
|
||||
execute_process(
|
||||
COMMAND brew --prefix
|
||||
OUTPUT_VARIABLE HOMEBREW_PREFIX
|
||||
COMMAND brew --prefix llvm@${LLVM_VERSION_MAJOR}
|
||||
OUTPUT_VARIABLE DEFAULT_LLVM_PREFIX
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||
ERROR_QUIET
|
||||
)
|
||||
|
||||
if(NOT HOMEBREW_PREFIX)
|
||||
if(CMAKE_SYSTEM_PROCESSOR MATCHES "arm64|ARM64|aarch64|AARCH64")
|
||||
set(HOMEBREW_PREFIX /opt/homebrew)
|
||||
else()
|
||||
set(HOMEBREW_PREFIX /usr/local)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
list(APPEND LLVM_PATHS ${HOMEBREW_PREFIX}/opt/llvm/bin)
|
||||
|
||||
if(USE_LLVM_VERSION)
|
||||
list(APPEND LLVM_PATHS ${HOMEBREW_PREFIX}/opt/llvm@${LLVM_VERSION_MAJOR}/bin)
|
||||
if(NOT DEFAULT_LLVM_PREFIX)
|
||||
set(DEFAULT_LLVM_PREFIX /opt/homebrew/opt/llvm)
|
||||
endif()
|
||||
elseif(NOT WIN32)
|
||||
set(DEFAULT_LLVM_PREFIX /usr/lib/llvm-${LLVM_VERSION_MAJOR})
|
||||
else()
|
||||
set(DEFAULT_LLVM_PREFIX /usr/lib)
|
||||
endif()
|
||||
|
||||
if(UNIX)
|
||||
list(APPEND LLVM_PATHS /usr/lib/llvm/bin)
|
||||
|
||||
if(USE_LLVM_VERSION)
|
||||
list(APPEND LLVM_PATHS
|
||||
/usr/lib/llvm-${LLVM_VERSION_MAJOR}.${LLVM_VERSION_MINOR}.${LLVM_VERSION_PATCH}/bin
|
||||
/usr/lib/llvm-${LLVM_VERSION_MAJOR}.${LLVM_VERSION_MINOR}/bin
|
||||
/usr/lib/llvm-${LLVM_VERSION_MAJOR}/bin
|
||||
)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
macro(find_llvm_command variable command)
|
||||
set(commands ${command})
|
||||
|
||||
if(USE_LLVM_VERSION)
|
||||
list(APPEND commands
|
||||
${command}-${LLVM_VERSION_MAJOR}.${LLVM_VERSION_MINOR}.${LLVM_VERSION_PATCH}
|
||||
${command}-${LLVM_VERSION_MAJOR}.${LLVM_VERSION_MINOR}
|
||||
${command}-${LLVM_VERSION_MAJOR}
|
||||
)
|
||||
endif()
|
||||
optionx(LLVM_PREFIX FILEPATH "The path to the LLVM installation" DEFAULT ${DEFAULT_LLVM_PREFIX})
|
||||
set(LLVM_PATH ${LLVM_PREFIX}/bin)
|
||||
|
||||
macro(find_llvm_command VARIABLE COMMAND)
|
||||
find_command(
|
||||
VARIABLE ${variable}
|
||||
VERSION_VARIABLE LLVM_VERSION
|
||||
COMMAND ${commands}
|
||||
PATHS ${LLVM_PATHS}
|
||||
VARIABLE ${VARIABLE}
|
||||
COMMAND ${COMMAND} ${COMMAND}-${LLVM_VERSION_MAJOR}
|
||||
PATHS ${LLVM_PATH}
|
||||
VERSION ${LLVM_VERSION}
|
||||
)
|
||||
list(APPEND CMAKE_ARGS -D${variable}=${${variable}})
|
||||
list(APPEND CMAKE_ARGS -D${VARIABLE}=${${VARIABLE}})
|
||||
endmacro()
|
||||
|
||||
macro(find_llvm_command_no_version variable command)
|
||||
set(commands ${command})
|
||||
|
||||
if(USE_LLVM_VERSION)
|
||||
list(APPEND commands
|
||||
${command}-${LLVM_VERSION_MAJOR}.${LLVM_VERSION_MINOR}.${LLVM_VERSION_PATCH}
|
||||
${command}-${LLVM_VERSION_MAJOR}.${LLVM_VERSION_MINOR}
|
||||
${command}-${LLVM_VERSION_MAJOR}
|
||||
)
|
||||
endif()
|
||||
|
||||
macro(find_llvm_command_no_version VARIABLE COMMAND)
|
||||
find_command(
|
||||
VARIABLE ${variable}
|
||||
VERSION_VARIABLE LLVM_VERSION
|
||||
COMMAND ${commands}
|
||||
PATHS ${LLVM_PATHS}
|
||||
VARIABLE ${VARIABLE}
|
||||
COMMAND ${COMMAND} ${COMMAND}-${LLVM_VERSION_MAJOR}
|
||||
PATHS ${LLVM_PATH}
|
||||
REQUIRED ON
|
||||
)
|
||||
list(APPEND CMAKE_ARGS -D${variable}=${${variable}})
|
||||
list(APPEND CMAKE_ARGS -D${VARIABLE}=${${VARIABLE}})
|
||||
endmacro()
|
||||
|
||||
if(WIN32)
|
||||
@@ -114,8 +69,3 @@ else()
|
||||
find_llvm_command(CMAKE_DSYMUTIL dsymutil)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
if(ENABLE_ANALYSIS)
|
||||
find_llvm_command(CLANG_FORMAT_PROGRAM clang-format)
|
||||
find_llvm_command(CLANG_TIDY_PROGRAM clang-tidy)
|
||||
endif()
|
||||
|
||||
@@ -2,7 +2,7 @@ option(WEBKIT_VERSION "The version of WebKit to use")
|
||||
option(WEBKIT_LOCAL "If a local version of WebKit should be used instead of downloading")
|
||||
|
||||
if(NOT WEBKIT_VERSION)
|
||||
set(WEBKIT_VERSION 543cca2140eafdba845f6689024abaac0d9924f5)
|
||||
set(WEBKIT_VERSION a303e09b6535ee560969b0310de50878cb66b454)
|
||||
endif()
|
||||
|
||||
if(WEBKIT_LOCAL)
|
||||
|
||||
@@ -1,262 +0,0 @@
|
||||
`Bun.color(input, outputFormat?)` leverages Bun's CSS parser to parse, normalize, and convert colors from user input to a variety of output formats, including:
|
||||
|
||||
| Format | Example |
|
||||
| ------------ | -------------------------------- |
|
||||
| `"css"` | `"red"` |
|
||||
| `"ansi"` | `"\x1b[38;2;255;0;0m"` |
|
||||
| `"ansi-16"` | `"\x1b[38;5;\tm"` |
|
||||
| `"ansi-256"` | `"\x1b[38;5;196m"` |
|
||||
| `"ansi-16m"` | `"\x1b[38;2;255;0;0m"` |
|
||||
| `"number"` | `0x1a2b3c` |
|
||||
| `"rgb"` | `"rgb(255, 99, 71)"` |
|
||||
| `"rgba"` | `"rgba(255, 99, 71, 0.5)"` |
|
||||
| `"hsl"` | `"hsl(120, 50%, 50%)"` |
|
||||
| `"hex"` | `"#1a2b3c"` |
|
||||
| `"HEX"` | `"#1A2B3C"` |
|
||||
| `"{rgb}"` | `{ r: 255, g: 99, b: 71 }` |
|
||||
| `"{rgba}"` | `{ r: 255, g: 99, b: 71, a: 1 }` |
|
||||
| `"[rgb]"` | `[ 255, 99, 71 ]` |
|
||||
| `"[rgba]"` | `[ 255, 99, 71, 255]` |
|
||||
|
||||
There are many different ways to use this API:
|
||||
|
||||
- Validate and normalize colors to persist in a database (`number` is the most database-friendly)
|
||||
- Convert colors to different formats
|
||||
- Colorful logging beyond the 16 colors many use today (use `ansi` if you don't want to figure out what the user's terminal supports, otherwise use `ansi-16`, `ansi-256`, or `ansi-16m` for how many colors the terminal supports)
|
||||
- Format colors for use in CSS injected into HTML
|
||||
- Get the `r`, `g`, `b`, and `a` color components as JavaScript objects or numbers from a CSS color string
|
||||
|
||||
You can think of this as an alternative to the popular npm packages [`color`](https://github.com/Qix-/color) and [`tinycolor2`](https://github.com/bgrins/TinyColor) except with full support for parsing CSS color strings and zero dependencies built directly into Bun.
|
||||
|
||||
### Flexible input
|
||||
|
||||
You can pass in any of the following:
|
||||
|
||||
- Standard CSS color names like `"red"`
|
||||
- Numbers like `0xff0000`
|
||||
- Hex strings like `"#f00"`
|
||||
- RGB strings like `"rgb(255, 0, 0)"`
|
||||
- RGBA strings like `"rgba(255, 0, 0, 1)"`
|
||||
- HSL strings like `"hsl(0, 100%, 50%)"`
|
||||
- HSLA strings like `"hsla(0, 100%, 50%, 1)"`
|
||||
- RGB objects like `{ r: 255, g: 0, b: 0 }`
|
||||
- RGBA objects like `{ r: 255, g: 0, b: 0, a: 1 }`
|
||||
- RGB arrays like `[255, 0, 0]`
|
||||
- RGBA arrays like `[255, 0, 0, 255]`
|
||||
- LAB strings like `"lab(50% 50% 50%)"`
|
||||
- ... anything else that CSS can parse as a single color value
|
||||
|
||||
### Format colors as CSS
|
||||
|
||||
The `"css"` format outputs valid CSS for use in stylesheets, inline styles, CSS variables, css-in-js, etc. It returns the most compact representation of the color as a string.
|
||||
|
||||
```ts
|
||||
Bun.color("red", "css"); // "red"
|
||||
Bun.color(0xff0000, "css"); // "#f000"
|
||||
Bun.color("#f00", "css"); // "red"
|
||||
Bun.color("#ff0000", "css"); // "red"
|
||||
Bun.color("rgb(255, 0, 0)", "css"); // "red"
|
||||
Bun.color("rgba(255, 0, 0, 1)", "css"); // "red"
|
||||
Bun.color("hsl(0, 100%, 50%)", "css"); // "red"
|
||||
Bun.color("hsla(0, 100%, 50%, 1)", "css"); // "red"
|
||||
Bun.color({ r: 255, g: 0, b: 0 }, "css"); // "red"
|
||||
Bun.color({ r: 255, g: 0, b: 0, a: 1 }, "css"); // "red"
|
||||
Bun.color([255, 0, 0], "css"); // "red"
|
||||
Bun.color([255, 0, 0, 255], "css"); // "red"
|
||||
```
|
||||
|
||||
If the input is unknown or fails to parse, `Bun.color` returns `null`.
|
||||
|
||||
### Format colors as ANSI (for terminals)
|
||||
|
||||
The `"ansi"` format outputs ANSI escape codes for use in terminals to make text colorful.
|
||||
|
||||
```ts
|
||||
Bun.color("red", "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
Bun.color(0xff0000, "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
Bun.color("#f00", "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
Bun.color("#ff0000", "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
Bun.color("rgb(255, 0, 0)", "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
Bun.color("rgba(255, 0, 0, 1)", "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
Bun.color("hsl(0, 100%, 50%)", "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
Bun.color("hsla(0, 100%, 50%, 1)", "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
Bun.color({ r: 255, g: 0, b: 0 }, "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
Bun.color({ r: 255, g: 0, b: 0, a: 1 }, "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
Bun.color([255, 0, 0], "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
Bun.color([255, 0, 0, 255], "ansi"); // "\u001b[38;2;255;0;0m"
|
||||
```
|
||||
|
||||
This gets the color depth of stdout and automatically chooses one of `"ansi-16m"`, `"ansi-256"`, `"ansi-16"` based on the environment variables. If stdout doesn't support any form of ANSI color, it returns an empty string. As with the rest of Bun's color API, if the input is unknown or fails to parse, it returns `null`.
|
||||
|
||||
#### 24-bit ANSI colors (`ansi-16m`)
|
||||
|
||||
The `"ansi-16m"` format outputs 24-bit ANSI colors for use in terminals to make text colorful. 24-bit color means you can display 16 million colors on supported terminals, and requires a modern terminal that supports it.
|
||||
|
||||
This converts the input color to RGBA, and then outputs that as an ANSI color.
|
||||
|
||||
```ts
|
||||
Bun.color("red", "ansi-16m"); // "\x1b[38;2;255;0;0m"
|
||||
Bun.color(0xff0000, "ansi-16m"); // "\x1b[38;2;255;0;0m"
|
||||
Bun.color("#f00", "ansi-16m"); // "\x1b[38;2;255;0;0m"
|
||||
Bun.color("#ff0000", "ansi-16m"); // "\x1b[38;2;255;0;0m"
|
||||
```
|
||||
|
||||
#### 256 ANSI colors (`ansi-256`)
|
||||
|
||||
The `"ansi-256"` format approximates the input color to the nearest of the 256 ANSI colors supported by some terminals.
|
||||
|
||||
```ts
|
||||
Bun.color("red", "ansi-256"); // "\u001b[38;5;196m"
|
||||
Bun.color(0xff0000, "ansi-256"); // "\u001b[38;5;196m"
|
||||
Bun.color("#f00", "ansi-256"); // "\u001b[38;5;196m"
|
||||
Bun.color("#ff0000", "ansi-256"); // "\u001b[38;5;196m"
|
||||
```
|
||||
|
||||
To convert from RGBA to one of the 256 ANSI colors, we ported the algorithm that [`tmux` uses](https://github.com/tmux/tmux/blob/dae2868d1227b95fd076fb4a5efa6256c7245943/colour.c#L44-L55).
|
||||
|
||||
#### 16 ANSI colors (`ansi-16`)
|
||||
|
||||
The `"ansi-16"` format approximates the input color to the nearest of the 16 ANSI colors supported by most terminals.
|
||||
|
||||
```ts
|
||||
Bun.color("red", "ansi-16"); // "\u001b[38;5;\tm"
|
||||
Bun.color(0xff0000, "ansi-16"); // "\u001b[38;5;\tm"
|
||||
Bun.color("#f00", "ansi-16"); // "\u001b[38;5;\tm"
|
||||
Bun.color("#ff0000", "ansi-16"); // "\u001b[38;5;\tm"
|
||||
```
|
||||
|
||||
This works by first converting the input to a 24-bit RGB color space, then to `ansi-256`, and then we convert that to the nearest 16 ANSI color.
|
||||
|
||||
### Format colors as numbers
|
||||
|
||||
The `"number"` format outputs a 24-bit number for use in databases, configuration, or any other use case where a compact representation of the color is desired.
|
||||
|
||||
```ts
|
||||
Bun.color("red", "number"); // 16711680
|
||||
Bun.color(0xff0000, "number"); // 16711680
|
||||
Bun.color({ r: 255, g: 0, b: 0 }, "number"); // 16711680
|
||||
Bun.color([255, 0, 0], "number"); // 16711680
|
||||
Bun.color("rgb(255, 0, 0)", "number"); // 16711680
|
||||
Bun.color("rgba(255, 0, 0, 1)", "number"); // 16711680
|
||||
Bun.color("hsl(0, 100%, 50%)", "number"); // 16711680
|
||||
Bun.color("hsla(0, 100%, 50%, 1)", "number"); // 16711680
|
||||
```
|
||||
|
||||
### Get the red, green, blue, and alpha channels
|
||||
|
||||
You can use the `"{rgba}"`, `"{rgb}"`, `"[rgba]"` and `"[rgb]"` formats to get the red, green, blue, and alpha channels as objects or arrays.
|
||||
|
||||
#### `{rgba}` object
|
||||
|
||||
The `"{rgba}"` format outputs an object with the red, green, blue, and alpha channels.
|
||||
|
||||
```ts
|
||||
type RGBAObject = {
|
||||
// 0 - 255
|
||||
r: number;
|
||||
// 0 - 255
|
||||
g: number;
|
||||
// 0 - 255
|
||||
b: number;
|
||||
// 0 - 1
|
||||
a: number;
|
||||
};
|
||||
```
|
||||
|
||||
Example:
|
||||
|
||||
```ts
|
||||
Bun.color("hsl(0, 0%, 50%)", "{rgba}"); // { r: 128, g: 128, b: 128, a: 1 }
|
||||
Bun.color("red", "{rgba}"); // { r: 255, g: 0, b: 0, a: 1 }
|
||||
Bun.color(0xff0000, "{rgba}"); // { r: 255, g: 0, b: 0, a: 1 }
|
||||
Bun.color({ r: 255, g: 0, b: 0 }, "{rgba}"); // { r: 255, g: 0, b: 0, a: 1 }
|
||||
Bun.color([255, 0, 0], "{rgba}"); // { r: 255, g: 0, b: 0, a: 1 }
|
||||
```
|
||||
|
||||
To behave similarly to CSS, the `a` channel is a decimal number between `0` and `1`.
|
||||
|
||||
The `"{rgb}"` format is similar, but it doesn't include the alpha channel.
|
||||
|
||||
```ts
|
||||
Bun.color("hsl(0, 0%, 50%)", "{rgb}"); // { r: 128, g: 128, b: 128 }
|
||||
Bun.color("red", "{rgb}"); // { r: 255, g: 0, b: 0 }
|
||||
Bun.color(0xff0000, "{rgb}"); // { r: 255, g: 0, b: 0 }
|
||||
Bun.color({ r: 255, g: 0, b: 0 }, "{rgb}"); // { r: 255, g: 0, b: 0 }
|
||||
Bun.color([255, 0, 0], "{rgb}"); // { r: 255, g: 0, b: 0 }
|
||||
```
|
||||
|
||||
#### `[rgba]` array
|
||||
|
||||
The `"[rgba]"` format outputs an array with the red, green, blue, and alpha channels.
|
||||
|
||||
```ts
|
||||
// All values are 0 - 255
|
||||
type RGBAArray = [number, number, number, number];
|
||||
```
|
||||
|
||||
Example:
|
||||
|
||||
```ts
|
||||
Bun.color("hsl(0, 0%, 50%)", "[rgba]"); // [128, 128, 128, 255]
|
||||
Bun.color("red", "[rgba]"); // [255, 0, 0, 255]
|
||||
Bun.color(0xff0000, "[rgba]"); // [255, 0, 0, 255]
|
||||
Bun.color({ r: 255, g: 0, b: 0 }, "[rgba]"); // [255, 0, 0, 255]
|
||||
Bun.color([255, 0, 0], "[rgba]"); // [255, 0, 0, 255]
|
||||
```
|
||||
|
||||
Unlike the `"{rgba}"` format, the alpha channel is an integer between `0` and `255`. This is useful for typed arrays where each channel must be the same underlying type.
|
||||
|
||||
The `"[rgb]"` format is similar, but it doesn't include the alpha channel.
|
||||
|
||||
```ts
|
||||
Bun.color("hsl(0, 0%, 50%)", "[rgb]"); // [128, 128, 128]
|
||||
Bun.color("red", "[rgb]"); // [255, 0, 0]
|
||||
Bun.color(0xff0000, "[rgb]"); // [255, 0, 0]
|
||||
Bun.color({ r: 255, g: 0, b: 0 }, "[rgb]"); // [255, 0, 0]
|
||||
Bun.color([255, 0, 0], "[rgb]"); // [255, 0, 0]
|
||||
```
|
||||
|
||||
### Format colors as hex strings
|
||||
|
||||
The `"hex"` format outputs a lowercase hex string for use in CSS or other contexts.
|
||||
|
||||
```ts
|
||||
Bun.color("hsl(0, 0%, 50%)", "hex"); // "#808080"
|
||||
Bun.color("red", "hex"); // "#ff0000"
|
||||
Bun.color(0xff0000, "hex"); // "#ff0000"
|
||||
Bun.color({ r: 255, g: 0, b: 0 }, "hex"); // "#ff0000"
|
||||
Bun.color([255, 0, 0], "hex"); // "#ff0000"
|
||||
```
|
||||
|
||||
The `"HEX"` format is similar, but it outputs a hex string with uppercase letters instead of lowercase letters.
|
||||
|
||||
```ts
|
||||
Bun.color("hsl(0, 0%, 50%)", "HEX"); // "#808080"
|
||||
Bun.color("red", "HEX"); // "#FF0000"
|
||||
Bun.color(0xff0000, "HEX"); // "#FF0000"
|
||||
Bun.color({ r: 255, g: 0, b: 0 }, "HEX"); // "#FF0000"
|
||||
Bun.color([255, 0, 0], "HEX"); // "#FF0000"
|
||||
```
|
||||
|
||||
### Bundle-time client-side color formatting
|
||||
|
||||
Like many of Bun's APIs, you can use macros to invoke `Bun.color` at bundle-time for use in client-side JavaScript builds:
|
||||
|
||||
```ts#client-side.ts
|
||||
import { color } from "bun" with { type: "macro" };
|
||||
|
||||
console.log(color("#f00", "css"));
|
||||
```
|
||||
|
||||
Then, build the client-side code:
|
||||
|
||||
```sh
|
||||
bun build ./client-side.ts
|
||||
```
|
||||
|
||||
This will output the following to `client-side.js`:
|
||||
|
||||
```js
|
||||
// client-side.ts
|
||||
console.log("red");
|
||||
```
|
||||
@@ -14,7 +14,7 @@ In Bun v1.1.9, we added support for DNS caching. This cache makes repeated conne
|
||||
|
||||
At the time of writing, we cache up to 255 entries for a maximum of 30 seconds (each). If any connections to a host fail, we remove the entry from the cache. When multiple connections are made to the same host simultaneously, DNS lookups are deduplicated to avoid making multiple requests for the same host.
|
||||
|
||||
This cache is automatically used by:
|
||||
This cache is automatically used by;
|
||||
|
||||
- `bun install`
|
||||
- `fetch()`
|
||||
@@ -99,7 +99,7 @@ console.log(stats);
|
||||
|
||||
### Configuring DNS cache TTL
|
||||
|
||||
Bun defaults to 30 seconds for the TTL of DNS cache entries. To change this, you can set the environment variable `$BUN_CONFIG_DNS_TIME_TO_LIVE_SECONDS`. For example, to set the TTL to 5 seconds:
|
||||
Bun defaults to 30 seconds for the TTL of DNS cache entries. To change this, you can set the envionrment variable `$BUN_CONFIG_DNS_TIME_TO_LIVE_SECONDS`. For example, to set the TTL to 5 seconds:
|
||||
|
||||
```sh
|
||||
BUN_CONFIG_DNS_TIME_TO_LIVE_SECONDS=5 bun run my-script.ts
|
||||
|
||||
@@ -206,42 +206,4 @@ console.log(arr);
|
||||
// => Uint8Array(32) [ 185, 77, 39, 185, 147, ... ]
|
||||
```
|
||||
|
||||
### HMAC in `Bun.CryptoHasher`
|
||||
|
||||
`Bun.CryptoHasher` can be used to compute HMAC digests. To do so, pass the key to the constructor.
|
||||
|
||||
```ts
|
||||
const hasher = new Bun.CryptoHasher("sha256", "secret-key");
|
||||
hasher.update("hello world");
|
||||
console.log(hasher.digest("hex"));
|
||||
// => "095d5a21fe6d0646db223fdf3de6436bb8dfb2fab0b51677ecf6441fcf5f2a67"
|
||||
```
|
||||
|
||||
When using HMAC, a more limited set of algorithms are supported:
|
||||
|
||||
- `"blake2b512"`
|
||||
- `"md5"`
|
||||
- `"sha1"`
|
||||
- `"sha224"`
|
||||
- `"sha256"`
|
||||
- `"sha384"`
|
||||
- `"sha512-224"`
|
||||
- `"sha512-256"`
|
||||
- `"sha512"`
|
||||
|
||||
Unlike the non-HMAC `Bun.CryptoHasher`, the HMAC `Bun.CryptoHasher` instance is not reset after `.digest()` is called, and attempting to use the same instance again will throw an error.
|
||||
|
||||
Other methods like `.copy()` and `.update()` are supported (as long as it's before `.digest()`), but methods like `.digest()` that finalize the hasher are not.
|
||||
|
||||
```ts
|
||||
const hasher = new Bun.CryptoHasher("sha256", "secret-key");
|
||||
hasher.update("hello world");
|
||||
|
||||
const copy = hasher.copy();
|
||||
copy.update("!");
|
||||
console.log(copy.digest("hex"));
|
||||
// => "3840176c3d8923f59ac402b7550404b28ab11cb0ef1fa199130a5c37864b5497"
|
||||
|
||||
console.log(hasher.digest("hex"));
|
||||
// => "095d5a21fe6d0646db223fdf3de6436bb8dfb2fab0b51677ecf6441fcf5f2a67"
|
||||
```
|
||||
<!-- Bun.sha; -->
|
||||
|
||||
@@ -402,7 +402,7 @@ Bun.serve({
|
||||
});
|
||||
```
|
||||
|
||||
### Server name indication (SNI)
|
||||
### Sever name indication (SNI)
|
||||
|
||||
To configure the server name indication (SNI) for the server, set the `serverName` field in the `tls` object.
|
||||
|
||||
|
||||
@@ -325,28 +325,6 @@ As a performance optimization, the class constructor is not called, default init
|
||||
|
||||
The database columns are set as properties on the class instance.
|
||||
|
||||
### `.iterate()` (`@@iterator`)
|
||||
|
||||
Use `.iterate()` to run a query and incrementally return results. This is useful for large result sets that you want to process one row at a time without loading all the results into memory.
|
||||
|
||||
```ts
|
||||
const query = db.query("SELECT * FROM foo");
|
||||
for (const row of query.iterate()) {
|
||||
console.log(row);
|
||||
}
|
||||
```
|
||||
|
||||
You can also use the `@@iterator` protocol:
|
||||
|
||||
```ts
|
||||
const query = db.query("SELECT * FROM foo");
|
||||
for (const row of query) {
|
||||
console.log(row);
|
||||
}
|
||||
```
|
||||
|
||||
This feature was added in Bun v1.1.31.
|
||||
|
||||
### `.values()`
|
||||
|
||||
Use `values()` to run a query and get back all results as an array of arrays.
|
||||
|
||||
@@ -580,65 +580,6 @@ const foo = new Foo();
|
||||
console.log(foo); // => "foo"
|
||||
```
|
||||
|
||||
## `Bun.inspect.table(tabularData, properties, options)`
|
||||
|
||||
Format tabular data into a string. Like [`console.table`](https://developer.mozilla.org/en-US/docs/Web/API/console/table_static), except it returns a string rather than printing to the console.
|
||||
|
||||
```ts
|
||||
console.log(
|
||||
Bun.inspect.table([
|
||||
{ a: 1, b: 2, c: 3 },
|
||||
{ a: 4, b: 5, c: 6 },
|
||||
{ a: 7, b: 8, c: 9 },
|
||||
]),
|
||||
);
|
||||
//
|
||||
// ┌───┬───┬───┬───┐
|
||||
// │ │ a │ b │ c │
|
||||
// ├───┼───┼───┼───┤
|
||||
// │ 0 │ 1 │ 2 │ 3 │
|
||||
// │ 1 │ 4 │ 5 │ 6 │
|
||||
// │ 2 │ 7 │ 8 │ 9 │
|
||||
// └───┴───┴───┴───┘
|
||||
```
|
||||
|
||||
Additionally, you can pass an array of property names to display only a subset of properties.
|
||||
|
||||
```ts
|
||||
console.log(
|
||||
Bun.inspect.table(
|
||||
[
|
||||
{ a: 1, b: 2, c: 3 },
|
||||
{ a: 4, b: 5, c: 6 },
|
||||
],
|
||||
["a", "c"],
|
||||
),
|
||||
);
|
||||
//
|
||||
// ┌───┬───┬───┐
|
||||
// │ │ a │ c │
|
||||
// ├───┼───┼───┤
|
||||
// │ 0 │ 1 │ 3 │
|
||||
// │ 1 │ 4 │ 6 │
|
||||
// └───┴───┴───┘
|
||||
```
|
||||
|
||||
You can also conditionally enable ANSI colors by passing `{ colors: true }`.
|
||||
|
||||
```ts
|
||||
console.log(
|
||||
Bun.inspect.table(
|
||||
[
|
||||
{ a: 1, b: 2, c: 3 },
|
||||
{ a: 4, b: 5, c: 6 },
|
||||
],
|
||||
{
|
||||
colors: true,
|
||||
},
|
||||
),
|
||||
);
|
||||
```
|
||||
|
||||
## `Bun.nanoseconds()`
|
||||
|
||||
Returns the number of nanoseconds since the current `bun` process started, as a `number`. Useful for high-precision timing and benchmarking.
|
||||
|
||||
@@ -100,30 +100,12 @@ When deploying to production, we recommend the following:
|
||||
bun build --compile --minify --sourcemap ./path/to/my/app.ts --outfile myapp
|
||||
```
|
||||
|
||||
### Bytecode compilation
|
||||
|
||||
To improve startup time, enable bytecode compilation:
|
||||
|
||||
```sh
|
||||
bun build --compile --minify --sourcemap --bytecode ./path/to/my/app.ts --outfile myapp
|
||||
```
|
||||
|
||||
Using bytecode compilation, `tsc` starts 2x faster:
|
||||
|
||||
{% image src="https://github.com/user-attachments/assets/dc8913db-01d2-48f8-a8ef-ac4e984f9763" width="689" /%}
|
||||
|
||||
Bytecode compilation moves parsing overhead for large input files from runtime to bundle time. Your app starts faster, in exchange for making the `bun build` command a little slower. It doesn't obscure source code.
|
||||
|
||||
**Experimental:** Bytecode compilation is an experimental feature introduced in Bun v1.1.30. Only `cjs` format is supported (which means no top-level-await). Let us know if you run into any issues!
|
||||
|
||||
### What do these flags do?
|
||||
**What do these flags do?**
|
||||
|
||||
The `--minify` argument optimizes the size of the transpiled output code. If you have a large application, this can save megabytes of space. For smaller applications, it might still improve start time a little.
|
||||
|
||||
The `--sourcemap` argument embeds a sourcemap compressed with zstd, so that errors & stacktraces point to their original locations instead of the transpiled location. Bun will automatically decompress & resolve the sourcemap when an error occurs.
|
||||
|
||||
The `--bytecode` argument enables bytecode compilation. Every time you run JavaScript code in Bun, JavaScriptCore (the engine) will compile your source code into bytecode. We can move this parsing work from runtime to bundle time, saving you startup time.
|
||||
|
||||
## Worker
|
||||
|
||||
To use workers in a standalone executable, add the worker's entrypoint to the CLI arguments:
|
||||
|
||||
@@ -330,8 +330,6 @@ Depending on the target, Bun will apply different module resolution rules and op
|
||||
|
||||
If any entrypoints contains a Bun shebang (`#!/usr/bin/env bun`) the bundler will default to `target: "bun"` instead of `"browser"`.
|
||||
|
||||
When using `target: "bun"` and `format: "cjs"` together, the `// @bun @bun-cjs` pragma is added and the CommonJS wrapper function is not compatible with Node.js.
|
||||
|
||||
---
|
||||
|
||||
- `node`
|
||||
@@ -343,11 +341,7 @@ Depending on the target, Bun will apply different module resolution rules and op
|
||||
|
||||
Specifies the module format to be used in the generated bundles.
|
||||
|
||||
Bun defaults to `"esm"`, and provides experimental support for `"cjs"` and `"iife"`.
|
||||
|
||||
#### `format: "esm"` - ES Module
|
||||
|
||||
This is the default format, which supports ES Module syntax including top-level `await`, import.meta, and more.
|
||||
Currently the bundler only supports one module format: `"esm"`. Support for `"cjs"` and `"iife"` are planned.
|
||||
|
||||
{% codetabs %}
|
||||
|
||||
@@ -365,31 +359,44 @@ $ bun build ./index.tsx --outdir ./out --format esm
|
||||
|
||||
{% /codetabs %}
|
||||
|
||||
To use ES Module syntax in browsers, set `format` to `"esm"` and make sure your `<script type="module">` tag has `type="module"` set.
|
||||
<!-- ### `bundling`
|
||||
|
||||
#### `format: "cjs"` - CommonJS
|
||||
Whether to enable bundling.
|
||||
|
||||
To build a CommonJS module, set `format` to `"cjs"`. When choosing `"cjs"`, the default target changes from `"browser"` (esm) to `"node"` (cjs). CommonJS modules transpiled with `format: "cjs", target: "node"` can be executed in both Bun and Node.js (assuming the APIs in use are supported by both).
|
||||
|
||||
{% codetabs %}
|
||||
{% codetabs group="a" %}
|
||||
|
||||
```ts#JavaScript
|
||||
await Bun.build({
|
||||
entrypoints: ['./index.tsx'],
|
||||
outdir: './out',
|
||||
format: "cjs",
|
||||
bundling: true, // default
|
||||
})
|
||||
```
|
||||
|
||||
```bash#CLI
|
||||
$ bun build ./index.tsx --outdir ./out --format cjs
|
||||
# bundling is enabled by default
|
||||
$ bun build ./index.tsx --outdir ./out
|
||||
```
|
||||
|
||||
{% /codetabs %}
|
||||
|
||||
#### `format: "iife"` - IIFE
|
||||
Set to `false` to disable bundling. Instead, files will be transpiled and individually written to `outdir`.
|
||||
|
||||
TODO: document IIFE once we support globalNames.
|
||||
{% codetabs group="a" %}
|
||||
|
||||
```ts#JavaScript
|
||||
await Bun.build({
|
||||
entrypoints: ['./index.tsx'],
|
||||
outdir: './out',
|
||||
bundling: false,
|
||||
})
|
||||
```
|
||||
|
||||
```bash#CLI
|
||||
$ bun build ./index.tsx --outdir ./out --no-bundling
|
||||
```
|
||||
|
||||
{% /codetabs %} -->
|
||||
|
||||
### `splitting`
|
||||
|
||||
@@ -751,7 +758,7 @@ $ bun build ./index.tsx --outdir ./out --external '*'
|
||||
|
||||
### `packages`
|
||||
|
||||
Control whatever package dependencies are included to bundle or not. Possible values: `bundle` (default), `external`. Bun treats any import which path do not start with `.`, `..` or `/` as package.
|
||||
Control whatever package dependencies are included to bundle or not. Possible values: `bundle` (default), `external`. Bun threats any import which path do not start with `.`, `..` or `/` as package.
|
||||
|
||||
{% codetabs group="a" %}
|
||||
|
||||
@@ -1090,84 +1097,6 @@ $ bun build ./index.tsx --outdir ./out --loader .png:dataurl --loader .txt:file
|
||||
|
||||
{% /codetabs %}
|
||||
|
||||
### `banner`
|
||||
|
||||
A banner to be added to the final bundle, this can be a directive like "use client" for react or a comment block such as a license for the code.
|
||||
|
||||
{% codetabs %}
|
||||
|
||||
```ts#JavaScript
|
||||
await Bun.build({
|
||||
entrypoints: ['./index.tsx'],
|
||||
outdir: './out',
|
||||
banner: '"use client";'
|
||||
})
|
||||
```
|
||||
|
||||
```bash#CLI
|
||||
$ bun build ./index.tsx --outdir ./out --banner "\"use client\";"
|
||||
```
|
||||
|
||||
{% /codetabs %}
|
||||
|
||||
### `footer`
|
||||
|
||||
A footer to be added to the final bundle, this can be something like a comment block for a license or just a fun easter egg.
|
||||
|
||||
{% codetabs %}
|
||||
|
||||
```ts#JavaScript
|
||||
await Bun.build({
|
||||
entrypoints: ['./index.tsx'],
|
||||
outdir: './out',
|
||||
footer: '// built with love in SF'
|
||||
})
|
||||
```
|
||||
|
||||
```bash#CLI
|
||||
$ bun build ./index.tsx --outdir ./out --footer="// built with love in SF"
|
||||
```
|
||||
|
||||
{% /codetabs %}
|
||||
|
||||
### `drop`
|
||||
|
||||
Remove function calls from a bundle. For example, `--drop=console` will remove all calls to `console.log`. Arguments to calls will also be removed, regardless of if those arguments may have side effects. Dropping `debugger` will remove all `debugger` statements.
|
||||
|
||||
{% codetabs %}
|
||||
|
||||
```ts#JavaScript
|
||||
await Bun.build({
|
||||
entrypoints: ['./index.tsx'],
|
||||
outdir: './out',
|
||||
drop: ["console", "debugger", "anyIdentifier.or.propertyAccess"],
|
||||
})
|
||||
```
|
||||
|
||||
```bash#CLI
|
||||
$ bun build ./index.tsx --outdir ./out --drop=console --drop=debugger --drop=anyIdentifier.or.propertyAccess
|
||||
```
|
||||
|
||||
{% /codetabs %}
|
||||
|
||||
### `experimentalCss`
|
||||
|
||||
Whether to enable _experimental_ support for bundling CSS files. Defaults to `false`.
|
||||
|
||||
This supports bundling CSS files imported from JS, as well as CSS entrypoints.
|
||||
|
||||
{% codetabs group="a" %}
|
||||
|
||||
```ts#JavaScript
|
||||
const result = await Bun.build({
|
||||
entrypoints: ["./index.ts"],
|
||||
experimentalCss: true,
|
||||
});
|
||||
// => { success: boolean, outputs: BuildArtifact[], logs: BuildMessage[] }
|
||||
```
|
||||
|
||||
{% /codetabs %}
|
||||
|
||||
## Outputs
|
||||
|
||||
The `Bun.build` function returns a `Promise<BuildOutput>`, defined as:
|
||||
@@ -1209,7 +1138,7 @@ Each artifact also contains the following properties:
|
||||
---
|
||||
|
||||
- `kind`
|
||||
- What kind of build output this file is. A build generates bundled entrypoints, code-split "chunks", sourcemaps, bytecode, and copied assets (like images).
|
||||
- What kind of build output this file is. A build generates bundled entrypoints, code-split "chunks", sourcemaps, and copied assets (like images).
|
||||
|
||||
---
|
||||
|
||||
@@ -1274,26 +1203,6 @@ BuildArtifact (entry-point) {
|
||||
|
||||
{% /codetabs %}
|
||||
|
||||
### Bytecode
|
||||
|
||||
The `bytecode: boolean` option can be used to generate bytecode for any JavaScript/TypeScript entrypoints. This can greatly improve startup times for large applications. Only supported for `"cjs"` format, only supports `"target": "bun"` and dependent on a matching version of Bun. This adds a corresponding `.jsc` file for each entrypoint.
|
||||
|
||||
{% codetabs %}
|
||||
|
||||
```ts#JavaScript
|
||||
await Bun.build({
|
||||
entrypoints: ["./index.tsx"],
|
||||
outdir: "./out",
|
||||
bytecode: true,
|
||||
})
|
||||
```
|
||||
|
||||
```bash#CLI
|
||||
$ bun build ./index.tsx --outdir ./out --bytecode
|
||||
```
|
||||
|
||||
{% /codetabs %}
|
||||
|
||||
### Executables
|
||||
|
||||
Bun supports "compiling" a JavaScript/TypeScript entrypoint into a standalone executable. This executable contains a copy of the Bun binary.
|
||||
@@ -1357,104 +1266,33 @@ interface Bun {
|
||||
build(options: BuildOptions): Promise<BuildOutput>;
|
||||
}
|
||||
|
||||
interface BuildConfig {
|
||||
entrypoints: string[]; // list of file path
|
||||
outdir?: string; // output directory
|
||||
target?: Target; // default: "browser"
|
||||
/**
|
||||
* Output module format. Top-level await is only supported for `"esm"`.
|
||||
*
|
||||
* Can be:
|
||||
* - `"esm"`
|
||||
* - `"cjs"` (**experimental**)
|
||||
* - `"iife"` (**experimental**)
|
||||
*
|
||||
* @default "esm"
|
||||
*/
|
||||
format?: /**
|
||||
|
||||
* ECMAScript Module format
|
||||
*/
|
||||
| "esm"
|
||||
/**
|
||||
* CommonJS format
|
||||
* **Experimental**
|
||||
*/
|
||||
| "cjs"
|
||||
/**
|
||||
* IIFE format
|
||||
* **Experimental**
|
||||
*/
|
||||
| "iife";
|
||||
interface BuildOptions {
|
||||
entrypoints: string[]; // required
|
||||
outdir?: string; // default: no write (in-memory only)
|
||||
format?: "esm"; // later: "cjs" | "iife"
|
||||
target?: "browser" | "bun" | "node"; // "browser"
|
||||
splitting?: boolean; // true
|
||||
plugins?: BunPlugin[]; // [] // See https://bun.sh/docs/bundler/plugins
|
||||
loader?: { [k in string]: Loader }; // See https://bun.sh/docs/bundler/loaders
|
||||
manifest?: boolean; // false
|
||||
external?: string[]; // []
|
||||
sourcemap?: "none" | "inline" | "linked" | "external" | "linked" | boolean; // "none"
|
||||
root?: string; // computed from entrypoints
|
||||
naming?:
|
||||
| string
|
||||
| {
|
||||
chunk?: string;
|
||||
entry?: string;
|
||||
asset?: string;
|
||||
}; // | string;
|
||||
root?: string; // project root
|
||||
splitting?: boolean; // default true, enable code splitting
|
||||
plugins?: BunPlugin[];
|
||||
// manifest?: boolean; // whether to return manifest
|
||||
external?: string[];
|
||||
packages?: "bundle" | "external";
|
||||
publicPath?: string;
|
||||
define?: Record<string, string>;
|
||||
// origin?: string; // e.g. http://mydomain.com
|
||||
loader?: { [k in string]: Loader };
|
||||
sourcemap?: "none" | "linked" | "inline" | "external" | "linked"; // default: "none", true -> "inline"
|
||||
/**
|
||||
* package.json `exports` conditions used when resolving imports
|
||||
*
|
||||
* Equivalent to `--conditions` in `bun build` or `bun run`.
|
||||
*
|
||||
* https://nodejs.org/api/packages.html#exports
|
||||
*/
|
||||
conditions?: Array<string> | string;
|
||||
entry?: string; // '[dir]/[name].[ext]'
|
||||
chunk?: string; // '[name]-[hash].[ext]'
|
||||
asset?: string; // '[name]-[hash].[ext]'
|
||||
};
|
||||
publicPath?: string; // e.g. http://mydomain.com/
|
||||
minify?:
|
||||
| boolean
|
||||
| boolean // false
|
||||
| {
|
||||
identifiers?: boolean;
|
||||
whitespace?: boolean;
|
||||
syntax?: boolean;
|
||||
identifiers?: boolean;
|
||||
};
|
||||
/**
|
||||
* Ignore dead code elimination/tree-shaking annotations such as @__PURE__ and package.json
|
||||
* "sideEffects" fields. This should only be used as a temporary workaround for incorrect
|
||||
* annotations in libraries.
|
||||
*/
|
||||
ignoreDCEAnnotations?: boolean;
|
||||
/**
|
||||
* Force emitting @__PURE__ annotations even if minify.whitespace is true.
|
||||
*/
|
||||
emitDCEAnnotations?: boolean;
|
||||
// treeshaking?: boolean;
|
||||
|
||||
// jsx?:
|
||||
// | "automatic"
|
||||
// | "classic"
|
||||
// | /* later: "preserve" */ {
|
||||
// runtime?: "automatic" | "classic"; // later: "preserve"
|
||||
// /** Only works when runtime=classic */
|
||||
// factory?: string; // default: "React.createElement"
|
||||
// /** Only works when runtime=classic */
|
||||
// fragment?: string; // default: "React.Fragment"
|
||||
// /** Only works when runtime=automatic */
|
||||
// importSource?: string; // default: "react"
|
||||
// };
|
||||
|
||||
/**
|
||||
* Generate bytecode for the output. This can dramatically improve cold
|
||||
* start times, but will make the final output larger and slightly increase
|
||||
* memory usage.
|
||||
*
|
||||
* Bytecode is currently only supported for CommonJS (`format: "cjs"`).
|
||||
*
|
||||
* Must be `target: "bun"`
|
||||
* @default false
|
||||
*/
|
||||
bytecode?: boolean;
|
||||
}
|
||||
|
||||
interface BuildOutput {
|
||||
@@ -1466,9 +1304,9 @@ interface BuildOutput {
|
||||
interface BuildArtifact extends Blob {
|
||||
path: string;
|
||||
loader: Loader;
|
||||
hash: string | null;
|
||||
kind: "entry-point" | "chunk" | "asset" | "sourcemap" | "bytecode";
|
||||
sourcemap: BuildArtifact | null;
|
||||
hash?: string;
|
||||
kind: "entry-point" | "chunk" | "asset" | "sourcemap";
|
||||
sourcemap?: BuildArtifact;
|
||||
}
|
||||
|
||||
type Loader =
|
||||
|
||||
@@ -59,7 +59,7 @@ In Bun's CLI, simple boolean flags like `--minify` do not accept an argument. Ot
|
||||
|
||||
- `--format`
|
||||
- `--format`
|
||||
- Bun supports `"esm"` and `"cjs"` currently, but more module formats are planned. esbuild defaults to `"iife"`.
|
||||
- Bun only supports `"esm"` currently but other module formats are planned. esbuild defaults to `"iife"`.
|
||||
|
||||
---
|
||||
|
||||
@@ -154,14 +154,8 @@ In Bun's CLI, simple boolean flags like `--minify` do not accept an argument. Ot
|
||||
---
|
||||
|
||||
- `--banner`
|
||||
- `--banner`
|
||||
- Only applies to js bundles
|
||||
|
||||
---
|
||||
|
||||
- `--footer`
|
||||
- `--footer`
|
||||
- Only applies to js bundles
|
||||
- n/a
|
||||
- Not supported
|
||||
|
||||
---
|
||||
|
||||
@@ -190,7 +184,8 @@ In Bun's CLI, simple boolean flags like `--minify` do not accept an argument. Ot
|
||||
---
|
||||
|
||||
- `--drop`
|
||||
- `--drop`
|
||||
- n/a
|
||||
- Not supported
|
||||
|
||||
---
|
||||
|
||||
@@ -200,6 +195,12 @@ In Bun's CLI, simple boolean flags like `--minify` do not accept an argument. Ot
|
||||
|
||||
---
|
||||
|
||||
- `--footer`
|
||||
- n/a
|
||||
- Not supported
|
||||
|
||||
---
|
||||
|
||||
- `--global-name`
|
||||
- n/a
|
||||
- Not applicable, Bun does not support `iife` output at this time
|
||||
|
||||
@@ -1,22 +1,5 @@
|
||||
The `bun pm` command group provides a set of utilities for working with Bun's package manager.
|
||||
|
||||
## pack
|
||||
|
||||
To create a tarball of the current workspace:
|
||||
|
||||
```bash
|
||||
$ bun pm pack
|
||||
```
|
||||
|
||||
Options for the `pack` command:
|
||||
|
||||
- `--dry-run`: Perform all tasks except writing the tarball to disk.
|
||||
- `--destination`: Specify the directory where the tarball will be saved.
|
||||
- `--ignore-scripts`: Skip running pre/postpack and prepare scripts.
|
||||
- `--gzip-level`: Set a custom compression level for gzip, ranging from 0 to 9 (default is 9).
|
||||
|
||||
## bin
|
||||
|
||||
To print the path to the `bin` directory for the local project:
|
||||
|
||||
```bash
|
||||
@@ -31,8 +14,6 @@ $ bun pm bin -g
|
||||
<$HOME>/.bun/bin
|
||||
```
|
||||
|
||||
## ls
|
||||
|
||||
To print a list of installed dependencies in the current project and their resolved versions, excluding their dependencies.
|
||||
|
||||
```bash
|
||||
@@ -64,36 +45,6 @@ $ bun pm ls --all
|
||||
├── ...
|
||||
```
|
||||
|
||||
## whoami
|
||||
|
||||
Print your npm username. Requires you to be logged in (`bunx npm login`) with credentials in either `bunfig.toml` or `.npmrc`:
|
||||
|
||||
```bash
|
||||
$ bun pm whoami
|
||||
```
|
||||
|
||||
## hash
|
||||
|
||||
To generate and print the hash of the current lockfile:
|
||||
|
||||
```bash
|
||||
$ bun pm hash
|
||||
```
|
||||
|
||||
To print the string used to hash the lockfile:
|
||||
|
||||
```bash
|
||||
$ bun pm hash-string
|
||||
```
|
||||
|
||||
To print the hash stored in the current lockfile:
|
||||
|
||||
```bash
|
||||
$ bun pm hash-print
|
||||
```
|
||||
|
||||
## cache
|
||||
|
||||
To print the path to Bun's global module cache:
|
||||
|
||||
```bash
|
||||
@@ -106,45 +57,16 @@ To clear Bun's global module cache:
|
||||
$ bun pm cache rm
|
||||
```
|
||||
|
||||
## migrate
|
||||
## List global installs
|
||||
|
||||
To migrate another package manager's lockfile without installing anything:
|
||||
To list all globally installed packages:
|
||||
|
||||
```bash
|
||||
$ bun pm migrate
|
||||
$ bun pm ls -g
|
||||
```
|
||||
|
||||
## untrusted
|
||||
|
||||
To print current untrusted dependencies with scripts:
|
||||
To list all globally installed packages, including nth-order dependencies:
|
||||
|
||||
```bash
|
||||
$ bun pm untrusted
|
||||
|
||||
./node_modules/@biomejs/biome @1.8.3
|
||||
» [postinstall]: node scripts/postinstall.js
|
||||
|
||||
These dependencies had their lifecycle scripts blocked during install.
|
||||
$ bun pm ls -g --all
|
||||
```
|
||||
|
||||
## trust
|
||||
|
||||
To run scripts for untrusted dependencies and add to `trustedDependencies`:
|
||||
|
||||
```bash
|
||||
$ bun pm trust <names>
|
||||
```
|
||||
|
||||
Options for the `trust` command:
|
||||
|
||||
- `--all`: Trust all untrusted dependencies.
|
||||
|
||||
## default-trusted
|
||||
|
||||
To print the default trusted dependencies list:
|
||||
|
||||
```bash
|
||||
$ bun pm default-trusted
|
||||
```
|
||||
|
||||
see the current list on GitHub [here](https://github.com/oven-sh/bun/blob/main/src/install/default-trusted-dependencies.txt)
|
||||
|
||||
@@ -1,107 +0,0 @@
|
||||
Use `bun publish` to publish a package to the npm registry.
|
||||
|
||||
`bun publish` will automatically pack your package into a tarball, strip workspace protocols from the `package.json` (resolving versions if necessary), and publish to the registry specified in your configuration files. Both `bunfig.toml` and `.npmrc` files are supported.
|
||||
|
||||
```sh
|
||||
## Publishing the package from the current working directory
|
||||
$ bun publish
|
||||
|
||||
## Output
|
||||
bun publish v1.1.30 (ca7428e9)
|
||||
|
||||
packed 203B package.json
|
||||
packed 224B README.md
|
||||
packed 30B index.ts
|
||||
packed 0.64KB tsconfig.json
|
||||
|
||||
Total files: 4
|
||||
Shasum: 79e2b4377b63f4de38dc7ea6e5e9dbee08311a69
|
||||
Integrity: sha512-6QSNlDdSwyG/+[...]X6wXHriDWr6fA==
|
||||
Unpacked size: 1.1KB
|
||||
Packed size: 0.76KB
|
||||
Tag: latest
|
||||
Access: default
|
||||
Registry: http://localhost:4873/
|
||||
|
||||
+ publish-1@1.0.0
|
||||
```
|
||||
|
||||
Alternatively, you can pack and publish your package separately by using `bun pm pack` followed by `bun publish` with the path to the output tarball.
|
||||
|
||||
```sh
|
||||
$ bun pm pack
|
||||
...
|
||||
$ bun publish ./package.tgz
|
||||
```
|
||||
|
||||
{% callout %}
|
||||
**Note** - `bun publish` will not run lifecycle scripts (`prepublishOnly/prepack/prepare/postpack/publish/postpublish`) if a tarball path is provided. Scripts will only be run if the package is packed by `bun publish`.
|
||||
{% /callout %}
|
||||
|
||||
### `--access`
|
||||
|
||||
The `--access` flag can be used to set the access level of the package being published. The access level can be one of `public` or `restricted`. Unscoped packages are always public, and attempting to publish an unscoped package with `--access restricted` will result in an error.
|
||||
|
||||
```sh
|
||||
$ bun publish --access public
|
||||
```
|
||||
|
||||
`--access` can also be set in the `publishConfig` field of your `package.json`.
|
||||
|
||||
```json
|
||||
{
|
||||
"publishConfig": {
|
||||
"access": "restricted"
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
### `--tag`
|
||||
|
||||
Set the tag of the package version being published. By default, the tag is `latest`. The initial version of a package is always given the `latest` tag in addition to the specified tag.
|
||||
|
||||
```sh
|
||||
$ bun publish --tag alpha
|
||||
```
|
||||
|
||||
`--tag` can also be set in the `publishConfig` field of your `package.json`.
|
||||
|
||||
```json
|
||||
{
|
||||
"publishConfig": {
|
||||
"tag": "next"
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
### `--dry-run`
|
||||
|
||||
The `--dry-run` flag can be used to simulate the publish process without actually publishing the package. This is useful for verifying the contents of the published package without actually publishing the package.
|
||||
|
||||
```sh
|
||||
$ bun publish --dry-run
|
||||
```
|
||||
|
||||
### `--auth-type`
|
||||
|
||||
If you have 2FA enabled for your npm account, `bun publish` will prompt you for a one-time password. This can be done through a browser or the CLI. The `--auth-type` flag can be used to tell the npm registry which method you prefer. The possible values are `web` and `legacy`, with `web` being the default.
|
||||
|
||||
```sh
|
||||
$ bun publish --auth-type legacy
|
||||
...
|
||||
This operation requires a one-time password.
|
||||
Enter OTP: 123456
|
||||
...
|
||||
```
|
||||
|
||||
### `--otp`
|
||||
|
||||
Provide a one-time password directly to the CLI. If the password is valid, this will skip the extra prompt for a one-time password before publishing. Example usage:
|
||||
|
||||
```sh
|
||||
$ bun publish --otp 123456
|
||||
```
|
||||
|
||||
### `--gzip-level`
|
||||
|
||||
Specify the level of gzip compression to use when packing the package. Only applies to `bun publish` without a tarball path argument. Values range from `0` to `9` (default is `9`).
|
||||
@@ -2,6 +2,12 @@
|
||||
name: Build an app with Next.js and Bun
|
||||
---
|
||||
|
||||
{% callout %}
|
||||
The Next.js [App Router](https://nextjs.org/docs/app) currently relies on Node.js APIs that Bun does not yet implement. The guide below uses Bun to initialize a project and install dependencies, but it uses Node.js to run the dev server.
|
||||
{% /callout %}
|
||||
|
||||
---
|
||||
|
||||
Initialize a Next.js app with `create-next-app`. This automatically installs dependencies using `npm`.
|
||||
|
||||
```sh
|
||||
|
||||
@@ -37,10 +37,7 @@ Alternatively, you can create a PM2 configuration file. Create a file named `pm2
|
||||
module.exports = {
|
||||
name: "app", // Name of your application
|
||||
script: "index.ts", // Entry point of your application
|
||||
interpreter: "bun", // Bun interpreter
|
||||
env: {
|
||||
PATH: `${process.env.HOME}/.bun/bin:${process.env.PATH}`, // Add "~/.bun/bin/bun" to PATH
|
||||
}
|
||||
interpreter: "~/.bun/bin/bun", // Path to the Bun interpreter
|
||||
};
|
||||
```
|
||||
|
||||
|
||||
@@ -17,7 +17,7 @@ If you are seeing one of the following errors, you are probably trying to use a
|
||||
|
||||
---
|
||||
|
||||
To allow Bun to execute lifecycle scripts for a specific package, add the package to `trustedDependencies` in your package.json file. You can do this automatically by running the command `bun pm trust <pkg>`.
|
||||
To tell Bun to allow lifecycle scripts for a particular package, add the package to `trustedDependencies` in your package.json.
|
||||
|
||||
{% callout %}
|
||||
Note that this only allows lifecycle scripts for the specific package listed in `trustedDependencies`, _not_ the dependencies of that dependency!
|
||||
|
||||
@@ -27,6 +27,16 @@ data.version; // => "1.0.0"
|
||||
data.author.name; // => "John Dough"
|
||||
```
|
||||
|
||||
Bun also supports [Import Attributes](https://github.com/tc39/proposal-import-attributes/) and [JSON modules](https://github.com/tc39/proposal-json-modules) syntax.
|
||||
|
||||
```ts
|
||||
import data from "./package.json" with { type: "json" };
|
||||
|
||||
data.name; // => "bun"
|
||||
data.version; // => "1.0.0"
|
||||
data.author.name; // => "John Dough"
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
Bun also supports [Import Attributes](https://github.com/tc39/proposal-import-attributes/) and [JSON modules](https://github.com/tc39/proposal-json-modules) syntax.
|
||||
|
||||
@@ -16,7 +16,7 @@ Add the following to your local or global `.gitattributes` file:
|
||||
*.lockb binary diff=lockb
|
||||
```
|
||||
|
||||
Then add the following to your local git config with:
|
||||
Then add the following to you local git config with:
|
||||
|
||||
```sh
|
||||
$ git config diff.lockb.textconv bun
|
||||
|
||||
@@ -41,7 +41,7 @@ In the root `package.json`, the `"workspaces"` key is used to indicate which sub
|
||||
**Glob support** — Bun supports full glob syntax in `"workspaces"` (see [here](https://bun.sh/docs/api/glob#supported-glob-patterns) for a comprehensive list of supported syntax), _except_ for exclusions (e.g. `!**/excluded/**`), which are not implemented yet.
|
||||
{% /callout %}
|
||||
|
||||
Each workspace has it's own `package.json`. When referencing other packages in the monorepo, semver or workspace protocols (e.g. `workspace:*`) can be used as the version field in your `package.json`.
|
||||
Each workspace has it's own `package.json` When referencing other packages in the monorepo, use `"workspace:*"` as the version field in your `package.json`.
|
||||
|
||||
```json
|
||||
{
|
||||
@@ -53,6 +53,10 @@ Each workspace has it's own `package.json`. When referencing other packages in t
|
||||
}
|
||||
```
|
||||
|
||||
{% callout %}
|
||||
**Version support** — Bun supports simple `workspace:*` versions in `"dependencies"`. Full version syntax (e.g. `workspace:^*`) is not yet supported.
|
||||
{% /callout %}
|
||||
|
||||
Workspaces have a couple major benefits.
|
||||
|
||||
- **Code can be split into logical parts.** If one package relies on another, you can simply add it as a dependency in `package.json`. If package `b` depends on `a`, `bun install` will install your local `packages/a` directory into `node_modules` instead of downloading it from the npm registry.
|
||||
|
||||
@@ -72,9 +72,8 @@ There are also image variants for different operating systems.
|
||||
```bash
|
||||
$ docker pull oven/bun:debian
|
||||
$ docker pull oven/bun:slim
|
||||
$ docker pull oven/bun:alpine
|
||||
$ docker pull oven/bun:distroless
|
||||
# alpine not recommended until #918 is fixed
|
||||
# $ docker pull oven/bun:alpine
|
||||
```
|
||||
|
||||
## Checking installation
|
||||
|
||||
@@ -164,9 +164,6 @@ export default {
|
||||
page("cli/update", "`bun update`", {
|
||||
description: "Update your project's dependencies.",
|
||||
}),
|
||||
page("cli/publish", "`bun publish`", {
|
||||
description: "Publish your package to an npm registry.",
|
||||
}),
|
||||
page("cli/outdated", "`bun outdated`", {
|
||||
description: "Check for outdated dependencies.",
|
||||
}),
|
||||
@@ -377,10 +374,6 @@ export default {
|
||||
description: `Bun's native Semver implementation is 20x faster than the popular \`node-semver\` package.`,
|
||||
}), // "`Semver`"),
|
||||
|
||||
page("api/color", "Color", {
|
||||
description: `Bun's color function leverages Bun's CSS parser for parsing, normalizing, and converting colors from user input to a variety of output formats.`,
|
||||
}), // "`Color`"),
|
||||
|
||||
// divider("Dev Server"),
|
||||
// page("bun-dev", "Vanilla"),
|
||||
// page("dev/css", "CSS"),
|
||||
|
||||
@@ -370,19 +370,6 @@ myorg = { username = "myusername", password = "$npm_password", url = "https://re
|
||||
myorg = { token = "$npm_token", url = "https://registry.myorg.com/" }
|
||||
```
|
||||
|
||||
### `install.ca` and `install.cafile`
|
||||
|
||||
To configure a CA certificate, use `install.ca` or `install.cafile` to specify a path to a CA certificate file.
|
||||
|
||||
```toml
|
||||
[install]
|
||||
# The CA certificate as a string
|
||||
ca = "-----BEGIN CERTIFICATE-----\n...\n-----END CERTIFICATE-----"
|
||||
|
||||
# A path to a CA certificate file. The file can contain multiple certificates.
|
||||
cafile = "path/to/cafile"
|
||||
```
|
||||
|
||||
### `install.cache`
|
||||
|
||||
To configure the cache behavior:
|
||||
|
||||
@@ -238,30 +238,6 @@ If `exports` is not defined, Bun falls back to `"module"` (ESM imports only) the
|
||||
}
|
||||
```
|
||||
|
||||
### Custom conditions
|
||||
|
||||
The `--conditions` flag allows you to specify a list of conditions to use when resolving packages from package.json `"exports"`.
|
||||
|
||||
This flag is supported in both `bun build` and Bun's runtime.
|
||||
|
||||
```sh
|
||||
# Use it with bun build:
|
||||
$ bun build --conditions="react-server" --target=bun ./app/foo/route.js
|
||||
|
||||
# Use it with bun's runtime:
|
||||
$ bun --conditions="react-server" ./app/foo/route.js
|
||||
```
|
||||
|
||||
You can also use `conditions` programmatically with `Bun.build`:
|
||||
|
||||
```js
|
||||
await Bun.build({
|
||||
conditions: ["react-server"],
|
||||
target: "bun",
|
||||
entryPoints: ["./app/foo/route.js"],
|
||||
});
|
||||
```
|
||||
|
||||
## Path re-mapping
|
||||
|
||||
In the spirit of treating TypeScript as a first-class citizen, the Bun runtime will re-map import paths according to the [`compilerOptions.paths`](https://www.typescriptlang.org/tsconfig#paths) field in `tsconfig.json`. This is a major divergence from Node.js, which doesn't support any form of import path re-mapping.
|
||||
|
||||
@@ -65,7 +65,7 @@ Some methods are not optimized yet.
|
||||
|
||||
### [`node:http2`](https://nodejs.org/api/http2.html)
|
||||
|
||||
🟡 Client & server are implemented (95.25% of gRPC's test suite passes). Missing `options.allowHTTP1`, `options.enableConnectProtocol`, ALTSVC extension, and `http2stream.pushStream`.
|
||||
🟡 Client is supported, but server isn't yet.
|
||||
|
||||
### [`node:https`](https://nodejs.org/api/https.html)
|
||||
|
||||
|
||||
@@ -76,12 +76,6 @@ test("wat", async () => {
|
||||
}, 500); // test must run in <500ms
|
||||
```
|
||||
|
||||
In `bun:test`, test timeouts throw an uncatchable exception to force the test to stop running and fail. We also kill any child processes that were spawned in the test to avoid leaving behind zombie processes lurking in the background.
|
||||
|
||||
### 🧟 Zombie process killer
|
||||
|
||||
When a test times out and processes spawned in the test via `Bun.spawn`, `Bun.spawnSync`, or `node:child_process` are not killed, they will be automatically killed and a message will be logged to the console.
|
||||
|
||||
## `test.skip`
|
||||
|
||||
Skip individual tests with `test.skip`. These tests will not be run.
|
||||
@@ -330,7 +324,6 @@ Bun implements the following matchers. Full Jest compatibility is on the roadmap
|
||||
- [`.toContainAllValues()`](https://jest-extended.jestcommunity.dev/docs/matchers/Object#tocontainallvaluesvalues)
|
||||
|
||||
---
|
||||
|
||||
- ✅
|
||||
- [`.toContainAnyValues()`](https://jest-extended.jestcommunity.dev/docs/matchers/Object#tocontainanyvaluesvalues)
|
||||
|
||||
|
||||
37
package.json
37
package.json
@@ -1,7 +1,7 @@
|
||||
{
|
||||
"private": true,
|
||||
"name": "bun",
|
||||
"version": "1.1.32",
|
||||
"version": "1.1.30",
|
||||
"workspaces": [
|
||||
"./packages/bun-types"
|
||||
],
|
||||
@@ -21,10 +21,7 @@
|
||||
"react": "^18.3.1",
|
||||
"react-dom": "^18.3.1",
|
||||
"source-map-js": "^1.2.0",
|
||||
"typescript": "^5.4.5",
|
||||
"caniuse-lite": "^1.0.30001620",
|
||||
"autoprefixer": "^10.4.19",
|
||||
"@mdn/browser-compat-data": "~5.5.28"
|
||||
"typescript": "^5.4.5"
|
||||
},
|
||||
"resolutions": {
|
||||
"bun-types": "workspace:packages/bun-types"
|
||||
@@ -43,7 +40,6 @@
|
||||
"build:release:local": "bun ./scripts/build.mjs -GNinja -DCMAKE_BUILD_TYPE=Release -DWEBKIT_LOCAL=ON -B build/release",
|
||||
"build:release:with_logs": "cmake . -DCMAKE_BUILD_TYPE=Release -DENABLE_LOGS=true -GNinja -Bbuild-release && ninja -Cbuild-release",
|
||||
"build:debug-zig-release": "cmake . -DCMAKE_BUILD_TYPE=Release -DZIG_OPTIMIZE=Debug -GNinja -Bbuild-debug-zig-release && ninja -Cbuild-debug-zig-release",
|
||||
"css-properties": "bun run src/css/properties/generate_properties.ts",
|
||||
"bump": "bun ./scripts/bump.ts",
|
||||
"typecheck": "tsc --noEmit && cd test && bun run typecheck",
|
||||
"fmt": "bun run prettier",
|
||||
@@ -59,20 +55,19 @@
|
||||
"zig:check": "bun run zig build check --summary new",
|
||||
"zig:check-all": "bun run zig build check-all --summary new",
|
||||
"zig:check-windows": "bun run zig build check-windows --summary new",
|
||||
"analysis": "bun ./scripts/build.mjs -DCMAKE_BUILD_TYPE=Debug -DENABLE_ANALYSIS=ON -DENABLE_CCACHE=OFF -B build/analysis",
|
||||
"analysis:no-llvm": "bun run analysis -DENABLE_LLVM=OFF",
|
||||
"clang-format": "bun run analysis --target clang-format",
|
||||
"clang-format:check": "bun run analysis --target clang-format-check",
|
||||
"clang-format:diff": "bun run analysis --target clang-format-diff",
|
||||
"clang-tidy": "bun run analysis --target clang-tidy",
|
||||
"clang-tidy:check": "bun run analysis --target clang-tidy-check",
|
||||
"clang-tidy:diff": "bun run analysis --target clang-tidy-diff",
|
||||
"zig-format": "bun run analysis:no-llvm --target zig-format",
|
||||
"zig-format:check": "bun run analysis:no-llvm --target zig-format-check",
|
||||
"zig-format:diff": "bun run analysis:no-llvm --target zig-format-diff",
|
||||
"prettier": "bun run analysis:no-llvm --target prettier",
|
||||
"prettier:check": "bun run analysis:no-llvm --target prettier-check",
|
||||
"prettier:extra": "bun run analysis:no-llvm --target prettier-extra",
|
||||
"prettier:diff": "bun run analysis:no-llvm --target prettier-diff"
|
||||
"cmake": "bun ./scripts/build.mjs -DCMAKE_BUILD_TYPE=Debug -B build/debug",
|
||||
"clang-format": "bun run cmake --target clang-format",
|
||||
"clang-format:check": "bun run cmake --target clang-format-check",
|
||||
"clang-format:diff": "bun run cmake --target clang-format-diff",
|
||||
"clang-tidy": "bun run cmake --target clang-tidy",
|
||||
"clang-tidy:check": "bun run cmake --target clang-tidy-check",
|
||||
"clang-tidy:diff": "bun run cmake --target clang-tidy-diff",
|
||||
"zig-format": "bun run cmake --target zig-format",
|
||||
"zig-format:check": "bun run cmake --target zig-format-check",
|
||||
"zig-format:diff": "bun run cmake --target zig-format-diff",
|
||||
"prettier": "bun run cmake --target prettier",
|
||||
"prettier:check": "bun run cmake --target prettier-check",
|
||||
"prettier:extra": "bun run cmake --target prettier-extra",
|
||||
"prettier:diff": "bun run cmake --target prettier-diff"
|
||||
}
|
||||
}
|
||||
|
||||
4
packages/bun-darwin-aarch64/.npmignore
Normal file
4
packages/bun-darwin-aarch64/.npmignore
Normal file
@@ -0,0 +1,4 @@
|
||||
bin/bun-profile
|
||||
bin/*.o
|
||||
*.o
|
||||
*.a
|
||||
4
packages/bun-linux-x64/.npmignore
Normal file
4
packages/bun-linux-x64/.npmignore
Normal file
@@ -0,0 +1,4 @@
|
||||
bin/bun-profile
|
||||
bin/*.o
|
||||
*.o
|
||||
*.a
|
||||
3
packages/bun-plugin-css/README.md
Normal file
3
packages/bun-plugin-css/README.md
Normal file
@@ -0,0 +1,3 @@
|
||||
# `bun-plugin-css`
|
||||
|
||||
Not implemented.
|
||||
1
packages/bun-plugin-css/index.ts
Normal file
1
packages/bun-plugin-css/index.ts
Normal file
@@ -0,0 +1 @@
|
||||
throw new Error("Not implemented.");
|
||||
10
packages/bun-plugin-css/package.json
Normal file
10
packages/bun-plugin-css/package.json
Normal file
@@ -0,0 +1,10 @@
|
||||
{
|
||||
"name": "bun-plugin-css",
|
||||
"version": "0.0.1-alpha.0",
|
||||
"module": "index.ts",
|
||||
"type": "module",
|
||||
"files": [
|
||||
"index.ts",
|
||||
"package.json"
|
||||
]
|
||||
}
|
||||
3
packages/bun-plugin-lightningcss/README.md
Normal file
3
packages/bun-plugin-lightningcss/README.md
Normal file
@@ -0,0 +1,3 @@
|
||||
# `bun-plugin-lightningcss`
|
||||
|
||||
Not implemented.
|
||||
1
packages/bun-plugin-lightningcss/index.ts
Normal file
1
packages/bun-plugin-lightningcss/index.ts
Normal file
@@ -0,0 +1 @@
|
||||
throw new Error("Not implemented.");
|
||||
10
packages/bun-plugin-lightningcss/package.json
Normal file
10
packages/bun-plugin-lightningcss/package.json
Normal file
@@ -0,0 +1,10 @@
|
||||
{
|
||||
"name": "bun-plugin-lightningcss",
|
||||
"version": "0.0.1-alpha.0",
|
||||
"module": "index.ts",
|
||||
"type": "module",
|
||||
"files": [
|
||||
"index.ts",
|
||||
"package.json"
|
||||
]
|
||||
}
|
||||
3
packages/bun-plugin-mdx/README.md
Normal file
3
packages/bun-plugin-mdx/README.md
Normal file
@@ -0,0 +1,3 @@
|
||||
# `bun-plugin-mdx`
|
||||
|
||||
Not implemented.
|
||||
1
packages/bun-plugin-mdx/index.ts
Normal file
1
packages/bun-plugin-mdx/index.ts
Normal file
@@ -0,0 +1 @@
|
||||
throw new Error("Not implemented.");
|
||||
10
packages/bun-plugin-mdx/package.json
Normal file
10
packages/bun-plugin-mdx/package.json
Normal file
@@ -0,0 +1,10 @@
|
||||
{
|
||||
"name": "bun-plugin-mdx",
|
||||
"version": "0.0.1-alpha.0",
|
||||
"module": "index.ts",
|
||||
"type": "module",
|
||||
"files": [
|
||||
"index.ts",
|
||||
"package.json"
|
||||
]
|
||||
}
|
||||
169
packages/bun-plugin-server-components/.gitignore
vendored
Normal file
169
packages/bun-plugin-server-components/.gitignore
vendored
Normal file
@@ -0,0 +1,169 @@
|
||||
# Based on https://raw.githubusercontent.com/github/gitignore/main/Node.gitignore
|
||||
|
||||
# Logs
|
||||
|
||||
logs
|
||||
_.log
|
||||
npm-debug.log_
|
||||
yarn-debug.log*
|
||||
yarn-error.log*
|
||||
lerna-debug.log*
|
||||
.pnpm-debug.log*
|
||||
|
||||
# Diagnostic reports (https://nodejs.org/api/report.html)
|
||||
|
||||
report.[0-9]_.[0-9]_.[0-9]_.[0-9]_.json
|
||||
|
||||
# Runtime data
|
||||
|
||||
pids
|
||||
_.pid
|
||||
_.seed
|
||||
\*.pid.lock
|
||||
|
||||
# Directory for instrumented libs generated by jscoverage/JSCover
|
||||
|
||||
lib-cov
|
||||
|
||||
# Coverage directory used by tools like istanbul
|
||||
|
||||
coverage
|
||||
\*.lcov
|
||||
|
||||
# nyc test coverage
|
||||
|
||||
.nyc_output
|
||||
|
||||
# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files)
|
||||
|
||||
.grunt
|
||||
|
||||
# Bower dependency directory (https://bower.io/)
|
||||
|
||||
bower_components
|
||||
|
||||
# node-waf configuration
|
||||
|
||||
.lock-wscript
|
||||
|
||||
# Compiled binary addons (https://nodejs.org/api/addons.html)
|
||||
|
||||
build/Release
|
||||
|
||||
# Dependency directories
|
||||
|
||||
node_modules/
|
||||
jspm_packages/
|
||||
|
||||
# Snowpack dependency directory (https://snowpack.dev/)
|
||||
|
||||
web_modules/
|
||||
|
||||
# TypeScript cache
|
||||
|
||||
\*.tsbuildinfo
|
||||
|
||||
# Optional npm cache directory
|
||||
|
||||
.npm
|
||||
|
||||
# Optional eslint cache
|
||||
|
||||
.eslintcache
|
||||
|
||||
# Optional stylelint cache
|
||||
|
||||
.stylelintcache
|
||||
|
||||
# Microbundle cache
|
||||
|
||||
.rpt2_cache/
|
||||
.rts2_cache_cjs/
|
||||
.rts2_cache_es/
|
||||
.rts2_cache_umd/
|
||||
|
||||
# Optional REPL history
|
||||
|
||||
.node_repl_history
|
||||
|
||||
# Output of 'npm pack'
|
||||
|
||||
\*.tgz
|
||||
|
||||
# Yarn Integrity file
|
||||
|
||||
.yarn-integrity
|
||||
|
||||
# dotenv environment variable files
|
||||
|
||||
.env
|
||||
.env.development.local
|
||||
.env.test.local
|
||||
.env.production.local
|
||||
.env.local
|
||||
|
||||
# parcel-bundler cache (https://parceljs.org/)
|
||||
|
||||
.cache
|
||||
.parcel-cache
|
||||
|
||||
# Next.js build output
|
||||
|
||||
.next
|
||||
out
|
||||
|
||||
# Nuxt.js build / generate output
|
||||
|
||||
.nuxt
|
||||
dist
|
||||
|
||||
# Gatsby files
|
||||
|
||||
.cache/
|
||||
|
||||
# Comment in the public line in if your project uses Gatsby and not Next.js
|
||||
|
||||
# https://nextjs.org/blog/next-9-1#public-directory-support
|
||||
|
||||
# public
|
||||
|
||||
# vuepress build output
|
||||
|
||||
.vuepress/dist
|
||||
|
||||
# vuepress v2.x temp and cache directory
|
||||
|
||||
.temp
|
||||
.cache
|
||||
|
||||
# Docusaurus cache and generated files
|
||||
|
||||
.docusaurus
|
||||
|
||||
# Serverless directories
|
||||
|
||||
.serverless/
|
||||
|
||||
# FuseBox cache
|
||||
|
||||
.fusebox/
|
||||
|
||||
# DynamoDB Local files
|
||||
|
||||
.dynamodb/
|
||||
|
||||
# TernJS port file
|
||||
|
||||
.tern-port
|
||||
|
||||
# Stores VSCode versions used for testing VSCode extensions
|
||||
|
||||
.vscode-test
|
||||
|
||||
# yarn v2
|
||||
|
||||
.yarn/cache
|
||||
.yarn/unplugged
|
||||
.yarn/build-state.yml
|
||||
.yarn/install-state.gz
|
||||
.pnp.\*
|
||||
149
packages/bun-plugin-server-components/README.md
Normal file
149
packages/bun-plugin-server-components/README.md
Normal file
@@ -0,0 +1,149 @@
|
||||
# `bun-plugin-server-components`
|
||||
|
||||
The official Bun plugin for **server components**.
|
||||
|
||||
## Installation
|
||||
|
||||
```sh
|
||||
bun add bun-plugin-server-components -d
|
||||
```
|
||||
|
||||
## Context
|
||||
|
||||
Server components are a new abstraction for building web applications. They look similar to standard React/JSX components, but render exclusively on the server. They differ from classic "client components" in a few ways:
|
||||
|
||||
1. They can be `async`.
|
||||
2. Their implementation can run privileged code like database queries. Normally this would be unsafe, because the source code of client components are typically bundled and sent to the client, where they can be inspected and reverse-engineered. Server components are never sent to the client, so they can run privileged code safely.
|
||||
3. They _cannot_ contain stateful hooks like `useState` or `useEffect`.
|
||||
|
||||
Server components require a deep integration with the bundler to work. To understand why, we need a bit of background on how server components work.
|
||||
|
||||
### How server components work
|
||||
|
||||
Imagine you have a server component that looks like this:
|
||||
|
||||
```tsx
|
||||
// index.tsx
|
||||
import { Component } from "./Component";
|
||||
export default async function HomePage() {
|
||||
return (
|
||||
<div>
|
||||
<Component />
|
||||
</div>
|
||||
);
|
||||
}
|
||||
```
|
||||
|
||||
This file imports a client component called `Component`.
|
||||
|
||||
```ts
|
||||
// ./Component.tsx
|
||||
"use client";
|
||||
|
||||
export function Component() {
|
||||
return <div>Hello world</div>;
|
||||
}
|
||||
```
|
||||
|
||||
To run this component we need to generate two builds.
|
||||
|
||||
> Here the term "build" refers to a typical bundling step—the act of converting a set of entrypoints into a set of bundles.
|
||||
|
||||
1. The first is our "server component build". It contains all the code we need to render `HomePage` to a component tree. When an incoming `Request` comes in, we can use React's built-in tools to convert this tree into a "virtual DOM stream" that we can return as a `Response`.
|
||||
2. The second is our "client build". It contains the bundled versions of all client components that were referenced by our server components.
|
||||
|
||||
The browser hits the server and gets back the "virtual DOM stream". The virtual DOM stream will contain references to client components, which will be loaded from the client bundle. React provides a built-in utility (`createFromFetch`)that accepts the VDOM stream, dynamically loads the necessary client components, and returns a renderable component.
|
||||
|
||||
```ts
|
||||
import { createRoot } from "react-dom/client";
|
||||
import { createFromFetch } from "react-server-dom-webpack/client.browser";
|
||||
|
||||
const stream = fetch("/", { headers: { Accept: "text/x-component" } });
|
||||
const data = createFromFetch(stream);
|
||||
|
||||
const root = createRoot(document);
|
||||
root.render(<App />);
|
||||
```
|
||||
|
||||
### Server-side rendering
|
||||
|
||||
One potentially confusing aspect of server components is that they "return" virtual DOM. From the perspective of a server component, client components are black boxes.
|
||||
|
||||
If we want to do server-side rendering, we need to render our server component to VDOM, _then_ render the VDOM to plain HTML. These are two distinct steps. The second step requires a _third build_, we we'll call the "SSR build". Like the "client build", this build will bundle all the client components. Unlike the "client build", those bundles will be intended for consumption on the server; in bundler terms, the build's `"target"` will be`"bun"` (or perhaps `"node"`).
|
||||
|
||||
### Bundling server components
|
||||
|
||||
That's a high-level overview of how server components work. The important takeaway is that we need to generate totally separate bundles for server and client components.
|
||||
|
||||
But it's not just a simple matter of running two separate bundling scripts. The true "entrypoints" of our application are the server components. Over the course of bundling our server components, we will discover some files containing the `"use client"` directive; these files then become the entrypoints for our "client build", which will require a totally separate build configuration from the server build.
|
||||
|
||||
The goal of this plugin is to hide the complexty of this multi-stage build from the user.
|
||||
|
||||
## Usage
|
||||
|
||||
To use this plugin:
|
||||
|
||||
```ts
|
||||
import ServerComponentsPlugin from "bun-plugin-server-components";
|
||||
|
||||
await Bun.build({
|
||||
entrypoints: ["./index.tsx"], // server component files
|
||||
plugins: [
|
||||
ServerComponentsPlugin({
|
||||
// plugin configuration
|
||||
}),
|
||||
],
|
||||
// other configuration
|
||||
});
|
||||
```
|
||||
|
||||
The `"entrypoints"` you pass into `Bun.build()` should be your _server components_. Bun's bundler will automatically detect any files containing the `"use client"` directive, and will use those files as entrypoints for the "client build" and "SSR build". The bundler configuration for these builds can be provided `client` and `ssr` keys respectively.
|
||||
|
||||
```ts
|
||||
import ServerComponentsPlugin from "bun-plugin-server-components";
|
||||
|
||||
await Bun.build({
|
||||
entrypoints: ["./index.tsx"], // server component files
|
||||
outdir: "./build",
|
||||
manifest: true,
|
||||
plugins: [ServerComponentsPlugin({
|
||||
client: {
|
||||
entrypoints: [], // optional - additional client entrypoints
|
||||
outdir: "./build/client", // default: inherits from the main build
|
||||
target: "browser",
|
||||
plugins: [/* */],
|
||||
}
|
||||
ssr: {
|
||||
entrypoints: [], // optional - additional SSR entrypoints
|
||||
outdir: "./build/client", // default: inherits from the main build
|
||||
target: "bun", // this is default
|
||||
plugins: [/* */],
|
||||
}
|
||||
})],
|
||||
});
|
||||
```
|
||||
|
||||
The result of `Bun.build()` will contain additional manifests for the SSR and client builds.
|
||||
|
||||
```ts
|
||||
const result = await Bun.build({
|
||||
// config
|
||||
plugins: [
|
||||
ServerComponentsPlugin({
|
||||
/* config */
|
||||
}),
|
||||
],
|
||||
});
|
||||
|
||||
// standard manifest
|
||||
// for the top-level (server components) build
|
||||
result.manifest;
|
||||
|
||||
// manifest for client build
|
||||
result.clientManifest;
|
||||
|
||||
// manifest for client build
|
||||
result.ssrManifest;
|
||||
```
|
||||
|
||||
Once the build is complete, use the manifests to implement your RSC server.
|
||||
BIN
packages/bun-plugin-server-components/bun.lockb
Executable file
BIN
packages/bun-plugin-server-components/bun.lockb
Executable file
Binary file not shown.
10
packages/bun-plugin-server-components/index.ts
Normal file
10
packages/bun-plugin-server-components/index.ts
Normal file
@@ -0,0 +1,10 @@
|
||||
import { BunPlugin, BuildConfig } from "bun";
|
||||
|
||||
function Plugin(config: { client?: BuildConfig; ssr?: BuildConfig }): BunPlugin {
|
||||
return {
|
||||
name: "bun-plugin-server-components",
|
||||
SECRET_SERVER_COMPONENTS_INTERNALS: config,
|
||||
} as any;
|
||||
}
|
||||
|
||||
export default Plugin;
|
||||
28
packages/bun-plugin-server-components/package.json
Normal file
28
packages/bun-plugin-server-components/package.json
Normal file
@@ -0,0 +1,28 @@
|
||||
{
|
||||
"name": "bun-plugin-server-components",
|
||||
"version": "0.0.1-alpha.0",
|
||||
"module": "index.ts",
|
||||
"type": "module",
|
||||
"types": "index.ts",
|
||||
"exports": {
|
||||
".": {
|
||||
"import": "./index.ts",
|
||||
"require": "./index.ts",
|
||||
"default": "./index.js"
|
||||
},
|
||||
"./package.json": "./package.json"
|
||||
},
|
||||
"files": [
|
||||
"index.ts",
|
||||
"tsconfig.json",
|
||||
"package.json",
|
||||
"modules.d.ts"
|
||||
],
|
||||
"devDependencies": {
|
||||
"@types/js-yaml": "^4.0.5"
|
||||
},
|
||||
"dependencies": {
|
||||
"bun-types": "canary",
|
||||
"js-yaml": "^4.1.0"
|
||||
}
|
||||
}
|
||||
23
packages/bun-plugin-server-components/tsconfig.json
Normal file
23
packages/bun-plugin-server-components/tsconfig.json
Normal file
@@ -0,0 +1,23 @@
|
||||
{
|
||||
"compilerOptions": {
|
||||
"lib": ["ESNext"],
|
||||
"module": "esnext",
|
||||
"target": "esnext",
|
||||
"moduleResolution": "bundler",
|
||||
"moduleDetection": "force",
|
||||
"allowImportingTsExtensions": true,
|
||||
"noEmit": true,
|
||||
"composite": true,
|
||||
"strict": true,
|
||||
"downlevelIteration": true,
|
||||
"skipLibCheck": true,
|
||||
"jsx": "react-jsx",
|
||||
"allowSyntheticDefaultImports": true,
|
||||
"forceConsistentCasingInFileNames": true,
|
||||
"allowJs": true,
|
||||
"types": [
|
||||
"bun-types" // add Bun global
|
||||
]
|
||||
},
|
||||
"include": ["**/*.ts", "modules.d.ts"]
|
||||
}
|
||||
222
packages/bun-types/bun.d.ts
vendored
222
packages/bun-types/bun.d.ts
vendored
@@ -1497,35 +1497,13 @@ declare module "bun" {
|
||||
kind: ImportKind;
|
||||
}
|
||||
|
||||
type ModuleFormat = "esm"; // later: "cjs", "iife"
|
||||
|
||||
interface BuildConfig {
|
||||
entrypoints: string[]; // list of file path
|
||||
outdir?: string; // output directory
|
||||
target?: Target; // default: "browser"
|
||||
/**
|
||||
* Output module format. Top-level await is only supported for `"esm"`.
|
||||
*
|
||||
* Can be:
|
||||
* - `"esm"`
|
||||
* - `"cjs"` (**experimental**)
|
||||
* - `"iife"` (**experimental**)
|
||||
*
|
||||
* @default "esm"
|
||||
*/
|
||||
format?: /**
|
||||
|
||||
* ECMAScript Module format
|
||||
*/
|
||||
| "esm"
|
||||
/**
|
||||
* CommonJS format
|
||||
* **Experimental**
|
||||
*/
|
||||
| "cjs"
|
||||
/**
|
||||
* IIFE format
|
||||
* **Experimental**
|
||||
*/
|
||||
| "iife";
|
||||
format?: ModuleFormat; // later: "cjs", "iife"
|
||||
naming?:
|
||||
| string
|
||||
| {
|
||||
@@ -1583,40 +1561,6 @@ declare module "bun" {
|
||||
// /** Only works when runtime=automatic */
|
||||
// importSource?: string; // default: "react"
|
||||
// };
|
||||
|
||||
/**
|
||||
* Generate bytecode for the output. This can dramatically improve cold
|
||||
* start times, but will make the final output larger and slightly increase
|
||||
* memory usage.
|
||||
*
|
||||
* Bytecode is currently only supported for CommonJS (`format: "cjs"`).
|
||||
*
|
||||
* Must be `target: "bun"`
|
||||
* @default false
|
||||
*/
|
||||
bytecode?: boolean;
|
||||
/**
|
||||
* Add a banner to the bundled code such as "use client";
|
||||
*/
|
||||
banner?: string;
|
||||
/**
|
||||
* Add a footer to the bundled code such as a comment block like
|
||||
*
|
||||
* `// made with bun!`
|
||||
*/
|
||||
footer?: string;
|
||||
|
||||
/**
|
||||
* **Experimental**
|
||||
*
|
||||
* Enable CSS support.
|
||||
*/
|
||||
experimentalCss?: boolean;
|
||||
|
||||
/**
|
||||
* Drop function calls to matching property accesses.
|
||||
*/
|
||||
drop?: string[];
|
||||
}
|
||||
|
||||
namespace Password {
|
||||
@@ -1650,7 +1594,7 @@ declare module "bun" {
|
||||
* automatically run in a worker thread.
|
||||
*
|
||||
* The underlying implementation of these functions are provided by the Zig
|
||||
* Standard Library. Thanks to @jedisct1 and other Zig contributors for their
|
||||
* Standard Library. Thanks to @jedisct1 and other Zig constributors for their
|
||||
* work on this.
|
||||
*
|
||||
* ### Example with argon2
|
||||
@@ -1753,7 +1697,7 @@ declare module "bun" {
|
||||
* instead which runs in a worker thread.
|
||||
*
|
||||
* The underlying implementation of these functions are provided by the Zig
|
||||
* Standard Library. Thanks to @jedisct1 and other Zig contributors for their
|
||||
* Standard Library. Thanks to @jedisct1 and other Zig constributors for their
|
||||
* work on this.
|
||||
*
|
||||
* ### Example with argon2
|
||||
@@ -1792,7 +1736,7 @@ declare module "bun" {
|
||||
* instead which runs in a worker thread.
|
||||
*
|
||||
* The underlying implementation of these functions are provided by the Zig
|
||||
* Standard Library. Thanks to @jedisct1 and other Zig contributors for their
|
||||
* Standard Library. Thanks to @jedisct1 and other Zig constributors for their
|
||||
* work on this.
|
||||
*
|
||||
* ### Example with argon2
|
||||
@@ -1837,7 +1781,7 @@ declare module "bun" {
|
||||
path: string;
|
||||
loader: Loader;
|
||||
hash: string | null;
|
||||
kind: "entry-point" | "chunk" | "asset" | "sourcemap" | "bytecode";
|
||||
kind: "entry-point" | "chunk" | "asset" | "sourcemap";
|
||||
sourcemap: BuildArtifact | null;
|
||||
}
|
||||
|
||||
@@ -2338,7 +2282,7 @@ declare module "bun" {
|
||||
*/
|
||||
development?: boolean;
|
||||
|
||||
error?: (this: Server, error: ErrorLike) => Response | Promise<Response> | undefined | Promise<undefined>;
|
||||
error?: (this: Server, request: ErrorLike) => Response | Promise<Response> | undefined | Promise<undefined>;
|
||||
|
||||
/**
|
||||
* Uniquely identify a server instance with an ID
|
||||
@@ -3023,7 +2967,6 @@ declare module "bun" {
|
||||
colors?: boolean;
|
||||
depth?: number;
|
||||
sorted?: boolean;
|
||||
compact?: boolean;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -3039,14 +2982,6 @@ declare module "bun" {
|
||||
* That can be used to declare custom inspect functions.
|
||||
*/
|
||||
const custom: typeof import("util").inspect.custom;
|
||||
|
||||
/**
|
||||
* Pretty-print an object or array as a table
|
||||
*
|
||||
* Like {@link console.table}, except it returns a string
|
||||
*/
|
||||
function table(tabularData: object | unknown[], properties?: string[], options?: { colors?: boolean }): string;
|
||||
function table(tabularData: object | unknown[], options?: { colors?: boolean }): string;
|
||||
}
|
||||
|
||||
interface MMapOptions {
|
||||
@@ -3094,105 +3029,6 @@ declare module "bun" {
|
||||
|
||||
type StringLike = string | { toString(): string };
|
||||
|
||||
type ColorInput =
|
||||
| { r: number; g: number; b: number; a?: number }
|
||||
| [number, number, number]
|
||||
| [number, number, number, number]
|
||||
| Uint8Array
|
||||
| Uint8ClampedArray
|
||||
| Float32Array
|
||||
| Float64Array
|
||||
| string
|
||||
| number
|
||||
| { toString(): string };
|
||||
|
||||
function color(
|
||||
input: ColorInput,
|
||||
outputFormat?: /**
|
||||
* True color ANSI color string, for use in terminals
|
||||
* @example \x1b[38;2;100;200;200m
|
||||
*/
|
||||
| "ansi"
|
||||
| "ansi-16"
|
||||
| "ansi-16m"
|
||||
/**
|
||||
* 256 color ANSI color string, for use in terminals which don't support true color
|
||||
*
|
||||
* Tries to match closest 24-bit color to 256 color palette
|
||||
*/
|
||||
| "ansi-256"
|
||||
/**
|
||||
* Picks the format that produces the shortest output
|
||||
*/
|
||||
| "css"
|
||||
/**
|
||||
* Lowercase hex color string without alpha
|
||||
* @example #ff9800
|
||||
*/
|
||||
| "hex"
|
||||
/**
|
||||
* Uppercase hex color string without alpha
|
||||
* @example #FF9800
|
||||
*/
|
||||
| "HEX"
|
||||
/**
|
||||
* @example hsl(35.764706, 1, 0.5)
|
||||
*/
|
||||
| "hsl"
|
||||
/**
|
||||
* @example lab(0.72732764, 33.938198, -25.311619)
|
||||
*/
|
||||
| "lab"
|
||||
/**
|
||||
* @example 16750592
|
||||
*/
|
||||
| "number"
|
||||
/**
|
||||
* RGB color string without alpha
|
||||
* @example rgb(255, 152, 0)
|
||||
*/
|
||||
| "rgb"
|
||||
/**
|
||||
* RGB color string with alpha
|
||||
* @example rgba(255, 152, 0, 1)
|
||||
*/
|
||||
| "rgba",
|
||||
): string | null;
|
||||
|
||||
function color(
|
||||
input: ColorInput,
|
||||
/**
|
||||
* An array of numbers representing the RGB color
|
||||
* @example [100, 200, 200]
|
||||
*/
|
||||
outputFormat: "[rgb]",
|
||||
): [number, number, number] | null;
|
||||
function color(
|
||||
input: ColorInput,
|
||||
/**
|
||||
* An array of numbers representing the RGBA color
|
||||
* @example [100, 200, 200, 255]
|
||||
*/
|
||||
outputFormat: "[rgba]",
|
||||
): [number, number, number, number] | null;
|
||||
function color(
|
||||
input: ColorInput,
|
||||
/**
|
||||
* An object representing the RGB color
|
||||
* @example { r: 100, g: 200, b: 200 }
|
||||
*/
|
||||
outputFormat: "{rgb}",
|
||||
): { r: number; g: number; b: number } | null;
|
||||
function color(
|
||||
input: ColorInput,
|
||||
/**
|
||||
* An object representing the RGBA color
|
||||
* @example { r: 100, g: 200, b: 200, a: 0.5 }
|
||||
*/
|
||||
outputFormat: "{rgba}",
|
||||
): { r: number; g: number; b: number; a: number } | null;
|
||||
function color(input: ColorInput, outputFormat: "number"): number | null;
|
||||
|
||||
interface Semver {
|
||||
/**
|
||||
* Test if the version satisfies the range. Stringifies both arguments. Returns `true` or `false`.
|
||||
@@ -3249,7 +3085,7 @@ declare module "bun" {
|
||||
}
|
||||
const unsafe: Unsafe;
|
||||
|
||||
type DigestEncoding = "utf8" | "ucs2" | "utf16le" | "latin1" | "ascii" | "base64" | "base64url" | "hex";
|
||||
type DigestEncoding = "hex" | "base64";
|
||||
|
||||
/**
|
||||
* Are ANSI colors enabled for stdin and stdout?
|
||||
@@ -3428,9 +3264,8 @@ declare module "bun" {
|
||||
* Create a new hasher
|
||||
*
|
||||
* @param algorithm The algorithm to use. See {@link algorithms} for a list of supported algorithms
|
||||
* @param hmacKey Optional key for HMAC. Must be a string or `TypedArray`. If not provided, the hasher will be a non-HMAC hasher.
|
||||
*/
|
||||
constructor(algorithm: SupportedCryptoAlgorithms, hmacKey?: string | NodeJS.TypedArray);
|
||||
constructor(algorithm: SupportedCryptoAlgorithms);
|
||||
|
||||
/**
|
||||
* Update the hash with data
|
||||
@@ -3993,7 +3828,7 @@ declare module "bun" {
|
||||
*
|
||||
* In a future version of Bun, this will be used in error messages.
|
||||
*/
|
||||
name: string;
|
||||
name?: string;
|
||||
|
||||
/**
|
||||
* The target JavaScript environment the plugin should be applied to.
|
||||
@@ -4466,18 +4301,15 @@ declare module "bun" {
|
||||
hostname: string;
|
||||
port: number;
|
||||
tls?: TLSOptions;
|
||||
exclusive?: boolean;
|
||||
}
|
||||
|
||||
interface TCPSocketConnectOptions<Data = undefined> extends SocketOptions<Data> {
|
||||
hostname: string;
|
||||
port: number;
|
||||
tls?: boolean;
|
||||
exclusive?: boolean;
|
||||
}
|
||||
|
||||
interface UnixSocketOptions<Data = undefined> extends SocketOptions<Data> {
|
||||
tls?: TLSOptions;
|
||||
unix: string;
|
||||
}
|
||||
|
||||
@@ -4783,32 +4615,6 @@ declare module "bun" {
|
||||
* @default cmds[0]
|
||||
*/
|
||||
argv0?: string;
|
||||
|
||||
/**
|
||||
* An {@link AbortSignal} that can be used to abort the subprocess.
|
||||
*
|
||||
* This is useful for aborting a subprocess when some other part of the
|
||||
* program is aborted, such as a `fetch` response.
|
||||
*
|
||||
* Internally, this works by calling `subprocess.kill(1)`.
|
||||
*
|
||||
* @example
|
||||
* ```ts
|
||||
* const controller = new AbortController();
|
||||
* const { signal } = controller;
|
||||
* const start = performance.now();
|
||||
* const subprocess = Bun.spawn({
|
||||
* cmd: ["sleep", "100"],
|
||||
* signal,
|
||||
* });
|
||||
* await Bun.sleep(1);
|
||||
* controller.abort();
|
||||
* await subprocess.exited;
|
||||
* const end = performance.now();
|
||||
* console.log(end - start); // 1ms instead of 101ms
|
||||
* ```
|
||||
*/
|
||||
signal?: AbortSignal;
|
||||
}
|
||||
|
||||
type OptionsToSubprocess<Opts extends OptionsObject> =
|
||||
@@ -5312,12 +5118,6 @@ declare module "bun" {
|
||||
*/
|
||||
const version: string;
|
||||
|
||||
/**
|
||||
* The current version of Bun with the shortened commit sha of the build
|
||||
* @example "v1.1.30 (d09df1af)"
|
||||
*/
|
||||
const version_with_sha: string;
|
||||
|
||||
/**
|
||||
* The git sha at the time the currently-running version of Bun was compiled
|
||||
* @example
|
||||
|
||||
8
packages/bun-types/globals.d.ts
vendored
8
packages/bun-types/globals.d.ts
vendored
@@ -1838,6 +1838,14 @@ declare global {
|
||||
withCredentials?: boolean;
|
||||
}
|
||||
|
||||
interface EventSource extends Bun.EventSource {}
|
||||
var EventSource: typeof globalThis extends {
|
||||
onerror: any;
|
||||
EventSource: infer T;
|
||||
}
|
||||
? T
|
||||
: EventSource;
|
||||
|
||||
interface PromiseConstructor {
|
||||
/**
|
||||
* Create a deferred promise, with exposed `resolve` and `reject` methods which can be called
|
||||
|
||||
9
packages/bun-types/sqlite.d.ts
vendored
9
packages/bun-types/sqlite.d.ts
vendored
@@ -579,15 +579,6 @@ declare module "bun:sqlite" {
|
||||
*/
|
||||
get(...params: ParamsType): ReturnType | null;
|
||||
|
||||
/**
|
||||
* Execute the prepared statement and return an
|
||||
*
|
||||
* @param params optional values to bind to the statement. If omitted, the statement is run with the last bound values or no parameters if there are none.
|
||||
*
|
||||
*/
|
||||
iterate(...params: ParamsType): IterableIterator<ReturnType>;
|
||||
[Symbol.iterator](): IterableIterator<ReturnType>;
|
||||
|
||||
/**
|
||||
* Execute the prepared statement. This returns `undefined`.
|
||||
*
|
||||
|
||||
@@ -208,6 +208,10 @@ const writableStream = new WritableStream();
|
||||
const a = new ResolveError();
|
||||
a.level;
|
||||
}
|
||||
{
|
||||
const a = new EventSource("asdf");
|
||||
a.CLOSED;
|
||||
}
|
||||
{
|
||||
const a = new AbortController();
|
||||
a;
|
||||
|
||||
@@ -3645,7 +3645,7 @@ CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\006\040\006\005\026\160\002
|
||||
END
|
||||
CKA_TRUST_SERVER_AUTH CK_TRUST CKT_NSS_TRUSTED_DELEGATOR
|
||||
CKA_TRUST_EMAIL_PROTECTION CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_EMAIL_PROTECTION CK_TRUST CKT_NSS_TRUSTED_DELEGATOR
|
||||
CKA_TRUST_CODE_SIGNING CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_STEP_UP_APPROVED CK_BBOOL CK_FALSE
|
||||
|
||||
@@ -7252,7 +7252,7 @@ CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\010\136\303\267\246\103\177\244\340
|
||||
END
|
||||
CKA_TRUST_SERVER_AUTH CK_TRUST CKT_NSS_TRUSTED_DELEGATOR
|
||||
CKA_TRUST_EMAIL_PROTECTION CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_EMAIL_PROTECTION CK_TRUST CKT_NSS_TRUSTED_DELEGATOR
|
||||
CKA_TRUST_CODE_SIGNING CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_STEP_UP_APPROVED CK_BBOOL CK_FALSE
|
||||
|
||||
@@ -17020,14 +17020,8 @@ CKA_VALUE MULTILINE_OCTAL
|
||||
\155\015\277\173\327\222
|
||||
END
|
||||
CKA_NSS_MOZILLA_CA_POLICY CK_BBOOL CK_TRUE
|
||||
# For Server Distrust After: Sun Jun 30 00:00:00 2024
|
||||
CKA_NSS_SERVER_DISTRUST_AFTER MULTILINE_OCTAL
|
||||
\062\064\060\066\063\060\060\060\060\060\060\060\132
|
||||
END
|
||||
# For Email Distrust After: Sun Jun 30 00:00:00 2024
|
||||
CKA_NSS_EMAIL_DISTRUST_AFTER MULTILINE_OCTAL
|
||||
\062\064\060\066\063\060\060\060\060\060\060\060\132
|
||||
END
|
||||
CKA_NSS_SERVER_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
CKA_NSS_EMAIL_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
|
||||
# Trust for "GLOBALTRUST 2020"
|
||||
# Issuer: CN=GLOBALTRUST 2020,O=e-commerce monitoring GmbH,C=AT
|
||||
@@ -25489,761 +25483,3 @@ CKA_TRUST_EMAIL_PROTECTION CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_CODE_SIGNING CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_STEP_UP_APPROVED CK_BBOOL CK_FALSE
|
||||
|
||||
#
|
||||
# Certificate "TWCA CYBER Root CA"
|
||||
#
|
||||
# Issuer: CN=TWCA CYBER Root CA,OU=Root CA,O=TAIWAN-CA,C=TW
|
||||
# Serial Number:40:01:34:8c:c2:00:00:00:00:00:00:00:01:3c:f2:c6
|
||||
# Subject: CN=TWCA CYBER Root CA,OU=Root CA,O=TAIWAN-CA,C=TW
|
||||
# Not Valid Before: Tue Nov 22 06:54:29 2022
|
||||
# Not Valid After : Fri Nov 22 15:59:59 2047
|
||||
# Fingerprint (SHA-256): 3F:63:BB:28:14:BE:17:4E:C8:B6:43:9C:F0:8D:6D:56:F0:B7:C4:05:88:3A:56:48:A3:34:42:4D:6B:3E:C5:58
|
||||
# Fingerprint (SHA1): F6:B1:1C:1A:83:38:E9:7B:DB:B3:A8:C8:33:24:E0:2D:9C:7F:26:66
|
||||
CKA_CLASS CK_OBJECT_CLASS CKO_CERTIFICATE
|
||||
CKA_TOKEN CK_BBOOL CK_TRUE
|
||||
CKA_PRIVATE CK_BBOOL CK_FALSE
|
||||
CKA_MODIFIABLE CK_BBOOL CK_FALSE
|
||||
CKA_LABEL UTF8 "TWCA CYBER Root CA"
|
||||
CKA_CERTIFICATE_TYPE CK_CERTIFICATE_TYPE CKC_X_509
|
||||
CKA_SUBJECT MULTILINE_OCTAL
|
||||
\060\120\061\013\060\011\006\003\125\004\006\023\002\124\127\061
|
||||
\022\060\020\006\003\125\004\012\023\011\124\101\111\127\101\116
|
||||
\055\103\101\061\020\060\016\006\003\125\004\013\023\007\122\157
|
||||
\157\164\040\103\101\061\033\060\031\006\003\125\004\003\023\022
|
||||
\124\127\103\101\040\103\131\102\105\122\040\122\157\157\164\040
|
||||
\103\101
|
||||
END
|
||||
CKA_ID UTF8 "0"
|
||||
CKA_ISSUER MULTILINE_OCTAL
|
||||
\060\120\061\013\060\011\006\003\125\004\006\023\002\124\127\061
|
||||
\022\060\020\006\003\125\004\012\023\011\124\101\111\127\101\116
|
||||
\055\103\101\061\020\060\016\006\003\125\004\013\023\007\122\157
|
||||
\157\164\040\103\101\061\033\060\031\006\003\125\004\003\023\022
|
||||
\124\127\103\101\040\103\131\102\105\122\040\122\157\157\164\040
|
||||
\103\101
|
||||
END
|
||||
CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\020\100\001\064\214\302\000\000\000\000\000\000\000\001\074
|
||||
\362\306
|
||||
END
|
||||
CKA_VALUE MULTILINE_OCTAL
|
||||
\060\202\005\215\060\202\003\165\240\003\002\001\002\002\020\100
|
||||
\001\064\214\302\000\000\000\000\000\000\000\001\074\362\306\060
|
||||
\015\006\011\052\206\110\206\367\015\001\001\014\005\000\060\120
|
||||
\061\013\060\011\006\003\125\004\006\023\002\124\127\061\022\060
|
||||
\020\006\003\125\004\012\023\011\124\101\111\127\101\116\055\103
|
||||
\101\061\020\060\016\006\003\125\004\013\023\007\122\157\157\164
|
||||
\040\103\101\061\033\060\031\006\003\125\004\003\023\022\124\127
|
||||
\103\101\040\103\131\102\105\122\040\122\157\157\164\040\103\101
|
||||
\060\036\027\015\062\062\061\061\062\062\060\066\065\064\062\071
|
||||
\132\027\015\064\067\061\061\062\062\061\065\065\071\065\071\132
|
||||
\060\120\061\013\060\011\006\003\125\004\006\023\002\124\127\061
|
||||
\022\060\020\006\003\125\004\012\023\011\124\101\111\127\101\116
|
||||
\055\103\101\061\020\060\016\006\003\125\004\013\023\007\122\157
|
||||
\157\164\040\103\101\061\033\060\031\006\003\125\004\003\023\022
|
||||
\124\127\103\101\040\103\131\102\105\122\040\122\157\157\164\040
|
||||
\103\101\060\202\002\042\060\015\006\011\052\206\110\206\367\015
|
||||
\001\001\001\005\000\003\202\002\017\000\060\202\002\012\002\202
|
||||
\002\001\000\306\370\312\036\331\011\040\176\035\154\116\316\217
|
||||
\343\107\063\104\234\307\311\151\252\072\133\170\356\160\322\222
|
||||
\370\004\263\122\122\035\147\162\050\241\337\213\135\225\012\376
|
||||
\352\315\355\367\051\316\360\157\177\254\315\075\357\263\034\105
|
||||
\152\367\050\220\361\141\127\305\014\304\243\120\135\336\324\265
|
||||
\313\031\312\200\271\165\316\051\316\322\205\042\354\002\143\314
|
||||
\104\060\040\332\352\221\133\126\346\035\034\325\235\146\307\077
|
||||
\337\206\312\113\123\304\331\215\262\035\352\370\334\047\123\243
|
||||
\107\341\141\314\175\265\260\370\356\163\221\305\316\163\157\316
|
||||
\356\020\037\032\006\317\351\047\140\305\117\031\344\353\316\042
|
||||
\046\105\327\140\231\335\316\117\067\340\177\347\143\255\260\270
|
||||
\131\270\320\006\150\065\140\323\066\256\161\103\004\361\151\145
|
||||
\170\174\363\037\363\312\050\237\132\040\225\146\264\315\267\356
|
||||
\217\170\244\105\030\351\046\057\215\233\051\050\261\244\267\072
|
||||
\155\271\324\034\070\162\105\130\261\136\353\360\050\233\267\202
|
||||
\312\375\317\326\063\017\237\373\227\236\261\034\234\236\352\137
|
||||
\136\333\252\335\124\351\060\041\050\155\216\171\363\165\222\214
|
||||
\046\376\334\305\366\303\260\337\104\131\103\243\266\003\050\366
|
||||
\010\060\252\015\063\341\357\234\251\007\042\343\131\133\100\217
|
||||
\332\210\267\151\010\250\267\043\056\104\011\131\067\133\307\343
|
||||
\027\362\042\353\156\071\122\305\336\124\247\230\311\113\040\225
|
||||
\334\106\211\137\264\022\371\205\051\216\353\310\047\025\040\300
|
||||
\113\324\314\174\014\154\064\014\046\233\046\061\246\074\247\366
|
||||
\331\320\113\242\144\377\073\231\101\162\301\340\160\227\361\044
|
||||
\273\053\304\164\042\261\254\153\042\062\044\323\170\052\300\300
|
||||
\241\057\361\122\005\311\077\357\166\146\342\105\330\015\075\255
|
||||
\225\310\307\211\046\310\017\256\247\003\056\373\301\137\372\040
|
||||
\341\160\255\260\145\040\067\063\140\260\325\257\327\014\034\302
|
||||
\220\160\327\112\030\274\176\001\260\260\353\025\036\104\006\315
|
||||
\244\117\350\014\321\303\040\020\341\124\145\236\266\121\320\032
|
||||
\166\153\102\132\130\166\064\352\267\067\031\256\056\165\371\226
|
||||
\345\301\131\367\224\127\051\045\215\072\114\253\115\232\101\320
|
||||
\137\046\003\002\003\001\000\001\243\143\060\141\060\016\006\003
|
||||
\125\035\017\001\001\377\004\004\003\002\001\006\060\017\006\003
|
||||
\125\035\023\001\001\377\004\005\060\003\001\001\377\060\037\006
|
||||
\003\125\035\043\004\030\060\026\200\024\235\205\141\024\174\301
|
||||
\142\157\227\150\344\117\067\100\341\255\340\015\126\067\060\035
|
||||
\006\003\125\035\016\004\026\004\024\235\205\141\024\174\301\142
|
||||
\157\227\150\344\117\067\100\341\255\340\015\126\067\060\015\006
|
||||
\011\052\206\110\206\367\015\001\001\014\005\000\003\202\002\001
|
||||
\000\144\217\172\304\142\016\265\210\314\270\307\206\016\241\112
|
||||
\026\315\160\013\267\247\205\013\263\166\266\017\247\377\010\213
|
||||
\013\045\317\250\324\203\165\052\270\226\210\266\373\337\055\055
|
||||
\264\151\123\041\065\127\326\211\115\163\277\151\217\160\243\141
|
||||
\314\232\333\036\232\340\040\370\154\273\233\042\235\135\204\061
|
||||
\232\054\212\335\152\241\327\050\151\312\376\166\125\172\106\147
|
||||
\353\314\103\210\026\242\003\326\271\027\370\031\154\155\043\002
|
||||
\177\361\137\320\012\051\043\073\321\252\012\355\251\027\046\124
|
||||
\012\115\302\245\115\370\305\375\270\201\317\053\054\170\243\147
|
||||
\114\251\007\232\363\337\136\373\174\365\211\315\164\227\141\020
|
||||
\152\007\053\201\132\322\216\267\347\040\321\040\156\044\250\204
|
||||
\047\241\127\254\252\125\130\057\334\331\312\372\150\004\236\355
|
||||
\104\044\371\164\100\073\043\063\253\203\132\030\046\102\266\155
|
||||
\124\265\026\140\060\154\261\240\370\270\101\240\135\111\111\322
|
||||
\145\005\072\352\376\235\141\274\206\331\277\336\323\272\072\261
|
||||
\177\176\222\064\216\311\000\156\334\230\275\334\354\200\005\255
|
||||
\002\075\337\145\355\013\003\367\367\026\204\004\061\272\223\224
|
||||
\330\362\022\370\212\343\277\102\257\247\324\315\021\027\026\310
|
||||
\102\035\024\250\102\366\322\100\206\240\117\043\312\226\105\126
|
||||
\140\006\315\267\125\001\246\001\224\145\376\156\005\011\272\264
|
||||
\244\252\342\357\130\276\275\047\126\330\357\163\161\133\104\063
|
||||
\362\232\162\352\260\136\076\156\251\122\133\354\160\155\265\207
|
||||
\217\067\136\074\214\234\316\344\360\316\014\147\101\314\316\366
|
||||
\200\253\116\314\114\126\365\301\141\131\223\264\076\246\332\270
|
||||
\067\022\237\052\062\343\213\270\041\354\303\053\145\014\357\042
|
||||
\336\210\051\073\114\327\372\376\267\341\107\276\234\076\076\203
|
||||
\373\121\135\365\150\367\056\041\205\334\277\361\132\342\174\327
|
||||
\305\344\203\301\152\353\272\200\132\336\134\055\160\166\370\310
|
||||
\345\207\207\312\240\235\241\345\042\022\047\017\104\075\035\154
|
||||
\352\324\302\213\057\157\171\253\177\120\246\304\031\247\241\172
|
||||
\267\226\371\301\037\142\132\242\103\007\100\136\046\306\254\355
|
||||
\256\160\026\305\252\312\162\212\115\260\317\001\213\003\077\156
|
||||
\327
|
||||
END
|
||||
CKA_NSS_MOZILLA_CA_POLICY CK_BBOOL CK_TRUE
|
||||
CKA_NSS_SERVER_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
CKA_NSS_EMAIL_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
|
||||
# Trust for "TWCA CYBER Root CA"
|
||||
# Issuer: CN=TWCA CYBER Root CA,OU=Root CA,O=TAIWAN-CA,C=TW
|
||||
# Serial Number:40:01:34:8c:c2:00:00:00:00:00:00:00:01:3c:f2:c6
|
||||
# Subject: CN=TWCA CYBER Root CA,OU=Root CA,O=TAIWAN-CA,C=TW
|
||||
# Not Valid Before: Tue Nov 22 06:54:29 2022
|
||||
# Not Valid After : Fri Nov 22 15:59:59 2047
|
||||
# Fingerprint (SHA-256): 3F:63:BB:28:14:BE:17:4E:C8:B6:43:9C:F0:8D:6D:56:F0:B7:C4:05:88:3A:56:48:A3:34:42:4D:6B:3E:C5:58
|
||||
# Fingerprint (SHA1): F6:B1:1C:1A:83:38:E9:7B:DB:B3:A8:C8:33:24:E0:2D:9C:7F:26:66
|
||||
CKA_CLASS CK_OBJECT_CLASS CKO_NSS_TRUST
|
||||
CKA_TOKEN CK_BBOOL CK_TRUE
|
||||
CKA_PRIVATE CK_BBOOL CK_FALSE
|
||||
CKA_MODIFIABLE CK_BBOOL CK_FALSE
|
||||
CKA_LABEL UTF8 "TWCA CYBER Root CA"
|
||||
CKA_CERT_SHA1_HASH MULTILINE_OCTAL
|
||||
\366\261\034\032\203\070\351\173\333\263\250\310\063\044\340\055
|
||||
\234\177\046\146
|
||||
END
|
||||
CKA_CERT_MD5_HASH MULTILINE_OCTAL
|
||||
\013\063\240\227\122\225\324\251\375\273\333\156\243\125\133\121
|
||||
END
|
||||
CKA_ISSUER MULTILINE_OCTAL
|
||||
\060\120\061\013\060\011\006\003\125\004\006\023\002\124\127\061
|
||||
\022\060\020\006\003\125\004\012\023\011\124\101\111\127\101\116
|
||||
\055\103\101\061\020\060\016\006\003\125\004\013\023\007\122\157
|
||||
\157\164\040\103\101\061\033\060\031\006\003\125\004\003\023\022
|
||||
\124\127\103\101\040\103\131\102\105\122\040\122\157\157\164\040
|
||||
\103\101
|
||||
END
|
||||
CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\020\100\001\064\214\302\000\000\000\000\000\000\000\001\074
|
||||
\362\306
|
||||
END
|
||||
CKA_TRUST_SERVER_AUTH CK_TRUST CKT_NSS_TRUSTED_DELEGATOR
|
||||
CKA_TRUST_EMAIL_PROTECTION CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_CODE_SIGNING CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_STEP_UP_APPROVED CK_BBOOL CK_FALSE
|
||||
|
||||
#
|
||||
# Certificate "TWCA Global Root CA G2"
|
||||
#
|
||||
# Issuer: CN=TWCA Global Root CA G2,OU=Root CA,O=TAIWAN-CA,C=TW
|
||||
# Serial Number:40:01:34:8c:c2:00:00:00:00:00:00:00:01:97:58:f4
|
||||
# Subject: CN=TWCA Global Root CA G2,OU=Root CA,O=TAIWAN-CA,C=TW
|
||||
# Not Valid Before: Tue Nov 22 06:42:21 2022
|
||||
# Not Valid After : Fri Nov 22 15:59:59 2047
|
||||
# Fingerprint (SHA-256): 3A:00:72:D4:9F:FC:04:E9:96:C5:9A:EB:75:99:1D:3C:34:0F:36:15:D6:FD:4D:CE:90:AC:0B:3D:88:EA:D4:F4
|
||||
# Fingerprint (SHA1): 73:FE:92:2F:83:63:91:FF:C8:C6:C4:DA:D6:20:2F:6B:07:2E:7F:1B
|
||||
CKA_CLASS CK_OBJECT_CLASS CKO_CERTIFICATE
|
||||
CKA_TOKEN CK_BBOOL CK_TRUE
|
||||
CKA_PRIVATE CK_BBOOL CK_FALSE
|
||||
CKA_MODIFIABLE CK_BBOOL CK_FALSE
|
||||
CKA_LABEL UTF8 "TWCA Global Root CA G2"
|
||||
CKA_CERTIFICATE_TYPE CK_CERTIFICATE_TYPE CKC_X_509
|
||||
CKA_SUBJECT MULTILINE_OCTAL
|
||||
\060\124\061\013\060\011\006\003\125\004\006\023\002\124\127\061
|
||||
\022\060\020\006\003\125\004\012\023\011\124\101\111\127\101\116
|
||||
\055\103\101\061\020\060\016\006\003\125\004\013\023\007\122\157
|
||||
\157\164\040\103\101\061\037\060\035\006\003\125\004\003\023\026
|
||||
\124\127\103\101\040\107\154\157\142\141\154\040\122\157\157\164
|
||||
\040\103\101\040\107\062
|
||||
END
|
||||
CKA_ID UTF8 "0"
|
||||
CKA_ISSUER MULTILINE_OCTAL
|
||||
\060\124\061\013\060\011\006\003\125\004\006\023\002\124\127\061
|
||||
\022\060\020\006\003\125\004\012\023\011\124\101\111\127\101\116
|
||||
\055\103\101\061\020\060\016\006\003\125\004\013\023\007\122\157
|
||||
\157\164\040\103\101\061\037\060\035\006\003\125\004\003\023\026
|
||||
\124\127\103\101\040\107\154\157\142\141\154\040\122\157\157\164
|
||||
\040\103\101\040\107\062
|
||||
END
|
||||
CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\020\100\001\064\214\302\000\000\000\000\000\000\000\001\227
|
||||
\130\364
|
||||
END
|
||||
CKA_VALUE MULTILINE_OCTAL
|
||||
\060\202\005\225\060\202\003\175\240\003\002\001\002\002\020\100
|
||||
\001\064\214\302\000\000\000\000\000\000\000\001\227\130\364\060
|
||||
\015\006\011\052\206\110\206\367\015\001\001\014\005\000\060\124
|
||||
\061\013\060\011\006\003\125\004\006\023\002\124\127\061\022\060
|
||||
\020\006\003\125\004\012\023\011\124\101\111\127\101\116\055\103
|
||||
\101\061\020\060\016\006\003\125\004\013\023\007\122\157\157\164
|
||||
\040\103\101\061\037\060\035\006\003\125\004\003\023\026\124\127
|
||||
\103\101\040\107\154\157\142\141\154\040\122\157\157\164\040\103
|
||||
\101\040\107\062\060\036\027\015\062\062\061\061\062\062\060\066
|
||||
\064\062\062\061\132\027\015\064\067\061\061\062\062\061\065\065
|
||||
\071\065\071\132\060\124\061\013\060\011\006\003\125\004\006\023
|
||||
\002\124\127\061\022\060\020\006\003\125\004\012\023\011\124\101
|
||||
\111\127\101\116\055\103\101\061\020\060\016\006\003\125\004\013
|
||||
\023\007\122\157\157\164\040\103\101\061\037\060\035\006\003\125
|
||||
\004\003\023\026\124\127\103\101\040\107\154\157\142\141\154\040
|
||||
\122\157\157\164\040\103\101\040\107\062\060\202\002\042\060\015
|
||||
\006\011\052\206\110\206\367\015\001\001\001\005\000\003\202\002
|
||||
\017\000\060\202\002\012\002\202\002\001\000\252\016\325\040\222
|
||||
\001\255\202\371\014\010\221\064\153\212\026\320\106\026\377\003
|
||||
\270\330\215\352\223\064\373\377\053\275\375\156\252\334\233\362
|
||||
\206\201\125\365\211\034\304\215\165\152\130\170\221\023\036\002
|
||||
\023\160\075\357\276\012\347\000\217\270\061\345\164\305\060\276
|
||||
\377\175\326\231\345\302\102\243\317\041\326\263\010\177\221\325
|
||||
\141\346\242\225\020\015\357\136\227\013\111\070\325\042\260\327
|
||||
\213\131\157\237\065\233\177\322\221\314\172\177\273\240\237\336
|
||||
\125\063\366\113\215\012\352\175\011\300\171\334\275\104\342\376
|
||||
\034\347\144\041\050\317\004\112\342\264\277\206\171\052\273\016
|
||||
\223\311\217\136\254\060\071\122\220\007\271\352\234\046\102\024
|
||||
\304\147\106\376\321\032\150\241\076\120\031\243\046\012\047\051
|
||||
\220\302\366\264\353\163\232\170\036\341\230\364\145\014\065\041
|
||||
\006\370\013\336\142\345\115\301\263\135\331\271\372\141\227\052
|
||||
\343\352\307\104\125\044\222\376\022\247\077\304\167\340\055\002
|
||||
\201\007\325\373\175\346\020\236\072\264\250\357\354\373\120\352
|
||||
\065\317\314\176\273\102\271\104\154\122\351\277\052\162\037\077
|
||||
\336\233\160\351\334\132\305\073\273\277\360\131\205\257\057\301
|
||||
\260\024\171\005\254\165\237\045\365\021\047\006\140\041\307\155
|
||||
\145\276\250\211\234\345\254\106\337\370\135\104\003\215\140\275
|
||||
\367\261\015\314\057\357\101\124\057\356\153\225\271\116\174\064
|
||||
\337\073\371\167\235\175\315\007\075\034\006\063\022\200\354\162
|
||||
\234\362\055\202\332\325\073\304\307\371\004\303\144\002\174\365
|
||||
\065\140\247\264\106\051\056\033\357\245\130\200\056\172\211\121
|
||||
\070\066\074\375\241\167\270\200\060\320\212\336\215\247\064\046
|
||||
\354\043\273\030\125\030\066\105\356\355\001\006\252\115\277\144
|
||||
\014\312\230\227\032\061\002\146\370\170\150\133\210\337\011\250
|
||||
\347\233\372\064\155\160\034\041\255\010\213\362\241\266\254\166
|
||||
\152\277\361\200\045\000\276\074\036\115\256\271\074\266\225\143
|
||||
\275\153\176\107\022\220\125\105\021\215\354\027\037\301\276\047
|
||||
\201\223\127\143\151\000\046\167\213\303\131\345\173\321\015\104
|
||||
\362\250\360\367\205\232\005\367\302\056\160\232\223\205\330\225
|
||||
\220\061\220\124\246\354\013\237\067\105\017\002\003\001\000\001
|
||||
\243\143\060\141\060\016\006\003\125\035\017\001\001\377\004\004
|
||||
\003\002\001\006\060\017\006\003\125\035\023\001\001\377\004\005
|
||||
\060\003\001\001\377\060\037\006\003\125\035\043\004\030\060\026
|
||||
\200\024\222\214\324\066\321\133\107\123\304\161\015\204\335\144
|
||||
\052\365\066\144\100\347\060\035\006\003\125\035\016\004\026\004
|
||||
\024\222\214\324\066\321\133\107\123\304\161\015\204\335\144\052
|
||||
\365\066\144\100\347\060\015\006\011\052\206\110\206\367\015\001
|
||||
\001\014\005\000\003\202\002\001\000\045\374\113\332\220\264\332
|
||||
\165\347\101\072\201\321\246\376\240\152\363\030\161\142\152\044
|
||||
\010\213\251\172\115\311\125\316\317\020\050\056\004\031\226\005
|
||||
\317\135\002\040\052\073\263\125\077\001\315\102\315\262\167\355
|
||||
\377\165\363\174\167\333\226\245\317\214\147\006\364\244\233\162
|
||||
\366\041\111\011\230\243\062\136\167\132\143\011\357\142\103\227
|
||||
\002\070\265\352\074\030\120\150\374\131\133\331\171\324\361\344
|
||||
\126\110\023\126\330\323\161\013\136\170\224\070\021\105\372\005
|
||||
\027\365\016\165\036\142\122\141\106\272\056\031\255\206\264\210
|
||||
\017\261\120\346\100\000\064\032\225\235\223\340\121\371\324\125
|
||||
\106\351\225\074\045\206\056\227\327\001\061\030\104\354\034\140
|
||||
\351\175\151\257\062\370\227\100\045\044\266\215\032\125\074\305
|
||||
\267\367\274\006\122\073\161\060\160\076\161\027\176\361\146\004
|
||||
\136\135\274\212\061\103\246\222\035\173\124\322\245\066\213\157
|
||||
\215\326\136\332\324\303\056\035\337\071\125\140\202\060\236\047
|
||||
\377\216\200\335\143\114\246\125\065\330\320\063\251\200\155\076
|
||||
\136\235\314\250\147\200\146\372\231\127\014\122\312\031\165\260
|
||||
\070\065\125\052\201\305\214\036\126\327\137\220\362\040\330\332
|
||||
\340\146\161\351\262\170\253\147\271\044\156\153\066\162\374\157
|
||||
\215\375\177\162\071\050\147\122\221\005\037\127\145\322\243\247
|
||||
\015\141\372\241\347\325\065\106\225\311\006\207\366\060\354\062
|
||||
\121\251\254\126\300\041\116\243\024\164\005\072\274\343\277\155
|
||||
\075\116\077\136\245\244\155\051\277\204\121\165\123\216\206\032
|
||||
\365\121\160\052\015\034\116\100\341\375\243\343\245\053\147\220
|
||||
\222\307\154\256\205\277\072\233\027\025\312\234\052\223\324\115
|
||||
\071\015\274\040\010\243\215\210\154\011\015\214\256\104\041\115
|
||||
\311\161\354\330\046\327\027\236\055\021\030\074\243\042\175\270
|
||||
\047\124\277\150\310\073\102\314\217\136\116\347\334\302\305\372
|
||||
\152\104\017\215\126\210\172\337\211\204\154\240\263\076\075\361
|
||||
\145\000\011\210\352\052\353\100\316\263\135\254\062\027\256\301
|
||||
\233\351\320\301\365\111\224\335\247\316\174\132\007\353\256\040
|
||||
\234\027\060\222\151\223\162\363\232\133\161\233\376\152\337\172
|
||||
\060\151\216\263\056\333\017\054\335
|
||||
END
|
||||
CKA_NSS_MOZILLA_CA_POLICY CK_BBOOL CK_TRUE
|
||||
CKA_NSS_SERVER_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
CKA_NSS_EMAIL_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
|
||||
# Trust for "TWCA Global Root CA G2"
|
||||
# Issuer: CN=TWCA Global Root CA G2,OU=Root CA,O=TAIWAN-CA,C=TW
|
||||
# Serial Number:40:01:34:8c:c2:00:00:00:00:00:00:00:01:97:58:f4
|
||||
# Subject: CN=TWCA Global Root CA G2,OU=Root CA,O=TAIWAN-CA,C=TW
|
||||
# Not Valid Before: Tue Nov 22 06:42:21 2022
|
||||
# Not Valid After : Fri Nov 22 15:59:59 2047
|
||||
# Fingerprint (SHA-256): 3A:00:72:D4:9F:FC:04:E9:96:C5:9A:EB:75:99:1D:3C:34:0F:36:15:D6:FD:4D:CE:90:AC:0B:3D:88:EA:D4:F4
|
||||
# Fingerprint (SHA1): 73:FE:92:2F:83:63:91:FF:C8:C6:C4:DA:D6:20:2F:6B:07:2E:7F:1B
|
||||
CKA_CLASS CK_OBJECT_CLASS CKO_NSS_TRUST
|
||||
CKA_TOKEN CK_BBOOL CK_TRUE
|
||||
CKA_PRIVATE CK_BBOOL CK_FALSE
|
||||
CKA_MODIFIABLE CK_BBOOL CK_FALSE
|
||||
CKA_LABEL UTF8 "TWCA Global Root CA G2"
|
||||
CKA_CERT_SHA1_HASH MULTILINE_OCTAL
|
||||
\163\376\222\057\203\143\221\377\310\306\304\332\326\040\057\153
|
||||
\007\056\177\033
|
||||
END
|
||||
CKA_CERT_MD5_HASH MULTILINE_OCTAL
|
||||
\023\215\135\372\031\265\346\253\144\173\020\164\160\032\043\056
|
||||
END
|
||||
CKA_ISSUER MULTILINE_OCTAL
|
||||
\060\124\061\013\060\011\006\003\125\004\006\023\002\124\127\061
|
||||
\022\060\020\006\003\125\004\012\023\011\124\101\111\127\101\116
|
||||
\055\103\101\061\020\060\016\006\003\125\004\013\023\007\122\157
|
||||
\157\164\040\103\101\061\037\060\035\006\003\125\004\003\023\026
|
||||
\124\127\103\101\040\107\154\157\142\141\154\040\122\157\157\164
|
||||
\040\103\101\040\107\062
|
||||
END
|
||||
CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\020\100\001\064\214\302\000\000\000\000\000\000\000\001\227
|
||||
\130\364
|
||||
END
|
||||
CKA_TRUST_SERVER_AUTH CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_EMAIL_PROTECTION CK_TRUST CKT_NSS_TRUSTED_DELEGATOR
|
||||
CKA_TRUST_CODE_SIGNING CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_STEP_UP_APPROVED CK_BBOOL CK_FALSE
|
||||
|
||||
#
|
||||
# Certificate "SecureSign Root CA12"
|
||||
#
|
||||
# Issuer: CN=SecureSign Root CA12,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Serial Number:66:f9:c7:c1:af:ec:c2:51:b4:ed:53:97:e6:e6:82:c3:2b:1c:90:16
|
||||
# Subject: CN=SecureSign Root CA12,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Not Valid Before: Wed Apr 08 05:36:46 2020
|
||||
# Not Valid After : Sun Apr 08 05:36:46 2040
|
||||
# Fingerprint (SHA-256): 3F:03:4B:B5:70:4D:44:B2:D0:85:45:A0:20:57:DE:93:EB:F3:90:5F:CE:72:1A:CB:C7:30:C0:6D:DA:EE:90:4E
|
||||
# Fingerprint (SHA1): 7A:22:1E:3D:DE:1B:06:AC:9E:C8:47:70:16:8E:3C:E5:F7:6B:06:F4
|
||||
CKA_CLASS CK_OBJECT_CLASS CKO_CERTIFICATE
|
||||
CKA_TOKEN CK_BBOOL CK_TRUE
|
||||
CKA_PRIVATE CK_BBOOL CK_FALSE
|
||||
CKA_MODIFIABLE CK_BBOOL CK_FALSE
|
||||
CKA_LABEL UTF8 "SecureSign Root CA12"
|
||||
CKA_CERTIFICATE_TYPE CK_CERTIFICATE_TYPE CKC_X_509
|
||||
CKA_SUBJECT MULTILINE_OCTAL
|
||||
\060\121\061\013\060\011\006\003\125\004\006\023\002\112\120\061
|
||||
\043\060\041\006\003\125\004\012\023\032\103\171\142\145\162\164
|
||||
\162\165\163\164\040\112\141\160\141\156\040\103\157\056\054\040
|
||||
\114\164\144\056\061\035\060\033\006\003\125\004\003\023\024\123
|
||||
\145\143\165\162\145\123\151\147\156\040\122\157\157\164\040\103
|
||||
\101\061\062
|
||||
END
|
||||
CKA_ID UTF8 "0"
|
||||
CKA_ISSUER MULTILINE_OCTAL
|
||||
\060\121\061\013\060\011\006\003\125\004\006\023\002\112\120\061
|
||||
\043\060\041\006\003\125\004\012\023\032\103\171\142\145\162\164
|
||||
\162\165\163\164\040\112\141\160\141\156\040\103\157\056\054\040
|
||||
\114\164\144\056\061\035\060\033\006\003\125\004\003\023\024\123
|
||||
\145\143\165\162\145\123\151\147\156\040\122\157\157\164\040\103
|
||||
\101\061\062
|
||||
END
|
||||
CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\024\146\371\307\301\257\354\302\121\264\355\123\227\346\346
|
||||
\202\303\053\034\220\026
|
||||
END
|
||||
CKA_VALUE MULTILINE_OCTAL
|
||||
\060\202\003\162\060\202\002\132\240\003\002\001\002\002\024\146
|
||||
\371\307\301\257\354\302\121\264\355\123\227\346\346\202\303\053
|
||||
\034\220\026\060\015\006\011\052\206\110\206\367\015\001\001\013
|
||||
\005\000\060\121\061\013\060\011\006\003\125\004\006\023\002\112
|
||||
\120\061\043\060\041\006\003\125\004\012\023\032\103\171\142\145
|
||||
\162\164\162\165\163\164\040\112\141\160\141\156\040\103\157\056
|
||||
\054\040\114\164\144\056\061\035\060\033\006\003\125\004\003\023
|
||||
\024\123\145\143\165\162\145\123\151\147\156\040\122\157\157\164
|
||||
\040\103\101\061\062\060\036\027\015\062\060\060\064\060\070\060
|
||||
\065\063\066\064\066\132\027\015\064\060\060\064\060\070\060\065
|
||||
\063\066\064\066\132\060\121\061\013\060\011\006\003\125\004\006
|
||||
\023\002\112\120\061\043\060\041\006\003\125\004\012\023\032\103
|
||||
\171\142\145\162\164\162\165\163\164\040\112\141\160\141\156\040
|
||||
\103\157\056\054\040\114\164\144\056\061\035\060\033\006\003\125
|
||||
\004\003\023\024\123\145\143\165\162\145\123\151\147\156\040\122
|
||||
\157\157\164\040\103\101\061\062\060\202\001\042\060\015\006\011
|
||||
\052\206\110\206\367\015\001\001\001\005\000\003\202\001\017\000
|
||||
\060\202\001\012\002\202\001\001\000\272\071\301\067\172\150\105
|
||||
\053\024\264\353\344\023\353\127\165\043\115\217\044\055\026\350
|
||||
\256\216\311\175\244\127\073\052\166\045\063\203\154\352\062\212
|
||||
\224\233\116\074\226\344\375\121\277\231\311\223\176\277\371\255
|
||||
\247\262\110\053\007\034\047\365\114\274\160\022\167\244\205\124
|
||||
\265\375\220\172\344\243\344\121\130\003\315\020\171\171\356\153
|
||||
\223\037\144\216\153\144\253\243\023\343\161\376\175\253\234\335
|
||||
\047\123\067\263\252\030\302\131\046\354\133\037\322\346\145\174
|
||||
\357\223\275\330\130\134\013\300\343\145\157\074\307\312\131\343
|
||||
\376\156\137\254\203\276\375\135\045\116\052\051\073\326\013\253
|
||||
\027\062\170\244\341\076\224\106\276\142\156\233\336\106\250\261
|
||||
\026\347\205\156\364\010\100\105\021\240\236\124\104\204\367\330
|
||||
\066\316\365\120\107\334\054\060\233\356\300\365\226\322\376\011
|
||||
\206\307\006\131\256\117\256\216\021\230\173\363\013\122\252\142
|
||||
\046\252\041\337\216\045\063\171\227\026\111\215\365\076\325\107
|
||||
\237\067\061\111\063\162\005\115\014\266\125\214\361\127\217\212
|
||||
\207\321\255\305\021\022\071\240\255\002\003\001\000\001\243\102
|
||||
\060\100\060\017\006\003\125\035\023\001\001\377\004\005\060\003
|
||||
\001\001\377\060\016\006\003\125\035\017\001\001\377\004\004\003
|
||||
\002\001\006\060\035\006\003\125\035\016\004\026\004\024\127\064
|
||||
\363\164\317\004\113\325\045\346\361\100\266\054\114\331\055\351
|
||||
\240\255\060\015\006\011\052\206\110\206\367\015\001\001\013\005
|
||||
\000\003\202\001\001\000\076\273\333\027\026\322\362\024\001\040
|
||||
\054\070\203\113\255\276\312\205\172\232\266\233\153\246\341\374
|
||||
\245\072\254\255\264\050\072\257\327\001\203\111\053\143\242\335
|
||||
\232\144\016\230\134\157\335\216\273\212\124\042\055\112\023\363
|
||||
\256\100\103\333\117\221\267\206\032\354\000\264\101\201\244\117
|
||||
\372\152\213\210\263\166\010\162\052\111\100\303\323\303\205\211
|
||||
\230\020\245\235\157\031\267\273\317\172\145\125\333\067\353\074
|
||||
\212\162\062\227\036\232\051\076\255\215\346\243\033\155\365\165
|
||||
\032\346\260\150\271\133\242\356\151\107\047\065\241\206\231\200
|
||||
\363\063\113\341\153\244\046\303\357\164\131\154\172\242\144\266
|
||||
\036\104\303\120\340\017\071\075\251\063\361\245\363\322\275\142
|
||||
\204\254\216\034\251\315\132\275\067\073\156\012\042\264\364\025
|
||||
\347\221\130\305\072\104\323\225\050\331\300\145\351\162\312\320
|
||||
\017\275\037\263\025\331\251\343\244\107\011\236\340\313\067\373
|
||||
\375\275\227\325\276\030\032\151\242\071\201\331\032\365\253\177
|
||||
\310\343\342\147\013\235\364\014\352\124\337\322\262\257\261\042
|
||||
\361\040\337\274\104\034
|
||||
END
|
||||
CKA_NSS_MOZILLA_CA_POLICY CK_BBOOL CK_TRUE
|
||||
CKA_NSS_SERVER_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
CKA_NSS_EMAIL_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
|
||||
# Trust for "SecureSign Root CA12"
|
||||
# Issuer: CN=SecureSign Root CA12,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Serial Number:66:f9:c7:c1:af:ec:c2:51:b4:ed:53:97:e6:e6:82:c3:2b:1c:90:16
|
||||
# Subject: CN=SecureSign Root CA12,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Not Valid Before: Wed Apr 08 05:36:46 2020
|
||||
# Not Valid After : Sun Apr 08 05:36:46 2040
|
||||
# Fingerprint (SHA-256): 3F:03:4B:B5:70:4D:44:B2:D0:85:45:A0:20:57:DE:93:EB:F3:90:5F:CE:72:1A:CB:C7:30:C0:6D:DA:EE:90:4E
|
||||
# Fingerprint (SHA1): 7A:22:1E:3D:DE:1B:06:AC:9E:C8:47:70:16:8E:3C:E5:F7:6B:06:F4
|
||||
CKA_CLASS CK_OBJECT_CLASS CKO_NSS_TRUST
|
||||
CKA_TOKEN CK_BBOOL CK_TRUE
|
||||
CKA_PRIVATE CK_BBOOL CK_FALSE
|
||||
CKA_MODIFIABLE CK_BBOOL CK_FALSE
|
||||
CKA_LABEL UTF8 "SecureSign Root CA12"
|
||||
CKA_CERT_SHA1_HASH MULTILINE_OCTAL
|
||||
\172\042\036\075\336\033\006\254\236\310\107\160\026\216\074\345
|
||||
\367\153\006\364
|
||||
END
|
||||
CKA_CERT_MD5_HASH MULTILINE_OCTAL
|
||||
\306\211\312\144\102\233\142\010\111\013\036\177\351\007\075\350
|
||||
END
|
||||
CKA_ISSUER MULTILINE_OCTAL
|
||||
\060\121\061\013\060\011\006\003\125\004\006\023\002\112\120\061
|
||||
\043\060\041\006\003\125\004\012\023\032\103\171\142\145\162\164
|
||||
\162\165\163\164\040\112\141\160\141\156\040\103\157\056\054\040
|
||||
\114\164\144\056\061\035\060\033\006\003\125\004\003\023\024\123
|
||||
\145\143\165\162\145\123\151\147\156\040\122\157\157\164\040\103
|
||||
\101\061\062
|
||||
END
|
||||
CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\024\146\371\307\301\257\354\302\121\264\355\123\227\346\346
|
||||
\202\303\053\034\220\026
|
||||
END
|
||||
CKA_TRUST_SERVER_AUTH CK_TRUST CKT_NSS_TRUSTED_DELEGATOR
|
||||
CKA_TRUST_EMAIL_PROTECTION CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_CODE_SIGNING CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_STEP_UP_APPROVED CK_BBOOL CK_FALSE
|
||||
|
||||
#
|
||||
# Certificate "SecureSign Root CA14"
|
||||
#
|
||||
# Issuer: CN=SecureSign Root CA14,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Serial Number:64:db:5a:0c:20:4e:e8:d7:29:77:c8:50:27:a2:5a:27:dd:2d:f2:cb
|
||||
# Subject: CN=SecureSign Root CA14,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Not Valid Before: Wed Apr 08 07:06:19 2020
|
||||
# Not Valid After : Sat Apr 08 07:06:19 2045
|
||||
# Fingerprint (SHA-256): 4B:00:9C:10:34:49:4F:9A:B5:6B:BA:3B:A1:D6:27:31:FC:4D:20:D8:95:5A:DC:EC:10:A9:25:60:72:61:E3:38
|
||||
# Fingerprint (SHA1): DD:50:C0:F7:79:B3:64:2E:74:A2:B8:9D:9F:D3:40:DD:BB:F0:F2:4F
|
||||
CKA_CLASS CK_OBJECT_CLASS CKO_CERTIFICATE
|
||||
CKA_TOKEN CK_BBOOL CK_TRUE
|
||||
CKA_PRIVATE CK_BBOOL CK_FALSE
|
||||
CKA_MODIFIABLE CK_BBOOL CK_FALSE
|
||||
CKA_LABEL UTF8 "SecureSign Root CA14"
|
||||
CKA_CERTIFICATE_TYPE CK_CERTIFICATE_TYPE CKC_X_509
|
||||
CKA_SUBJECT MULTILINE_OCTAL
|
||||
\060\121\061\013\060\011\006\003\125\004\006\023\002\112\120\061
|
||||
\043\060\041\006\003\125\004\012\023\032\103\171\142\145\162\164
|
||||
\162\165\163\164\040\112\141\160\141\156\040\103\157\056\054\040
|
||||
\114\164\144\056\061\035\060\033\006\003\125\004\003\023\024\123
|
||||
\145\143\165\162\145\123\151\147\156\040\122\157\157\164\040\103
|
||||
\101\061\064
|
||||
END
|
||||
CKA_ID UTF8 "0"
|
||||
CKA_ISSUER MULTILINE_OCTAL
|
||||
\060\121\061\013\060\011\006\003\125\004\006\023\002\112\120\061
|
||||
\043\060\041\006\003\125\004\012\023\032\103\171\142\145\162\164
|
||||
\162\165\163\164\040\112\141\160\141\156\040\103\157\056\054\040
|
||||
\114\164\144\056\061\035\060\033\006\003\125\004\003\023\024\123
|
||||
\145\143\165\162\145\123\151\147\156\040\122\157\157\164\040\103
|
||||
\101\061\064
|
||||
END
|
||||
CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\024\144\333\132\014\040\116\350\327\051\167\310\120\047\242
|
||||
\132\047\335\055\362\313
|
||||
END
|
||||
CKA_VALUE MULTILINE_OCTAL
|
||||
\060\202\005\162\060\202\003\132\240\003\002\001\002\002\024\144
|
||||
\333\132\014\040\116\350\327\051\167\310\120\047\242\132\047\335
|
||||
\055\362\313\060\015\006\011\052\206\110\206\367\015\001\001\014
|
||||
\005\000\060\121\061\013\060\011\006\003\125\004\006\023\002\112
|
||||
\120\061\043\060\041\006\003\125\004\012\023\032\103\171\142\145
|
||||
\162\164\162\165\163\164\040\112\141\160\141\156\040\103\157\056
|
||||
\054\040\114\164\144\056\061\035\060\033\006\003\125\004\003\023
|
||||
\024\123\145\143\165\162\145\123\151\147\156\040\122\157\157\164
|
||||
\040\103\101\061\064\060\036\027\015\062\060\060\064\060\070\060
|
||||
\067\060\066\061\071\132\027\015\064\065\060\064\060\070\060\067
|
||||
\060\066\061\071\132\060\121\061\013\060\011\006\003\125\004\006
|
||||
\023\002\112\120\061\043\060\041\006\003\125\004\012\023\032\103
|
||||
\171\142\145\162\164\162\165\163\164\040\112\141\160\141\156\040
|
||||
\103\157\056\054\040\114\164\144\056\061\035\060\033\006\003\125
|
||||
\004\003\023\024\123\145\143\165\162\145\123\151\147\156\040\122
|
||||
\157\157\164\040\103\101\061\064\060\202\002\042\060\015\006\011
|
||||
\052\206\110\206\367\015\001\001\001\005\000\003\202\002\017\000
|
||||
\060\202\002\012\002\202\002\001\000\305\322\172\241\326\212\277
|
||||
\026\061\320\230\321\072\224\374\132\270\156\042\301\142\367\247
|
||||
\012\047\357\120\366\056\261\236\150\022\360\154\044\143\071\361
|
||||
\360\337\020\306\336\267\122\040\325\122\133\102\231\236\363\240
|
||||
\276\122\037\137\314\147\155\247\056\120\242\301\227\215\266\370
|
||||
\225\365\260\272\334\235\340\276\313\337\367\070\362\107\365\246
|
||||
\232\222\225\052\142\131\120\013\242\261\065\347\145\262\141\262
|
||||
\352\222\161\151\344\051\360\117\201\201\004\074\262\245\133\324
|
||||
\305\250\131\147\173\125\034\111\253\172\235\302\347\163\115\357
|
||||
\315\011\302\304\127\022\333\001\016\043\171\011\007\073\242\350
|
||||
\374\212\317\217\300\106\044\234\070\047\340\203\235\033\240\277
|
||||
\170\025\020\353\206\116\012\132\375\337\332\054\202\176\356\312
|
||||
\366\051\341\372\161\241\367\210\150\234\234\360\215\276\017\111
|
||||
\221\330\352\072\371\375\320\150\161\333\351\265\053\116\202\222
|
||||
\157\146\037\340\360\334\114\354\312\321\352\272\164\006\371\263
|
||||
\204\220\224\321\137\216\163\031\020\135\002\345\160\245\300\020
|
||||
\320\020\174\157\305\130\111\264\260\156\232\332\175\225\365\314
|
||||
\332\002\257\270\054\175\171\217\276\103\361\371\050\050\215\011
|
||||
\103\370\010\335\153\310\213\054\044\261\215\122\007\275\170\233
|
||||
\313\312\150\262\244\335\014\114\171\140\306\231\321\223\361\060
|
||||
\032\007\323\256\042\302\352\316\361\204\011\314\340\024\156\177
|
||||
\077\176\322\202\205\254\334\251\026\116\205\240\140\313\366\234
|
||||
\327\310\263\216\355\306\233\230\165\015\125\350\137\345\225\213
|
||||
\002\244\256\103\051\050\021\244\346\022\060\001\113\165\153\036
|
||||
\146\235\171\057\245\166\057\035\100\264\155\311\175\171\010\354
|
||||
\321\152\266\135\052\262\245\146\275\153\205\364\164\126\303\365
|
||||
\347\165\122\050\054\245\377\146\107\245\324\376\376\236\124\277
|
||||
\145\176\001\326\060\217\245\066\234\242\120\034\356\070\200\001
|
||||
\110\306\307\164\364\306\254\303\100\111\026\141\164\054\257\214
|
||||
\157\065\355\173\030\000\133\066\074\234\120\015\312\222\063\020
|
||||
\361\046\111\155\337\165\044\067\202\042\327\350\226\375\025\113
|
||||
\002\226\076\007\162\225\176\253\075\114\056\327\312\360\337\340
|
||||
\130\077\055\057\004\232\070\243\001\002\003\001\000\001\243\102
|
||||
\060\100\060\017\006\003\125\035\023\001\001\377\004\005\060\003
|
||||
\001\001\377\060\016\006\003\125\035\017\001\001\377\004\004\003
|
||||
\002\001\006\060\035\006\003\125\035\016\004\026\004\024\006\223
|
||||
\243\012\136\050\151\067\252\141\035\353\353\374\055\157\043\344
|
||||
\363\240\060\015\006\011\052\206\110\206\367\015\001\001\014\005
|
||||
\000\003\202\002\001\000\226\200\162\011\006\176\234\314\223\004
|
||||
\026\273\240\072\215\222\116\267\021\032\012\161\161\020\315\004
|
||||
\255\177\245\105\120\020\146\116\112\101\242\003\331\021\117\172
|
||||
\067\271\113\342\306\217\062\146\165\045\373\353\316\077\003\051
|
||||
\046\215\270\026\035\366\037\063\156\110\346\350\370\127\262\033
|
||||
\171\337\073\207\012\342\144\272\000\312\154\357\176\320\043\353
|
||||
\170\217\377\144\233\064\067\237\065\145\242\244\000\075\022\043
|
||||
\226\130\135\312\143\207\306\243\007\210\115\347\151\166\212\123
|
||||
\315\361\117\354\102\362\223\343\231\244\067\074\207\270\142\333
|
||||
\360\354\037\067\077\067\137\103\314\121\235\265\360\227\302\267
|
||||
\205\152\150\013\104\036\345\121\356\223\316\113\156\206\301\322
|
||||
\014\044\131\066\032\237\054\221\217\343\030\333\224\225\012\355
|
||||
\221\252\016\231\334\226\123\343\141\203\306\026\272\043\272\334
|
||||
\335\176\032\306\173\102\266\331\132\005\334\232\137\325\337\270
|
||||
\332\107\175\332\070\333\254\071\325\036\153\154\052\027\214\141
|
||||
\315\261\155\162\001\303\303\040\000\142\150\026\061\325\166\252
|
||||
\206\273\016\252\236\306\371\360\331\370\015\041\002\344\305\050
|
||||
\026\131\021\271\331\151\163\052\222\170\270\222\127\233\010\362
|
||||
\072\345\057\225\260\130\267\153\040\024\155\024\357\012\274\176
|
||||
\330\125\330\210\332\057\372\031\245\373\213\340\177\071\365\162
|
||||
\053\205\304\054\254\357\031\105\222\114\263\141\007\334\115\037
|
||||
\156\322\201\023\134\232\363\022\147\203\317\233\077\213\237\235
|
||||
\244\271\250\226\003\172\305\356\040\336\063\332\057\236\032\172
|
||||
\164\036\341\356\314\132\072\004\335\263\032\004\250\024\143\254
|
||||
\267\107\022\203\232\154\365\346\351\025\025\221\032\204\031\016
|
||||
\224\104\347\022\216\045\133\200\147\031\334\143\223\020\013\145
|
||||
\056\212\372\011\232\116\332\206\050\175\252\141\065\330\016\247
|
||||
\050\032\273\122\340\170\370\154\272\154\260\156\271\207\136\351
|
||||
\231\065\067\361\075\144\053\251\240\064\223\317\143\057\325\201
|
||||
\337\256\143\047\245\036\116\215\334\051\170\131\370\371\241\040
|
||||
\214\247\046\100\156\202\162\315\170\262\310\217\074\036\163\347
|
||||
\301\037\277\317\316\245\052\233\333\104\144\062\240\273\177\134
|
||||
\045\023\110\265\177\222
|
||||
END
|
||||
CKA_NSS_MOZILLA_CA_POLICY CK_BBOOL CK_TRUE
|
||||
CKA_NSS_SERVER_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
CKA_NSS_EMAIL_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
|
||||
# Trust for "SecureSign Root CA14"
|
||||
# Issuer: CN=SecureSign Root CA14,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Serial Number:64:db:5a:0c:20:4e:e8:d7:29:77:c8:50:27:a2:5a:27:dd:2d:f2:cb
|
||||
# Subject: CN=SecureSign Root CA14,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Not Valid Before: Wed Apr 08 07:06:19 2020
|
||||
# Not Valid After : Sat Apr 08 07:06:19 2045
|
||||
# Fingerprint (SHA-256): 4B:00:9C:10:34:49:4F:9A:B5:6B:BA:3B:A1:D6:27:31:FC:4D:20:D8:95:5A:DC:EC:10:A9:25:60:72:61:E3:38
|
||||
# Fingerprint (SHA1): DD:50:C0:F7:79:B3:64:2E:74:A2:B8:9D:9F:D3:40:DD:BB:F0:F2:4F
|
||||
CKA_CLASS CK_OBJECT_CLASS CKO_NSS_TRUST
|
||||
CKA_TOKEN CK_BBOOL CK_TRUE
|
||||
CKA_PRIVATE CK_BBOOL CK_FALSE
|
||||
CKA_MODIFIABLE CK_BBOOL CK_FALSE
|
||||
CKA_LABEL UTF8 "SecureSign Root CA14"
|
||||
CKA_CERT_SHA1_HASH MULTILINE_OCTAL
|
||||
\335\120\300\367\171\263\144\056\164\242\270\235\237\323\100\335
|
||||
\273\360\362\117
|
||||
END
|
||||
CKA_CERT_MD5_HASH MULTILINE_OCTAL
|
||||
\161\015\162\372\222\031\145\136\211\004\254\026\063\360\274\325
|
||||
END
|
||||
CKA_ISSUER MULTILINE_OCTAL
|
||||
\060\121\061\013\060\011\006\003\125\004\006\023\002\112\120\061
|
||||
\043\060\041\006\003\125\004\012\023\032\103\171\142\145\162\164
|
||||
\162\165\163\164\040\112\141\160\141\156\040\103\157\056\054\040
|
||||
\114\164\144\056\061\035\060\033\006\003\125\004\003\023\024\123
|
||||
\145\143\165\162\145\123\151\147\156\040\122\157\157\164\040\103
|
||||
\101\061\064
|
||||
END
|
||||
CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\024\144\333\132\014\040\116\350\327\051\167\310\120\047\242
|
||||
\132\047\335\055\362\313
|
||||
END
|
||||
CKA_TRUST_SERVER_AUTH CK_TRUST CKT_NSS_TRUSTED_DELEGATOR
|
||||
CKA_TRUST_EMAIL_PROTECTION CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_CODE_SIGNING CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_STEP_UP_APPROVED CK_BBOOL CK_FALSE
|
||||
|
||||
#
|
||||
# Certificate "SecureSign Root CA15"
|
||||
#
|
||||
# Issuer: CN=SecureSign Root CA15,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Serial Number:16:15:c7:c3:d8:49:a7:be:69:0c:8a:88:ed:f0:70:f9:dd:b7:3e:87
|
||||
# Subject: CN=SecureSign Root CA15,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Not Valid Before: Wed Apr 08 08:32:56 2020
|
||||
# Not Valid After : Sat Apr 08 08:32:56 2045
|
||||
# Fingerprint (SHA-256): E7:78:F0:F0:95:FE:84:37:29:CD:1A:00:82:17:9E:53:14:A9:C2:91:44:28:05:E1:FB:1D:8F:B6:B8:88:6C:3A
|
||||
# Fingerprint (SHA1): CB:BA:83:C8:C1:5A:5D:F1:F9:73:6F:CA:D7:EF:28:13:06:4A:07:7D
|
||||
CKA_CLASS CK_OBJECT_CLASS CKO_CERTIFICATE
|
||||
CKA_TOKEN CK_BBOOL CK_TRUE
|
||||
CKA_PRIVATE CK_BBOOL CK_FALSE
|
||||
CKA_MODIFIABLE CK_BBOOL CK_FALSE
|
||||
CKA_LABEL UTF8 "SecureSign Root CA15"
|
||||
CKA_CERTIFICATE_TYPE CK_CERTIFICATE_TYPE CKC_X_509
|
||||
CKA_SUBJECT MULTILINE_OCTAL
|
||||
\060\121\061\013\060\011\006\003\125\004\006\023\002\112\120\061
|
||||
\043\060\041\006\003\125\004\012\023\032\103\171\142\145\162\164
|
||||
\162\165\163\164\040\112\141\160\141\156\040\103\157\056\054\040
|
||||
\114\164\144\056\061\035\060\033\006\003\125\004\003\023\024\123
|
||||
\145\143\165\162\145\123\151\147\156\040\122\157\157\164\040\103
|
||||
\101\061\065
|
||||
END
|
||||
CKA_ID UTF8 "0"
|
||||
CKA_ISSUER MULTILINE_OCTAL
|
||||
\060\121\061\013\060\011\006\003\125\004\006\023\002\112\120\061
|
||||
\043\060\041\006\003\125\004\012\023\032\103\171\142\145\162\164
|
||||
\162\165\163\164\040\112\141\160\141\156\040\103\157\056\054\040
|
||||
\114\164\144\056\061\035\060\033\006\003\125\004\003\023\024\123
|
||||
\145\143\165\162\145\123\151\147\156\040\122\157\157\164\040\103
|
||||
\101\061\065
|
||||
END
|
||||
CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\024\026\025\307\303\330\111\247\276\151\014\212\210\355\360
|
||||
\160\371\335\267\076\207
|
||||
END
|
||||
CKA_VALUE MULTILINE_OCTAL
|
||||
\060\202\002\043\060\202\001\251\240\003\002\001\002\002\024\026
|
||||
\025\307\303\330\111\247\276\151\014\212\210\355\360\160\371\335
|
||||
\267\076\207\060\012\006\010\052\206\110\316\075\004\003\003\060
|
||||
\121\061\013\060\011\006\003\125\004\006\023\002\112\120\061\043
|
||||
\060\041\006\003\125\004\012\023\032\103\171\142\145\162\164\162
|
||||
\165\163\164\040\112\141\160\141\156\040\103\157\056\054\040\114
|
||||
\164\144\056\061\035\060\033\006\003\125\004\003\023\024\123\145
|
||||
\143\165\162\145\123\151\147\156\040\122\157\157\164\040\103\101
|
||||
\061\065\060\036\027\015\062\060\060\064\060\070\060\070\063\062
|
||||
\065\066\132\027\015\064\065\060\064\060\070\060\070\063\062\065
|
||||
\066\132\060\121\061\013\060\011\006\003\125\004\006\023\002\112
|
||||
\120\061\043\060\041\006\003\125\004\012\023\032\103\171\142\145
|
||||
\162\164\162\165\163\164\040\112\141\160\141\156\040\103\157\056
|
||||
\054\040\114\164\144\056\061\035\060\033\006\003\125\004\003\023
|
||||
\024\123\145\143\165\162\145\123\151\147\156\040\122\157\157\164
|
||||
\040\103\101\061\065\060\166\060\020\006\007\052\206\110\316\075
|
||||
\002\001\006\005\053\201\004\000\042\003\142\000\004\013\120\164
|
||||
\215\144\062\231\231\263\322\140\010\270\042\216\106\164\054\170
|
||||
\300\053\104\055\155\137\035\311\256\113\122\040\203\075\270\024
|
||||
\155\123\207\140\236\137\154\205\333\006\024\225\340\307\050\377
|
||||
\235\137\344\252\361\263\213\155\355\117\057\113\311\112\224\221
|
||||
\144\165\376\001\354\301\330\353\172\224\170\126\030\103\137\153
|
||||
\201\313\366\274\332\264\014\266\051\223\010\151\217\243\102\060
|
||||
\100\060\017\006\003\125\035\023\001\001\377\004\005\060\003\001
|
||||
\001\377\060\016\006\003\125\035\017\001\001\377\004\004\003\002
|
||||
\001\006\060\035\006\003\125\035\016\004\026\004\024\353\101\310
|
||||
\256\374\325\236\121\110\365\275\213\364\207\040\223\101\053\323
|
||||
\364\060\012\006\010\052\206\110\316\075\004\003\003\003\150\000
|
||||
\060\145\002\061\000\331\056\211\176\136\116\244\021\007\275\131
|
||||
\302\007\336\253\062\070\123\052\106\104\006\027\172\316\121\351
|
||||
\340\377\146\055\011\116\340\117\364\005\321\205\366\065\140\334
|
||||
\365\162\263\106\175\002\060\104\230\106\032\202\205\036\141\151
|
||||
\211\113\007\113\146\265\236\252\272\240\036\101\331\001\164\072
|
||||
\156\105\072\211\200\031\173\062\230\125\143\253\353\143\156\223
|
||||
\155\253\033\011\140\061\116
|
||||
END
|
||||
CKA_NSS_MOZILLA_CA_POLICY CK_BBOOL CK_TRUE
|
||||
CKA_NSS_SERVER_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
CKA_NSS_EMAIL_DISTRUST_AFTER CK_BBOOL CK_FALSE
|
||||
|
||||
# Trust for "SecureSign Root CA15"
|
||||
# Issuer: CN=SecureSign Root CA15,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Serial Number:16:15:c7:c3:d8:49:a7:be:69:0c:8a:88:ed:f0:70:f9:dd:b7:3e:87
|
||||
# Subject: CN=SecureSign Root CA15,O="Cybertrust Japan Co., Ltd.",C=JP
|
||||
# Not Valid Before: Wed Apr 08 08:32:56 2020
|
||||
# Not Valid After : Sat Apr 08 08:32:56 2045
|
||||
# Fingerprint (SHA-256): E7:78:F0:F0:95:FE:84:37:29:CD:1A:00:82:17:9E:53:14:A9:C2:91:44:28:05:E1:FB:1D:8F:B6:B8:88:6C:3A
|
||||
# Fingerprint (SHA1): CB:BA:83:C8:C1:5A:5D:F1:F9:73:6F:CA:D7:EF:28:13:06:4A:07:7D
|
||||
CKA_CLASS CK_OBJECT_CLASS CKO_NSS_TRUST
|
||||
CKA_TOKEN CK_BBOOL CK_TRUE
|
||||
CKA_PRIVATE CK_BBOOL CK_FALSE
|
||||
CKA_MODIFIABLE CK_BBOOL CK_FALSE
|
||||
CKA_LABEL UTF8 "SecureSign Root CA15"
|
||||
CKA_CERT_SHA1_HASH MULTILINE_OCTAL
|
||||
\313\272\203\310\301\132\135\361\371\163\157\312\327\357\050\023
|
||||
\006\112\007\175
|
||||
END
|
||||
CKA_CERT_MD5_HASH MULTILINE_OCTAL
|
||||
\023\060\374\304\142\246\251\336\265\301\150\257\265\322\061\107
|
||||
END
|
||||
CKA_ISSUER MULTILINE_OCTAL
|
||||
\060\121\061\013\060\011\006\003\125\004\006\023\002\112\120\061
|
||||
\043\060\041\006\003\125\004\012\023\032\103\171\142\145\162\164
|
||||
\162\165\163\164\040\112\141\160\141\156\040\103\157\056\054\040
|
||||
\114\164\144\056\061\035\060\033\006\003\125\004\003\023\024\123
|
||||
\145\143\165\162\145\123\151\147\156\040\122\157\157\164\040\103
|
||||
\101\061\065
|
||||
END
|
||||
CKA_SERIAL_NUMBER MULTILINE_OCTAL
|
||||
\002\024\026\025\307\303\330\111\247\276\151\014\212\210\355\360
|
||||
\160\371\335\267\076\207
|
||||
END
|
||||
CKA_TRUST_SERVER_AUTH CK_TRUST CKT_NSS_TRUSTED_DELEGATOR
|
||||
CKA_TRUST_EMAIL_PROTECTION CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_CODE_SIGNING CK_TRUST CKT_NSS_MUST_VERIFY_TRUST
|
||||
CKA_TRUST_STEP_UP_APPROVED CK_BBOOL CK_FALSE
|
||||
|
||||
@@ -212,13 +212,12 @@ void us_socket_context_add_server_name(int ssl, struct us_socket_context_t *cont
|
||||
}
|
||||
#endif
|
||||
}
|
||||
int us_bun_socket_context_add_server_name(int ssl, struct us_socket_context_t *context, const char *hostname_pattern, struct us_bun_socket_context_options_t options, void *user) {
|
||||
void us_bun_socket_context_add_server_name(int ssl, struct us_socket_context_t *context, const char *hostname_pattern, struct us_bun_socket_context_options_t options, void *user) {
|
||||
#ifndef LIBUS_NO_SSL
|
||||
if (ssl) {
|
||||
return us_bun_internal_ssl_socket_context_add_server_name((struct us_internal_ssl_socket_context_t *) context, hostname_pattern, options, user);
|
||||
us_bun_internal_ssl_socket_context_add_server_name((struct us_internal_ssl_socket_context_t *) context, hostname_pattern, options, user);
|
||||
}
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Remove SNI context */
|
||||
@@ -279,11 +278,11 @@ struct us_socket_context_t *us_create_socket_context(int ssl, struct us_loop_t *
|
||||
return context;
|
||||
}
|
||||
|
||||
struct us_socket_context_t *us_create_bun_socket_context(int ssl, struct us_loop_t *loop, int context_ext_size, struct us_bun_socket_context_options_t options, enum create_bun_socket_error_t *err) {
|
||||
struct us_socket_context_t *us_create_bun_socket_context(int ssl, struct us_loop_t *loop, int context_ext_size, struct us_bun_socket_context_options_t options) {
|
||||
#ifndef LIBUS_NO_SSL
|
||||
if (ssl) {
|
||||
/* This function will call us, again, with SSL = false and a bigger ext_size */
|
||||
return (struct us_socket_context_t *) us_internal_bun_create_ssl_socket_context(loop, context_ext_size, options, err);
|
||||
return (struct us_socket_context_t *) us_internal_bun_create_ssl_socket_context(loop, context_ext_size, options);
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
@@ -855,11 +855,6 @@ create_ssl_context_from_options(struct us_socket_context_options_t options) {
|
||||
}
|
||||
}
|
||||
|
||||
if (ERR_peek_error() != 0) {
|
||||
free_ssl_context(ssl_context);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* This must be free'd with free_ssl_context, not SSL_CTX_free */
|
||||
return ssl_context;
|
||||
}
|
||||
@@ -1109,10 +1104,7 @@ int us_verify_callback(int preverify_ok, X509_STORE_CTX *ctx) {
|
||||
}
|
||||
|
||||
SSL_CTX *create_ssl_context_from_bun_options(
|
||||
struct us_bun_socket_context_options_t options,
|
||||
enum create_bun_socket_error_t *err) {
|
||||
ERR_clear_error();
|
||||
|
||||
struct us_bun_socket_context_options_t options) {
|
||||
/* Create the context */
|
||||
SSL_CTX *ssl_context = SSL_CTX_new(TLS_method());
|
||||
|
||||
@@ -1182,7 +1174,6 @@ SSL_CTX *create_ssl_context_from_bun_options(
|
||||
STACK_OF(X509_NAME) * ca_list;
|
||||
ca_list = SSL_load_client_CA_file(options.ca_file_name);
|
||||
if (ca_list == NULL) {
|
||||
*err = CREATE_BUN_SOCKET_ERROR_LOAD_CA_FILE;
|
||||
free_ssl_context(ssl_context);
|
||||
return NULL;
|
||||
}
|
||||
@@ -1190,7 +1181,6 @@ SSL_CTX *create_ssl_context_from_bun_options(
|
||||
SSL_CTX_set_client_CA_list(ssl_context, ca_list);
|
||||
if (SSL_CTX_load_verify_locations(ssl_context, options.ca_file_name,
|
||||
NULL) != 1) {
|
||||
*err = CREATE_BUN_SOCKET_ERROR_INVALID_CA_FILE;
|
||||
free_ssl_context(ssl_context);
|
||||
return NULL;
|
||||
}
|
||||
@@ -1213,14 +1203,10 @@ SSL_CTX *create_ssl_context_from_bun_options(
|
||||
}
|
||||
|
||||
if (!add_ca_cert_to_ctx_store(ssl_context, options.ca[i], cert_store)) {
|
||||
*err = CREATE_BUN_SOCKET_ERROR_INVALID_CA;
|
||||
free_ssl_context(ssl_context);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
// It may return spurious errors here.
|
||||
ERR_clear_error();
|
||||
|
||||
if (options.reject_unauthorized) {
|
||||
SSL_CTX_set_verify(ssl_context,
|
||||
SSL_VERIFY_PEER | SSL_VERIFY_FAIL_IF_NO_PEER_CERT,
|
||||
@@ -1346,17 +1332,13 @@ void us_internal_ssl_socket_context_add_server_name(
|
||||
}
|
||||
}
|
||||
|
||||
int us_bun_internal_ssl_socket_context_add_server_name(
|
||||
void us_bun_internal_ssl_socket_context_add_server_name(
|
||||
struct us_internal_ssl_socket_context_t *context,
|
||||
const char *hostname_pattern,
|
||||
struct us_bun_socket_context_options_t options, void *user) {
|
||||
|
||||
/* Try and construct an SSL_CTX from options */
|
||||
enum create_bun_socket_error_t err = CREATE_BUN_SOCKET_ERROR_NONE;
|
||||
SSL_CTX *ssl_context = create_ssl_context_from_bun_options(options, &err);
|
||||
if (ssl_context == NULL) {
|
||||
return -1;
|
||||
}
|
||||
SSL_CTX *ssl_context = create_ssl_context_from_bun_options(options);
|
||||
|
||||
/* Attach the user data to this context */
|
||||
if (1 != SSL_CTX_set_ex_data(ssl_context, 0, user)) {
|
||||
@@ -1364,15 +1346,15 @@ int us_bun_internal_ssl_socket_context_add_server_name(
|
||||
printf("CANNOT SET EX DATA!\n");
|
||||
abort();
|
||||
#endif
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (sni_add(context->sni, hostname_pattern, ssl_context)) {
|
||||
/* If we already had that name, ignore */
|
||||
free_ssl_context(ssl_context);
|
||||
/* We do not want to hold any nullptr's in our SNI tree */
|
||||
if (ssl_context) {
|
||||
if (sni_add(context->sni, hostname_pattern, ssl_context)) {
|
||||
/* If we already had that name, ignore */
|
||||
free_ssl_context(ssl_context);
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
void us_internal_ssl_socket_context_on_server_name(
|
||||
@@ -1486,15 +1468,14 @@ struct us_internal_ssl_socket_context_t *us_internal_create_ssl_socket_context(
|
||||
struct us_internal_ssl_socket_context_t *
|
||||
us_internal_bun_create_ssl_socket_context(
|
||||
struct us_loop_t *loop, int context_ext_size,
|
||||
struct us_bun_socket_context_options_t options,
|
||||
enum create_bun_socket_error_t *err) {
|
||||
struct us_bun_socket_context_options_t options) {
|
||||
/* If we haven't initialized the loop data yet, do so .
|
||||
* This is needed because loop data holds shared OpenSSL data and
|
||||
* the function is also responsible for initializing OpenSSL */
|
||||
us_internal_init_loop_ssl_data(loop);
|
||||
|
||||
/* First of all we try and create the SSL context from options */
|
||||
SSL_CTX *ssl_context = create_ssl_context_from_bun_options(options, err);
|
||||
SSL_CTX *ssl_context = create_ssl_context_from_bun_options(options);
|
||||
if (!ssl_context) {
|
||||
/* We simply fail early if we cannot even create the OpenSSL context */
|
||||
return NULL;
|
||||
@@ -1506,7 +1487,7 @@ us_internal_bun_create_ssl_socket_context(
|
||||
(struct us_internal_ssl_socket_context_t *)us_create_bun_socket_context(
|
||||
0, loop,
|
||||
sizeof(struct us_internal_ssl_socket_context_t) + context_ext_size,
|
||||
options, err);
|
||||
options);
|
||||
|
||||
/* I guess this is the only optional callback */
|
||||
context->on_server_name = NULL;
|
||||
@@ -2002,10 +1983,9 @@ struct us_internal_ssl_socket_t *us_internal_ssl_socket_wrap_with_tls(
|
||||
struct us_socket_context_t *old_context = us_socket_context(0, s);
|
||||
us_socket_context_ref(0,old_context);
|
||||
|
||||
enum create_bun_socket_error_t err = CREATE_BUN_SOCKET_ERROR_NONE;
|
||||
struct us_socket_context_t *context = us_create_bun_socket_context(
|
||||
1, old_context->loop, sizeof(struct us_wrapped_socket_context_t),
|
||||
options, &err);
|
||||
options);
|
||||
|
||||
// Handle SSL context creation failure
|
||||
if (UNLIKELY(!context)) {
|
||||
|
||||
@@ -3614,101 +3614,4 @@ static struct us_cert_string_t root_certs[] = {
|
||||
"fKR7w4l1M+E7qUW/Runpod3JIha3RxEL2Jq68cgLcFBTApFwhVmpHqTm6iMxoAACMQD94viz\n"
|
||||
"rxa5HnPEluPBMBnYfubDl94cT7iJLzPrSA8Z94dGXSaQpYXFuXqUPoeovQA=\n"
|
||||
"-----END CERTIFICATE-----",.len=917},
|
||||
|
||||
/* TWCA CYBER Root CA */
|
||||
{.str="-----BEGIN CERTIFICATE-----\n"
|
||||
"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\n"
|
||||
"Jsas7a5wFsWqynKKTbDPAYsDP27X\n"
|
||||
"-----END CERTIFICATE-----",.len=1980},
|
||||
|
||||
/* SecureSign Root CA12 */
|
||||
{.str="-----BEGIN CERTIFICATE-----\n"
|
||||
"MIIDcjCCAlqgAwIBAgIUZvnHwa/swlG07VOX5uaCwysckBYwDQYJKoZIhvcNAQELBQAwUTEL\n"
|
||||
"MAkGA1UEBhMCSlAxIzAhBgNVBAoTGkN5YmVydHJ1c3QgSmFwYW4gQ28uLCBMdGQuMR0wGwYD\n"
|
||||
"VQQDExRTZWN1cmVTaWduIFJvb3QgQ0ExMjAeFw0yMDA0MDgwNTM2NDZaFw00MDA0MDgwNTM2\n"
|
||||
"NDZaMFExCzAJBgNVBAYTAkpQMSMwIQYDVQQKExpDeWJlcnRydXN0IEphcGFuIENvLiwgTHRk\n"
|
||||
"LjEdMBsGA1UEAxMUU2VjdXJlU2lnbiBSb290IENBMTIwggEiMA0GCSqGSIb3DQEBAQUAA4IB\n"
|
||||
"DwAwggEKAoIBAQC6OcE3emhFKxS06+QT61d1I02PJC0W6K6OyX2kVzsqdiUzg2zqMoqUm048\n"
|
||||
"luT9Ub+ZyZN+v/mtp7JIKwccJ/VMvHASd6SFVLX9kHrko+RRWAPNEHl57muTH2SOa2SroxPj\n"
|
||||
"cf59q5zdJ1M3s6oYwlkm7Fsf0uZlfO+TvdhYXAvA42VvPMfKWeP+bl+sg779XSVOKik71gur\n"
|
||||
"FzJ4pOE+lEa+Ym6b3kaosRbnhW70CEBFEaCeVESE99g2zvVQR9wsMJvuwPWW0v4JhscGWa5P\n"
|
||||
"ro4RmHvzC1KqYiaqId+OJTN5lxZJjfU+1UefNzFJM3IFTQy2VYzxV4+Kh9GtxRESOaCtAgMB\n"
|
||||
"AAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBRXNPN0\n"
|
||||
"zwRL1SXm8UC2LEzZLemgrTANBgkqhkiG9w0BAQsFAAOCAQEAPrvbFxbS8hQBICw4g0utvsqF\n"
|
||||
"epq2m2um4fylOqyttCg6r9cBg0krY6LdmmQOmFxv3Y67ilQiLUoT865AQ9tPkbeGGuwAtEGB\n"
|
||||
"pE/6aouIs3YIcipJQMPTw4WJmBClnW8Zt7vPemVV2zfrPIpyMpcemik+rY3moxtt9XUa5rBo\n"
|
||||
"uVui7mlHJzWhhpmA8zNL4WukJsPvdFlseqJkth5Ew1DgDzk9qTPxpfPSvWKErI4cqc1avTc7\n"
|
||||
"bgoitPQV55FYxTpE05Uo2cBl6XLK0A+9H7MV2anjpEcJnuDLN/v9vZfVvhgaaaI5gdka9at/\n"
|
||||
"yOPiZwud9AzqVN/Ssq+xIvEg37xEHA==\n"
|
||||
"-----END CERTIFICATE-----",.len=1254},
|
||||
|
||||
/* SecureSign Root CA14 */
|
||||
{.str="-----BEGIN CERTIFICATE-----\n"
|
||||
"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\n"
|
||||
"-----END CERTIFICATE-----",.len=1943},
|
||||
|
||||
/* SecureSign Root CA15 */
|
||||
{.str="-----BEGIN CERTIFICATE-----\n"
|
||||
"MIICIzCCAamgAwIBAgIUFhXHw9hJp75pDIqI7fBw+d23PocwCgYIKoZIzj0EAwMwUTELMAkG\n"
|
||||
"A1UEBhMCSlAxIzAhBgNVBAoTGkN5YmVydHJ1c3QgSmFwYW4gQ28uLCBMdGQuMR0wGwYDVQQD\n"
|
||||
"ExRTZWN1cmVTaWduIFJvb3QgQ0ExNTAeFw0yMDA0MDgwODMyNTZaFw00NTA0MDgwODMyNTZa\n"
|
||||
"MFExCzAJBgNVBAYTAkpQMSMwIQYDVQQKExpDeWJlcnRydXN0IEphcGFuIENvLiwgTHRkLjEd\n"
|
||||
"MBsGA1UEAxMUU2VjdXJlU2lnbiBSb290IENBMTUwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQL\n"
|
||||
"UHSNZDKZmbPSYAi4Io5GdCx4wCtELW1fHcmuS1Iggz24FG1Th2CeX2yF2wYUleDHKP+dX+Sq\n"
|
||||
"8bOLbe1PL0vJSpSRZHX+AezB2Ot6lHhWGENfa4HL9rzatAy2KZMIaY+jQjBAMA8GA1UdEwEB\n"
|
||||
"/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTrQciu/NWeUUj1vYv0hyCTQSvT\n"
|
||||
"9DAKBggqhkjOPQQDAwNoADBlAjEA2S6Jfl5OpBEHvVnCB96rMjhTKkZEBhd6zlHp4P9mLQlO\n"
|
||||
"4E/0BdGF9jVg3PVys0Z9AjBEmEYagoUeYWmJSwdLZrWeqrqgHkHZAXQ6bkU6iYAZezKYVWOr\n"
|
||||
"62Nuk22rGwlgMU4=\n"
|
||||
"-----END CERTIFICATE-----",.len=800},
|
||||
};
|
||||
|
||||
@@ -302,7 +302,7 @@ void us_internal_ssl_socket_context_add_server_name(
|
||||
us_internal_ssl_socket_context_r context,
|
||||
const char *hostname_pattern, struct us_socket_context_options_t options,
|
||||
void *user);
|
||||
int us_bun_internal_ssl_socket_context_add_server_name(
|
||||
void us_bun_internal_ssl_socket_context_add_server_name(
|
||||
us_internal_ssl_socket_context_r context,
|
||||
const char *hostname_pattern,
|
||||
struct us_bun_socket_context_options_t options, void *user);
|
||||
@@ -330,8 +330,7 @@ struct us_internal_ssl_socket_context_t *us_internal_create_ssl_socket_context(
|
||||
struct us_internal_ssl_socket_context_t *
|
||||
us_internal_bun_create_ssl_socket_context(
|
||||
struct us_loop_t *loop, int context_ext_size,
|
||||
struct us_bun_socket_context_options_t options,
|
||||
enum create_bun_socket_error_t *err);
|
||||
struct us_bun_socket_context_options_t options);
|
||||
|
||||
void us_internal_ssl_socket_context_free(
|
||||
us_internal_ssl_socket_context_r context);
|
||||
|
||||
@@ -234,7 +234,7 @@ unsigned short us_socket_context_timestamp(int ssl, us_socket_context_r context)
|
||||
|
||||
/* Adds SNI domain and cert in asn1 format */
|
||||
void us_socket_context_add_server_name(int ssl, us_socket_context_r context, const char *hostname_pattern, struct us_socket_context_options_t options, void *user);
|
||||
int us_bun_socket_context_add_server_name(int ssl, us_socket_context_r context, const char *hostname_pattern, struct us_bun_socket_context_options_t options, void *user);
|
||||
void us_bun_socket_context_add_server_name(int ssl, us_socket_context_r context, const char *hostname_pattern, struct us_bun_socket_context_options_t options, void *user);
|
||||
void us_socket_context_remove_server_name(int ssl, us_socket_context_r context, const char *hostname_pattern);
|
||||
void us_socket_context_on_server_name(int ssl, us_socket_context_r context, void (*cb)(us_socket_context_r context, const char *hostname));
|
||||
void *us_socket_server_name_userdata(int ssl, us_socket_r s);
|
||||
@@ -246,16 +246,8 @@ void *us_socket_context_get_native_handle(int ssl, us_socket_context_r context);
|
||||
/* A socket context holds shared callbacks and user data extension for associated sockets */
|
||||
struct us_socket_context_t *us_create_socket_context(int ssl, us_loop_r loop,
|
||||
int ext_size, struct us_socket_context_options_t options) nonnull_fn_decl;
|
||||
|
||||
enum create_bun_socket_error_t {
|
||||
CREATE_BUN_SOCKET_ERROR_NONE = 0,
|
||||
CREATE_BUN_SOCKET_ERROR_LOAD_CA_FILE,
|
||||
CREATE_BUN_SOCKET_ERROR_INVALID_CA_FILE,
|
||||
CREATE_BUN_SOCKET_ERROR_INVALID_CA,
|
||||
};
|
||||
|
||||
struct us_socket_context_t *us_create_bun_socket_context(int ssl, struct us_loop_t *loop,
|
||||
int ext_size, struct us_bun_socket_context_options_t options, enum create_bun_socket_error_t *err);
|
||||
int ext_size, struct us_bun_socket_context_options_t options);
|
||||
|
||||
/* Delete resources allocated at creation time (will call unref now and only free when ref count == 0). */
|
||||
void us_socket_context_free(int ssl, us_socket_context_r context) nonnull_fn_decl;
|
||||
|
||||
@@ -106,17 +106,14 @@ public:
|
||||
|
||||
|
||||
/* Server name */
|
||||
TemplatedApp &&addServerName(std::string hostname_pattern, SocketContextOptions options = {}, bool *success = nullptr) {
|
||||
TemplatedApp &&addServerName(std::string hostname_pattern, SocketContextOptions options = {}) {
|
||||
|
||||
/* Do nothing if not even on SSL */
|
||||
if constexpr (SSL) {
|
||||
/* First we create a new router for this domain */
|
||||
auto *domainRouter = new HttpRouter<typename HttpContextData<SSL>::RouterData>();
|
||||
|
||||
int result = us_bun_socket_context_add_server_name(SSL, (struct us_socket_context_t *) httpContext, hostname_pattern.c_str(), options, domainRouter);
|
||||
if (success) {
|
||||
*success = result == 0;
|
||||
}
|
||||
us_bun_socket_context_add_server_name(SSL, (struct us_socket_context_t *) httpContext, hostname_pattern.c_str(), options, domainRouter);
|
||||
}
|
||||
|
||||
return std::move(*this);
|
||||
@@ -241,18 +238,6 @@ public:
|
||||
httpContext = HttpContext<SSL>::create(Loop::get(), options);
|
||||
}
|
||||
|
||||
TemplatedApp(HttpContext<SSL> &context) {
|
||||
httpContext = &context;
|
||||
}
|
||||
|
||||
static TemplatedApp<SSL>* create(SocketContextOptions options = {}) {
|
||||
auto* httpContext = HttpContext<SSL>::create(Loop::get(), options);
|
||||
if (!httpContext) {
|
||||
return nullptr;
|
||||
}
|
||||
return new TemplatedApp<SSL>(*httpContext);
|
||||
}
|
||||
|
||||
bool constructorFailed() {
|
||||
return !httpContext;
|
||||
}
|
||||
|
||||
@@ -348,14 +348,11 @@ private:
|
||||
return (us_socket_t *) asyncSocket;
|
||||
}
|
||||
|
||||
if (returnedSocket != nullptr) {
|
||||
/* It is okay to uncork a closed socket, and we need to */
|
||||
((AsyncSocket<SSL> *) s)->uncork();
|
||||
return s;
|
||||
}
|
||||
/* It is okay to uncork a closed socket and we need to */
|
||||
((AsyncSocket<SSL> *) s)->uncork();
|
||||
|
||||
// It's okay if this returns nullptr.
|
||||
return static_cast<us_socket_t*>(nullptr);
|
||||
/* We cannot return nullptr to the underlying stack in any case */
|
||||
return s;
|
||||
});
|
||||
|
||||
/* Handle HTTP write out (note: SSL_read may trigger this spuriously, the app need to handle spurious calls) */
|
||||
@@ -436,8 +433,7 @@ public:
|
||||
static HttpContext *create(Loop *loop, us_bun_socket_context_options_t options = {}) {
|
||||
HttpContext *httpContext;
|
||||
|
||||
enum create_bun_socket_error_t err = CREATE_BUN_SOCKET_ERROR_NONE;
|
||||
httpContext = (HttpContext *) us_create_bun_socket_context(SSL, (us_loop_t *) loop, sizeof(HttpContextData<SSL>), options, &err);
|
||||
httpContext = (HttpContext *) us_create_bun_socket_context(SSL, (us_loop_t *) loop, sizeof(HttpContextData<SSL>), options);
|
||||
|
||||
if (!httpContext) {
|
||||
return nullptr;
|
||||
|
||||
@@ -24,7 +24,6 @@
|
||||
#include "LoopData.h"
|
||||
#include <libusockets.h>
|
||||
#include <iostream>
|
||||
#include "AsyncSocket.h"
|
||||
|
||||
extern "C" int bun_is_exiting();
|
||||
|
||||
@@ -149,10 +148,6 @@ public:
|
||||
getLazyLoop().loop = nullptr;
|
||||
}
|
||||
|
||||
static LoopData* data(struct us_loop_t *loop) {
|
||||
return (LoopData *) us_loop_ext(loop);
|
||||
}
|
||||
|
||||
void addPostHandler(void *key, MoveOnlyFunction<void(Loop *)> &&handler) {
|
||||
LoopData *loopData = (LoopData *) us_loop_ext((us_loop_t *) this);
|
||||
|
||||
|
||||
@@ -63,7 +63,6 @@ public:
|
||||
}
|
||||
delete [] corkBuffer;
|
||||
}
|
||||
|
||||
void* getCorkedSocket() {
|
||||
return this->corkedSocket;
|
||||
}
|
||||
|
||||
@@ -1,58 +0,0 @@
|
||||
--- a/libarchive/archive_write_add_filter_gzip.c
|
||||
+++ b/libarchive/archive_write_add_filter_gzip.c
|
||||
@@ -58,6 +58,7 @@ archive_write_set_compression_gzip(struct archive *a)
|
||||
struct private_data {
|
||||
int compression_level;
|
||||
int timestamp;
|
||||
+ unsigned char os;
|
||||
#ifdef HAVE_ZLIB_H
|
||||
z_stream stream;
|
||||
int64_t total_in;
|
||||
@@ -106,6 +107,7 @@ archive_write_add_filter_gzip(struct archive *_a)
|
||||
archive_set_error(&a->archive, ENOMEM, "Out of memory");
|
||||
return (ARCHIVE_FATAL);
|
||||
}
|
||||
+ data->os = 3; /* default Unix */
|
||||
f->data = data;
|
||||
f->open = &archive_compressor_gzip_open;
|
||||
f->options = &archive_compressor_gzip_options;
|
||||
@@ -166,6 +168,30 @@ archive_compressor_gzip_options(struct archive_write_filter *f, const char *key,
|
||||
return (ARCHIVE_OK);
|
||||
}
|
||||
|
||||
+ if (strcmp(key, "os") == 0) {
|
||||
+ if (value == NULL)
|
||||
+ return (ARCHIVE_WARN);
|
||||
+
|
||||
+ if (strcmp(value, "FAT") == 0) data->os = 0;
|
||||
+ else if (strcmp(value, "Amiga") == 0) data->os = 1;
|
||||
+ else if (strcmp(value, "VMS") == 0 || strcmp(value, "OpenVMS") == 0) data->os = 2;
|
||||
+ else if (strcmp(value, "Unix") == 0) data->os = 3;
|
||||
+ else if (strcmp(value, "VM") == 0 || strcmp(value, "VM/CMS") == 0) data->os = 4;
|
||||
+ else if (strcmp(value, "Atari TOS") == 0) data->os = 5;
|
||||
+ else if (strcmp(value, "HPFS") == 0) data->os = 6;
|
||||
+ else if (strcmp(value, "Macintosh") == 0) data->os = 7;
|
||||
+ else if (strcmp(value, "Z-System") == 0) data->os = 8;
|
||||
+ else if (strcmp(value, "CP/M") == 0) data->os = 9;
|
||||
+ else if (strcmp(value, "TOPS-20") == 0) data->os = 10;
|
||||
+ else if (strcmp(value, "NTFS") == 0) data->os = 11;
|
||||
+ else if (strcmp(value, "QDOS") == 0) data->os = 12;
|
||||
+ else if (strcmp(value, "Acorn RISCOS") == 0) data->os = 13;
|
||||
+ else if (strcmp(value, "Unknown") == 0) data->os = 255;
|
||||
+ else return (ARCHIVE_WARN);
|
||||
+
|
||||
+ return (ARCHIVE_OK);
|
||||
+ }
|
||||
+
|
||||
/* Note: The "warn" return is just to inform the options
|
||||
* supervisor that we didn't handle it. It will generate
|
||||
* a suitable error if no one used this option. */
|
||||
@@ -226,7 +252,7 @@ archive_compressor_gzip_open(struct archive_write_filter *f)
|
||||
data->compressed[8] = 4;
|
||||
else
|
||||
data->compressed[8] = 0;
|
||||
- data->compressed[9] = 3; /* OS=Unix */
|
||||
+ data->compressed[9] = data->os;
|
||||
data->stream.next_out += 10;
|
||||
data->stream.avail_out -= 10;
|
||||
|
||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user