erigon-pulse/pedersen_hash/hash.go
primal_concrete_sledge c4805e0262
WIP: issue/issue-281-create_binding_to_pedersen_hash (#301)
* issue/issue-281-create_binding_to_pedersen_hash

* Add //nolint

* Add more nolints

* move nolint

* Remove nolit

* Add gcc install

* Upd .ci

* Remove staticcheck

* Add envs

* try to exclude pedersen_hash from test

* try to fix mac os build

* Add include for mac os

* Add include for mac os

* Fix runner_os

* remove test for macos

* Change restrictions

* restrict tests to ubuntu

* Try test windows

* Add build constraint
2022-02-10 14:47:28 +00:00

54 lines
1.1 KiB
Go

// +build linux
package hash
/*
#include <stdlib.h>
#include "hash.h"
*/
import "C"
import (
"encoding/hex"
"fmt"
"unsafe"
)
func reverseHexEndianRepresentation(s string) string {
rns := []rune(s)
for i, j := 0, len(rns)-2; i < j; i, j = i+2, j-2 {
rns[i], rns[j] = rns[j], rns[i]
rns[i+1], rns[j+1] = rns[j+1], rns[i+1]
}
return string(rns)
}
func Hash(input1, input2 string) (string, error) {
input1Dec, _ := hex.DecodeString(reverseHexEndianRepresentation(input1))
input2Dec, _ := hex.DecodeString(reverseHexEndianRepresentation(input2))
in1 := C.CBytes(input1Dec)
in2 := C.CBytes(input2Dec)
var o [1024]byte
out := C.CBytes(o[:])
upIn1 := unsafe.Pointer(in1)
upIn2 := unsafe.Pointer(in2)
upOut := unsafe.Pointer(out)
defer func() {
C.free(upIn1)
C.free(upIn2)
C.free(upOut)
}()
res := C.CHash(
(*C.char)(upIn1),
(*C.char)(upIn2),
(*C.char)(upOut))
if res != 0 {
return "", fmt.Errorf("Pedersen hash encountered an error: %s\n", C.GoBytes(unsafe.Pointer(out), 1024))
}
hashResult := "0x" + reverseHexEndianRepresentation(
hex.EncodeToString(C.GoBytes(unsafe.Pointer(out), 32)))
return hashResult, nil
}