Open Quantumplation opened 1 year ago
As far as we can tell, there's no way to opt-out of this new compiler to produce contracts that work on main net.
Is the recommendation still to use 1.3.0, or is there some other best practice that I'm missing?
Try
{-# OPTIONS_GHC -fplugin-opt PlutusTx.Plugin:target-version=1.0.0 #-}
in the file that you want to compile or update ghc-options
in the .cabal
file of your project to include
-fplugin-opt PlutusTx.Plugin:target-version=1.0.0
Ooo, that looks like exactly what I'm looking for @effectfully, I'll give it a try. Sorry I missed it; Is that documented somewhere?
Is that documented somewhere?
It's mentioned on https://plutus.readthedocs.io in Plutus Tx Compiler Options.
Sorry I missed it;
No problem at all, we do welcome and appreciate questions, requests, reports etc.
BTW, if you think we could improve discoverability of the plugin options, we'd be interested in any ideas.
Please let us know if using target-version=1.0.0
helped.
@effectfully tentatively, it seems like that worked!
As for discoverability, I have a few suggestions:
migration guide
would be a godsend, focusing on
Also, ideally these flags would be the default, with new versions of the compiler opt-in until they produce scripts that would be valid on mainnet.
Thanks again for the help!
@Quantumplation this is fantastic feedback, thank you very much. I'll pass it to the team and make sure we address it (probably not very soon, unfortunately).
@effectfully tentatively, it seems like that worked!
Great, glad it seemed to help. Please do report if something doesn't work as expected.
With any release that introduces breaking changes, a migration guide
We have a changelog but it's indeed quite far from providing any sort of migration guide.
Also, ideally these flags would be the default, with new versions of the compiler opt-in until they produce scripts that would be valid on mainnet.
Well, that's a really good point indeed!
Generally speaking, our users do ask questions like "how can I be sure that what works now will keep working in future?" and we don't have any answer to that, so I believe we definitely need to prioritize making transitioning from one Plutus/ledger version to another easier, otherwise we're going to keep breaking things and annoying everybody with that.
Thanks again for the help!
Thanks for all the extremely helpful feedback!
I'm going to keep the ticket open at the very least until we have a strategy of addressing the points that you've raised.
Summary
We're working on porting PlutusV1 contracts to PlutusV2; but when compiling these new contracts using the latest
main
branch, it produces scripts with the version prefix010100
, which I assume is the new version with sum-of-products terms; it also means it produces UPLC with these unrecognized terms ("Unknown term constructor tag: 8.")As far as we can tell, there's no way to opt-out of this new compiler to produce contracts that work on main net.
Is the recommendation still to use 1.3.0, or is there some other best practice that I'm missing?
Steps to reproduce the behavior
main
Actual Result
584e0101000033222222800245209b4e9e9af27b5dfa4d383be20535b94b16f4c0aa00ddc4b1ea4391396518bb500048811c000000000000000000000000000000000000000000000000000000000001
Expected Result
Plutus v1 and v2 scripts should compile succesfully for mainnet use; or there should be some way to specify the version of the VM / Compiler to use.
Describe the approach you would take to fix this
No response
System info
N/A