summaryrefslogtreecommitdiff
path: root/vendor/github.com/dmacvicar/libvirt-go/interface.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/dmacvicar/libvirt-go/interface.go')
-rw-r--r--vendor/github.com/dmacvicar/libvirt-go/interface.go87
1 files changed, 87 insertions, 0 deletions
diff --git a/vendor/github.com/dmacvicar/libvirt-go/interface.go b/vendor/github.com/dmacvicar/libvirt-go/interface.go
new file mode 100644
index 00000000..60f0c06b
--- /dev/null
+++ b/vendor/github.com/dmacvicar/libvirt-go/interface.go
@@ -0,0 +1,87 @@
+package libvirt
+
+/*
+#cgo LDFLAGS: -lvirt
+#include <libvirt/libvirt.h>
+#include <libvirt/virterror.h>
+#include <stdlib.h>
+*/
+import "C"
+
+import (
+ "unsafe"
+)
+
+type VirInterface struct {
+ ptr C.virInterfacePtr
+}
+
+func (n *VirInterface) Create(flags uint32) error {
+ result := C.virInterfaceCreate(n.ptr, C.uint(flags))
+ if result == -1 {
+ return GetLastError()
+ }
+ return nil
+}
+
+func (n *VirInterface) Destroy(flags uint32) error {
+ result := C.virInterfaceDestroy(n.ptr, C.uint(flags))
+ if result == -1 {
+ return GetLastError()
+ }
+ return nil
+}
+
+func (n *VirInterface) IsActive() (bool, error) {
+ result := C.virInterfaceIsActive(n.ptr)
+ if result == -1 {
+ return false, GetLastError()
+ }
+ if result == 1 {
+ return true, nil
+ }
+ return false, nil
+}
+
+func (n *VirInterface) GetMACString() (string, error) {
+ result := C.virInterfaceGetMACString(n.ptr)
+ if result == nil {
+ return "", GetLastError()
+ }
+ mac := C.GoString(result)
+ return mac, nil
+}
+
+func (n *VirInterface) GetName() (string, error) {
+ result := C.virInterfaceGetName(n.ptr)
+ if result == nil {
+ return "", GetLastError()
+ }
+ name := C.GoString(result)
+ return name, nil
+}
+
+func (n *VirInterface) GetXMLDesc(flags uint32) (string, error) {
+ result := C.virInterfaceGetXMLDesc(n.ptr, C.uint(flags))
+ if result == nil {
+ return "", GetLastError()
+ }
+ xml := C.GoString(result)
+ C.free(unsafe.Pointer(result))
+ return xml, nil
+}
+
+func (n *VirInterface) Undefine() error {
+ result := C.virInterfaceUndefine(n.ptr)
+ if result == -1 {
+ return GetLastError()
+ }
+ return nil
+}
+
+func (n *VirInterface) Free() error {
+ if result := C.virInterfaceFree(n.ptr); result != 0 {
+ return GetLastError()
+ }
+ return nil
+}