d2/README.md

239 lines
7.8 KiB
Markdown
Raw Normal View History

<div align="center">
<h1>
<img src="./docs/assets/logo.svg" alt="D2" />
</h1>
<p>A modern DSL that turns text into diagrams.</p>
2022-11-08 18:24:32 +00:00
[Language docs](https://d2lang.com) | [Cheat sheet](./docs/assets/cheat_sheet.pdf)
[![ci](https://github.com/terrastruct/d2/actions/workflows/ci.yml/badge.svg)](https://github.com/terrastruct/d2/actions/workflows/ci.yml)
[![release](https://img.shields.io/github/v/release/terrastruct/d2)](https://github.com/terrastruct/d2/releases)
2022-11-09 21:59:00 +00:00
[![discord](https://img.shields.io/discord/1039184639652265985?label=discord)](https://discord.gg/NF6X8K4eDq)
[![twitter](https://img.shields.io/twitter/follow/terrastruct?style=social)](https://twitter.com/terrastruct)
[![license](https://img.shields.io/github/license/terrastruct/d2?color=9cf)](./LICENSE.txt)
<img src="./docs/assets/cli.gif" alt="D2 CLI" />
</div>
# Table of Contents
<!-- toc -->
2022-11-15 01:05:05 +00:00
- [Quickstart](#quickstart)
- [Install](#install)
* [Install script](#install-script)
2022-11-15 00:50:21 +00:00
* [Install from source](#install-from-source)
2022-11-15 01:05:05 +00:00
- [D2 as a library](#d2-as-a-library)
- [Themes](#themes)
- [Fonts](#fonts)
- [Export file types](#export-file-types)
- [Language tooling](#language-tooling)
2022-11-15 00:50:21 +00:00
- [Plugins](#plugins)
- [Comparison](#comparison)
- [Contributing](#contributing)
- [License](#license)
- [Related](#related)
* [VSCode extension](#vscode-extension)
* [Vim extension](#vim-extension)
* [Misc](#misc)
2022-11-15 00:50:21 +00:00
- [FAQ](#faq)
<!-- tocstop -->
2022-11-15 01:05:05 +00:00
## Quickstart
2022-11-09 22:46:19 +00:00
The most convenient way to use D2 is to just run it as a CLI executable to
produce SVGs from `.d2` files.
```sh
2022-11-14 23:23:16 +00:00
# First, install D2
curl -fsSL https://d2lang.com/install.sh | sh -s --
echo 'x -> y -> z' > in.d2
d2 --watch in.d2 out.svg
```
A browser window will open with `out.svg` and live-reload on changes to `in.d2`.
2022-11-15 01:05:05 +00:00
## Install
For more detailed installation docs with examples for if you do not wish to use the
install script see [./doc/INSTALL.md](./doc/INSTALL.md).
2022-11-15 01:05:05 +00:00
### Install script
2022-11-14 23:23:16 +00:00
The recommended way to install is to run our install script, which will figure out the
2022-11-15 07:14:21 +00:00
best way to install based on your machine.
2022-11-14 06:47:32 +00:00
```sh
2022-11-15 20:24:46 +00:00
# With --dry-run the install script will print the commands it will use
2022-11-14 06:47:32 +00:00
# to install without actually installing so you know what it's going to do.
2022-11-15 20:24:46 +00:00
curl -fsSL https://d2lang.com/install.sh | sh -s -- --dry-run
2022-11-14 06:47:32 +00:00
# If things look good, install for real.
curl -fsSL https://d2lang.com/install.sh | sh -s --
```
2022-11-14 23:23:16 +00:00
We have precompiled binaries on the [releases](https://github.com/terrastruct/d2/releases)
page for macOS and Linux. For both amd64 and arm64. We will release package manager
distributions like .rpm, .deb soon. We also want to get D2 on Homebrew for macOS
and release a docker image.
2022-11-14 06:47:32 +00:00
To uninstall:
```sh
2022-11-15 20:24:46 +00:00
curl -fsSL https://d2lang.com/install.sh | sh -s -- --uninstall --dry-run
2022-11-14 23:23:16 +00:00
# If things look good, uninstall for real.
2022-11-14 06:47:32 +00:00
curl -fsSL https://d2lang.com/install.sh | sh -s -- --uninstall
```
> warn: Our binary releases aren't fully portable like normal Go binaries due to the C
> dependency on v8go for executing dagre.
2022-11-15 01:05:05 +00:00
### Install from source
2022-11-15 01:06:14 +00:00
Alternatively, you can install from source:
2022-11-15 01:05:05 +00:00
```sh
go install oss.terrastruct.com/d2/cmd/d2@latest
2022-11-15 01:05:05 +00:00
```
## D2 as a library
2022-11-09 22:46:19 +00:00
In addition to being a runnable CLI tool, D2 can also be used to produce diagrams from
Go programs.
```go
import (
2022-11-15 00:50:21 +00:00
"github.com/terrastruct/d2/d2compiler"
"github.com/terrastruct/d2/d2exporter"
"github.com/terrastruct/d2/d2layouts/d2dagrelayout"
"github.com/terrastruct/d2/d2renderers/textmeasure"
"github.com/terrastruct/d2/d2themes/d2themescatalog"
)
func main() {
graph, err := d2compiler.Compile("", strings.NewReader("x -> y"), &d2compiler.CompileOptions{ UTF16: true })
ruler, err := textmeasure.NewRuler()
err = graph.SetDimensions(nil, ruler)
err = d2dagrelayout.Layout(ctx, graph)
diagram, err := d2exporter.Export(ctx, graph, d2themescatalog.NeutralDefault)
ioutil.WriteFile(filepath.Join("out.svg"), d2svg.Render(*diagram), 0600)
}
```
D2 is built to be hackable -- the language has an API built on top of it to make edits
programmatically.
```go
import (
"github.com/terrastruct/d2/d2oracle"
"github.com/terrastruct/d2/d2format"
)
// ...modifying the diagram `x -> y` from above
// Create a shape with the ID, "meow"
2022-11-03 18:48:36 +00:00
graph, err = d2oracle.Create(graph, "meow")
// Style the shape green
2022-11-03 18:48:36 +00:00
graph, err = d2oracle.Set(graph, "meow.style.fill", "green")
// Create a shape with the ID, "cat"
2022-11-03 18:48:36 +00:00
graph, err = d2oracle.Create(graph, "cat")
// Move the shape "meow" inside the container "cat"
2022-11-03 18:48:36 +00:00
graph, err = d2oracle.Move(graph, "meow", "cat.meow")
// Prints formatted D2 code
println(d2format.Format(graph.AST))
```
This makes it easy to build functionality on top of D2. Terrastruct uses the above API to
implement editing of D2 from mouse actions in a visual interface.
## Themes
D2 includes a variety of official themes to style your diagrams beautifully right out of
the box. See [./d2themes](./d2themes) to browse the available themes and make or
contribute your own creation.
## Fonts
D2 ships with "Source Sans Pro" as the font in renders. If you wish to use a different
one, please see [./d2renderers/d2fonts](./d2renderers/d2fonts).
## Export file types
D2 currently supports SVG exports. More coming soon.
## Language tooling
D2 is designed with language tooling in mind. D2's parser can parse multiple errors from a
broken program, has an autoformatter, syntax highlighting, and we have plans for LSP's and
more. Good language tooling is necessary for creating and maintaining large diagrams.
The extensions for VSCode and Vim can be found in the [Related](#related) section.
2022-11-12 18:03:32 +00:00
## Plugins
2022-11-12 18:03:32 +00:00
D2 is designed to be extensible and composable. The plugin system allows you to
change out layout engines and customize the rendering pipeline. Plugins can either be
bundled with the build or separately installed as a standalone binary.
2022-11-12 18:03:32 +00:00
**Layout engines**:
2022-11-12 18:03:32 +00:00
- [dagre](https://github.com/dagrejs/dagre) (default, bundled): A fast, directed graph
layout engine that produces layered/hierarchical layouts. Based on Graphviz's DOT
algorithm.
- [ELK](https://github.com/kieler/elkjs) (bundled): A directed graph layout engine
particularly suited for node-link diagrams with an inherent direction and ports.
- [TALA](https://github.com/terrastruct/TALA) (binary): Novel layout engine designed
2022-11-14 23:23:16 +00:00
specifically for software architecture diagrams. Requires separate install, visit the
Github page for more.
2022-11-12 18:03:32 +00:00
D2 intends to integrate with a variety of layout engines, e.g. `dot`, as well as
single-purpose layout types like sequence diagrams. You can choose whichever layout engine
you like and works best for the diagram you're making.
## Comparison
For a comparison against other popular text-to-diagram tools, see
[https://text-to-diagram.com](https://text-to-diagram.com).
## Contributing
Contributions are welcome! See [./docs/CONTRIBUTING.md](./docs/CONTRIBUTING.md).
## License
Copyright © 2022 Terrastruct, Inc. Open-source licensed under the Mozilla Public License
2.0.
## Related
### VSCode extension
[https://github.com/terrastruct/d2-vscode](https://github.com/terrastruct/d2-vscode)
### Vim extension
[https://github.com/terrastruct/d2-vim](https://github.com/terrastruct/d2-vim)
2022-11-15 02:29:59 +00:00
### Language docs
[https://github.com/terrastruct/d2-docs](https://github.com/terrastruct/d2-docs)
### Misc
2022-11-15 02:29:59 +00:00
- [https://github.com/terrastruct/text-to-diagram-site](https://github.com/terrastruct/text-to-diagram-site)
2022-11-09 21:55:33 +00:00
## FAQ
- Does D2 collect telemetry?
- No, D2 does not use an internet connection after installation, except to check for
version updates from Github periodically.
2022-11-12 18:03:32 +00:00
- Does D2 need a browser to run?
- No, D2 can run entirely server-side.
2022-11-09 21:55:33 +00:00
- I have a question or need help.
2022-11-15 00:50:21 +00:00
- The best way to get help is to ask on [D2 Discord](https://discord.gg/NF6X8K4eDq)
- I have a feature request, proposal, or bug report.
- Please open up a Github Issue.
2022-11-09 22:00:12 +00:00
- I have a private inquiry.
2022-11-09 22:44:48 +00:00
- Please reach out at [hi@d2lang.com](hi@d2lang.com).