mirror of
https://github.com/golang/go
synced 2024-11-17 12:24:51 -07:00
5a34472d74
Add a C.CBytes function to copy a Go byte slice into C memory. This returns an unsafe.Pointer, since that is what needs to be passed to C.free, and the data is often opaque bytes anyway. Fixes #14838 Change-Id: Ic7bc29637eb6f1f5ee409b3898c702a59833a85a Reviewed-on: https://go-review.googlesource.com/20762 Reviewed-by: Ian Lance Taylor <iant@golang.org>
38 lines
705 B
Go
38 lines
705 B
Go
// Copyright 2016 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// Issue 14838. add CBytes function
|
|
|
|
package cgotest
|
|
|
|
/*
|
|
#include <stdlib.h>
|
|
|
|
int check_cbytes(char *b, size_t l) {
|
|
int i;
|
|
for (i = 0; i < l; i++) {
|
|
if (b[i] != i) {
|
|
return 0;
|
|
}
|
|
}
|
|
return 1;
|
|
}
|
|
*/
|
|
import "C"
|
|
|
|
import (
|
|
"testing"
|
|
"unsafe"
|
|
)
|
|
|
|
func test14838(t *testing.T) {
|
|
data := []byte{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
|
|
cData := C.CBytes(data)
|
|
defer C.free(cData)
|
|
|
|
if C.check_cbytes((*C.char)(cData), C.size_t(len(data))) == 0 {
|
|
t.Fatalf("mismatched data: expected %v, got %v", data, (*(*[10]byte)(unsafe.Pointer(cData)))[:])
|
|
}
|
|
}
|