Exemplo n.º 1
0
func (mh *MD5Hash) Write(msg []byte) (n int, err error) {
	size := C.size_t(len(msg))
	if C.MD5_Update(&mh.md5, unsafe.Pointer(C.CString(string(msg))), size) != 1 {
		panic("problem updating hash")
	}
	return len(msg), nil
}
Exemplo n.º 2
0
Arquivo: md5.go Projeto: runcom/gossl
func (d *digest) Write(msg []byte) (n int, err error) {
	size := C.size_t(len(msg))
	if C.MD5_Update(&d.ctx, unsafe.Pointer(C.CString(string(msg))), size) != 1 {
		return 0, sslerr.Error()
	}
	return len(msg), nil
}
Exemplo n.º 3
0
func (d *digest) Write(p []byte) (nn int, err error) {
	if len(p) == 0 || C.MD5_Update(d.context, unsafe.Pointer(&p[0]),
		C.ulong(len(p))) == 1 {
		return len(p), nil
	}

	return 0, errors.New("MD5_Update failed")
}
Exemplo n.º 4
0
func (ctx *MD5Context) Update(data []byte) error {
	if len(data) == 0 {
		return nil
	}
	ret := C.MD5_Update((*C.MD5_CTX)(ctx), unsafe.Pointer(&data[0]), C.size_t(len(data)))
	if ret == 0 {
		return errors.New("Error during MD5 update")
	}

	return nil
}
Exemplo n.º 5
0
func (m *M) Write(data []byte) (n int, err error) {
	n = len(data)
	C.MD5_Update(m.ctx, unsafe.Pointer(&data[0]), C.size_t(n))
	return
}