mirror of
https://github.com/JanDeDobbeleer/oh-my-posh.git
synced 2025-01-03 15:27:26 -08:00
parent
7aa2ad14fc
commit
7dce0fe3e7
|
@ -50,10 +50,10 @@ A backup of the current config can be found at ~/myconfig.omp.json.bak.`,
|
||||||
defer env.Close()
|
defer env.Close()
|
||||||
cfg := engine.LoadConfig(env)
|
cfg := engine.LoadConfig(env)
|
||||||
if write {
|
if write {
|
||||||
cfg.BackupAndMigrate(env)
|
cfg.BackupAndMigrate()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
cfg.Migrate(env)
|
cfg.Migrate()
|
||||||
fmt.Print(cfg.Export(format))
|
fmt.Print(cfg.Export(format))
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,10 +89,9 @@ func (cfg *Config) getPalette() ansi.Palette {
|
||||||
// LoadConfig returns the default configuration including possible user overrides
|
// LoadConfig returns the default configuration including possible user overrides
|
||||||
func LoadConfig(env platform.Environment) *Config {
|
func LoadConfig(env platform.Environment) *Config {
|
||||||
cfg := loadConfig(env)
|
cfg := loadConfig(env)
|
||||||
cfg.env = env
|
|
||||||
// only migrate automatically when the switch isn't set
|
// only migrate automatically when the switch isn't set
|
||||||
if !env.Flags().Migrate && cfg.Version < configVersion {
|
if !env.Flags().Migrate && cfg.Version < configVersion {
|
||||||
cfg.BackupAndMigrate(env)
|
cfg.BackupAndMigrate()
|
||||||
}
|
}
|
||||||
return cfg
|
return cfg
|
||||||
}
|
}
|
||||||
|
@ -102,12 +101,14 @@ func loadConfig(env platform.Environment) *Config {
|
||||||
configFile := env.Flags().Config
|
configFile := env.Flags().Config
|
||||||
|
|
||||||
if len(configFile) == 0 {
|
if len(configFile) == 0 {
|
||||||
return defaultConfig(false)
|
env.Debug("no config file specified, using default")
|
||||||
|
return defaultConfig(env, false)
|
||||||
}
|
}
|
||||||
|
|
||||||
var cfg Config
|
var cfg Config
|
||||||
cfg.origin = configFile
|
cfg.origin = configFile
|
||||||
cfg.format = strings.TrimPrefix(filepath.Ext(configFile), ".")
|
cfg.format = strings.TrimPrefix(filepath.Ext(configFile), ".")
|
||||||
|
cfg.env = env
|
||||||
if cfg.format == "yml" {
|
if cfg.format == "yml" {
|
||||||
cfg.format = YAML
|
cfg.format = YAML
|
||||||
}
|
}
|
||||||
|
@ -126,12 +127,14 @@ func loadConfig(env platform.Environment) *Config {
|
||||||
|
|
||||||
err := config.LoadFiles(configFile)
|
err := config.LoadFiles(configFile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return defaultConfig(true)
|
env.Error(err)
|
||||||
|
return defaultConfig(env, true)
|
||||||
}
|
}
|
||||||
|
|
||||||
err = config.BindStruct("", &cfg)
|
err = config.BindStruct("", &cfg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return defaultConfig(true)
|
env.Error(err)
|
||||||
|
return defaultConfig(env, true)
|
||||||
}
|
}
|
||||||
|
|
||||||
return &cfg
|
return &cfg
|
||||||
|
@ -194,9 +197,9 @@ func (cfg *Config) Export(format string) string {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (cfg *Config) BackupAndMigrate(env platform.Environment) {
|
func (cfg *Config) BackupAndMigrate() {
|
||||||
cfg.Backup()
|
cfg.Backup()
|
||||||
cfg.Migrate(env)
|
cfg.Migrate()
|
||||||
cfg.Write(cfg.format)
|
cfg.Write(cfg.format)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -301,7 +304,7 @@ func escapeGlyphs(s string, migrate bool) string {
|
||||||
return builder.String()
|
return builder.String()
|
||||||
}
|
}
|
||||||
|
|
||||||
func defaultConfig(warning bool) *Config {
|
func defaultConfig(env platform.Environment, warning bool) *Config {
|
||||||
exitBackgroundTemplate := "{{ if gt .Code 0 }}p:red{{ end }}"
|
exitBackgroundTemplate := "{{ if gt .Code 0 }}p:red{{ end }}"
|
||||||
exitTemplate := " {{ if gt .Code 0 }}\uf00d{{ else }}\uf00c{{ end }} "
|
exitTemplate := " {{ if gt .Code 0 }}\uf00d{{ else }}\uf00c{{ end }} "
|
||||||
if warning {
|
if warning {
|
||||||
|
@ -489,5 +492,6 @@ func defaultConfig(warning bool) *Config {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
cfg.env = env
|
||||||
return cfg
|
return cfg
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,14 +17,14 @@ const (
|
||||||
segmentTemplate = properties.Property("template")
|
segmentTemplate = properties.Property("template")
|
||||||
)
|
)
|
||||||
|
|
||||||
func (cfg *Config) Migrate(env platform.Environment) {
|
func (cfg *Config) Migrate() {
|
||||||
for _, block := range cfg.Blocks {
|
for _, block := range cfg.Blocks {
|
||||||
for _, segment := range block.Segments {
|
for _, segment := range block.Segments {
|
||||||
segment.migrate(env, cfg.Version)
|
segment.migrate(cfg.env, cfg.Version)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for _, segment := range cfg.Tooltips {
|
for _, segment := range cfg.Tooltips {
|
||||||
segment.migrate(env, cfg.Version)
|
segment.migrate(cfg.env, cfg.Version)
|
||||||
}
|
}
|
||||||
if strings.Contains(cfg.ConsoleTitleTemplate, ".Path") {
|
if strings.Contains(cfg.ConsoleTitleTemplate, ".Path") {
|
||||||
cfg.ConsoleTitleTemplate = strings.ReplaceAll(cfg.ConsoleTitleTemplate, ".Path", ".PWD")
|
cfg.ConsoleTitleTemplate = strings.ReplaceAll(cfg.ConsoleTitleTemplate, ".Path", ".PWD")
|
||||||
|
|
|
@ -427,8 +427,9 @@ func TestMigrateConfig(t *testing.T) {
|
||||||
for _, tc := range cases {
|
for _, tc := range cases {
|
||||||
cfg := &Config{
|
cfg := &Config{
|
||||||
ConsoleTitleTemplate: tc.Template,
|
ConsoleTitleTemplate: tc.Template,
|
||||||
|
env: &mock.MockedEnvironment{},
|
||||||
}
|
}
|
||||||
cfg.Migrate(&mock.MockedEnvironment{})
|
cfg.Migrate()
|
||||||
assert.Equal(t, tc.Expected, cfg.ConsoleTitleTemplate, tc.Case)
|
assert.Equal(t, tc.Expected, cfg.ConsoleTitleTemplate, tc.Case)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -275,11 +275,13 @@ func (env *Shell) resolveConfigPath() {
|
||||||
env.CmdFlags.Config = env.Getenv("POSH_THEME")
|
env.CmdFlags.Config = env.Getenv("POSH_THEME")
|
||||||
}
|
}
|
||||||
if len(env.CmdFlags.Config) == 0 {
|
if len(env.CmdFlags.Config) == 0 {
|
||||||
|
env.Debug("No config set, fallback to default config")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if strings.HasPrefix(env.CmdFlags.Config, "https://") {
|
if strings.HasPrefix(env.CmdFlags.Config, "https://") {
|
||||||
if err := env.downloadConfig(env.CmdFlags.Config); err != nil {
|
if err := env.downloadConfig(env.CmdFlags.Config); err != nil {
|
||||||
// make it use default config when download fails
|
// make it use default config when download fails
|
||||||
|
env.Error(err)
|
||||||
env.CmdFlags.Config = ""
|
env.CmdFlags.Config = ""
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -287,6 +289,7 @@ func (env *Shell) resolveConfigPath() {
|
||||||
// Cygwin path always needs the full path as we're on Windows but not really.
|
// Cygwin path always needs the full path as we're on Windows but not really.
|
||||||
// Doing filepath actions will convert it to a Windows path and break the init script.
|
// Doing filepath actions will convert it to a Windows path and break the init script.
|
||||||
if env.Platform() == WINDOWS && env.Shell() == "bash" {
|
if env.Platform() == WINDOWS && env.Shell() == "bash" {
|
||||||
|
env.Debug("Cygwin detected, using full path for config")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
configFile := env.CmdFlags.Config
|
configFile := env.CmdFlags.Config
|
||||||
|
|
Loading…
Reference in a new issue