-
-
Save sts10/df620672662fe4c6f03ac296a02b8e72 to your computer and use it in GitHub Desktop.
| # Configuration for Alacritty, the GPU enhanced terminal emulator | |
| # Any items in the `env` entry below will be added as | |
| # environment variables. Some entries may override variables | |
| # set by alacritty it self. | |
| env: | |
| # TERM env customization. | |
| # | |
| # If this property is not set, alacritty will set it to xterm-256color. | |
| # | |
| # Note that some xterm terminfo databases don't declare support for italics. | |
| # You can verify this by checking for the presence of `smso` and `sitm` in | |
| # `infocmp xterm-256color`. | |
| TERM: xterm-256color | |
| # TERM:"" nvim | |
| window: | |
| # Window dimensions in character columns and lines | |
| # (changes require restart) | |
| dimensions: | |
| columns: 0 | |
| lines: 0 | |
| # Adds this many blank pixels of padding around the window | |
| # Units are physical pixels; this is not DPI aware. | |
| # (change requires restart) | |
| padding: | |
| x: 2 | |
| y: 2 | |
| dynamic_padding: false | |
| # Window decorations | |
| # | |
| # Available values: | |
| # - `full`: Window with title bar and title bar buttons | |
| # - `none`: Window without title bar, rounded corners, or drop shadow | |
| # - `transparent`: Window with title bar with transparent background and title | |
| # bar buttons | |
| # - `buttonless`: Window with title bar with transparent background and no | |
| # title bar buttons | |
| # Window decorations | |
| # | |
| # Values for `decorations`: | |
| # - full: Borders and title bar | |
| # - none: Neither borders nor title bar | |
| # - buttonless: Title bar, transparent background and title bar buttons | |
| # - transparent: Title bar, transparent background, but no title bar buttons | |
| decorations: full | |
| # Startup Mode (changes require restart) | |
| # | |
| # Values for `startup_mode`: | |
| # - Windowed | |
| # - Maximized | |
| # - Fullscreen | |
| # | |
| # Values for `startup_mode` (macOS only): | |
| # - SimpleFullscreen | |
| startup_mode: Windowed | |
| # scrolling.multiplier: 3 | |
| scrolling: | |
| # Maximum number of lines in the scrollback buffer. | |
| # Specifying '0' will disable scrolling. | |
| history: 10000 | |
| # Number of lines the viewport will move for every line scrolled when | |
| # scrollback is enabled (history > 0). | |
| multiplier: 3 | |
| # Scroll to the bottom when new text is written to the terminal. | |
| auto_scroll: false | |
| # Display tabs using this many cells (changes require restart) | |
| tabspaces: 4 | |
| # When true, bold text is drawn using the bright variant of colors. | |
| draw_bold_text_with_bright_colors: true | |
| # Font configuration (changes require restart) | |
| font: | |
| # The normal (roman) font face to use. | |
| normal: | |
| # family: "Fira Code" | |
| # family: "Roboto Mono" | |
| family: "Hack" | |
| # family: "Droid Sans Mono" | |
| # Style can be specified to pick a specific face. | |
| # style: Regular | |
| # The bold font face | |
| bold: | |
| # family: "Roboto Mono" | |
| family: "Hack" | |
| # family: "Droid Sans Mono" | |
| # Style can be specified to pick a specific face. | |
| style: Bold | |
| # The italic font face | |
| italic: | |
| # family: "Roboto Mono" | |
| # family: "Droid Sans Mono" | |
| family: "Hack" | |
| # Style can be specified to pick a specific face. | |
| style: Italic | |
| # Point size of the font | |
| size: 22.0 | |
| # Offset is the extra space around each character. offset.y can be thought of | |
| # as modifying the linespacing, and offset.x as modifying the letter spacing. | |
| offset: | |
| x: 0 | |
| y: 0 | |
| # Glyph offset determines the locations of the glyphs within their cells with | |
| # the default being at the bottom. Increase the x offset to move the glyph to | |
| # the right, increase the y offset to move the glyph upward.test_test1 | |
| glyph_offset: | |
| x: 0 | |
| y: 1 | |
| # OS X only: use thin stroke font rendering. Thin strokes are suitable | |
| # for retina displays, but for non-retina you probably want this set to | |
| # false. | |
| use_thin_strokes: false | |
| debug: | |
| # Display the time it takes to redraw each frame. | |
| render_timer: false | |
| # Keep the log file after quitting Alacritty. | |
| persistent_logging: false | |
| # Log level | |
| # | |
| # Values for `log_level`: | |
| # - None | |
| # - Error | |
| # - Warn | |
| # - Info | |
| # - Debug | |
| # - Trace | |
| log_level: Warn | |
| # Print all received window events. | |
| print_events: false | |
| # Record all characters and escape sequences as test data. | |
| ref_test: false | |
| # Colors (Pink Moon) | |
| colors: | |
| # Default colors | |
| primary: | |
| background: '0x2a2e38' | |
| foreground: '0xF0FDFF' | |
| # (Optional) Bright and Dim foreground colors | |
| # | |
| # The dimmed foreground color is calculated automatically if it is not present. | |
| # If the bright foreground color is not set, or `draw_bold_text_with_bright_colors` | |
| # is `false`, the normal foreground color will be used. | |
| # | |
| # dim_foreground: '0x9a9a9a' | |
| # bright_foreground: '0xffffff' | |
| # Normal colors | |
| normal: | |
| black: '0x2a2e38' | |
| red: '0xd08785' | |
| green: '0x6f98b3' | |
| yellow: '0xfdf8ce' | |
| blue: '0xa6b8cc' | |
| magenta: '0xfcdbd9' | |
| cyan: '0xffd17f' | |
| white: '0xf0fdff' | |
| # Bright colors | |
| bright: | |
| black: '0x71798a' | |
| red: '0xff3334' | |
| green: '0x9ec400' | |
| yellow: '0xe7c547' | |
| blue: '0x7aa6da' | |
| magenta: '0xb77ee0' | |
| cyan: '0x54ced6' | |
| white: '0xffffff' | |
| # Dim colors (Optional) | |
| dim: | |
| black: '0x333333' | |
| red: '0xf2777a' | |
| green: '0x99cc99' | |
| yellow: '0xffcc66' | |
| blue: '0x6699cc' | |
| magenta: '0xcc99cc' | |
| cyan: '0x66cccc' | |
| white: '0xdddddd' | |
| # Optional: Colors the cursor will use (test) | |
| cursor: | |
| text: '0x2a2e38' | |
| # cursor: '0x71798a' | |
| # cursor: '0xF0FDFF' | |
| # cursor: '0xe6d3c6' | |
| cursor: '0xffd17f' | |
| selection: | |
| text: '0x2a2e38' | |
| cursor: '0xF0FDFF' | |
| # Visual Bell | |
| # | |
| # Any time the BEL code is received, Alacritty "rings" the visual bell. Once | |
| # rung, the terminal background will be set to white and transition back to the | |
| # default background color. You can control the rate of this transition by | |
| # setting the `duration` property (represented in milliseconds). You can also | |
| # configure the transition function by setting the `animation` property. | |
| # | |
| # Possible values for `animation` | |
| # `Ease` | |
| # `EaseOut` | |
| # `EaseOutSine` | |
| # `EaseOutQuad` | |
| # `EaseOutCubic` | |
| # `EaseOutQuart` | |
| # `EaseOutQuint` | |
| # `EaseOutExpo` | |
| # `EaseOutCirc` | |
| # `Linear` | |
| # | |
| # To completely disable the visual bell, set its duration to 0. | |
| # | |
| visual_bell: | |
| animation: EaseOutExpo | |
| duration: 0 | |
| # Background opacity | |
| background_opacity: 1.0 | |
| # Mouse bindings | |
| # | |
| # Currently doesn't support modifiers. Both the `mouse` and `action` fields must | |
| # be specified. | |
| # | |
| # Values for `mouse`: | |
| # - Middle | |
| # - Left | |
| # - Right | |
| # - Numeric identifier such as `5` | |
| # | |
| # Values for `action`: | |
| # - Paste | |
| # - PasteSelection | |
| # - Copy (TODO) | |
| mouse_bindings: | |
| - { mouse: Middle, action: PasteSelection } | |
| mouse: | |
| # Click settings | |
| # | |
| # The `double_click` and `triple_click` settings control the time | |
| # alacritty should wait for accepting multiple clicks as one double | |
| # or triple click. | |
| double_click: { threshold: 300 } | |
| triple_click: { threshold: 300 } | |
| hide_when_typing: false | |
| # Faux Scrollback | |
| # | |
| # The `faux_scrollback_lines` setting controls the number | |
| # of lines the terminal should scroll when the alternate | |
| # screen buffer is active. This is used to allow mouse | |
| # scrolling for applications like `man`. | |
| # | |
| # To disable this completely, set `faux_scrollback_lines` to 0. | |
| # faux_scrollback_lines: 1 | |
| url: | |
| # URL launcher | |
| # | |
| # This program is executed when clicking on a text which is recognized as a URL. | |
| # The URL is always added to the command as the last parameter. | |
| launcher: open | |
| # URL modifiers | |
| # | |
| # These are the modifiers that need to be held down for opening URLs when clicking | |
| # on them. The available modifiers are documented in the key binding section. | |
| #modifiers: Control|Shift | |
| selection: | |
| semantic_escape_chars: ",│`|:\"' ()[]{}<>" | |
| # When set to `true`, selected text will be copied to the primary clipboard. | |
| save_to_clipboard: false | |
| dynamic_title: true | |
| cursor: | |
| # Style of the cursor | |
| # | |
| # Values for 'cursor_style': | |
| # - Block | |
| # - Underline | |
| # - Beam | |
| style: Block | |
| # Whether the cursor should be a hollow block on window focus loss | |
| unfocused_hollow: true | |
| # Live config reload (changes require restart) | |
| live_config_reload: true | |
| # Shell | |
| # | |
| # You can set shell.program to the path of your favorite shell, e.g. /bin/fish. | |
| # Entries in shell.args are passed unmodified as arguments to the shell. | |
| # | |
| # shell: | |
| # program: /bin/bash | |
| # args: | |
| # - --login | |
| shell: | |
| program: /bin/bash | |
| args: | |
| - -c | |
| - cd ~/Documents/code && exec bash | |
| # Key bindings | |
| # | |
| # Each binding is defined as an object with some properties. Most of the | |
| # properties are optional. All of the alphabetical keys should have a letter for | |
| # the `key` value such as `V`. Function keys are probably what you would expect | |
| # as well (F1, F2, ..). The number keys above the main keyboard are encoded as | |
| # `Key1`, `Key2`, etc. Keys on the number pad are encoded `Number1`, `Number2`, | |
| # etc. These all match the glutin::VirtualKeyCode variants. | |
| # | |
| # A list with all available `key` names can be found here: | |
| # https://docs.rs/glutin/*/glutin/enum.VirtualKeyCode.html#variants | |
| # | |
| # Possible values for `mods` | |
| # `Command`, `Super` refer to the super/command/windows key | |
| # `Control` for the control key | |
| # `Shift` for the Shift key | |
| # `Alt` and `Option` refer to alt/option | |
| # | |
| # mods may be combined with a `|`. For example, requiring control and shift | |
| # looks like: | |
| # | |
| # mods: Control|Shift | |
| # | |
| # The parser is currently quite sensitive to whitespace and capitalization - | |
| # capitalization must match exactly, and piped items must not have whitespace | |
| # around them. | |
| # | |
| # Either an `action`, `chars`, or `command` field must be present. | |
| # `action` must be one of `Paste`, `PasteSelection`, `Copy`, or `Quit`. | |
| # `chars` writes the specified string every time that binding is activated. | |
| # These should generally be escape sequences, but they can be configured to | |
| # send arbitrary strings of bytes. | |
| # `command` must be a map containing a `program` string, and `args` array of | |
| # strings. For example: | |
| # - { ... , command: { program: "alacritty", args: ["-e", "vttest"] } } | |
| key_bindings: | |
| # - { key: N, mods: Command, command: { program: "open", args: ["-n", "/Applications/Alacritty.app"] } } | |
| - { key: N, mods: Command, action: SpawnNewInstance } | |
| - { key: V, mods: Command, action: Paste } | |
| - { key: C, mods: Command, action: Copy } | |
| - { key: Paste, action: Paste } | |
| - { key: Copy, action: Copy } | |
| - { key: H, mods: Command, action: Hide } | |
| - { key: Q, mods: Command, action: Quit } | |
| - { key: W, mods: Command, action: Quit } | |
| - { key: Home, chars: "\x1bOH", mode: AppCursor } | |
| - { key: Home, chars: "\x1b[H", mode: ~AppCursor } | |
| - { key: End, chars: "\x1bOF", mode: AppCursor } | |
| - { key: End, chars: "\x1b[F", mode: ~AppCursor } | |
| - { key: Key0, mods: Command, action: ResetFontSize } | |
| - { key: Equals, mods: Command, action: IncreaseFontSize } | |
| - { key: Minus, mods: Command, action: DecreaseFontSize } | |
| - { key: PageUp, mods: Shift, chars: "\x1b[5;2~" } | |
| - { key: PageUp, mods: Control, chars: "\x1b[5;5~" } | |
| - { key: PageUp, chars: "\x1b[5~" } | |
| - { key: PageDown, mods: Shift, chars: "\x1b[6;2~" } | |
| - { key: PageDown, mods: Control, chars: "\x1b[6;5~" } | |
| - { key: PageDown, chars: "\x1b[6~" } | |
| - { key: Tab, mods: Shift, chars: "\x1b[Z" } | |
| - { key: Back, chars: "\x7f" } | |
| - { key: Back, mods: Alt, chars: "\x1b\x7f" } | |
| - { key: Insert, chars: "\x1b[2~" } | |
| - { key: Delete, chars: "\x1b[3~" } | |
| - { key: Left, mods: Shift, chars: "\x1b[1;2D" } | |
| - { key: Left, mods: Control, chars: "\x1b[1;5D" } | |
| - { key: Left, mods: Alt, chars: "\x1b[1;3D" } | |
| - { key: Left, chars: "\x1b[D", mode: ~AppCursor } | |
| - { key: Left, chars: "\x1bOD", mode: AppCursor } | |
| - { key: Right, mods: Shift, chars: "\x1b[1;2C" } | |
| - { key: Right, mods: Control, chars: "\x1b[1;5C" } | |
| - { key: Right, mods: Alt, chars: "\x1b[1;3C" } | |
| - { key: Right, chars: "\x1b[C", mode: ~AppCursor } | |
| - { key: Right, chars: "\x1bOC", mode: AppCursor } | |
| - { key: Up, mods: Shift, chars: "\x1b[1;2A" } | |
| - { key: Up, mods: Control, chars: "\x1b[1;5A" } | |
| - { key: Up, mods: Alt, chars: "\x1b[1;3A" } | |
| - { key: Up, chars: "\x1b[A", mode: ~AppCursor } | |
| - { key: Up, chars: "\x1bOA", mode: AppCursor } | |
| - { key: Down, mods: Shift, chars: "\x1b[1;2B" } | |
| - { key: Down, mods: Control, chars: "\x1b[1;5B" } | |
| - { key: Down, mods: Alt, chars: "\x1b[1;3B" } | |
| - { key: Down, chars: "\x1b[B", mode: ~AppCursor } | |
| - { key: Down, chars: "\x1bOB", mode: AppCursor } | |
| - { key: F1, chars: "\x1bOP" } | |
| - { key: F2, chars: "\x1bOQ" } | |
| - { key: F3, chars: "\x1bOR" } | |
| - { key: F4, chars: "\x1bOS" } | |
| - { key: F5, chars: "\x1b[15~" } | |
| - { key: F6, chars: "\x1b[17~" } | |
| - { key: F7, chars: "\x1b[18~" } | |
| - { key: F8, chars: "\x1b[19~" } | |
| - { key: F9, chars: "\x1b[20~" } | |
| - { key: F10, chars: "\x1b[21~" } | |
| - { key: F11, chars: "\x1b[23~" } | |
| - { key: F12, chars: "\x1b[24~" } | |
| - { key: F1, mods: Shift, chars: "\x1b[1;2P" } | |
| - { key: F2, mods: Shift, chars: "\x1b[1;2Q" } | |
| - { key: F3, mods: Shift, chars: "\x1b[1;2R" } | |
| - { key: F4, mods: Shift, chars: "\x1b[1;2S" } | |
| - { key: F5, mods: Shift, chars: "\x1b[15;2~" } | |
| - { key: F6, mods: Shift, chars: "\x1b[17;2~" } | |
| - { key: F7, mods: Shift, chars: "\x1b[18;2~" } | |
| - { key: F8, mods: Shift, chars: "\x1b[19;2~" } | |
| - { key: F9, mods: Shift, chars: "\x1b[20;2~" } | |
| - { key: F10, mods: Shift, chars: "\x1b[21;2~" } | |
| - { key: F11, mods: Shift, chars: "\x1b[23;2~" } | |
| - { key: F12, mods: Shift, chars: "\x1b[24;2~" } | |
| - { key: F1, mods: Control, chars: "\x1b[1;5P" } | |
| - { key: F2, mods: Control, chars: "\x1b[1;5Q" } | |
| - { key: F3, mods: Control, chars: "\x1b[1;5R" } | |
| - { key: F4, mods: Control, chars: "\x1b[1;5S" } | |
| - { key: F5, mods: Control, chars: "\x1b[15;5~" } | |
| - { key: F6, mods: Control, chars: "\x1b[17;5~" } | |
| - { key: F7, mods: Control, chars: "\x1b[18;5~" } | |
| - { key: F8, mods: Control, chars: "\x1b[19;5~" } | |
| - { key: F9, mods: Control, chars: "\x1b[20;5~" } | |
| - { key: F10, mods: Control, chars: "\x1b[21;5~" } | |
| - { key: F11, mods: Control, chars: "\x1b[23;5~" } | |
| - { key: F12, mods: Control, chars: "\x1b[24;5~" } | |
| - { key: F1, mods: Alt, chars: "\x1b[1;6P" } | |
| - { key: F2, mods: Alt, chars: "\x1b[1;6Q" } | |
| - { key: F3, mods: Alt, chars: "\x1b[1;6R" } | |
| - { key: F4, mods: Alt, chars: "\x1b[1;6S" } | |
| - { key: F5, mods: Alt, chars: "\x1b[15;6~" } | |
| - { key: F6, mods: Alt, chars: "\x1b[17;6~" } | |
| - { key: F7, mods: Alt, chars: "\x1b[18;6~" } | |
| - { key: F8, mods: Alt, chars: "\x1b[19;6~" } | |
| - { key: F9, mods: Alt, chars: "\x1b[20;6~" } | |
| - { key: F10, mods: Alt, chars: "\x1b[21;6~" } | |
| - { key: F11, mods: Alt, chars: "\x1b[23;6~" } | |
| - { key: F12, mods: Alt, chars: "\x1b[24;6~" } | |
| - { key: F1, mods: Command, chars: "\x1b[1;3P" } | |
| - { key: F2, mods: Command, chars: "\x1b[1;3Q" } | |
| - { key: F3, mods: Command, chars: "\x1b[1;3R" } | |
| - { key: F4, mods: Command, chars: "\x1b[1;3S" } | |
| - { key: F5, mods: Command, chars: "\x1b[15;3~" } | |
| - { key: F6, mods: Command, chars: "\x1b[17;3~" } | |
| - { key: F7, mods: Command, chars: "\x1b[18;3~" } | |
| - { key: F8, mods: Command, chars: "\x1b[19;3~" } | |
| - { key: F9, mods: Command, chars: "\x1b[20;3~" } | |
| - { key: F10, mods: Command, chars: "\x1b[21;3~" } | |
| - { key: F11, mods: Command, chars: "\x1b[23;3~" } | |
| - { key: F12, mods: Command, chars: "\x1b[24;3~" } | |
| - { key: NumpadEnter, chars: "\n" } |
Hm, not sure.
For finding the exact name of fonts, MacOS has an application called Font Book that may help.
I'll note that this config file may be out of date -- I don't use Alacritty anymore (I switched to Kitty). You might want to work off the current config example.
But I'll take some guesses: Are you setting the font name to the variable family? I remember finding that odd at the time. Maybe try single quotes instead of double? Make sure font is installed correctly. Could try commenting in or out the style: Regular line...
Hey, thanks for the reply. I think your config is pretty good as an example still.
I was trying to use some obscure, patched vim font and ended up doing a giant find command and going down a rabbit hole (apparently fc-list isn't a mac thing). Anyway, it was family: TerminessTTF Nerd Font Mono
Strangely, the style is style: Medium
How'd you find the font names? I'm typing them verbatim from the Terminal app but Alacritty can't find them.