Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

allow specifying default columns for each sub command #423

Closed
wants to merge 4 commits into from

Conversation

cedi
Copy link
Contributor

@cedi cedi commented Nov 16, 2022

I am a heavy user of the hcloud-cli. However, I usually change the columns that are displayed and don't like the default and would prefer specifying the default columns used in the config file.
Note: This PR adds on top of the work of #421 and should not be merged
before #421.

Currently, I always type hcloud server list -o 'columns=name,status,ipv6,private_net' to only get the columns that I'm interested in

since the -o flag is part of the list subcommand and not the hcloud base command (like in many other software that makes use of the Cobra framework),
I cannot simply alias hcloud-"hcloud -o 'columns='" in my shell to default the columns.

This commit adds a [defaults] section to the config toml which allows to override the default sorting behavior for individual hcloud subcommands.

The following behavior is used to determine the displayed columns

config file flag result
not-set not-set display default columns
not-set set display -o flag columns
set not-set display config file columns
set set display -o flag columns

@cedi cedi changed the title allow sorting to be configured globally ( #418) allow specifying default columns for each sub command Nov 16, 2022
cedi added 4 commits November 17, 2022 16:00
I am a heavy user of the hcloud-cli. However, I really don't like the
default sorting by server-id, and would prefer sorting by age
(see hetznercloud#417/hetznercloud#420) or name.

Currently, I always type `hcloud server list -s name` to sort by name.

since the `-s` flag is part of the `list` subcommand and not the `hcloud`
base command (like in many other software that makes use of the Cobra
framework), I cannot simply `alias hcloud-"hcloud -s name"` in my shell
to default the sorting to "by name".

This commit adds a `[defaults]` section to the config toml which allows
to override the default sorting behavior for individual `hcloud`
subcommands.

The following behavior is used to determine the sorting-order

| config file | flag    | result               |
|-------------|---------|----------------------|
| not-set     | not-set | sort by id (default) |
| not-set     | set     | sort by flag value   |
| set         | not-set | sort by config value |
| set         | set     | sort by flag value   |
I am a heavy user of the hcloud-cli. However, I usually change the columns that are displayed and don't like the default and would prefer specifying the default columns used in the config file.
Note: This PR adds on top of the work of hetznercloud#421 and should not be merged
before hetznercloud#421.

Currently, I always type `hcloud server list -o 'columns=name,status,ipv6,private_net'` to only get the columns that I'm interested in

since the `-o` flag is part of the `list` subcommand and not the `hcloud` base command (like in many other software that makes use of the Cobra framework),
I cannot simply `alias hcloud-"hcloud -o 'columns='"` in my shell to default the columns.

This commit adds a `[defaults]` section to the config toml which allows to override the default sorting behavior for individual `hcloud` subcommands.

The following behavior is used to determine the displayed columns

| config file | flag    | result                      |
|-------------|---------|-----------------------------|
| not-set     | not-set | display default columns     |
| not-set     | set     | display -o flag columns     |
| set         | not-set | display config file columns |
| set         | set     | display -o flag columns     |
@github-actions
Copy link
Contributor

This PR has been marked as stale because it has not had recent activity. The bot will close the PR if no further action occurs.

@github-actions github-actions bot added the stale label Feb 16, 2023
@apricote apricote removed the stale label Feb 16, 2023
@github-actions
Copy link
Contributor

This PR has been marked as stale because it has not had recent activity. The bot will close the PR if no further action occurs.

@github-actions github-actions bot added the stale label May 18, 2023
@github-actions github-actions bot closed this Jun 18, 2023
@apricote apricote reopened this Jun 19, 2023
@github-actions github-actions bot removed the stale label Jun 19, 2023
@github-actions
Copy link
Contributor

This PR has been marked as stale because it has not had recent activity. The bot will close the PR if no further action occurs.

@github-actions github-actions bot added the stale label Sep 18, 2023
@apricote apricote removed the stale label Sep 18, 2023
Copy link
Contributor

This PR has been marked as stale because it has not had recent activity. The bot will close the PR if no further action occurs.

@github-actions github-actions bot added the stale label Dec 18, 2023
@github-actions github-actions bot closed this Jan 18, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants