Ho un semplice test runner per il bug che è nel mio modulo OpenPGP https://github.com/singpolyma/OpenPGP-Haskell/blob/master/Data/OpenPGP.hs:Perché questo codice si comporta diversamente con le optomisations attivate o disattivate?
module Main where
import Data.OpenPGP
import Data.Binary (encode, decode)
packet = EmbeddedSignaturePacket (signaturePacket 2 168 ECDSA SHA256 [] [SignatureCreationTimePacket 1013401916,IssuerPacket "36FE856F4219F1C7"] 48065 [MPI 4,MPI 11,MPI 60,MPI 69,MPI 37,MPI 33,MPI 18,MPI 72,MPI 41,MPI 36,MPI 43,MPI 41,MPI 53,MPI 9,MPI 53,MPI 35,MPI 3,MPI 40,MPI 14,MPI 79,MPI 1,MPI 4,MPI 51,MPI 23,MPI 62,MPI 62,MPI 62,MPI 7,MPI 68,MPI 51,MPI 13,MPI 49,MPI 8,MPI 64,MPI 32,MPI 50,MPI 59,MPI 17,MPI 43,MPI 12,MPI 67,MPI 5,MPI 67,MPI 5,MPI 25,MPI 63,MPI 0,MPI 53,MPI 2,MPI 36,MPI 83,MPI 39,MPI 54,MPI 65,MPI 54,MPI 35,MPI 62,MPI 63,MPI 26,MPI 4,MPI 82,MPI 57,MPI 85,MPI 71,MPI 43,MPI 77])
main = print $ decode (encode packet) == packet
Se si compila questo (su GHC 7.4.1) con:
ghc -O0 -fforce-recomp --make t.hs
Esso funziona come previsto (vale a dire, la stampa True
), ma se si compila in questo modo:
ghc -O1 -fforce-recomp --make t.hs
o questo:
ghc -O2 -fforce-recomp --make t.hs
Stampa False
.
Non sto usando alcuna estensione (eccetto un uso banale di CPP) o chiamate di basso livello o non sicure, e il comportamento dovrebbe provenire dalla mia libreria e non da una dipendenza, poiché è solo il mio codice che viene ricompilato qui .
Posso riprodurre questo errore in GHC 7.4.2 –
Stai usando il binario o il cereale quando osservi questo errore? –