2019-12-20 22:47:47 +01:00
|
|
|
|
# Glow
|
2019-11-09 16:12:54 -06:00
|
|
|
|
|
|
|
|
|
Render markdown on the CLI, with _pizzazz_!
|
|
|
|
|
|
2020-03-04 22:36:08 -05:00
|
|
|
|
<p align="center">
|
|
|
|
|
<img src="https://stuff.charm.sh/glow-github.gif" alt="Glow Logo">
|
|
|
|
|
<a href="https://github.com/charmbracelet/glow/releases"><img src="https://img.shields.io/github/release/charmbracelet/glow.svg" alt="Latest Release"></a>
|
|
|
|
|
<a href="https://pkg.go.dev/github.com/charmbracelet/glow?tab=doc"><img src="https://godoc.org/github.com/golang/gddo?status.svg" alt="GoDoc"></a>
|
|
|
|
|
<a href="https://github.com/charmbracelet/glow/actions"><img src="https://github.com/charmbracelet/glow/workflows/build/badge.svg" alt="Build Status"></a>
|
2020-05-05 07:51:26 +02:00
|
|
|
|
<a href="http://goreportcard.com/report/github.com/charmbracelet/glow"><img src="http://goreportcard.com/badge/charmbracelet/glow" alt="Go ReportCard"></a>
|
2020-03-04 22:36:08 -05:00
|
|
|
|
</p>
|
|
|
|
|
|
2020-07-29 13:21:56 -04:00
|
|
|
|
<p align="center">
|
|
|
|
|
<img src="https://stuff.charm.sh/glow2-ui-github.gif" width="600" alt="Glow UI Demo">
|
|
|
|
|
</p>
|
2019-12-18 21:49:29 -05:00
|
|
|
|
|
2020-07-29 11:49:36 -05:00
|
|
|
|
## What is it?
|
|
|
|
|
|
|
|
|
|
Glow is a terminal based markdown reader designed from the ground up to bring
|
2020-07-29 13:21:56 -04:00
|
|
|
|
out the beauty—and power—of the CLI.
|
2020-07-29 11:49:36 -05:00
|
|
|
|
|
2020-08-27 13:32:05 -04:00
|
|
|
|
Use it to discover markdown files, read documentation directly on the command
|
|
|
|
|
line and stash markdown files to your own private collection so you can read
|
2020-08-27 13:36:08 -04:00
|
|
|
|
them anywhere. Glow will find local markdown files in subdirectories or a local
|
|
|
|
|
Git repository.
|
2020-08-27 13:32:05 -04:00
|
|
|
|
|
|
|
|
|
By the way, all data stashed is encrypted end-to-end: only you can decrypt it.
|
|
|
|
|
More on that below.
|
2019-12-18 21:36:30 -05:00
|
|
|
|
|
2019-12-16 06:04:55 -05:00
|
|
|
|
## Installation
|
|
|
|
|
|
2019-12-18 21:36:30 -05:00
|
|
|
|
Use your fave package manager:
|
|
|
|
|
|
|
|
|
|
```bash
|
2020-01-12 14:24:07 -05:00
|
|
|
|
# macOS or Linux
|
2020-01-12 16:54:36 +01:00
|
|
|
|
brew install glow
|
|
|
|
|
|
2020-10-17 16:15:03 -04:00
|
|
|
|
# macOS (with MacPorts)
|
|
|
|
|
sudo port install glow
|
|
|
|
|
|
2019-12-18 21:36:30 -05:00
|
|
|
|
# Arch Linux (btw)
|
2019-12-20 22:47:47 +01:00
|
|
|
|
yay -S glow
|
2019-12-23 20:44:56 +01:00
|
|
|
|
|
2020-02-26 11:47:09 -05:00
|
|
|
|
# Void Linux
|
|
|
|
|
xbps-install -S glow
|
|
|
|
|
|
2020-01-13 12:44:52 -05:00
|
|
|
|
# Nix
|
|
|
|
|
nix-env -iA nixpkgs.glow
|
|
|
|
|
|
2019-12-23 20:44:56 +01:00
|
|
|
|
# FreeBSD
|
|
|
|
|
pkg install glow
|
2020-10-20 08:42:39 +08:00
|
|
|
|
|
|
|
|
|
# Windows (with Scoop)
|
|
|
|
|
scoop install glow
|
2019-12-18 21:36:30 -05:00
|
|
|
|
```
|
|
|
|
|
|
2020-10-13 22:56:33 -04:00
|
|
|
|
Or download a binary from the [releases][releases] page. MacOS, Linux, Windows,
|
|
|
|
|
FreeBSD, and OpenBSD binaries are available, as well as Debian, RPM, and Alpine
|
2020-10-14 04:57:57 +02:00
|
|
|
|
packages. ARM builds are also available for Linux, FreeBSD, and OpenBSD.
|
2019-12-21 20:37:01 -05:00
|
|
|
|
|
2020-10-17 14:30:03 +02:00
|
|
|
|
Or just build it yourself (requires Go 1.13+):
|
2019-12-18 21:36:30 -05:00
|
|
|
|
|
|
|
|
|
```bash
|
2020-10-17 14:30:03 +02:00
|
|
|
|
git clone https://github.com/charmbracelet/glow.git
|
|
|
|
|
cd glow
|
|
|
|
|
go build
|
2019-12-16 18:52:10 +01:00
|
|
|
|
```
|
2019-12-16 06:04:55 -05:00
|
|
|
|
|
2019-12-21 20:37:01 -05:00
|
|
|
|
[releases]: https://github.com/charmbracelet/glow/releases
|
|
|
|
|
|
2019-12-18 21:36:30 -05:00
|
|
|
|
|
2020-08-27 14:21:45 -04:00
|
|
|
|
## The TUI
|
2019-11-09 16:12:54 -06:00
|
|
|
|
|
2020-10-18 19:11:45 +03:00
|
|
|
|
Simply run `glow` without arguments to start the textual user interface and
|
2020-10-20 20:01:05 +08:00
|
|
|
|
browse local and stashed markdown. Glow will find local markdown files in the
|
2020-10-12 08:02:32 -04:00
|
|
|
|
current directory and below or, if you’re in a Git repository, Glow will search
|
2020-08-27 14:21:45 -04:00
|
|
|
|
the repo.
|
|
|
|
|
|
|
|
|
|
Markdown files can be read with Glow's high-performance pager. Most of the
|
2020-10-20 20:01:05 +08:00
|
|
|
|
keystrokes you know from `less` are the same, but you can press `?` to list
|
2020-08-27 14:21:45 -04:00
|
|
|
|
the hotkeys.
|
|
|
|
|
|
|
|
|
|
### Stashing
|
|
|
|
|
|
|
|
|
|
Glow works with the Charm Cloud to allow you to store any markdown files in
|
|
|
|
|
your own private collection. You can stash a local document from the Glow TUI by
|
|
|
|
|
pressing `s`.
|
|
|
|
|
|
|
|
|
|
You can also stash from the CLI:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
glow stash README.md
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Then, when you run `glow` without arguments will you can browse through your
|
|
|
|
|
stashed documents. This is a great way to keep track of things that you need to
|
|
|
|
|
reference often.
|
|
|
|
|
|
|
|
|
|
Stashing is private, its contents will not be exposed publicly, and it's
|
|
|
|
|
encrypted end-to-end. More on encryption below.
|
|
|
|
|
|
|
|
|
|
## The CLI
|
|
|
|
|
|
|
|
|
|
In addition to a TUI, Glow has a CLI for working with Markdown. To format a
|
|
|
|
|
document use a markdown source as the primary argument:
|
2019-11-09 16:12:54 -06:00
|
|
|
|
|
2019-12-18 21:36:30 -05:00
|
|
|
|
```bash
|
2019-12-13 20:44:32 +01:00
|
|
|
|
# Read from file
|
2019-12-20 22:47:47 +01:00
|
|
|
|
glow README.md
|
2019-12-13 20:36:25 +01:00
|
|
|
|
|
2019-12-13 20:44:32 +01:00
|
|
|
|
# Read from stdin
|
2019-12-20 22:47:47 +01:00
|
|
|
|
glow -
|
2019-11-22 04:51:44 +01:00
|
|
|
|
|
2019-12-28 04:47:15 +01:00
|
|
|
|
# Fetch README from GitHub / GitLab
|
2019-12-20 22:47:47 +01:00
|
|
|
|
glow github.com/charmbracelet/glow
|
2019-11-25 05:03:26 +01:00
|
|
|
|
|
2019-12-13 20:45:25 +01:00
|
|
|
|
# Fetch markdown from HTTP
|
2019-12-20 22:47:47 +01:00
|
|
|
|
glow https://host.tld/file.md
|
2019-11-22 04:51:44 +01:00
|
|
|
|
```
|
|
|
|
|
|
2020-07-29 11:49:36 -05:00
|
|
|
|
### Stashing
|
|
|
|
|
|
2020-08-27 14:21:45 -04:00
|
|
|
|
You can also stash documents from the CLI:
|
2020-07-29 11:49:36 -05:00
|
|
|
|
|
2020-08-27 13:50:46 -04:00
|
|
|
|
```bash
|
|
|
|
|
glow stash README.md
|
|
|
|
|
```
|
2020-07-29 11:49:36 -05:00
|
|
|
|
|
2020-08-27 13:50:46 -04:00
|
|
|
|
Then, when you run `glow` without arguments will you can browse through your
|
|
|
|
|
stashed documents. This is a great way to keep track of things that you need to
|
|
|
|
|
reference often.
|
2020-07-29 11:49:36 -05:00
|
|
|
|
|
2019-12-13 03:29:52 +01:00
|
|
|
|
### Word Wrapping
|
2019-12-13 03:25:02 +01:00
|
|
|
|
|
2019-12-18 21:36:30 -05:00
|
|
|
|
The `-w` flag lets you set a maximum width at which the output will be wrapped:
|
2019-12-13 20:36:25 +01:00
|
|
|
|
|
2019-12-18 21:36:30 -05:00
|
|
|
|
```bash
|
2019-12-20 22:47:47 +01:00
|
|
|
|
glow -w 60
|
2019-12-13 03:25:02 +01:00
|
|
|
|
```
|
|
|
|
|
|
2019-12-31 11:22:52 +01:00
|
|
|
|
### Paging
|
|
|
|
|
|
2020-08-27 13:50:46 -04:00
|
|
|
|
CLI output can be displayed in your preferred pager with the `-p` flag. This defaults
|
|
|
|
|
to the ANSI-aware `less -r` if `$PAGER` is not explicitly set.
|
2019-12-31 11:22:52 +01:00
|
|
|
|
|
2019-12-13 03:29:52 +01:00
|
|
|
|
### Styles
|
2019-12-13 03:25:02 +01:00
|
|
|
|
|
2020-01-14 02:20:21 +01:00
|
|
|
|
You can choose a style with the `-s` flag. When no flag is provided `glow` tries
|
|
|
|
|
to detect your terminal's current background color and automatically picks
|
|
|
|
|
either the `dark` or the `light` style for you.
|
2019-12-13 20:36:25 +01:00
|
|
|
|
|
2019-12-18 21:36:30 -05:00
|
|
|
|
```bash
|
2019-12-20 22:47:47 +01:00
|
|
|
|
glow -s [dark|light]
|
2019-12-13 03:25:02 +01:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Alternatively you can also supply a custom JSON stylesheet:
|
2019-12-13 20:36:25 +01:00
|
|
|
|
|
2019-12-18 21:36:30 -05:00
|
|
|
|
```bash
|
2019-12-20 22:47:47 +01:00
|
|
|
|
glow -s mystyle.json
|
2019-11-26 21:03:46 +01:00
|
|
|
|
```
|
|
|
|
|
|
2019-12-18 21:36:30 -05:00
|
|
|
|
For additional usage details see:
|
|
|
|
|
|
|
|
|
|
```bash
|
2019-12-20 22:47:47 +01:00
|
|
|
|
glow --help
|
2019-12-18 21:36:30 -05:00
|
|
|
|
```
|
|
|
|
|
|
2020-08-27 13:32:05 -04:00
|
|
|
|
Check out the [Glamour Style Section](https://github.com/charmbracelet/glamour/blob/master/styles/gallery/README.md)
|
|
|
|
|
to find more styles. Or [make your own](https://github.com/charmbracelet/glamour/tree/master/styles)!
|
|
|
|
|
|
2020-10-23 08:34:32 +02:00
|
|
|
|
## The Config File
|
|
|
|
|
|
|
|
|
|
If you find yourself supplying the same flags to `glow` all the time, it's
|
2020-10-27 15:02:53 +01:00
|
|
|
|
probably a good idea to create a config file. Run `glow config`, which will open
|
|
|
|
|
it in your favorite $EDITOR. Alternatively you can manually put a file named
|
|
|
|
|
`glow.yml` in the default config path of you platform. If you're not sure where
|
|
|
|
|
that is, please refer to `glow --help`.
|
2020-10-23 08:34:32 +02:00
|
|
|
|
|
|
|
|
|
Here's an example config:
|
|
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
|
# style name or JSON path (default "auto")
|
|
|
|
|
style: "light"
|
|
|
|
|
# show local files only; no network (TUI-mode only)
|
|
|
|
|
local: true
|
2020-10-23 08:46:59 +02:00
|
|
|
|
# word-wrap at width
|
|
|
|
|
width: 80
|
2020-10-23 08:34:32 +02:00
|
|
|
|
```
|
|
|
|
|
|
2020-08-27 14:21:45 -04:00
|
|
|
|
## 🔒 Encryption: How It Works
|
2020-08-27 13:32:05 -04:00
|
|
|
|
|
|
|
|
|
Encryption works by issuing symmetric keys (basically a generated password) and
|
|
|
|
|
encrypting it with the local SSH public key generated by the open-source
|
|
|
|
|
[charm][charmlib] library. That encrypted key is then sent up to our server.
|
|
|
|
|
We can’t read it since we don’t have your private key. When you want to decrypt
|
|
|
|
|
something or view your stash, that key is downloaded from our server and
|
|
|
|
|
decrypted locally using the SSH private key. When you link accounts, the
|
|
|
|
|
symmetric key is encrypted for each new public key. This happens on your
|
|
|
|
|
machine and not our server, so we never see any unencrypted data.
|
|
|
|
|
|
|
|
|
|
[charmlib]: https://github.com/charmbracelet/charm
|
|
|
|
|
|
2019-12-18 21:36:30 -05:00
|
|
|
|
## License
|
2019-11-09 16:12:54 -06:00
|
|
|
|
|
2019-12-20 22:47:47 +01:00
|
|
|
|
[MIT](https://github.com/charmbracelet/glow/raw/master/LICENSE)
|
2020-04-27 11:48:11 -04:00
|
|
|
|
|
2020-04-27 11:50:31 -04:00
|
|
|
|
Part of [Charm](https://charm.sh).
|
|
|
|
|
|
2020-10-20 10:16:30 -04:00
|
|
|
|
<a href="https://charm.sh/"><img alt="the Charm logo" src="https://stuff.charm.sh/charm-badge.jpg" width="400"></a>
|
2020-04-27 11:50:31 -04:00
|
|
|
|
|
2020-08-27 13:50:46 -04:00
|
|
|
|
Charm热爱开源! / Charm loves open source!
|
2020-10-20 10:16:30 -04:00
|
|
|
|
|