On Sat, Feb 18, 2023 at 01:28:38AM +0000, Andrew Poelstra wrote: > On Sat, Feb 18, 2023 at 02:03:15AM +0200, Peter Todd wrote: > > On February 18, 2023 1:35:34 AM GMT+02:00, Andrew Poelstra via bitcoin-dev > > >You could try statically analyze `` to determine whether the > > >IF branch could ever be taken. For example there is no path through > > >the "inscription script" that would result in all the crap being dropped > > >by the end of the script, violating the CLEANSTACK rule. > > > > > >This sort of filtering, assuming it could be reliably and efficiently > > >done, would at least force inscription scripts to be "plausible", and > > >would greatly increase their space cost by e.g. requiring OP_DROP to be > > >added somewhere hundreds of times. > > > > "greatly increase their space cost"? > > > > Tell me, what is the actual % increase to adding OP_DROPs like you propose? > > > > By standardness rules (where you can have up to 80-byte pushes), a > little over 1%. By consensus (520-byte pushes) less than 0.2%. > > Perhaps "greatly increase" is a stretch :) but if the fee market is > functioning and we're talking about large amounts of data, it's not > trivial either. I would definitely call ~1% trivial. Fees vary more by that on an hour to hour basis. Anyway, it goes to show that protocols relying on data embedded in Bitcoin transactions would do well to have flexible encoding rules, eg by considering all PUSHDATA's with certain characteristics to be data, so that encoders can be adapted on the fly if there are any censorship issues. It's also useful if the rules allow data to be encoded in UTXO outputs, so that censorship of witness data always risks people switching to filling up the UTXO set. A kind of Mutually Assured Destruction threat in a way. FWIW, OpenTimestamps was deliberately designed to have this property. So don't mess with it. :D -- https://petertodd.org 'peter'[:-1]@petertodd.org