diff options
author | David Sommerseth <davids@redhat.com> | 2010-04-28 20:26:59 +0200 |
---|---|---|
committer | David Sommerseth <davids@redhat.com> | 2010-04-28 20:26:59 +0200 |
commit | 5efffc01353311b73625cc4731ef66333ed550de (patch) | |
tree | 4ddc61836262827d53bc0be0a64cefd72d9efc40 | |
parent | 70957dc6941f3e9122cbc3996e3ec393759fd876 (diff) | |
download | python-ethtool-5efffc01353311b73625cc4731ef66333ed550de.tar.gz python-ethtool-5efffc01353311b73625cc4731ef66333ed550de.tar.xz python-ethtool-5efffc01353311b73625cc4731ef66333ed550de.zip |
Clean up - avoid static variables in etherinfo_obj.h
-rw-r--r-- | python-ethtool/etherinfo_obj.c | 79 | ||||
-rw-r--r-- | python-ethtool/etherinfo_obj.h | 79 | ||||
-rw-r--r-- | python-ethtool/ethtool.c | 1 |
3 files changed, 80 insertions, 79 deletions
diff --git a/python-ethtool/etherinfo_obj.c b/python-ethtool/etherinfo_obj.c index a20ed6b..b408a88 100644 --- a/python-ethtool/etherinfo_obj.c +++ b/python-ethtool/etherinfo_obj.c @@ -188,3 +188,82 @@ PyObject *_ethtool_etherinfo_str(etherinfo_py *self) } return ret; } + + +/** + * This is required by Python, which lists all accessible methods + * in the object. But no methods are provided. + * + */ +static PyMethodDef _ethtool_etherinfo_methods[] = { + {NULL} /**< No methods defined */ +}; + +/** + * Defines all accessible object members + * + */ +static PyMemberDef _ethtool_etherinfo_members[] = { + {"device", T_OBJECT_EX, offsetof(etherinfo_py, data), 0, + "Device name of the interface"}, + {"mac_address", T_OBJECT_EX, offsetof(etherinfo_py, data), 0, + "MAC address / hardware address of the interface"}, + {"ipv4_address", T_OBJECT_EX, offsetof(etherinfo_py, data), 0, + "IPv4 address"}, + {"ipv4_netmask", T_INT, offsetof(etherinfo_py, data), 0, + "IPv4 netmask in bits"}, + {"ipv4_broadcast", T_OBJECT_EX, offsetof(etherinfo_py, data), 0, + "IPv4 broadcast address"}, + {"ipv6_address", T_OBJECT_EX, offsetof(etherinfo_py, data), 0, + "IPv6 address"}, + {"ipv6_netmask", T_INT, offsetof(etherinfo_py, data), 0, + "IPv6 netmask in bits"}, + {NULL} /* End of member list */ +}; + +/** + * Definition of the functions a Python class/object requires. + * + */ +PyTypeObject ethtool_etherinfoType = { + PyObject_HEAD_INIT(NULL) + 0, /*ob_size*/ + "ethtool.etherinfo", /*tp_name*/ + sizeof(etherinfo_py), /*tp_basicsize*/ + 0, /*tp_itemsize*/ + (destructor)_ethtool_etherinfo_dealloc,/*tp_dealloc*/ + 0, /*tp_print*/ + 0, /*tp_getattr*/ + 0, /*tp_setattr*/ + 0, /*tp_compare*/ + 0, /*tp_repr*/ + 0, /*tp_as_number*/ + 0, /*tp_as_sequence*/ + 0, /*tp_as_mapping*/ + 0, /*tp_hash */ + 0, /*tp_call*/ + (reprfunc)_ethtool_etherinfo_str, /*tp_str*/ + (getattrofunc)_ethtool_etherinfo_getter, /*tp_getattro*/ + (setattrofunc)_ethtool_etherinfo_setter, /*tp_setattro*/ + 0, /*tp_as_buffer*/ + Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /*tp_flags*/ + "Contains information about a specific ethernet device", /* tp_doc */ + 0, /* tp_traverse */ + 0, /* tp_clear */ + 0, /* tp_richcompare */ + 0, /* tp_weaklistoffset */ + 0, /* tp_iter */ + 0, /* tp_iternext */ + _ethtool_etherinfo_methods, /* tp_methods */ + _ethtool_etherinfo_members, /* tp_members */ + 0, /* tp_getset */ + 0, /* tp_base */ + 0, /* tp_dict */ + 0, /* tp_descr_get */ + 0, /* tp_descr_set */ + 0, /* tp_dictoffset */ + (initproc)_ethtool_etherinfo_init, /* tp_init */ + 0, /* tp_alloc */ + _ethtool_etherinfo_new, /* tp_new */ +}; + diff --git a/python-ethtool/etherinfo_obj.h b/python-ethtool/etherinfo_obj.h index 340dea8..ed63383 100644 --- a/python-ethtool/etherinfo_obj.h +++ b/python-ethtool/etherinfo_obj.h @@ -11,8 +11,6 @@ #define __ETHERINFO_OBJ_H #include <Python.h> -#include "structmember.h" -#include "etherinfo.h" #include "etherinfo_struct.h" void _ethtool_etherinfo_dealloc(etherinfo_py *); @@ -22,81 +20,4 @@ PyObject *_ethtool_etherinfo_getter(etherinfo_py *, PyObject *); int _ethtool_etherinfo_setter(etherinfo_py *, PyObject *, PyObject *); PyObject *_ethtool_etherinfo_str(etherinfo_py *self); -/** - * This is required by Python, which lists all accessible methods - * in the object. But no methods are provided. - * - */ -static PyMethodDef _ethtool_etherinfo_methods[] = { - {NULL} /**< No methods defined */ -}; - -/** - * Defines all accessible object members - * - */ -static PyMemberDef _ethtool_etherinfo_members[] = { - {"device", T_OBJECT_EX, offsetof(etherinfo_py, data), 0, - "Device name of the interface"}, - {"mac_address", T_OBJECT_EX, offsetof(etherinfo_py, data), 0, - "MAC address / hardware address of the interface"}, - {"ipv4_address", T_OBJECT_EX, offsetof(etherinfo_py, data), 0, - "IPv4 address"}, - {"ipv4_netmask", T_INT, offsetof(etherinfo_py, data), 0, - "IPv4 netmask in bits"}, - {"ipv4_broadcast", T_OBJECT_EX, offsetof(etherinfo_py, data), 0, - "IPv4 broadcast address"}, - {"ipv6_address", T_OBJECT_EX, offsetof(etherinfo_py, data), 0, - "IPv6 address"}, - {"ipv6_netmask", T_INT, offsetof(etherinfo_py, data), 0, - "IPv6 netmask in bits"}, - {NULL} /* End of member list */ -}; - -/** - * Definition of the functions a Python class/object requires. - * - */ -PyTypeObject ethtool_etherinfoType = { - PyObject_HEAD_INIT(NULL) - 0, /*ob_size*/ - "ethtool.etherinfo", /*tp_name*/ - sizeof(etherinfo_py), /*tp_basicsize*/ - 0, /*tp_itemsize*/ - (destructor)_ethtool_etherinfo_dealloc,/*tp_dealloc*/ - 0, /*tp_print*/ - 0, /*tp_getattr*/ - 0, /*tp_setattr*/ - 0, /*tp_compare*/ - 0, /*tp_repr*/ - 0, /*tp_as_number*/ - 0, /*tp_as_sequence*/ - 0, /*tp_as_mapping*/ - 0, /*tp_hash */ - 0, /*tp_call*/ - (reprfunc)_ethtool_etherinfo_str, /*tp_str*/ - (getattrofunc)_ethtool_etherinfo_getter, /*tp_getattro*/ - (setattrofunc)_ethtool_etherinfo_setter, /*tp_setattro*/ - 0, /*tp_as_buffer*/ - Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /*tp_flags*/ - "Contains information about a specific ethernet device", /* tp_doc */ - 0, /* tp_traverse */ - 0, /* tp_clear */ - 0, /* tp_richcompare */ - 0, /* tp_weaklistoffset */ - 0, /* tp_iter */ - 0, /* tp_iternext */ - _ethtool_etherinfo_methods, /* tp_methods */ - _ethtool_etherinfo_members, /* tp_members */ - 0, /* tp_getset */ - 0, /* tp_base */ - 0, /* tp_dict */ - 0, /* tp_descr_get */ - 0, /* tp_descr_set */ - 0, /* tp_dictoffset */ - (initproc)_ethtool_etherinfo_init, /* tp_init */ - 0, /* tp_alloc */ - _ethtool_etherinfo_new, /* tp_new */ -}; - #endif diff --git a/python-ethtool/ethtool.c b/python-ethtool/ethtool.c index 04d37ca..85c4737 100644 --- a/python-ethtool/ethtool.c +++ b/python-ethtool/ethtool.c @@ -31,6 +31,7 @@ #include "etherinfo.h" static struct _nlconnection nlconnection; +extern PyTypeObject ethtool_etherinfoType; #ifndef IFF_DYNAMIC #define IFF_DYNAMIC 0x8000 /* dialup device with changing addresses*/ |