2024-08-25 04:08:24 +00:00
|
|
|
package qt
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
|
|
#include "gen_qcryptographichash.h"
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
*/
|
|
|
|
import "C"
|
|
|
|
|
|
|
|
import (
|
|
|
|
"runtime"
|
|
|
|
"unsafe"
|
|
|
|
)
|
|
|
|
|
2024-09-04 06:54:22 +00:00
|
|
|
type QCryptographicHash__Algorithm int
|
|
|
|
|
|
|
|
const (
|
|
|
|
QCryptographicHash__Algorithm__Md4 QCryptographicHash__Algorithm = 0
|
|
|
|
QCryptographicHash__Algorithm__Md5 QCryptographicHash__Algorithm = 1
|
|
|
|
QCryptographicHash__Algorithm__Sha1 QCryptographicHash__Algorithm = 2
|
|
|
|
QCryptographicHash__Algorithm__Sha224 QCryptographicHash__Algorithm = 3
|
|
|
|
QCryptographicHash__Algorithm__Sha256 QCryptographicHash__Algorithm = 4
|
|
|
|
QCryptographicHash__Algorithm__Sha384 QCryptographicHash__Algorithm = 5
|
|
|
|
QCryptographicHash__Algorithm__Sha512 QCryptographicHash__Algorithm = 6
|
|
|
|
QCryptographicHash__Algorithm__Keccak_224 QCryptographicHash__Algorithm = 7
|
|
|
|
QCryptographicHash__Algorithm__Keccak_256 QCryptographicHash__Algorithm = 8
|
|
|
|
QCryptographicHash__Algorithm__Keccak_384 QCryptographicHash__Algorithm = 9
|
|
|
|
QCryptographicHash__Algorithm__Keccak_512 QCryptographicHash__Algorithm = 10
|
|
|
|
QCryptographicHash__Algorithm__RealSha3_224 QCryptographicHash__Algorithm = 11
|
|
|
|
QCryptographicHash__Algorithm__RealSha3_256 QCryptographicHash__Algorithm = 12
|
|
|
|
QCryptographicHash__Algorithm__RealSha3_384 QCryptographicHash__Algorithm = 13
|
|
|
|
QCryptographicHash__Algorithm__RealSha3_512 QCryptographicHash__Algorithm = 14
|
|
|
|
QCryptographicHash__Algorithm__Sha3_224 QCryptographicHash__Algorithm = 11
|
|
|
|
QCryptographicHash__Algorithm__Sha3_256 QCryptographicHash__Algorithm = 12
|
|
|
|
QCryptographicHash__Algorithm__Sha3_384 QCryptographicHash__Algorithm = 13
|
|
|
|
QCryptographicHash__Algorithm__Sha3_512 QCryptographicHash__Algorithm = 14
|
|
|
|
)
|
|
|
|
|
2024-08-25 04:08:24 +00:00
|
|
|
type QCryptographicHash struct {
|
|
|
|
h *C.QCryptographicHash
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *QCryptographicHash) cPointer() *C.QCryptographicHash {
|
|
|
|
if this == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return this.h
|
|
|
|
}
|
|
|
|
|
|
|
|
func newQCryptographicHash(h *C.QCryptographicHash) *QCryptographicHash {
|
2024-09-01 02:23:55 +00:00
|
|
|
if h == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2024-08-25 04:08:24 +00:00
|
|
|
return &QCryptographicHash{h: h}
|
|
|
|
}
|
|
|
|
|
|
|
|
func newQCryptographicHash_U(h unsafe.Pointer) *QCryptographicHash {
|
|
|
|
return newQCryptographicHash((*C.QCryptographicHash)(h))
|
|
|
|
}
|
|
|
|
|
2024-08-29 07:01:51 +00:00
|
|
|
// NewQCryptographicHash constructs a new QCryptographicHash object.
|
2024-09-04 06:54:22 +00:00
|
|
|
func NewQCryptographicHash(method QCryptographicHash__Algorithm) *QCryptographicHash {
|
2024-08-29 07:01:51 +00:00
|
|
|
ret := C.QCryptographicHash_new((C.uintptr_t)(method))
|
|
|
|
return newQCryptographicHash(ret)
|
|
|
|
}
|
|
|
|
|
2024-08-25 04:08:24 +00:00
|
|
|
func (this *QCryptographicHash) Reset() {
|
|
|
|
C.QCryptographicHash_Reset(this.h)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *QCryptographicHash) AddData(data string, length int) {
|
|
|
|
data_Cstring := C.CString(data)
|
|
|
|
defer C.free(unsafe.Pointer(data_Cstring))
|
|
|
|
C.QCryptographicHash_AddData(this.h, data_Cstring, (C.int)(length))
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *QCryptographicHash) AddDataWithData(data *QByteArray) {
|
|
|
|
C.QCryptographicHash_AddDataWithData(this.h, data.cPointer())
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *QCryptographicHash) AddDataWithDevice(device *QIODevice) bool {
|
2024-09-14 22:29:05 +00:00
|
|
|
_ret := C.QCryptographicHash_AddDataWithDevice(this.h, device.cPointer())
|
|
|
|
return (bool)(_ret)
|
2024-08-25 04:08:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (this *QCryptographicHash) Result() *QByteArray {
|
2024-09-14 22:29:05 +00:00
|
|
|
_ret := C.QCryptographicHash_Result(this.h)
|
|
|
|
_goptr := newQByteArray(_ret)
|
|
|
|
_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
|
|
|
return _goptr
|
2024-08-25 04:08:24 +00:00
|
|
|
}
|
|
|
|
|
2024-09-04 06:54:22 +00:00
|
|
|
func QCryptographicHash_Hash(data *QByteArray, method QCryptographicHash__Algorithm) *QByteArray {
|
2024-09-14 22:29:05 +00:00
|
|
|
_ret := C.QCryptographicHash_Hash(data.cPointer(), (C.uintptr_t)(method))
|
|
|
|
_goptr := newQByteArray(_ret)
|
|
|
|
_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
|
|
|
return _goptr
|
2024-08-29 07:01:51 +00:00
|
|
|
}
|
|
|
|
|
2024-09-04 06:54:22 +00:00
|
|
|
func QCryptographicHash_HashLength(method QCryptographicHash__Algorithm) int {
|
2024-09-14 22:29:05 +00:00
|
|
|
_ret := C.QCryptographicHash_HashLength((C.uintptr_t)(method))
|
|
|
|
return (int)(_ret)
|
2024-08-29 07:01:51 +00:00
|
|
|
}
|
|
|
|
|
2024-09-14 22:29:05 +00:00
|
|
|
// Delete this object from C++ memory.
|
2024-08-25 04:08:24 +00:00
|
|
|
func (this *QCryptographicHash) Delete() {
|
|
|
|
C.QCryptographicHash_Delete(this.h)
|
|
|
|
}
|
2024-09-14 22:29:05 +00:00
|
|
|
|
|
|
|
// GoGC adds a Go Finalizer to this pointer, so that it will be deleted
|
|
|
|
// from C++ memory once it is unreachable from Go memory.
|
|
|
|
func (this *QCryptographicHash) GoGC() {
|
|
|
|
runtime.SetFinalizer(this, func(this *QCryptographicHash) {
|
|
|
|
this.Delete()
|
|
|
|
runtime.KeepAlive(this.h)
|
|
|
|
})
|
|
|
|
}
|