[API BREAK] Introduce explicit contexts #208
pull sipa wants to merge 1 commits into bitcoin-core:master from sipa:context changing 14 files +342 −277-
sipa commented at 1:27 am on February 4, 2015: contributor
-
DavidEGrayson commented at 2:05 am on February 4, 2015: noneI looked at the changes to the main header file and they look good. I would be tempted to remove the
flags
argument fromsecp256k1_context_create
and just let people use the other functions, since it makes the API surface a bit smaller. -
gmaxwell commented at 2:09 am on February 4, 2015: contributorNeed to worry about some combinatorial blowup, e.g. with each mixture of starting options having a new entry point. (We may have more options in the future). Otherwise I’d be agreeing with that.
-
gmaxwell commented at 2:22 am on February 4, 2015: contributorFor flags. Because if you have six flags or wahtever you might need 2^6 (or more) entriy points otherwise)
-
DavidEGrayson commented at 2:37 am on February 4, 2015: noneYou just need one
secp256k1_context_initialize_*
entry point for each high-level feature, because multiple initialization functions can be called on the same context after it is created. -
gmaxwell commented at 2:42 am on February 4, 2015: contributor
Hm. Doesn’t address the case where it’s cheaper to initilize a&&b than a, b or where b means you throw out what A does, without having a weird interface where some interact and some don’t and some are slower unless you combine them.
Now I don’t know what I prefer. I know I don’t want separate contexts. Since state can potentially be shared (esp in low-mem builds).
-
DavidEGrayson commented at 2:51 am on February 4, 2015: noneYeah, so that would be a good reason to keep the
flags
argument around. -
DavidEGrayson commented at 5:20 pm on February 4, 2015: none
I think the API for creation/initialization could be simplified to just two functions:
0secp256k1_context* secp256k1_context_create(); 1void secp256k1_context_initialize(secp256k1_context* ctx, int flags); // can call multiple times
This allows special optimizations of the initialization process, regardless of when the initialization is performed, without combinatorial blowup of entry points. It makes the API simpler because there would be fewer functions and only one way to enable a feature. (Sorry if I’m missing something and this is just another lame idea for some reason!)
-
sipa commented at 5:41 pm on February 4, 2015: contributorSo there’s a follow-up plan which is probably not obvious here, namely that some initializations may gain parameters (specifically: the size of the tables), which you probably can’t encode as just flags. The explicit initialization functions can then serve as ‘advanced’ versions, while the flagged create_context does defaulty things.
-
sipa cross-referenced this on Feb 13, 2015 from issue secp256k1 benchmarking programs can now accept parameters by midnightmagic
-
sipa cross-referenced this on Feb 13, 2015 from issue Add scalar blinding for ecmult_gen() by gmaxwell
-
sipa cross-referenced this on Feb 13, 2015 from issue enable libsecp256k1_jni shared lib by theuni
-
sipa cross-referenced this on Feb 23, 2015 from issue Initial gcov work by cbatson
-
DavidEGrayson cross-referenced this on Feb 25, 2015 from issue How to use the library? by ShaliDaliHaliDa
-
sipa force-pushed on Mar 2, 2015
-
sipa commented at 10:43 am on March 2, 2015: contributorRebased.
-
sipa force-pushed on Mar 2, 2015
-
sipa commented at 10:48 am on March 2, 2015: contributorAnd rebased again.
-
sipa force-pushed on Mar 16, 2015
-
sipa commented at 10:19 pm on March 16, 2015: contributor
-
sipa force-pushed on Mar 16, 2015
-
sipa commented at 10:38 pm on March 16, 2015: contributorRemoved the per-feature initialization functions for now.
-
sipa force-pushed on Mar 16, 2015
-
sipa force-pushed on Mar 29, 2015
-
sipa commented at 11:14 pm on March 29, 2015: contributorRebased.
-
gmaxwell commented at 3:04 am on April 3, 2015: contributorOkay, I think I’ve run out of nits.
-
sipa force-pushed on Apr 10, 2015
-
sipa commented at 9:03 am on April 10, 2015: contributorNits addressed.
-
gmaxwell commented at 2:43 am on April 11, 2015: contributorWould be nice to brace that IF; either way: ACK.
-
[API BREAK] Introduce explicit contexts a9b6595ef8
-
sipa force-pushed on Apr 11, 2015
-
sipa merged this on Apr 11, 2015
-
sipa closed this on Apr 11, 2015
-
sipa referenced this in commit 3608c7f2f6 on Apr 11, 2015
-
DavidEGrayson cross-referenced this on Apr 12, 2015 from issue Expose ability to deep-copy a context by apoelstra
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
More mirrored repositories can be found on mirror.b10c.me