Support for optional parts #277

issue sipa openend this issue on July 16, 2015
  1. sipa commented at 11:41 pm on July 16, 2015: contributor

    So far, all pieces of libsecp256k1 functionality have been part of a single offered interface. This made sense as long as all we were doing was implementing a pre-existing ECDSA standard.

    However, there are now a few self-defined algorithms implemented and under review (Schnorr/SHA256, ECDH SHA256, ECDH x-only) and a few more externally maintained patches for extra functionality.

    I wonder what kind of model we want for these. I feel that it’s not optimal to “force” these standards on people using the library for pure ECDSA, but dozens of patch sets is not a maintainable situation either.

    Of course, functionality could be compiled optionally, which is pretty easy because of the library’s all-internal-implementations-is-in-headers, but there would be a question of headers. secp256k1.h could get optional parts, which get macro processed before install time, or (my preference) have separate .h files (secp256k1/ecdsa.h secp256k1/eckey.h secp256k1/schnorr.h, …).

    Opinions? @gmaxwell @apoelstra @peterdettman @theuni @laanwj?

  2. gmaxwell commented at 1:02 am on July 17, 2015: contributor

    I think it’s valuable to try to minimize the options where possible; avoids a testing combination explosion. E.g. do we really need seperate build options for ecdh-X-only and ecdh-sha256.

    If things are setup right then unused parts would be excluded at link time, potentially reducing the impact from unneeded parts, and maybe this would permit having fewer options.

  3. sipa commented at 5:21 pm on July 17, 2015: contributor
    The question is mostly: do we want any optional parts at all, and if so, how do we do that interface-wise?
  4. gmaxwell commented at 6:08 pm on July 17, 2015: contributor
    I think we do– I mean, I don’t thing we want the range proofs in a default build, or PIR protocols or…
  5. sipa commented at 0:35 am on August 28, 2015: contributor
    I think this is now accomplished through #212, #252 and (upcoming) #291.
  6. sipa closed this on Aug 28, 2015


sipa gmaxwell


github-metadata-mirror

This is a metadata mirror of the GitHub repository bitcoin-core/secp256k1. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-24 08:15 UTC

This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me