Choose fields to display with -o flag
This commit is contained in:
parent
eebc7da169
commit
4eeb6d0d99
@ -189,7 +189,8 @@ func displayStructFields(jails []Jail, valsToDisplay []string) {
|
|||||||
/* Get Jails from datastores. Store config and running metadata into gJails global var */
|
/* Get Jails from datastores. Store config and running metadata into gJails global var */
|
||||||
func ListJails(args []string, display bool) {
|
func ListJails(args []string, display bool) {
|
||||||
//fields := []string{"JID", "Name", "Config.Release", "Config.Ip4_addr", "RootPath", "Running", "Config.Jail_zfs", "Config.Jail_zfs_dataset", "Zpool"}
|
//fields := []string{"JID", "Name", "Config.Release", "Config.Ip4_addr", "RootPath", "Running", "Config.Jail_zfs", "Config.Jail_zfs_dataset", "Zpool"}
|
||||||
fields := []string{"JID", "Name", "Config.Release", "Config.Ip4_addr", "Running", "Zpool"}
|
//fields := []string{"JID", "Name", "Config.Release", "Config.Ip4_addr", "Running", "Zpool"}
|
||||||
|
fields := strings.Split(gDisplayColumns, ",")
|
||||||
|
|
||||||
for _, d := range viper.GetStringSlice("datastore") {
|
for _, d := range viper.GetStringSlice("datastore") {
|
||||||
listJailsFromDatastore(d)
|
listJailsFromDatastore(d)
|
||||||
|
13
cmd/root.go
13
cmd/root.go
@ -19,6 +19,8 @@ var (
|
|||||||
gUseSudo bool
|
gUseSudo bool
|
||||||
|
|
||||||
gConfigFile string
|
gConfigFile string
|
||||||
|
gDisplayColumns string
|
||||||
|
|
||||||
|
|
||||||
rootCmd = & cobra.Command{
|
rootCmd = & cobra.Command{
|
||||||
Use: "gocage",
|
Use: "gocage",
|
||||||
@ -73,8 +75,8 @@ func init() {
|
|||||||
rootCmd.PersistentFlags().BoolVarP(&gUseSudo, "sudo", "s", false, "Use sudo to run commands")
|
rootCmd.PersistentFlags().BoolVarP(&gUseSudo, "sudo", "s", false, "Use sudo to run commands")
|
||||||
|
|
||||||
// Command dependant switches
|
// Command dependant switches
|
||||||
/* listComputerCmd.PersistentFlags().BoolVarP(&gDisplayAsCSV, "csv-format", "v", false, "Show results in CSV (separator = ';')")
|
listCmd.PersistentFlags().StringVarP(&gDisplayColumns, "outcol", "o", "JID,Name,Config.Release,Config.Ip4_addr,Running", "Show these columns in output")
|
||||||
searchComputerCmd.PersistentFlags().BoolVarP(&gShowAccount, "show-account", "c", false, "Show account when listing computer")
|
/* searchComputerCmd.PersistentFlags().BoolVarP(&gShowAccount, "show-account", "c", false, "Show account when listing computer")
|
||||||
searchComputerCmd.PersistentFlags().BoolVarP(&gDisplayAsCSV, "csv-format", "v", false, "Show results in CSV (separator = ';')")
|
searchComputerCmd.PersistentFlags().BoolVarP(&gDisplayAsCSV, "csv-format", "v", false, "Show results in CSV (separator = ';')")
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -102,8 +104,15 @@ func initConfig() {
|
|||||||
// fmt.Println("Using config file:", viper.ConfigFileUsed())
|
// fmt.Println("Using config file:", viper.ConfigFileUsed())
|
||||||
// fmt.Printf("datastore in config : %s\n", viper.GetStringSlice("datastore"))
|
// fmt.Printf("datastore in config : %s\n", viper.GetStringSlice("datastore"))
|
||||||
// fmt.Printf("datastore.0 in config : %s\n", viper.GetStringSlice("datastore.0"))
|
// fmt.Printf("datastore.0 in config : %s\n", viper.GetStringSlice("datastore.0"))
|
||||||
|
|
||||||
|
// Command line flags have priority on config file
|
||||||
|
if false == rootCmd.Flags().Lookup("sudo").Changed {
|
||||||
gUseSudo = viper.GetBool("sudo")
|
gUseSudo = viper.GetBool("sudo")
|
||||||
}
|
}
|
||||||
|
if false == listCmd.Flags().Lookup("outcol").Changed {
|
||||||
|
gDisplayColumns = viper.GetString("outcol")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func Execute() {
|
func Execute() {
|
||||||
if err := rootCmd.Execute(); err != nil {
|
if err := rootCmd.Execute(); err != nil {
|
||||||
|
@ -3,3 +3,7 @@ datastore:
|
|||||||
- /iocage
|
- /iocage
|
||||||
|
|
||||||
sudo: false
|
sudo: false
|
||||||
|
|
||||||
|
# Columns to display when "gocage list". Column names are struct fields, see cmd/struct.go
|
||||||
|
outcol: 'JID,Name,Config.Release,Config.Ip4_addr,Running'
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user