silverbullet/website/Development.md

43 lines
1.5 KiB
Markdown
Raw Permalink Normal View History

2023-12-19 23:18:33 +08:00
# Stack
SilverBullet is written in [TypeScript](https://www.typescriptlang.org/) and built on top of the excellent [CodeMirror 6](https://codemirror.net/) editor component. Additional UI is built using [Preact](https://preactjs.com/). [ES Build](https://esbuild.github.io) is used to build both the front-end and back-end bundles. The server backend runs as an HTTP server on [Deno](https://deno.land/) using [Hono](https://hono.dev).
2022-06-28 20:14:15 +08:00
2023-12-19 23:18:33 +08:00
# Development
Requirements: [Deno](https://deno.land/) 1.39 or newer. If you installed [[Install/Deno]] SilverBullet you will already have your toolchain installed. Convenient!
2022-06-28 20:14:15 +08:00
Clone the repository from GitHub:
2022-11-27 18:21:03 +08:00
```shell
git clone git@github.com:silverbulletmd/silverbullet.git
cd silverbullet
```
And build it:
2022-06-28 20:14:15 +08:00
2022-10-10 20:55:48 +08:00
```shell
deno task build
```
2022-06-28 20:14:15 +08:00
2022-11-27 18:21:03 +08:00
For convenience, replace your `silverbullet` install with the one from this repo via:
```shell
deno task install
```
You can now run the server in “watch mode” (automatically restarting when you change source files) with:
2022-10-10 20:55:48 +08:00
```shell
2022-10-29 22:57:12 +08:00
deno task watch-server <PATH-TO-YOUR-SPACE>
2022-10-10 20:55:48 +08:00
```
2022-06-28 20:14:15 +08:00
2022-11-27 18:21:03 +08:00
It's convenient to run three commands in parallel (in separate terminals):
2022-06-28 20:14:15 +08:00
```shell
2022-10-10 20:55:48 +08:00
deno task watch-web
2022-10-29 22:57:12 +08:00
deno task watch-server <PATH-TO-YOUR-SPACE>
2022-10-10 20:55:48 +08:00
deno task watch-plugs
2022-06-28 20:14:15 +08:00
```
2022-11-27 18:21:03 +08:00
All of these watch for file changes and a rebuild should trigger automatically.
Note that there are dependencies between these builds. Any change to any of the built-in _plugs_ requires a rebuild of the web app. Any rebuild of the web app will only be picked up by the server after it restarts (which should happen automatically).