2014-10-03 17:04:27 -04:00
|
|
|
// Copyright © 2013, 2014, The Go-LXC Authors. All rights reserved.
|
2013-10-28 23:32:39 -04:00
|
|
|
// Use of this source code is governed by a LGPLv2.1
|
|
|
|
|
// license that can be found in the LICENSE file.
|
2013-09-06 01:36:09 -04:00
|
|
|
|
2023-06-20 21:20:07 -04:00
|
|
|
//go:build linux && cgo
|
2014-10-11 16:10:08 -04:00
|
|
|
// +build linux,cgo
|
2013-03-30 12:14:57 -04:00
|
|
|
|
|
|
|
|
package lxc
|
|
|
|
|
|
2013-09-17 21:29:29 -04:00
|
|
|
/*
|
|
|
|
|
#include <stdlib.h>
|
2013-10-11 17:16:41 -04:00
|
|
|
#include <lxc/lxccontainer.h>
|
2013-09-17 21:29:29 -04:00
|
|
|
|
2014-09-28 23:38:35 -04:00
|
|
|
static char** makeCharArray(size_t size) {
|
2014-05-20 19:10:02 -04:00
|
|
|
// caller checks return value
|
2018-09-25 03:00:00 +02:00
|
|
|
return calloc(size, sizeof(char*));
|
2013-09-17 21:29:29 -04:00
|
|
|
}
|
|
|
|
|
|
2014-09-28 23:38:35 -04:00
|
|
|
static void setArrayString(char **array, char *string, size_t n) {
|
2013-09-17 21:29:29 -04:00
|
|
|
array[n] = string;
|
|
|
|
|
}
|
|
|
|
|
|
2014-09-28 23:38:35 -04:00
|
|
|
static void freeCharArray(char **array, size_t size) {
|
|
|
|
|
size_t i;
|
2014-05-20 19:10:02 -04:00
|
|
|
for (i = 0; i < size; i++) {
|
2013-09-17 21:29:29 -04:00
|
|
|
free(array[i]);
|
2014-05-20 19:10:02 -04:00
|
|
|
}
|
2013-09-17 21:29:29 -04:00
|
|
|
free(array);
|
|
|
|
|
}
|
2013-10-11 17:16:41 -04:00
|
|
|
|
2014-09-28 23:38:35 -04:00
|
|
|
static void freeSnapshotArray(struct lxc_snapshot *s, size_t size) {
|
|
|
|
|
size_t i;
|
2013-10-11 17:16:41 -04:00
|
|
|
for (i = 0; i < size; i++) {
|
|
|
|
|
s[i].free(&s[i]);
|
|
|
|
|
}
|
|
|
|
|
free(s);
|
|
|
|
|
}
|
2014-09-28 23:38:35 -04:00
|
|
|
|
|
|
|
|
static size_t getArrayLength(char **array) {
|
|
|
|
|
char **p;
|
|
|
|
|
size_t size = 0;
|
|
|
|
|
for (p = (char **)array; *p; p++) {
|
|
|
|
|
size++;
|
|
|
|
|
}
|
|
|
|
|
return size;
|
|
|
|
|
}
|
2013-09-17 21:29:29 -04:00
|
|
|
*/
|
2013-03-30 12:14:57 -04:00
|
|
|
import "C"
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"unsafe"
|
|
|
|
|
)
|
|
|
|
|
|
2013-10-30 17:21:42 -04:00
|
|
|
func makeNullTerminatedArgs(args []string) **C.char {
|
2014-09-28 23:38:35 -04:00
|
|
|
cparams := C.makeCharArray(C.size_t(len(args) + 1))
|
2014-05-20 19:10:02 -04:00
|
|
|
if cparams == nil {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
2014-09-28 23:38:35 -04:00
|
|
|
for i := 0; i < len(args); i++ {
|
|
|
|
|
C.setArrayString(cparams, C.CString(args[i]), C.size_t(i))
|
2013-10-30 17:21:42 -04:00
|
|
|
}
|
2014-09-28 23:38:35 -04:00
|
|
|
C.setArrayString(cparams, nil, C.size_t(len(args)))
|
2014-05-20 19:10:02 -04:00
|
|
|
|
2013-10-30 17:21:42 -04:00
|
|
|
return cparams
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func freeNullTerminatedArgs(cArgs **C.char, length int) {
|
2014-09-28 23:38:35 -04:00
|
|
|
C.freeCharArray(cArgs, C.size_t(length+1))
|
2013-10-30 17:21:42 -04:00
|
|
|
}
|
|
|
|
|
|
2013-09-17 21:29:29 -04:00
|
|
|
func convertArgs(cArgs **C.char) []string {
|
|
|
|
|
if cArgs == nil {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
2014-09-28 23:38:35 -04:00
|
|
|
return convertNArgs(cArgs, int(C.getArrayLength(cArgs)))
|
2013-03-30 12:14:57 -04:00
|
|
|
}
|
2013-10-11 17:16:41 -04:00
|
|
|
|
2013-10-15 18:06:42 -04:00
|
|
|
func convertNArgs(cArgs **C.char, size int) []string {
|
|
|
|
|
if cArgs == nil || size <= 0 {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
2021-03-23 15:49:32 -04:00
|
|
|
tmpslice := (*[(1 << 29) - 1]*C.char)(unsafe.Pointer(cArgs))[:size:size]
|
2014-09-28 23:38:35 -04:00
|
|
|
result := make([]string, size)
|
2021-03-22 17:52:51 -04:00
|
|
|
for i, s := range tmpslice {
|
|
|
|
|
result[i] = C.GoString(s)
|
2014-09-28 23:38:35 -04:00
|
|
|
}
|
|
|
|
|
return result
|
2013-10-15 18:06:42 -04:00
|
|
|
}
|
|
|
|
|
|
2013-10-11 17:16:41 -04:00
|
|
|
func freeSnapshots(snapshots *C.struct_lxc_snapshot, size int) {
|
2014-09-28 23:38:35 -04:00
|
|
|
C.freeSnapshotArray(snapshots, C.size_t(size))
|
2013-10-11 17:16:41 -04:00
|
|
|
}
|