Consensus: Introduce static GetScriptFlags (mostly MOVEONLY) #10427
pull jtimon wants to merge 1 commits into bitcoin:master from jtimon:b15-consensus-script-flags-min changing 1 files +38 −23-
jtimon commented at 2:36 am on May 19, 2017: contributorThis have been proposed many times with different variations, including #9271 and ancestors, and proposals by @TheBlueMatt ( #10192 ) and @CodeShark (#6747) for example. I think this is something very easy to review and agree with. Regardless of later steps, let’s please take the first step already.
-
Consensus: Introduce static GetScriptFlags (mostly MOVEONLY) 0b3fcd42fc
-
fanquake added the label Refactoring on May 19, 2017
-
fanquake added the label Validation on May 19, 2017
-
TheBlueMatt commented at 0:52 am on June 6, 2017: memberI’m not sold on passing in the VersionBitsCache (which is the primary difference between this and the version at #10192) - why should ConnectBlock even be aware that there is a fancy cache making GetScriptFlags faster?
-
jtimon commented at 12:43 pm on June 7, 2017: contributor
why should ConnectBlock even be aware that there is a fancy cache making GetScriptFlags faster?
Well, GetScriptFlags is aware of it anyway, so at a minimum, I think not calling IsWitnessEnabled from it is very reasonable.
Regarding the question, ConnectBlock should is aware of the global versionbitscache because it uses it though GetScriptFlags, whether we chose to make that dependency explicit or not. But I guess this comes down to me liking globals being used explicitly instead of hidden when possible (and lower level functions that don’t need to use the globals and can use local parameters instead do that instead of using globals they don’t need to depend on). But from past discussions I think you don’t believe there’s anything wrong with using globals when you don’t need them or anything good with functions declaring all their dependencies explicitly as parameters, so I guess I can’t convince you on that.
-
TheBlueMatt commented at 5:09 pm on June 7, 2017: memberGuess its all a personal preference thing - make functions more static and pass globals in from higher up the stack, or put a bit more encapsulation in the lower-level functions and keep the globals only for those functions. I tend to prefer the second, myself, but open to other views.
-
jtimon commented at 5:22 pm on June 7, 2017: contributorThoughts on at least removing the use of IsWitnessEnabled() from your version of the change? That’s just removing the use of an unnecessary wrapper.
-
TheBlueMatt commented at 5:52 pm on June 7, 2017: memberI dont have any strong feelings, but IsWitnessEnabled is a much clearer expression of whats going on, and also keeps duplication of that check to one place, which is nice (especially given all the folks running around doing crazy 148/149/etc implementations).
-
jtimon commented at 9:04 pm on June 7, 2017: contributorWhatever, I guess I can do this changes later if I ever get to the point where I can actually use them. Closing.
-
jtimon closed this on Jun 7, 2017
-
DrahtBot locked this on Sep 8, 2021
Labels
Refactoring
Validation
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2024-12-22 18:12 UTC
More mirrored repositories can be found on mirror.b10c.me