oh-my-posh/website/docs/configuration/overview.mdx

183 lines
5.7 KiB
Plaintext
Raw Normal View History

2020-10-05 02:33:12 -07:00
---
2022-04-20 09:43:59 -07:00
id: overview
title: General
sidebar_label: General
2020-10-05 02:33:12 -07:00
---
2022-06-03 13:35:11 -07:00
import Tabs from "@theme/Tabs";
2022-06-04 15:40:50 -07:00
import TabItem from "@theme/TabItem";
2022-06-03 13:35:11 -07:00
Oh My Posh renders your prompt based on the definition of _blocks_ (like Lego) which contain one or more _segments_.
2021-11-12 10:14:16 -08:00
A really simple configuration could look like this. The default format is `json`, but we also support `toml` and `yaml`.
There's a [schema][schema] available which is kept up-to-date and helps with autocomplete and validation of the configuration.
:::info
There are a few [themes][themes] available which are basically predefined configs. You can use these as they are, or as a
starting point to create your own configuration.
:::
2020-10-05 02:33:12 -07:00
2022-06-03 13:35:11 -07:00
<Tabs
defaultValue="json"
groupId="sample"
values={[
{ label: 'json', value: 'json', },
{ label: 'yaml', value: 'yaml', },
{ label: 'toml', value: 'toml', },
]
}>
<TabItem value="json">
2020-10-05 02:33:12 -07:00
```json
{
2021-11-12 10:14:16 -08:00
"$schema": "https://raw.githubusercontent.com/JanDeDobbeleer/oh-my-posh/main/themes/schema.json",
2020-10-05 02:33:12 -07:00
"final_space": true,
"blocks": [
{
"type": "prompt",
"alignment": "left",
"segments": [
{
"type": "path",
"style": "powerline",
2020-10-15 23:37:43 -07:00
"powerline_symbol": "\uE0B0",
2020-10-05 02:33:12 -07:00
"foreground": "#ffffff",
"background": "#61AFEF",
"properties": {
"style": "folder"
}
}
]
}
]
}
```
2022-06-03 13:35:11 -07:00
</TabItem>
<TabItem value="yaml">
```yaml
# yaml-language-server: $schema=https://raw.githubusercontent.com/JanDeDobbeleer/oh-my-posh/main/themes/schema.json
final_space: true
blocks:
2022-06-04 15:40:50 -07:00
- type: prompt
alignment: left
segments:
- type: path
style: powerline
powerline_symbol: ""
foreground: "#ffffff"
background: "#61AFEF"
properties:
style: folder
2022-06-03 13:35:11 -07:00
```
</TabItem>
<TabItem value="toml">
```toml
"$schema" = "https://raw.githubusercontent.com/JanDeDobbeleer/oh-my-posh/main/themes/schema.json"
final_space = true
[[blocks]]
type = "prompt"
alignment = "left"
[[blocks.segments]]
type = "path"
style = "powerline"
powerline_symbol = ""
foreground = "#ffffff"
background = "#61AFEF"
[blocks.segments.properties]
style = "folder"
```
</TabItem>
</Tabs>
2020-10-05 02:33:12 -07:00
With this configuration, a single powerline segment is rendered that shows the name of the folder you're currently in.
To set this configuration in combination with a Oh My Posh [executable][releases], use the `--config` flag to
2022-06-03 13:35:11 -07:00
set a path to a file containing the above code. The `--shell universal` flag is used to print the prompt without
2020-11-04 02:41:34 -08:00
escape characters to see the prompt as it would be shown inside a prompt function for your shell.
2021-09-01 04:45:33 -07:00
:::caution
2020-11-04 02:41:34 -08:00
The command below will not persist the configuration for your shell but print the prompt in your terminal.
2021-06-03 11:01:46 -07:00
If you want to use your own configuration permanently, adjust the prompt configuration to use your custom
2020-11-04 02:41:34 -08:00
theme.
:::
2020-10-05 02:33:12 -07:00
```bash
2022-03-25 11:03:37 -07:00
oh-my-posh print primary --config sample.json --shell uni
2020-10-05 02:33:12 -07:00
```
If all goes according to plan, you should see the prompt being printed out on the line below. In case you see a lot of
2021-11-12 10:14:16 -08:00
boxes with question marks, set up your terminal to use a [supported font][font] before continuing.
2020-10-05 02:33:12 -07:00
:::tip
The `--config` flag can accept either a local filepath or a remotely hosted config file.
For example, the following is a valid `--config` flag:
`--config 'https://raw.githubusercontent.com/JanDeDobbeleer/oh-my-posh/main/themes/jandedobbeleer.omp.json'`
:::
2020-10-05 02:33:12 -07:00
## General Settings
2020-10-12 00:02:33 -07:00
- final_space: `boolean` - when true adds a space at the end of the prompt
2021-02-15 13:19:19 -08:00
- osc99: `boolean` - when true adds support for OSC9;9; (notify terminal of current working directory)
- terminal_background: `string` [color][colors] - terminal background color, set to your terminal's background color when
2022-06-04 15:40:50 -07:00
you notice black elements in Windows Terminal or the Visual Studio Code integrated terminal
2022-05-22 00:11:16 -07:00
- accent_color: `string` [color][colors] - accent color, used as a fallback when the `accent` [color][accent] is not supported
2020-10-05 02:33:12 -07:00
2022-06-03 13:35:11 -07:00
### JSON Schema Validation
As mentioned above, Oh My Posh themes can utilize JSON Schema to validate their contents. Themes should include a link to
the [external schema document][schema] which prescribes the appropriate structure and contents for various elements. If
your code editor is configured to use JSON Schema, it will compare your custom theme to the external document, and issue
warnings for discrepancies.
For example, given the following code:
```json
...
"segments": [
{
"type": "an_invalid_entry",
"template": "{{ if gt .Code 0 }}\uf134{{ end }}",
}
]
...
```
Warnings will be raised for type, since `an_invalid_entry` is not in the list of acceptable values, as well as
for the entire segment item (enclosed in {}), since it lacks the required `style` key. Take advantage of these
warnings, and ignore them at your peril.
### Accepted Formats
Oh My Posh supports three file formats for themes: `json`, `yaml`, and `toml`.
Various converters exist to convert between these, although they aren't perfect and will require manaual
adjustment. Notably, the schema implementation for json is as follows:
```json
{
"$schema": "https://raw.githubusercontent.com/JanDeDobbeleer/oh-my-posh/main/themes/schema.json"
}
```
While for yaml:
```yaml
# yaml-language-server: $schema=https://raw.githubusercontent.com/JanDeDobbeleer/oh-my-posh/main/themes/schema.json
```
Converters won't catch this change, so you will need to adjust manually.
2021-02-15 23:36:37 -08:00
[releases]: https://github.com/JanDeDobbeleer/oh-my-posh/releases/latest
2022-06-04 15:40:50 -07:00
[font]: /docs/installation/fonts
2021-11-12 10:14:16 -08:00
[schema]: https://github.com/JanDeDobbeleer/oh-my-posh/blob/main/themes/schema.json
[themes]: https://github.com/JanDeDobbeleer/oh-my-posh/tree/main/themes
2022-05-22 00:11:16 -07:00
[colors]: /docs/configuration/colors
[accent]: /docs/configuration/colors#standard-colors