summaryrefslogtreecommitdiff
path: root/vendor/github.com/dmacvicar/libvirt-go/nwfilter.go
diff options
context:
space:
mode:
authorFlavio Castelli <fcastelli@suse.com>2017-05-03 11:37:08 +0200
committerAlvaro <alvaro.saurin@gmail.com>2017-05-03 11:40:31 +0200
commitee12004ab93e54f326896e9909ba9e6a2bd11e89 (patch)
tree1ea30d204b04425ebd1dadaf8cc991d572c7f0fb /vendor/github.com/dmacvicar/libvirt-go/nwfilter.go
parenta286dc5494691c2b04c48ef6695ed0c902912c0f (diff)
downloadterraform-provider-libvirt-ee12004ab93e54f326896e9909ba9e6a2bd11e89.tar
terraform-provider-libvirt-ee12004ab93e54f326896e9909ba9e6a2bd11e89.tar.gz
Vendor dependencies with vndr
This fixes issue #123
Diffstat (limited to 'vendor/github.com/dmacvicar/libvirt-go/nwfilter.go')
-rw-r--r--vendor/github.com/dmacvicar/libvirt-go/nwfilter.go70
1 files changed, 70 insertions, 0 deletions
diff --git a/vendor/github.com/dmacvicar/libvirt-go/nwfilter.go b/vendor/github.com/dmacvicar/libvirt-go/nwfilter.go
new file mode 100644
index 00000000..d196f02f
--- /dev/null
+++ b/vendor/github.com/dmacvicar/libvirt-go/nwfilter.go
@@ -0,0 +1,70 @@
+package libvirt
+
+/*
+#cgo LDFLAGS: -lvirt
+#include <libvirt/libvirt.h>
+#include <libvirt/virterror.h>
+#include <stdlib.h>
+*/
+import "C"
+
+import (
+ "unsafe"
+)
+
+type VirNWFilter struct {
+ ptr C.virNWFilterPtr
+}
+
+func (f *VirNWFilter) Free() error {
+ if result := C.virNWFilterFree(f.ptr); result != 0 {
+ return GetLastError()
+ }
+ return nil
+}
+
+func (f *VirNWFilter) GetName() (string, error) {
+ name := C.virNWFilterGetName(f.ptr)
+ if name == nil {
+ return "", GetLastError()
+ }
+ return C.GoString(name), nil
+}
+
+func (f *VirNWFilter) Undefine() error {
+ result := C.virNWFilterUndefine(f.ptr)
+ if result == -1 {
+ return GetLastError()
+ }
+ return nil
+}
+
+func (f *VirNWFilter) GetUUID() ([]byte, error) {
+ var cUuid [C.VIR_UUID_BUFLEN](byte)
+ cuidPtr := unsafe.Pointer(&cUuid)
+ result := C.virNWFilterGetUUID(f.ptr, (*C.uchar)(cuidPtr))
+ if result != 0 {
+ return []byte{}, GetLastError()
+ }
+ return C.GoBytes(cuidPtr, C.VIR_UUID_BUFLEN), nil
+}
+
+func (f *VirNWFilter) GetUUIDString() (string, error) {
+ var cUuid [C.VIR_UUID_STRING_BUFLEN](C.char)
+ cuidPtr := unsafe.Pointer(&cUuid)
+ result := C.virNWFilterGetUUIDString(f.ptr, (*C.char)(cuidPtr))
+ if result != 0 {
+ return "", GetLastError()
+ }
+ return C.GoString((*C.char)(cuidPtr)), nil
+}
+
+func (f *VirNWFilter) GetXMLDesc(flags uint32) (string, error) {
+ result := C.virNWFilterGetXMLDesc(f.ptr, C.uint(flags))
+ if result == nil {
+ return "", GetLastError()
+ }
+ xml := C.GoString(result)
+ C.free(unsafe.Pointer(result))
+ return xml, nil
+}