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

Default values (again!!) #1003

Open
Zirbo opened this issue Nov 17, 2023 · 7 comments
Open

Default values (again!!) #1003

Zirbo opened this issue Nov 17, 2023 · 7 comments

Comments

@Zirbo
Copy link

Zirbo commented Nov 17, 2023

Hallo,
I know this has been mentioned plenty of times (#462, #165 (comment) and so on) and that you can implement UnmarshalYAML to set your own defaults.
Buuuuuut if you have multiple types of configs, and in each of them just a single field needs a default, implementing UnmarshalYAML in each of them makes your code quite bloated. It really seems complexity that could be hidden in the library itself.
Is something like

type Config struct {
    A string  `string_name, omitempty, default="abc"`
    B int       `int_name, omitempty, default=10`
    C bool    `bool_name, omitempty, default=true`
}

in the roadmap? Or is there some deeper reason (I mean in the code) for this missing feature so it will never be implemented?

@rew1nter
Copy link

rew1nter commented Dec 4, 2023

This would be so nice

@fishjam
Copy link

fishjam commented Jan 5, 2024

I want this feature too.
but seems this project is no longer maintained, there are already 100+ PR pending :(

@MeNsaaH
Copy link

MeNsaaH commented Jan 18, 2024

I believe this fork has been created by k8s maintainers and would can serve for now: kubernetes-sigs/yaml#76

@romshark
Copy link

Or is there some deeper reason (I mean in the code) for this missing feature so it will never be implemented?

The reason is: it's already possible without struct tags.
https://go.dev/play/p/SPwo265oeO2

@Zirbo
Copy link
Author

Zirbo commented May 20, 2024

Or is there some deeper reason (I mean in the code) for this missing feature so it will never be implemented?

The reason is: it's already possible without struct tags. https://go.dev/play/p/SPwo265oeO2

You, my good sir, are amazing. This is not what I wanted, but it's almost as good.

If I ever meet you in person, you will drink as much beer as you want without ever having to touch your wallet.

@Ludmuterol
Copy link

Or is there some deeper reason (I mean in the code) for this missing feature so it will never be implemented?

The reason is: it's already possible without struct tags. go.dev/play/p/SPwo265oeO2

For anyone curious you can absolutely just define the structs as well and then it even works with structs (ie giving them a name instead of doing that anonymous struct definition)
https://go.dev/play/p/KU0o4qgjuD-

@ufukty
Copy link

ufukty commented Dec 18, 2024

the hack only covers one use case of this feature

supplying pre initialized values is impossible if there is unknown number of the container (such as when the struct [which contain fields with default values] are needed to be placed in a slice)

https://go.dev/play/p/lopx3dR5QyP

reproduce: make the Dict type declaration element type. now, you can only supply limited number of them to be overwritten.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

7 participants