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

Stabalization - roadmap to v1.0 #43

Open
tcharding opened this issue Nov 1, 2023 · 9 comments
Open

Stabalization - roadmap to v1.0 #43

tcharding opened this issue Nov 1, 2023 · 9 comments
Labels
1.0 Issues and PRs required or helping to stabilize the API

Comments

@tcharding
Copy link
Member

tcharding commented Nov 1, 2023

Tracking issue for what is needed for us to be able to stabalize the hex-conservative crate.

TODO

@tcharding tcharding added the 1.0 Issues and PRs required or helping to stabilize the API label Nov 6, 2023
@tcharding
Copy link
Member Author

@Kixunil can we come up with a list of things that need doing and get it done?

@Kixunil
Copy link
Collaborator

Kixunil commented Sep 4, 2024

At minimum:

  • Remove core2
  • Fix error APIs
  • Multi error support (if we still want it, I personally do but I'm now questioning if it should be global)
  • Consider cleaning up the buffer stuff (IIRC it doesn't need to be exposed anymore).
  • Go over the API guidelines checklist
  • Do a final review of the API.

@apoelstra
Copy link
Member

  • Multi error support (if we still want it, I personally do but I'm now questioning if it should be global)

I don't think we want this. It would be a huge job, incur a ton of complexity to make it nostd/noalloc-compatible in a nonbreaking way, has limited value (if the user is providing invalid hex there are a small number of likely culprits, none of which would benefit from seeing multiple error locations), and also I've literally never seen multi-error support on hex decoding in any user-facing software I've used.

@tcharding
Copy link
Member Author

BufEncoder is used in rust-bitcoin but only in test code, we could remove that?

@Kixunil
Copy link
Collaborator

Kixunil commented Sep 5, 2024

I don't think we want this. It would be a huge job, incur a ton of complexity

I've already done it before, it's not too bad.

make it nostd/noalloc-compatible

It only requires alloc, not std and would be obviously feature gated.

none of which would benefit from seeing multiple error locations

Making multiple typos is certainly realistic scenario. If we assume this library is only used for long hashes then it's quite reasonable to expect that people won't type them but I'd at least expect people accidentally copying whitespace before/after the value.

I've literally never seen multi-error support on hex decoding in any user-facing software I've used.

That doesn't mean such software should never be built. I find seeing multiple errors from rustc/gcc very helpful (unless one causes another which sadly is true) yet I've never seen those in Turbo Pascal... I have long-term plans to improve things in this area in various applications.

BufEncoder is used in rust-bitcoin but only in test code, we could remove that?

Yes, IDK what those tests use BufEncoder for but them existing sounds sus and it's possible that they should just use arrayvec::ArrayString instead.

@apoelstra
Copy link
Member

If you're willing to do the work, including to close the error types sufficiently that they present the same API with or without multi-error support, I suppose I'll review and ACK it.

But I don't see how "it's very useful seeing multiple errors in compilation of tens of thousands of lines" implies "it's useful at all to see multiple errors in fewer than ten characters" (with more than ten the data is almost certainly copy/pasted and errors are either "wrong paste" or "crap at the beginning/end" neither of which need any error indication beyond "invalid hex"). I suspect in practice this will just be extra noise. But it's easy for users of the library to just ignore the extra information so no harm done.

@Kixunil
Copy link
Collaborator

Kixunil commented Sep 5, 2024

OK. It'll be almost invisible to those who don't use it. The only difference is they'll have to use a method to access the enum. (We could also have a field but it makes no real difference.)

@tcharding
Copy link
Member Author

We are starting to get close to 1.0'ing this crate. @Kixunil it would be great to get your acknowledgement before we do but since primitives 1.0 requires hex to be stable we cannot wait indefinitely. Posting this here and also I'll email you, how about we can give you 3 months from now.

@tcharding
Copy link
Member Author

BufEncoder is used in rust-bitcoin but only in test code, we could remove that?

This comment is incorrect. We use BufEncoder in consensus::serde::hex.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
1.0 Issues and PRs required or helping to stabilize the API
Projects
None yet
Development

No branches or pull requests

3 participants