vm: optimize IsSignatureContract
We use it a lot in (*Blockchain).IsTxStillRelevant(). name old time/op new time/op delta IsSignatureContract-8 19.1ns ± 5% 1.2ns ± 4% -93.81% (p=0.000 n=10+10) name old alloc/op new alloc/op delta IsSignatureContract-8 0.00B 0.00B ~ (all equal) name old allocs/op new allocs/op delta IsSignatureContract-8 0.00 0.00 ~ (all equal)
This commit is contained in:
parent
92c94f265c
commit
19ad31dc52
2 changed files with 16 additions and 10 deletions
|
@ -48,3 +48,12 @@ func BenchmarkScriptPushPop(t *testing.B) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func BenchmarkIsSignatureContract(t *testing.B) {
|
||||||
|
b64script := "DCED2eixa9myLTNF1tTN4xvhw+HRYVMuPQzOy5Xs4utYM25BVuezJw=="
|
||||||
|
script, err := base64.StdEncoding.DecodeString(b64script)
|
||||||
|
require.NoError(t, err)
|
||||||
|
for n := 0; n < t.N; n++ {
|
||||||
|
_ = IsSignatureContract(script)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -118,18 +118,15 @@ func ParseSignatureContract(script []byte) ([]byte, bool) {
|
||||||
return nil, false
|
return nil, false
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx := NewContext(script)
|
// We don't use Context for this simple case, it's more efficient this way.
|
||||||
instr, param, err := ctx.Next()
|
if script[0] == byte(opcode.PUSHDATA1) && // PUSHDATA1
|
||||||
if err != nil || instr != opcode.PUSHDATA1 || len(param) != 33 {
|
script[1] == 33 && // with a public key parameter
|
||||||
return nil, false
|
script[35] == byte(opcode.SYSCALL) && // and a CheckSig SYSCALL.
|
||||||
|
binary.LittleEndian.Uint32(script[36:]) == verifyInteropID {
|
||||||
|
return script[2:35], true
|
||||||
}
|
}
|
||||||
pub := param
|
|
||||||
instr, param, err = ctx.Next()
|
|
||||||
if err != nil || instr != opcode.SYSCALL || binary.LittleEndian.Uint32(param) != verifyInteropID {
|
|
||||||
return nil, false
|
return nil, false
|
||||||
}
|
}
|
||||||
return pub, true
|
|
||||||
}
|
|
||||||
|
|
||||||
// IsStandardContract checks whether the passed script is a signature or
|
// IsStandardContract checks whether the passed script is a signature or
|
||||||
// multi-signature contract.
|
// multi-signature contract.
|
||||||
|
|
Loading…
Reference in a new issue