mirror of
https://github.com/keanuplayz/dotfiles.git
synced 2024-08-15 02:33:12 +00:00
Compare commits
No commits in common. "006b9f37a2b6e625aa2f99af7473840430a46ec6" and "9c70e7bfa4abe894fd1e8a1cf35c7cfeab75af2a" have entirely different histories.
006b9f37a2
...
9c70e7bfa4
8 changed files with 30 additions and 35 deletions
|
@ -3,7 +3,7 @@
|
|||
import json
|
||||
import os
|
||||
from abc import abstractmethod
|
||||
from typing import Dict, Iterator, List, Protocol, TextIO
|
||||
from typing import Dict, Iterator, List, Protocol, TextIO, runtime_checkable
|
||||
|
||||
__dir__ = os.path.dirname(__file__)
|
||||
|
||||
|
@ -60,10 +60,23 @@ BASE16_TO_ANSI_MAPPING: List[int] = [
|
|||
ANSI_TO_BASE16_MAPPING: List[int] = [BASE16_TO_ANSI_MAPPING.index(i) for i in range(16)]
|
||||
|
||||
|
||||
@runtime_checkable
|
||||
class Theme(Protocol):
|
||||
base16_name: str
|
||||
is_dark: bool
|
||||
base16_colors: List[Color]
|
||||
|
||||
@property
|
||||
@abstractmethod
|
||||
def base16_name(self) -> str:
|
||||
raise NotImplementedError()
|
||||
|
||||
@property
|
||||
@abstractmethod
|
||||
def is_dark(self) -> bool:
|
||||
raise NotImplementedError()
|
||||
|
||||
@property
|
||||
@abstractmethod
|
||||
def base16_colors(self) -> List[Color]:
|
||||
raise NotImplementedError()
|
||||
|
||||
@property
|
||||
def name(self) -> str:
|
||||
|
@ -139,6 +152,7 @@ class MyTheme(Theme):
|
|||
]
|
||||
|
||||
|
||||
@runtime_checkable
|
||||
class ThemeGenerator(Protocol):
|
||||
|
||||
@abstractmethod
|
||||
|
@ -234,7 +248,7 @@ class ThemeGeneratorVim(ThemeGenerator):
|
|||
output.write("let {}base16_colors = [\n".format(namespace))
|
||||
for gui_color, cterm_color in zip(theme.base16_colors, ANSI_TO_BASE16_MAPPING):
|
||||
output.write(
|
||||
"\\ {{'gui': '{}', 'cterm': '{:02}'}},\n".format(gui_color.css_hex, cterm_color),
|
||||
"\\ {{'gui': '{}', 'cterm': '{:02}'}},\n".format(gui_color.css_hex, cterm_color)
|
||||
)
|
||||
output.write("\\ ]\n")
|
||||
|
||||
|
@ -279,7 +293,7 @@ class ThemeGeneratorXfceTerminal(ThemeGenerator):
|
|||
output.write("TabActivityColor={}\n".format(theme.base16_colors[0x8].css_hex))
|
||||
output.write("ColorBoldUseDefault=TRUE\n")
|
||||
output.write(
|
||||
"ColorPalette={}\n".format(";".join(color.css_hex for color in theme.ansi_colors)),
|
||||
"ColorPalette={}\n".format(";".join(color.css_hex for color in theme.ansi_colors))
|
||||
)
|
||||
|
||||
|
||||
|
@ -326,7 +340,7 @@ class ThemeGeneratorIterm(ThemeGenerator):
|
|||
def generate(self, theme: Theme, output: TextIO) -> None:
|
||||
output.write('<?xml version="1.0" encoding="UTF-8"?>\n')
|
||||
output.write(
|
||||
'<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">\n',
|
||||
'<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">\n'
|
||||
)
|
||||
output.write('<plist version="1.0">\n')
|
||||
output.write("<dict>\n")
|
||||
|
|
|
@ -1,17 +1,15 @@
|
|||
let g:coc_global_extensions += ['coc-pyright']
|
||||
let g:coc_filetypes += ['python']
|
||||
|
||||
" let g:coc_user_config['python.autocomplete.showAdvancedMembers'] = v:false
|
||||
let g:coc_user_config['python'] = {
|
||||
\ 'formatting': {
|
||||
\ 'provider': 'yapf',
|
||||
\ 'yapfArgs': ['--style=' . simplify(g:dotfiles_dir.'/python/yapf.ini')],
|
||||
\ 'yapfArgs': ['--style=' . simplify(g:dotfiles_dir.'/python/yapf.ini')]
|
||||
\ },
|
||||
\ 'linting': {
|
||||
\ 'pylintEnabled': v:false,
|
||||
\ 'flake8Enabled': v:true,
|
||||
\ 'flake8Args': ['--config=' . simplify(g:dotfiles_dir.'/python/flake8.ini')],
|
||||
\ },
|
||||
\ 'analysis': {
|
||||
\ 'typeCheckingMode': 'strict',
|
||||
\ },
|
||||
\ }
|
||||
|
|
|
@ -142,9 +142,6 @@ set commentstring=//%s
|
|||
xnoremap <M-L> zL
|
||||
xnoremap <M-Right> zl
|
||||
|
||||
" Repeat the last edit n times, taken from <https://gist.github.com/romainl/db725db7babc84a9a6436180cedee188>
|
||||
nnoremap . <Cmd>execute "normal!" repeat(".", v:count1)<CR>
|
||||
|
||||
" }}}
|
||||
|
||||
|
||||
|
|
|
@ -137,17 +137,6 @@ endif
|
|||
nmap [l <Plug>(qf_loc_previous)
|
||||
nmap ]l <Plug>(qf_loc_next)
|
||||
let g:qf_mapping_ack_style = 1
|
||||
|
||||
" Based on <https://stackoverflow.com/a/1330556/12005228>, inspired by
|
||||
" <https://gist.github.com/romainl/f7e2e506dc4d7827004e4994f1be2df6>.
|
||||
" But apparently `vimgrep /pattern/ %` can be used instead?
|
||||
function! s:CmdGlobal(pattern, bang)
|
||||
let pattern = substitute(a:pattern, "/.*$", "", "")
|
||||
let matches = []
|
||||
execute "g" . (a:bang ? "!" : "") . "/" . pattern . "/call add(matches, expand(\"%\").\":\".line(\".\").\":\".col(\".\").\":\".getline(\".\"))"
|
||||
cexpr matches
|
||||
endfunction
|
||||
command! -bang -nargs=1 Global call <SID>CmdGlobal(<q-args>, <bang>0)
|
||||
" }}}
|
||||
|
||||
|
||||
|
|
|
@ -2,7 +2,7 @@ import os
|
|||
import subprocess
|
||||
import sys
|
||||
from pathlib import Path
|
||||
from typing import Iterable, NoReturn, Optional
|
||||
from typing import Iterable, NoReturn
|
||||
|
||||
if os.name == "posix":
|
||||
DOTFILES_CONFIG_DIR: Path = Path.home() / ".config" / "dotfiles"
|
||||
|
@ -13,7 +13,7 @@ def platform_not_supported_error() -> NoReturn:
|
|||
raise Exception("platform '{}' is not supported!".format(sys.platform))
|
||||
|
||||
|
||||
def run_chooser(choices: Iterable[str], prompt: Optional[str] = None, async_read: bool = False) -> int:
|
||||
def run_chooser(choices: Iterable[str], prompt: str = None, async_read: bool = False) -> int:
|
||||
supports_result_index = True
|
||||
if os.isatty(sys.stderr.fileno()):
|
||||
process_args = [
|
||||
|
@ -36,13 +36,10 @@ def run_chooser(choices: Iterable[str], prompt: Optional[str] = None, async_read
|
|||
platform_not_supported_error()
|
||||
|
||||
chooser_process = subprocess.Popen(process_args, stdin=subprocess.PIPE, stdout=subprocess.PIPE)
|
||||
assert chooser_process.stdin is not None
|
||||
assert chooser_process.stdout is not None
|
||||
|
||||
with chooser_process.stdin as pipe:
|
||||
for index, choice in enumerate(choices):
|
||||
if "\n" not in choice:
|
||||
raise Exception("choices can only span a single line")
|
||||
assert "\n" not in choice
|
||||
if not supports_result_index:
|
||||
pipe.write(str(index).encode())
|
||||
pipe.write(b" ")
|
||||
|
@ -57,7 +54,7 @@ def run_chooser(choices: Iterable[str], prompt: Optional[str] = None, async_read
|
|||
return chosen_index
|
||||
|
||||
|
||||
def send_notification(title: str, message: str, url: Optional[str] = None) -> None:
|
||||
def send_notification(title: str, message: str, url: str = None) -> None:
|
||||
if sys.platform == "darwin":
|
||||
process_args = [
|
||||
"terminal-notifier",
|
||||
|
|
|
@ -3,7 +3,7 @@ from fractions import Fraction
|
|||
|
||||
|
||||
def factors(n: int) -> "set[int]":
|
||||
result: "set[int]" = set()
|
||||
result = set()
|
||||
for i in range(1, int(sqrt(n)) + 1):
|
||||
if n % i == 0:
|
||||
result.add(i)
|
||||
|
|
|
@ -14,7 +14,7 @@ def bright_colored(string: str, *colors: str) -> str:
|
|||
|
||||
|
||||
def colorize_percent(
|
||||
percent: float, warning: float, critical: float, inverse: bool = False,
|
||||
percent: float, warning: float, critical: float, inverse: bool = False
|
||||
) -> str:
|
||||
colors = [Fore.GREEN, Fore.YELLOW, Fore.RED]
|
||||
|
||||
|
|
|
@ -13,7 +13,7 @@ from humanize import humanize_bytes, humanize_timedelta
|
|||
def get_system_info() -> Tuple[List[str], List[str]]:
|
||||
info_lines: List[str] = []
|
||||
|
||||
def info(name: str, value: str, *format_args: object) -> None:
|
||||
def info(name: str, value: str, *format_args) -> None:
|
||||
line = bright_colored(name + ":", Fore.YELLOW) + " " + value
|
||||
if format_args:
|
||||
line = line % format_args
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue