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

Simplify signatures in js.go #45

Open
smoyer64 opened this issue May 28, 2019 · 2 comments
Open

Simplify signatures in js.go #45

smoyer64 opened this issue May 28, 2019 · 2 comments
Labels
question Further information is requested

Comments

@smoyer64
Copy link
Contributor

In PR #41 I talked about simplifying the signatures of several methods in js.go but rejected that as I thought it would be a breaking change. Since then, I've realized that because the first parameter is the same type as the second variadic parameter, the change is not in fact breaking and simplifies the signature of the end-user API.

I'd suggest that the following three method signatures be changed below:

  • From Get(name string, path ...string) to Get(name ...string
  • From Class(class string, path ...string) to Class(class ...string)
  • From (v Value) Get(name string, path ...string) to (v Value) Get(name ...string)

The change to the Class method slightly simplifies the key generation but otherwise the code is pretty much the same. The main benefit is that, having a single parameter, it makes more sense when a nested class is specified. Consider Class("mdc", "chips", "MDCChipSet") as described in my previous example - with the original signature, the class parameter would contain mdc but the actual class (MDCChipSet) being loaded would be the second element of the path slice. With the revised signature, the elements make sense in the order they're provided.

I do realize this is a completely cosmetic change but wanted to present the idea prior to the library reaching 1.0. If it sounds reasonable, I've got a branch I used to test that this could be done simply - assign this to me and I'll clean up that branch and submit a PR.

@dennwc
Copy link
Owner

dennwc commented May 28, 2019

You are totally right about this not being a breaking change.

Although I initially decided to go the string, ...string way to make sure that the compiler catches things like Get() with no arguments. I think this kind of safety precaution may be important for this low-level API.

At the same time, this API only makes sense for the static set of names (consts). For example, if you try to do something like path := []string{...}; v.Get(path...) it won't work, because the call expects the first argument separately. v.Get(path[0], path[1:]...) works though, so it may be a reasonable tradeoff for catching the Get() call (and Class() now) at the compile time instead of runtime.

Still open for the discussion on changing this 🙂

@dennwc dennwc added the question Further information is requested label May 28, 2019
@smoyer64
Copy link
Contributor Author

As I noted ... I just wanted to at least talk about it. One thing I didn't think about was that my test code will currently panic if no arguments are passed (since zero is not a valid index for an empty array). That probably negates the very slight simplification of the implementing code. I guess only real question is whether it's worth making the API simpler in exchange.

I'll leave this up to you ... and there's no hurry either way so we can mull it over as long as you want.

smoyer64 pushed a commit to selesy/dom that referenced this issue Jun 3, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
question Further information is requested
Projects
None yet
Development

No branches or pull requests

2 participants