env: introduce Env() factory and jpictl env -e to export variables
#2
+10
-1
@@ -16,10 +16,19 @@ var envCmd = &cobra.Command{
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return m.WriteEnv(os.Stdout)
|
_, err = m.Env(*envExport).WriteTo(os.Stdout)
|
||||||
|
return err
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Command Flags
|
||||||
|
var (
|
||||||
|
envExport *bool
|
||||||
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
rootCmd.AddCommand(envCmd)
|
rootCmd.AddCommand(envCmd)
|
||||||
|
|
||||||
|
envExport = envCmd.PersistentFlags().BoolP("export", "e", false,
|
||||||
|
"export generated variables")
|
||||||
}
|
}
|
||||||
|
|||||||
+34
-12
@@ -7,8 +7,23 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
// WriteEnv generates environment variables for shell scripts
|
// Env is a shell environment factory for this cluster
|
||||||
func (m *Zones) WriteEnv(w io.Writer) error {
|
type Env struct {
|
||||||
|
ZoneIterator
|
||||||
|
|
||||||
|
export bool
|
||||||
|
}
|
||||||
|
|
||||||
|
// Env returns a shell environment factory
|
||||||
|
func (m *Zones) Env(export bool) *Env {
|
||||||
|
return &Env{
|
||||||
|
ZoneIterator: m,
|
||||||
|
export: export,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// WriteTo generates environment variables for shell scripts
|
||||||
|
func (m *Env) WriteTo(w io.Writer) (int64, error) {
|
||||||
var buf bytes.Buffer
|
var buf bytes.Buffer
|
||||||
|
|
||||||
m.writeEnvVarFn(&buf, genEnvZones, "ZONES")
|
m.writeEnvVarFn(&buf, genEnvZones, "ZONES")
|
||||||
@@ -17,11 +32,10 @@ func (m *Zones) WriteEnv(w io.Writer) error {
|
|||||||
return false
|
return false
|
||||||
})
|
})
|
||||||
|
|
||||||
_, err := buf.WriteTo(w)
|
return buf.WriteTo(w)
|
||||||
return err
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Zones) writeEnvZone(w io.Writer, z *Zone) {
|
func (m *Env) writeEnvZone(w io.Writer, z *Zone) {
|
||||||
zoneID := z.ID
|
zoneID := z.ID
|
||||||
|
|
||||||
// ZONE{zoneID}
|
// ZONE{zoneID}
|
||||||
@@ -42,7 +56,7 @@ func (m *Zones) writeEnvZone(w io.Writer, z *Zone) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Zones) writeEnvVarFn(w io.Writer, fn func(*Zones) string, name string, args ...any) {
|
func (m *Env) writeEnvVarFn(w io.Writer, fn func(*Env) string, name string, args ...any) {
|
||||||
var value string
|
var value string
|
||||||
|
|
||||||
if fn != nil {
|
if fn != nil {
|
||||||
@@ -52,7 +66,13 @@ func (m *Zones) writeEnvVarFn(w io.Writer, fn func(*Zones) string, name string,
|
|||||||
m.writeEnvVar(w, value, name, args...)
|
m.writeEnvVar(w, value, name, args...)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (*Zones) writeEnvVar(w io.Writer, value string, name string, args ...any) {
|
func (m *Env) writeEnvVar(w io.Writer, value string, name string, args ...any) {
|
||||||
|
var prefix string
|
||||||
|
|
||||||
|
if m.export {
|
||||||
|
prefix = "export "
|
||||||
|
}
|
||||||
|
|
||||||
if len(args) > 0 {
|
if len(args) > 0 {
|
||||||
name = fmt.Sprintf(name, args...)
|
name = fmt.Sprintf(name, args...)
|
||||||
}
|
}
|
||||||
@@ -60,15 +80,17 @@ func (*Zones) writeEnvVar(w io.Writer, value string, name string, args ...any) {
|
|||||||
if name != "" {
|
if name != "" {
|
||||||
value = strings.TrimSpace(value)
|
value = strings.TrimSpace(value)
|
||||||
|
|
||||||
_, _ = fmt.Fprintf(w, "%s=%q\n", name, value)
|
_, _ = fmt.Fprintf(w, "%s%s=%q\n", prefix, name, value)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func genEnvZones(m *Zones) string {
|
func genEnvZones(m *Env) string {
|
||||||
s := make([]string, 0, len(m.Zones))
|
var s []string
|
||||||
for _, z := range m.Zones {
|
|
||||||
|
m.ForEachZone(func(z *Zone) bool {
|
||||||
s = append(s, fmt.Sprintf("%v", z.ID))
|
s = append(s, fmt.Sprintf("%v", z.ID))
|
||||||
}
|
return false
|
||||||
|
})
|
||||||
|
|
||||||
return strings.Join(s, " ")
|
return strings.Join(s, " ")
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user