Finish porting support for color schemes to SSH kitten

This commit is contained in:
Kovid Goyal 2023-02-28 12:08:55 +05:30
parent c877b2a5cb
commit 3558d1c274
No known key found for this signature in database
GPG Key ID: 06BC317B515ACE7C
3 changed files with 79 additions and 19 deletions

View File

@ -25,6 +25,7 @@ import (
"time" "time"
"kitty/tools/cli" "kitty/tools/cli"
"kitty/tools/themes"
"kitty/tools/tty" "kitty/tools/tty"
"kitty/tools/tui" "kitty/tools/tui"
"kitty/tools/tui/loop" "kitty/tools/tui/loop"
@ -549,6 +550,38 @@ func drain_potential_tty_garbage(term *tty.Term) {
} }
} }
func change_colors(color_scheme string) (ans string, err error) {
if color_scheme == "" {
return
}
var theme *themes.Theme
if !strings.HasSuffix(color_scheme, ".conf") {
cs := os.ExpandEnv(color_scheme)
tc, closer, err := themes.LoadThemes(-1)
if err != nil && errors.Is(err, themes.ErrNoCacheFound) {
tc, closer, err = themes.LoadThemes(time.Hour * 24)
}
if err != nil {
return "", err
}
defer closer.Close()
theme = tc.ThemeByName(cs)
if theme == nil {
return "", fmt.Errorf("No theme named %#v found", cs)
}
} else {
theme, err = themes.ThemeFromFile(utils.ResolveConfPath(color_scheme))
if err != nil {
return "", err
}
}
ans, err = theme.AsEscapeCodes()
if err == nil {
ans = "\033[#P" + ans
}
return
}
func run_ssh(ssh_args, server_args, found_extra_args []string) (rc int, err error) { func run_ssh(ssh_args, server_args, found_extra_args []string) (rc int, err error) {
go Data() go Data()
go RelevantKittyOpts() go RelevantKittyOpts()
@ -611,12 +644,21 @@ func run_ssh(ssh_args, server_args, found_extra_args []string) (rc int, err erro
cd.host_opts, cd.literal_env = host_opts, literal_env cd.host_opts, cd.literal_env = host_opts, literal_env
cd.request_data = need_to_request_data cd.request_data = need_to_request_data
cd.hostname_for_match, cd.username = hostname_for_match, uname cd.hostname_for_match, cd.username = hostname_for_match, uname
err = term.WriteAllString(loop.SAVE_PRIVATE_MODE_VALUES + loop.HANDLE_TERMIOS_SIGNALS.EscapeCodeToSet()) escape_codes_to_set_colors, err := change_colors(cd.host_opts.Color_scheme)
if err == nil {
err = term.WriteAllString(escape_codes_to_set_colors + loop.SAVE_PRIVATE_MODE_VALUES + loop.HANDLE_TERMIOS_SIGNALS.EscapeCodeToSet())
}
if err != nil { if err != nil {
return 1, err return 1, err
} }
defer term.WriteAllString(loop.RESTORE_PRIVATE_MODE_VALUES) restore_escape_codes := loop.RESTORE_PRIVATE_MODE_VALUES
defer term.RestoreAndClose() if escape_codes_to_set_colors != "" {
restore_escape_codes += "\x1b[#Q"
}
defer func() {
term.WriteAllString(restore_escape_codes)
term.RestoreAndClose()
}()
err = get_remote_command(&cd) err = get_remote_command(&cd)
if err != nil { if err != nil {
return 1, err return 1, err

View File

@ -263,7 +263,6 @@ func (self *Theme) AsEscapeCodes() (string, error) {
w := strings.Builder{} w := strings.Builder{}
w.Grow(4096) w.Grow(4096)
w.WriteString("\033]4")
set_color := func(i int, sharp string) { set_color := func(i int, sharp string) {
w.WriteByte(';') w.WriteByte(';')
w.WriteString(strconv.Itoa(i)) w.WriteString(strconv.Itoa(i))
@ -296,6 +295,7 @@ func (self *Theme) AsEscapeCodes() (string, error) {
set_default_color("selection_background", style.DefaultColors.SelectionBg, 17) set_default_color("selection_background", style.DefaultColors.SelectionBg, 17)
set_default_color("selection_foreground", style.DefaultColors.SelectionFg, 19) set_default_color("selection_foreground", style.DefaultColors.SelectionFg, 19)
w.WriteString("\033]4")
for i := 0; i < 256; i++ { for i := 0; i < 256; i++ {
key := "color" + strconv.Itoa(i) key := "color" + strconv.Itoa(i)
val := settings[key] val := settings[key]
@ -330,6 +330,20 @@ func theme_name_from_file_name(fname string) string {
return strings.Join(utils.Map(strings.Split(fname, " "), strings.Title), " ") return strings.Join(utils.Map(strings.Split(fname, " "), strings.Title), " ")
} }
func (self *Themes) AddFromFile(path string) (*Theme, error) {
m, conf, err := parse_theme_metadata(path)
if err != nil {
return nil, err
}
if m.Name == "" {
m.Name = theme_name_from_file_name(filepath.Base(path))
}
t := Theme{metadata: m, is_user_defined: true, settings: conf}
self.name_map[m.Name] = &t
return &t, nil
}
func (self *Themes) add_from_dir(dirpath string) error { func (self *Themes) add_from_dir(dirpath string) error {
entries, err := os.ReadDir(dirpath) entries, err := os.ReadDir(dirpath)
if err != nil { if err != nil {
@ -340,15 +354,9 @@ func (self *Themes) add_from_dir(dirpath string) error {
} }
for _, e := range entries { for _, e := range entries {
if !e.IsDir() && strings.HasSuffix(e.Name(), ".conf") { if !e.IsDir() && strings.HasSuffix(e.Name(), ".conf") {
m, conf, err := parse_theme_metadata(filepath.Join(dirpath, e.Name())) if _, err = self.AddFromFile(filepath.Join(dirpath, e.Name())); err != nil {
if err != nil {
return err return err
} }
if m.Name == "" {
m.Name = theme_name_from_file_name(e.Name())
}
t := Theme{metadata: m, is_user_defined: true, settings: conf}
self.name_map[m.Name] = &t
} }
} }
return nil return nil
@ -399,17 +407,14 @@ func (self *Themes) ThemeByName(name string) *Theme {
return self.name_map[name] return self.name_map[name]
} }
func LoadThemes(cache_age time.Duration, ignore_no_cache bool) (ans *Themes, closer io.Closer, err error) { func LoadThemes(cache_age time.Duration) (ans *Themes, closer io.Closer, err error) {
zip_path, err := FetchCached(cache_age) zip_path, err := FetchCached(cache_age)
ans = &Themes{name_map: make(map[string]*Theme)} ans = &Themes{name_map: make(map[string]*Theme)}
if err != nil { if err != nil {
if !errors.Is(err, ErrNoCacheFound) || ignore_no_cache { return nil, nil, err
return nil, nil, err }
} if closer, err = ans.add_from_zip_file(zip_path); err != nil {
} else { return nil, nil, err
if closer, err = ans.add_from_zip_file(zip_path); err != nil {
return nil, nil, err
}
} }
if err = ans.add_from_dir(filepath.Join(utils.ConfigDir(), "themes")); err != nil { if err = ans.add_from_dir(filepath.Join(utils.ConfigDir(), "themes")); err != nil {
return nil, nil, err return nil, nil, err
@ -418,3 +423,8 @@ func LoadThemes(cache_age time.Duration, ignore_no_cache bool) (ans *Themes, clo
ans.index_map = utils.StableSortWithKey(ans.index_map, strings.ToLower) ans.index_map = utils.StableSortWithKey(ans.index_map, strings.ToLower)
return ans, closer, nil return ans, closer, nil
} }
func ThemeFromFile(path string) (*Theme, error) {
ans := &Themes{name_map: make(map[string]*Theme)}
return ans.AddFromFile(path)
}

View File

@ -274,3 +274,11 @@ func RandomFilename() string {
return base32.StdEncoding.WithPadding(base32.NoPadding).EncodeToString(b) return base32.StdEncoding.WithPadding(base32.NoPadding).EncodeToString(b)
} }
func ResolveConfPath(path string) string {
cs := os.ExpandEnv(Expanduser(path))
if !filepath.IsAbs(cs) {
cs = filepath.Join(ConfigDir(), cs)
}
return cs
}