mirror of
https://github.com/wez/wezterm.git
synced 2025-01-06 13:59:33 +03:00
50 lines
1.6 KiB
Markdown
50 lines
1.6 KiB
Markdown
|
## Hyperlinks
|
||
|
|
||
|
wezterm has support for both implicit and explicit hyperlinks.
|
||
|
|
||
|
### Implicit Hyperlinks
|
||
|
|
||
|
Implicit hyperlinks are produced by running a series of rules over the output
|
||
|
displayed in the terminal to produce a hyperlink. There is a default rule
|
||
|
to match URLs and make them clickable, but you can also specify your own rules
|
||
|
to make your own links. As an example, at my place of work many of our internal
|
||
|
tools use `T123` to indicate task number 123 in our internal task tracking system.
|
||
|
It is desirable to make this clickable, and that can be done with the following
|
||
|
configuration:
|
||
|
|
||
|
```toml
|
||
|
# Linkify things that look like URLs
|
||
|
# This is actually the default if you don't specify any hyperlink_rules
|
||
|
[[hyperlink_rules]]
|
||
|
regex = "\\b\\w+://(?:[\\w.-]+)\\.[a-z]{2,15}\\S*\\b"
|
||
|
format = "$0"
|
||
|
|
||
|
# Un-comment this if you want to linkify email addresses
|
||
|
#[[hyperlink_rules]]
|
||
|
#regex = "\\b\\w+@[\\w-]+(\\.[\\w-]+)+\\b"
|
||
|
#format = "mailto:$0"
|
||
|
|
||
|
# Make task numbers clickable
|
||
|
[[hyperlink_rules]]
|
||
|
regex = "\\b[tT](\\d+)\\b"
|
||
|
format = "https://example.com/tasks/?t=$1"
|
||
|
```
|
||
|
|
||
|
### Explicit Hyperlinks
|
||
|
|
||
|
wezterm supports the relatively new [Hyperlinks in Terminal
|
||
|
Emulators](https://gist.github.com/egmontkob/eb114294efbcd5adb1944c9f3cb5feda)
|
||
|
specification that allows emitting text that can be clicked and resolve to a
|
||
|
specific URL, without the URL being part of the display text. This allows
|
||
|
for a cleaner presentation.
|
||
|
|
||
|
The gist of it is that running the following bash one-liner:
|
||
|
|
||
|
```bash
|
||
|
printf '\e]8;;http://example.com\e\\This is a link\e]8;;\e\\\n'
|
||
|
```
|
||
|
|
||
|
will output the text `This is a link` that when clicked will open
|
||
|
`http://example.com` in your browser.
|
||
|
|