mirror of
https://github.com/JanDeDobbeleer/oh-my-posh.git
synced 2024-12-31 13:57:26 -08:00
feat(python): add support for pyvenv.cfg prompt
This commit is contained in:
parent
cef49107fb
commit
8f03f415e1
|
@ -63,6 +63,10 @@ func (p *Python) loadContext() {
|
||||||
if !p.language.props.GetBool(FetchVirtualEnv, true) {
|
if !p.language.props.GetBool(FetchVirtualEnv, true) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
if prompt := p.pyvenvCfgPrompt(); len(prompt) > 0 {
|
||||||
|
p.Venv = prompt
|
||||||
|
return
|
||||||
|
}
|
||||||
venvVars := []string{
|
venvVars := []string{
|
||||||
"VIRTUAL_ENV",
|
"VIRTUAL_ENV",
|
||||||
"CONDA_ENV_PATH",
|
"CONDA_ENV_PATH",
|
||||||
|
@ -142,3 +146,33 @@ func (p *Python) pyenvVersion() (string, error) {
|
||||||
}
|
}
|
||||||
return parts[0], nil
|
return parts[0], nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (p *Python) pyvenvCfgPrompt() string {
|
||||||
|
path := p.language.env.CommandPath("python")
|
||||||
|
if len(path) == 0 {
|
||||||
|
path = p.language.env.CommandPath("python3")
|
||||||
|
}
|
||||||
|
if len(path) == 0 {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
pyvenvDir := filepath.Dir(path)
|
||||||
|
if !p.language.env.HasFilesInDir(pyvenvDir, "pyvenv.cfg") {
|
||||||
|
pyvenvDir = filepath.Dir(pyvenvDir)
|
||||||
|
}
|
||||||
|
if !p.language.env.HasFilesInDir(pyvenvDir, "pyvenv.cfg") {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
pyvenvCfg := p.env.FileContent(filepath.Join(pyvenvDir, "pyvenv.cfg"))
|
||||||
|
for _, line := range strings.Split(pyvenvCfg, "\n") {
|
||||||
|
lineSplit := strings.SplitN(line, "=", 2)
|
||||||
|
if len(lineSplit) != 2 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
key := strings.TrimSpace(lineSplit[0])
|
||||||
|
if key == "prompt" {
|
||||||
|
value := strings.TrimSpace(lineSplit[1])
|
||||||
|
return value
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package segments
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
|
"path/filepath"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/jandedobbeleer/oh-my-posh/src/mock"
|
"github.com/jandedobbeleer/oh-my-posh/src/mock"
|
||||||
|
@ -26,6 +27,7 @@ func TestPythonTemplate(t *testing.T) {
|
||||||
FetchVersion bool
|
FetchVersion bool
|
||||||
PythonPath string
|
PythonPath string
|
||||||
ResolveSymlink ResolveSymlink
|
ResolveSymlink ResolveSymlink
|
||||||
|
PyvenvCfg string
|
||||||
}{
|
}{
|
||||||
{Case: "No virtual env present", FetchVersion: true, Expected: "3.8.4", Template: "{{ if .Venv }}{{ .Venv }} {{ end }}{{ .Full }}"},
|
{Case: "No virtual env present", FetchVersion: true, Expected: "3.8.4", Template: "{{ if .Venv }}{{ .Venv }} {{ end }}{{ .Full }}"},
|
||||||
{Case: "Virtual env present", FetchVersion: true, Expected: "VENV 3.8.4", VirtualEnvName: "VENV", Template: "{{ if .Venv }}{{ .Venv }} {{ end }}{{ .Full }}"},
|
{Case: "Virtual env present", FetchVersion: true, Expected: "VENV 3.8.4", VirtualEnvName: "VENV", Template: "{{ if .Venv }}{{ .Venv }} {{ end }}{{ .Full }}"},
|
||||||
|
@ -76,6 +78,15 @@ func TestPythonTemplate(t *testing.T) {
|
||||||
Template: "{{ .Venv }} {{ .Full }}",
|
Template: "{{ .Venv }} {{ .Full }}",
|
||||||
ResolveSymlink: ResolveSymlink{Path: "/home/user/.pyenv/versions/demo", Err: nil},
|
ResolveSymlink: ResolveSymlink{Path: "/home/user/.pyenv/versions/demo", Err: nil},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
Case: "pyvenv.cfg prompt",
|
||||||
|
FetchVersion: true,
|
||||||
|
VirtualEnvName: "VENV",
|
||||||
|
PythonPath: "/home/user/.pyenv/shims/python",
|
||||||
|
Template: "{{ if .Venv }}{{ .Venv }} {{ end }}{{ .Major }}.{{ .Minor }}",
|
||||||
|
PyvenvCfg: "home = /usr/bin/\nprompt = pyvenvCfgPrompt\n",
|
||||||
|
Expected: "pyvenvCfgPrompt 3.8",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tc := range cases {
|
for _, tc := range cases {
|
||||||
|
@ -86,6 +97,8 @@ func TestPythonTemplate(t *testing.T) {
|
||||||
env.On("RunCommand", "python", []string{"--version"}).Return("Python 3.8.4", nil)
|
env.On("RunCommand", "python", []string{"--version"}).Return("Python 3.8.4", nil)
|
||||||
env.On("RunCommand", "pyenv", []string{"version-name"}).Return(tc.VirtualEnvName, nil)
|
env.On("RunCommand", "pyenv", []string{"version-name"}).Return(tc.VirtualEnvName, nil)
|
||||||
env.On("HasFiles", "*.py").Return(true)
|
env.On("HasFiles", "*.py").Return(true)
|
||||||
|
env.On("HasFilesInDir", mock2.Anything, "pyvenv.cfg").Return(len(tc.PyvenvCfg) > 0)
|
||||||
|
env.On("FileContent", filepath.Join(filepath.Dir(tc.PythonPath), "pyvenv.cfg")).Return(tc.PyvenvCfg)
|
||||||
env.On("Getenv", "VIRTUAL_ENV").Return(tc.VirtualEnvName)
|
env.On("Getenv", "VIRTUAL_ENV").Return(tc.VirtualEnvName)
|
||||||
env.On("Getenv", "CONDA_ENV_PATH").Return(tc.VirtualEnvName)
|
env.On("Getenv", "CONDA_ENV_PATH").Return(tc.VirtualEnvName)
|
||||||
env.On("Getenv", "CONDA_DEFAULT_ENV").Return(tc.VirtualEnvName)
|
env.On("Getenv", "CONDA_DEFAULT_ENV").Return(tc.VirtualEnvName)
|
||||||
|
@ -122,6 +135,8 @@ func TestPythonPythonInContext(t *testing.T) {
|
||||||
env := new(mock.MockedEnvironment)
|
env := new(mock.MockedEnvironment)
|
||||||
env.On("GOOS").Return("")
|
env.On("GOOS").Return("")
|
||||||
env.On("PathSeparator").Return("/")
|
env.On("PathSeparator").Return("/")
|
||||||
|
env.On("CommandPath", mock2.Anything).Return("")
|
||||||
|
env.On("HasFilesInDir", mock2.Anything, "pyvenv.cfg").Return(false)
|
||||||
env.On("Getenv", "VIRTUAL_ENV").Return(tc.VirtualEnvName)
|
env.On("Getenv", "VIRTUAL_ENV").Return(tc.VirtualEnvName)
|
||||||
env.On("Getenv", "CONDA_ENV_PATH").Return("")
|
env.On("Getenv", "CONDA_ENV_PATH").Return("")
|
||||||
env.On("Getenv", "CONDA_DEFAULT_ENV").Return("")
|
env.On("Getenv", "CONDA_DEFAULT_ENV").Return("")
|
||||||
|
|
Loading…
Reference in a new issue