2012-10-12 02:08:47 +01:00
/*
* Liblvm - - Python interface to LVM2 API .
*
2013-06-18 15:13:27 -04:00
* Copyright ( C ) 2010 , 2013 Red Hat , Inc . All rights reserved .
2012-10-12 02:08:47 +01:00
*
* This program is free software : you can redistribute it and / or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation , either version 2.1 of the License , or
* ( at your option ) any later version .
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU Lesser General Public License for more details .
* You should have received a copy of the GNU Lesser General Public License
* along with this program . If not , see < http : //www.gnu.org/licenses/>.
*
* Authors : Lars Sjostrom ( lars sjostrom redhat com )
* Andy Grover ( agrover redhat com )
* Tony Asleson ( tasleson redhat com )
*/
# include <Python.h>
# include "lvm2app.h"
2012-10-15 13:26:01 -07:00
static lvm_t libh ;
2012-10-12 02:08:47 +01:00
typedef struct {
PyObject_HEAD
2012-12-14 10:32:35 -08:00
vg_t vg ; /* vg handle */
2012-10-12 02:08:47 +01:00
} vgobject ;
2013-03-19 17:37:04 -04:00
typedef struct {
PyObject_HEAD
struct dm_list * pvslist ;
} pvslistobject ;
2012-10-12 02:08:47 +01:00
typedef struct {
PyObject_HEAD
2012-12-14 10:32:35 -08:00
lv_t lv ; /* lv handle */
vgobject * parent_vgobj ;
2012-10-12 02:08:47 +01:00
} lvobject ;
typedef struct {
PyObject_HEAD
2012-12-14 10:32:35 -08:00
pv_t pv ; /* pv handle */
vgobject * parent_vgobj ;
2013-03-19 17:37:04 -04:00
pvslistobject * parent_pvslistobj ;
2012-10-12 02:08:47 +01:00
} pvobject ;
typedef struct {
PyObject_HEAD
2012-12-14 10:32:35 -08:00
lvseg_t lv_seg ; /* lv segment handle */
lvobject * parent_lvobj ;
2012-10-12 02:08:47 +01:00
} lvsegobject ;
typedef struct {
PyObject_HEAD
2012-12-14 10:32:35 -08:00
pvseg_t pv_seg ; /* pv segment handle */
pvobject * parent_pvobj ;
2012-10-12 02:08:47 +01:00
} pvsegobject ;
static PyTypeObject LibLVMvgType ;
static PyTypeObject LibLVMlvType ;
2013-03-19 17:37:04 -04:00
static PyTypeObject LibLVMpvlistType ;
2012-10-12 02:08:47 +01:00
static PyTypeObject LibLVMpvType ;
static PyTypeObject LibLVMlvsegType ;
static PyTypeObject LibLVMpvsegType ;
static PyObject * LibLVMError ;
2012-10-15 13:26:01 -07:00
# define LVM_VALID() \
2012-10-12 02:08:47 +01:00
do { \
2012-10-15 13:26:01 -07:00
if ( ! libh ) { \
PyErr_SetString ( PyExc_UnboundLocalError , " LVM handle invalid " ) ; \
2012-10-12 02:08:47 +01:00
return NULL ; \
} \
} while ( 0 )
2013-06-18 15:13:27 -04:00
/**
* Ensure that we initialize all the bits to a sane state .
*/
static pvobject
* create_py_pv ( void )
{
pvobject * pvobj = PyObject_New ( pvobject , & LibLVMpvType ) ;
if ( pvobj ) {
pvobj - > pv = NULL ;
pvobj - > parent_vgobj = NULL ;
pvobj - > parent_pvslistobj = NULL ;
}
return pvobj ;
}
static vgobject
* create_py_vg ( void )
{
vgobject * vgobj = PyObject_New ( vgobject , & LibLVMvgType ) ;
if ( vgobj ) {
vgobj - > vg = NULL ;
}
return vgobj ;
}
2012-10-12 02:08:47 +01:00
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_get_last_error ( void )
2012-10-12 02:08:47 +01:00
{
PyObject * info ;
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
2012-10-15 13:34:43 -07:00
if ( ( info = PyTuple_New ( 2 ) ) = = NULL )
2012-10-12 02:08:47 +01:00
return NULL ;
2012-10-15 13:26:01 -07:00
PyTuple_SetItem ( info , 0 , PyInt_FromLong ( ( long ) lvm_errno ( libh ) ) ) ;
PyTuple_SetItem ( info , 1 , PyString_FromString ( lvm_errmsg ( libh ) ) ) ;
2012-10-12 02:08:47 +01:00
return info ;
}
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_library_get_version ( void )
2012-10-12 02:08:47 +01:00
{
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
return Py_BuildValue ( " s " , lvm_library_get_version ( ) ) ;
}
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_lvm_list_vg_names ( void )
2012-10-12 02:08:47 +01:00
{
struct dm_list * vgnames ;
struct lvm_str_list * strl ;
PyObject * pytuple ;
int i = 0 ;
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
2012-10-15 13:26:01 -07:00
vgnames = lvm_list_vg_names ( libh ) ;
2012-10-12 02:08:47 +01:00
if ( ! vgnames ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
pytuple = PyTuple_New ( dm_list_size ( vgnames ) ) ;
if ( ! pytuple )
return NULL ;
dm_list_iterate_items ( strl , vgnames ) {
PyTuple_SET_ITEM ( pytuple , i , PyString_FromString ( strl - > str ) ) ;
i + + ;
}
return pytuple ;
}
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_lvm_list_vg_uuids ( void )
2012-10-12 02:08:47 +01:00
{
struct dm_list * uuids ;
struct lvm_str_list * strl ;
PyObject * pytuple ;
int i = 0 ;
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
2012-10-15 13:26:01 -07:00
uuids = lvm_list_vg_uuids ( libh ) ;
2012-10-12 02:08:47 +01:00
if ( ! uuids ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
pytuple = PyTuple_New ( dm_list_size ( uuids ) ) ;
if ( ! pytuple )
return NULL ;
dm_list_iterate_items ( strl , uuids ) {
PyTuple_SET_ITEM ( pytuple , i , PyString_FromString ( strl - > str ) ) ;
i + + ;
}
return pytuple ;
}
2013-03-19 17:37:04 -04:00
static PyObject *
liblvm_lvm_pvlist_get ( pvslistobject * pvsobj )
{
struct lvm_pv_list * pvl ;
PyObject * pytuple ;
pvobject * pvobj ;
int i = 0 ;
/* unlike other LVM api calls, if there are no results, we get NULL */
pvsobj - > pvslist = lvm_list_pvs ( libh ) ;
if ( ! pvsobj - > pvslist )
return Py_BuildValue ( " () " ) ;
pytuple = PyTuple_New ( dm_list_size ( pvsobj - > pvslist ) ) ;
if ( ! pytuple )
return NULL ;
dm_list_iterate_items ( pvl , pvsobj - > pvslist ) {
/* Create and initialize the object */
2013-06-18 15:13:27 -04:00
pvobj = create_py_pv ( ) ;
2013-03-19 17:37:04 -04:00
if ( ! pvobj ) {
Py_DECREF ( pytuple ) ;
return NULL ;
}
/* We don't have a parent vg object to be concerned about */
pvobj - > parent_vgobj = NULL ;
pvobj - > parent_pvslistobj = pvsobj ;
Py_INCREF ( pvobj - > parent_pvslistobj ) ;
pvobj - > pv = pvl - > pv ;
PyTuple_SET_ITEM ( pytuple , i , ( PyObject * ) pvobj ) ;
i + + ;
}
return pytuple ;
}
static PyObject *
liblvm_lvm_pvlist_put ( pvslistobject * self )
{
int rc = 0 ;
if ( self - > pvslist ) {
rc = lvm_list_pvs_free ( self - > pvslist ) ;
if ( 0 ! = rc ) {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
return NULL ;
}
self - > pvslist = NULL ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
return NULL ;
}
static PyObject *
liblvm_pvlist_dealloc ( pvslistobject * self )
{
if ( self - > pvslist ) {
liblvm_lvm_pvlist_put ( self ) ;
}
PyObject_Del ( self ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
liblvm_lvm_list_pvs ( void )
{
pvslistobject * pvslistobj ;
LVM_VALID ( ) ;
if ( ( pvslistobj = PyObject_New ( pvslistobject , & LibLVMpvlistType ) ) = = NULL )
return NULL ;
pvslistobj - > pvslist = NULL ;
return ( PyObject * ) pvslistobj ;
}
2013-04-02 16:10:57 -04:00
static PyObject *
liblvm_lvm_pv_remove ( PyObject * self , PyObject * arg )
{
const char * pv_name ;
LVM_VALID ( ) ;
if ( ! PyArg_ParseTuple ( arg , " s " , & pv_name ) )
return NULL ;
int rc = lvm_pv_remove ( libh , pv_name ) ;
if ( 0 ! = rc ) {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2013-04-03 17:54:12 -04:00
static PyObject *
liblvm_lvm_pv_create ( PyObject * self , PyObject * arg )
{
const char * pv_name ;
uint64_t size ;
LVM_VALID ( ) ;
if ( ! PyArg_ParseTuple ( arg , " sl " , & pv_name , & size ) )
return NULL ;
int rc = lvm_pv_create ( libh , pv_name , size ) ;
if ( 0 ! = rc ) {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2012-10-12 02:08:47 +01:00
static PyObject *
2012-10-23 14:50:14 -05:00
liblvm_lvm_percent_to_float ( PyObject * self , PyObject * arg )
2012-10-12 02:08:47 +01:00
{
double converted ;
int percent ;
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
if ( ! PyArg_ParseTuple ( arg , " i " , & percent ) )
return NULL ;
converted = lvm_percent_to_float ( percent ) ;
return Py_BuildValue ( " d " , converted ) ;
}
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_lvm_vgname_from_pvid ( PyObject * self , PyObject * arg )
2012-10-12 02:08:47 +01:00
{
const char * pvid ;
const char * vgname ;
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
if ( ! PyArg_ParseTuple ( arg , " s " , & pvid ) )
return NULL ;
2012-10-15 13:34:43 -07:00
if ( ( vgname = lvm_vgname_from_pvid ( libh , pvid ) ) = = NULL ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
return Py_BuildValue ( " s " , vgname ) ;
}
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_lvm_vgname_from_device ( PyObject * self , PyObject * arg )
2012-10-12 02:08:47 +01:00
{
const char * device ;
const char * vgname ;
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
if ( ! PyArg_ParseTuple ( arg , " s " , & device ) )
return NULL ;
2012-10-15 13:34:43 -07:00
if ( ( vgname = lvm_vgname_from_device ( libh , device ) ) = = NULL ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
return Py_BuildValue ( " s " , vgname ) ;
}
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_lvm_config_find_bool ( PyObject * self , PyObject * arg )
2012-10-12 02:08:47 +01:00
{
const char * config ;
int rval ;
PyObject * rc ;
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
if ( ! PyArg_ParseTuple ( arg , " s " , & config ) )
return NULL ;
2012-10-15 13:26:01 -07:00
if ( ( rval = lvm_config_find_bool ( libh , config , - 10 ) ) = = - 10 ) {
2012-10-12 02:08:47 +01:00
/* Retrieving error information yields no error in this case */
PyErr_Format ( PyExc_ValueError , " config path not found " ) ;
return NULL ;
}
rc = ( rval ) ? Py_True : Py_False ;
Py_INCREF ( rc ) ;
return rc ;
}
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_lvm_config_reload ( void )
2012-10-12 02:08:47 +01:00
{
int rval ;
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
2012-10-15 13:34:43 -07:00
if ( ( rval = lvm_config_reload ( libh ) ) = = - 1 ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_lvm_scan ( void )
2012-10-12 02:08:47 +01:00
{
int rval ;
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
2012-10-15 13:34:43 -07:00
if ( ( rval = lvm_scan ( libh ) ) = = - 1 ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_lvm_config_override ( PyObject * self , PyObject * arg )
2012-10-12 02:08:47 +01:00
{
const char * config ;
int rval ;
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
if ( ! PyArg_ParseTuple ( arg , " s " , & config ) )
return NULL ;
2012-10-15 13:26:01 -07:00
if ( ( rval = lvm_config_override ( libh , config ) ) = = - 1 ) {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
/* ----------------------------------------------------------------------
* VG object initialization / deallocation
*/
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_lvm_vg_open ( PyObject * self , PyObject * args )
2012-10-12 02:08:47 +01:00
{
const char * vgname ;
const char * mode = NULL ;
2012-10-15 13:26:01 -07:00
vgobject * vgobj ;
2012-10-12 02:08:47 +01:00
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
if ( ! PyArg_ParseTuple ( args , " s|s " , & vgname , & mode ) ) {
return NULL ;
}
if ( mode = = NULL )
mode = " r " ;
2013-06-18 15:13:27 -04:00
if ( ( vgobj = create_py_vg ( ) ) = = NULL )
2012-10-12 02:08:47 +01:00
return NULL ;
2012-10-15 13:26:01 -07:00
if ( ( vgobj - > vg = lvm_vg_open ( libh , vgname , mode , 0 ) ) = = NULL ) {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-25 17:31:11 -05:00
Py_DECREF ( vgobj ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
2012-10-15 13:26:01 -07:00
return ( PyObject * ) vgobj ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_lvm_vg_create ( PyObject * self , PyObject * args )
2012-10-12 02:08:47 +01:00
{
const char * vgname ;
2012-10-15 13:26:01 -07:00
vgobject * vgobj ;
2012-10-12 02:08:47 +01:00
2012-10-15 13:26:01 -07:00
LVM_VALID ( ) ;
2012-10-12 02:08:47 +01:00
if ( ! PyArg_ParseTuple ( args , " s " , & vgname ) ) {
return NULL ;
}
2013-06-18 15:13:27 -04:00
if ( ( vgobj = create_py_vg ( ) ) = = NULL )
2012-10-12 02:08:47 +01:00
return NULL ;
2012-10-15 13:26:01 -07:00
if ( ( vgobj - > vg = lvm_vg_create ( libh , vgname ) ) = = NULL ) {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-25 17:31:11 -05:00
Py_DECREF ( vgobj ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
2012-10-15 13:26:01 -07:00
return ( PyObject * ) vgobj ;
2012-10-12 02:08:47 +01:00
}
static void
liblvm_vg_dealloc ( vgobject * self )
{
/* if already closed, don't reclose it */
2013-06-18 15:13:27 -04:00
if ( self - > vg ! = NULL ) {
2012-10-12 02:08:47 +01:00
lvm_vg_close ( self - > vg ) ;
2013-06-18 15:13:27 -04:00
self - > vg = NULL ;
}
2012-10-12 02:08:47 +01:00
PyObject_Del ( self ) ;
}
/* VG Methods */
# define VG_VALID(vgobject) \
do { \
2012-10-17 12:55:25 -07:00
LVM_VALID ( ) ; \
2012-10-12 02:08:47 +01:00
if ( ! vgobject - > vg ) { \
PyErr_SetString ( PyExc_UnboundLocalError , " VG object invalid " ) ; \
return NULL ; \
} \
} while ( 0 )
2013-03-19 17:37:04 -04:00
# define PVSLIST_VALID(pvslistobject) \
do { \
LVM_VALID ( ) ; \
if ( ! pvslistobject - > pvslist ) { \
PyErr_SetString ( PyExc_UnboundLocalError , " PVS object invalid " ) ; \
return NULL ; \
} \
} while ( 0 )
2012-10-12 02:08:47 +01:00
static PyObject *
liblvm_lvm_vg_close ( vgobject * self )
{
/* if already closed, don't reclose it */
if ( self - > vg ! = NULL )
lvm_vg_close ( self - > vg ) ;
self - > vg = NULL ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
liblvm_lvm_vg_get_name ( vgobject * self )
{
VG_VALID ( self ) ;
return Py_BuildValue ( " s " , lvm_vg_get_name ( self - > vg ) ) ;
}
static PyObject *
liblvm_lvm_vg_get_uuid ( vgobject * self )
{
VG_VALID ( self ) ;
return Py_BuildValue ( " s " , lvm_vg_get_uuid ( self - > vg ) ) ;
}
static PyObject *
liblvm_lvm_vg_remove ( vgobject * self )
{
int rval ;
VG_VALID ( self ) ;
if ( ( rval = lvm_vg_remove ( self - > vg ) ) = = - 1 )
goto error ;
if ( lvm_vg_write ( self - > vg ) = = - 1 )
goto error ;
2012-10-25 17:31:11 -05:00
/* Not much you can do with a vg that is removed so close it */
if ( lvm_vg_close ( self - > vg ) = = - 1 )
goto error ;
2012-10-12 02:08:47 +01:00
self - > vg = NULL ;
Py_INCREF ( Py_None ) ;
return Py_None ;
error :
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
static PyObject *
liblvm_lvm_vg_extend ( vgobject * self , PyObject * args )
{
const char * device ;
int rval ;
VG_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " s " , & device ) ) {
return NULL ;
}
if ( ( rval = lvm_vg_extend ( self - > vg , device ) ) = = - 1 )
goto error ;
if ( lvm_vg_write ( self - > vg ) = = - 1 )
goto error ;
Py_INCREF ( Py_None ) ;
return Py_None ;
error :
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
static PyObject *
liblvm_lvm_vg_reduce ( vgobject * self , PyObject * args )
{
const char * device ;
int rval ;
VG_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " s " , & device ) ) {
return NULL ;
}
if ( ( rval = lvm_vg_reduce ( self - > vg , device ) ) = = - 1 )
goto error ;
if ( lvm_vg_write ( self - > vg ) = = - 1 )
goto error ;
Py_INCREF ( Py_None ) ;
return Py_None ;
error :
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
static PyObject *
liblvm_lvm_vg_add_tag ( vgobject * self , PyObject * args )
{
const char * tag ;
int rval ;
VG_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " s " , & tag ) ) {
return NULL ;
}
if ( ( rval = lvm_vg_add_tag ( self - > vg , tag ) ) = = - 1 )
goto error ;
if ( lvm_vg_write ( self - > vg ) = = - 1 )
goto error ;
return Py_BuildValue ( " i " , rval ) ;
error :
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
static PyObject *
liblvm_lvm_vg_remove_tag ( vgobject * self , PyObject * args )
{
const char * tag ;
int rval ;
VG_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " s " , & tag ) ) {
return NULL ;
}
if ( ( rval = lvm_vg_remove_tag ( self - > vg , tag ) ) = = - 1 )
goto error ;
if ( lvm_vg_write ( self - > vg ) = = - 1 )
goto error ;
Py_INCREF ( Py_None ) ;
return Py_None ;
error :
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
static PyObject *
liblvm_lvm_vg_is_clustered ( vgobject * self )
{
PyObject * rval ;
VG_VALID ( self ) ;
rval = ( lvm_vg_is_clustered ( self - > vg ) = = 1 ) ? Py_True : Py_False ;
Py_INCREF ( rval ) ;
return rval ;
}
static PyObject *
liblvm_lvm_vg_is_exported ( vgobject * self )
{
PyObject * rval ;
VG_VALID ( self ) ;
rval = ( lvm_vg_is_exported ( self - > vg ) = = 1 ) ? Py_True : Py_False ;
Py_INCREF ( rval ) ;
return rval ;
}
static PyObject *
liblvm_lvm_vg_is_partial ( vgobject * self )
{
PyObject * rval ;
VG_VALID ( self ) ;
rval = ( lvm_vg_is_partial ( self - > vg ) = = 1 ) ? Py_True : Py_False ;
Py_INCREF ( rval ) ;
return rval ;
}
static PyObject *
liblvm_lvm_vg_get_seqno ( vgobject * self )
{
VG_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_vg_get_seqno ( self - > vg ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_vg_get_size ( vgobject * self )
{
VG_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_vg_get_size ( self - > vg ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_vg_get_free_size ( vgobject * self )
{
VG_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_vg_get_free_size ( self - > vg ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_vg_get_extent_size ( vgobject * self )
{
VG_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_vg_get_extent_size ( self - > vg ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_vg_get_extent_count ( vgobject * self )
{
VG_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_vg_get_extent_count ( self - > vg ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_vg_get_free_extent_count ( vgobject * self )
{
VG_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_vg_get_free_extent_count ( self - > vg ) ) ;
2012-10-12 02:08:47 +01:00
}
/* Builds a python tuple ([string|number], bool) from a struct lvm_property_value */
static PyObject *
2012-10-15 13:26:01 -07:00
get_property ( struct lvm_property_value * prop )
2012-10-12 02:08:47 +01:00
{
PyObject * pytuple ;
PyObject * setable ;
2012-10-15 13:34:43 -07:00
if ( ! prop - > is_valid ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
pytuple = PyTuple_New ( 2 ) ;
if ( ! pytuple )
return NULL ;
2012-10-15 13:34:43 -07:00
if ( prop - > is_integer ) {
2012-10-12 02:08:47 +01:00
PyTuple_SET_ITEM ( pytuple , 0 , Py_BuildValue ( " K " , prop - > value . integer ) ) ;
} else {
PyTuple_SET_ITEM ( pytuple , 0 , PyString_FromString ( prop - > value . string ) ) ;
}
if ( prop - > is_settable ) {
setable = Py_True ;
} else {
setable = Py_False ;
}
Py_INCREF ( setable ) ;
PyTuple_SET_ITEM ( pytuple , 1 , setable ) ;
return pytuple ;
}
/* This will return a tuple of (value, bool) with the value being a string or
integer and bool indicating if property is settable */
static PyObject *
2012-12-14 10:32:35 -08:00
liblvm_lvm_vg_get_property ( vgobject * self , PyObject * args )
2012-10-12 02:08:47 +01:00
{
const char * name ;
struct lvm_property_value prop_value ;
VG_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " s " , & name ) )
return NULL ;
prop_value = lvm_vg_get_property ( self - > vg , name ) ;
2012-10-15 13:26:01 -07:00
return get_property ( & prop_value ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
2012-12-14 10:32:35 -08:00
liblvm_lvm_vg_set_property ( vgobject * self , PyObject * args )
2012-10-12 02:08:47 +01:00
{
const char * property_name = NULL ;
PyObject * variant_type_arg = NULL ;
struct lvm_property_value lvm_property ;
char * string_value = NULL ;
VG_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " sO " , & property_name , & variant_type_arg ) )
return NULL ;
lvm_property = lvm_vg_get_property ( self - > vg , property_name ) ;
2012-10-15 13:34:43 -07:00
if ( ! lvm_property . is_valid ) {
2012-10-12 02:08:47 +01:00
goto lvmerror ;
}
2012-10-15 13:34:43 -07:00
if ( PyObject_IsInstance ( variant_type_arg , ( PyObject * ) & PyString_Type ) ) {
2012-10-12 02:08:47 +01:00
if ( ! lvm_property . is_string ) {
PyErr_Format ( PyExc_ValueError , " Property requires string value " ) ;
goto bail ;
}
2013-06-18 15:13:27 -04:00
string_value = PyString_AsString ( variant_type_arg ) ;
2012-10-12 02:08:47 +01:00
lvm_property . value . string = string_value ;
2012-10-15 13:34:43 -07:00
if ( ! lvm_property . value . string ) {
2012-10-12 02:08:47 +01:00
PyErr_NoMemory ( ) ;
goto bail ;
}
} else {
if ( ! lvm_property . is_integer ) {
PyErr_Format ( PyExc_ValueError , " Property requires numeric value " ) ;
goto bail ;
}
2012-10-15 13:34:43 -07:00
if ( PyObject_IsInstance ( variant_type_arg , ( PyObject * ) & PyInt_Type ) ) {
2012-10-12 02:08:47 +01:00
int temp_py_int = PyInt_AsLong ( variant_type_arg ) ;
/* -1 could be valid, need to see if an exception was gen. */
2012-10-15 13:34:43 -07:00
if ( temp_py_int = = - 1 & & PyErr_Occurred ( ) ) {
goto bail ;
2012-10-12 02:08:47 +01:00
}
if ( temp_py_int < 0 ) {
PyErr_Format ( PyExc_ValueError , " Positive integers only! " ) ;
goto bail ;
}
lvm_property . value . integer = temp_py_int ;
2012-10-15 13:34:43 -07:00
} else if ( PyObject_IsInstance ( variant_type_arg , ( PyObject * ) & PyLong_Type ) ) {
2013-06-18 15:13:27 -04:00
/* If PyLong_AsUnsignedLongLong function fails an OverflowError is
* raised and ( unsigned long long ) - 1 is returned
*/
2012-10-12 02:08:47 +01:00
unsigned long long temp_py_long = PyLong_AsUnsignedLongLong ( variant_type_arg ) ;
2012-10-15 13:34:43 -07:00
if ( temp_py_long = = ( unsigned long long ) - 1 ) {
2012-10-12 02:08:47 +01:00
goto bail ;
}
lvm_property . value . integer = temp_py_long ;
} else {
PyErr_Format ( PyExc_ValueError , " supported value types are numeric and string " ) ;
goto bail ;
}
}
2012-10-15 13:34:43 -07:00
if ( lvm_vg_set_property ( self - > vg , property_name , & lvm_property ) = = - 1 ) {
2012-10-12 02:08:47 +01:00
goto lvmerror ;
}
2012-10-15 13:34:43 -07:00
if ( lvm_vg_write ( self - > vg ) = = - 1 ) {
2012-10-12 02:08:47 +01:00
goto lvmerror ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
lvmerror :
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
bail :
return NULL ;
}
static PyObject *
liblvm_lvm_vg_get_pv_count ( vgobject * self )
{
VG_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_vg_get_pv_count ( self - > vg ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_vg_get_max_pv ( vgobject * self )
{
VG_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_vg_get_max_pv ( self - > vg ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_vg_get_max_lv ( vgobject * self )
{
VG_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_vg_get_max_lv ( self - > vg ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_vg_set_extent_size ( vgobject * self , PyObject * args )
{
uint32_t new_size ;
int rval ;
VG_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " l " , & new_size ) ) {
return NULL ;
}
if ( ( rval = lvm_vg_set_extent_size ( self - > vg , new_size ) ) = = - 1 ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
2012-10-17 12:55:25 -07:00
liblvm_lvm_vg_list_lvs ( vgobject * self )
2012-10-12 02:08:47 +01:00
{
struct dm_list * lvs ;
struct lvm_lv_list * lvl ;
PyObject * pytuple ;
2012-10-17 12:55:25 -07:00
lvobject * lvobj ;
2012-10-12 02:08:47 +01:00
int i = 0 ;
2012-10-17 12:55:25 -07:00
VG_VALID ( self ) ;
2012-10-12 02:08:47 +01:00
/* unlike other LVM api calls, if there are no results, we get NULL */
2012-10-17 12:55:25 -07:00
lvs = lvm_vg_list_lvs ( self - > vg ) ;
2012-10-12 02:08:47 +01:00
if ( ! lvs )
return Py_BuildValue ( " () " ) ;
pytuple = PyTuple_New ( dm_list_size ( lvs ) ) ;
if ( ! pytuple )
return NULL ;
dm_list_iterate_items ( lvl , lvs ) {
/* Create and initialize the object */
2012-10-17 12:55:25 -07:00
lvobj = PyObject_New ( lvobject , & LibLVMlvType ) ;
if ( ! lvobj ) {
2012-10-12 02:08:47 +01:00
Py_DECREF ( pytuple ) ;
return NULL ;
}
2012-10-17 12:55:25 -07:00
lvobj - > parent_vgobj = self ;
Py_INCREF ( lvobj - > parent_vgobj ) ;
lvobj - > lv = lvl - > lv ;
PyTuple_SET_ITEM ( pytuple , i , ( PyObject * ) lvobj ) ;
2012-10-12 02:08:47 +01:00
i + + ;
}
return pytuple ;
}
static PyObject *
liblvm_lvm_vg_get_tags ( vgobject * self )
{
struct dm_list * tags ;
struct lvm_str_list * strl ;
PyObject * pytuple ;
int i = 0 ;
VG_VALID ( self ) ;
tags = lvm_vg_get_tags ( self - > vg ) ;
if ( ! tags ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
pytuple = PyTuple_New ( dm_list_size ( tags ) ) ;
if ( ! pytuple )
return NULL ;
dm_list_iterate_items ( strl , tags ) {
PyTuple_SET_ITEM ( pytuple , i , PyString_FromString ( strl - > str ) ) ;
i + + ;
}
return pytuple ;
}
static PyObject *
2012-10-17 12:55:25 -07:00
liblvm_lvm_vg_create_lv_linear ( vgobject * self , PyObject * args )
2012-10-12 02:08:47 +01:00
{
const char * vgname ;
uint64_t size ;
2012-10-17 12:55:25 -07:00
lvobject * lvobj ;
2012-10-12 02:08:47 +01:00
2012-10-17 12:55:25 -07:00
VG_VALID ( self ) ;
2012-10-12 02:08:47 +01:00
if ( ! PyArg_ParseTuple ( args , " sl " , & vgname , & size ) ) {
return NULL ;
}
2012-10-17 12:55:25 -07:00
if ( ( lvobj = PyObject_New ( lvobject , & LibLVMlvType ) ) = = NULL )
2012-10-12 02:08:47 +01:00
return NULL ;
2012-10-25 17:31:11 -05:00
/* Initialize the parent ptr in case lv create fails and we dealloc lvobj */
lvobj - > parent_vgobj = NULL ;
2012-10-17 12:55:25 -07:00
if ( ( lvobj - > lv = lvm_vg_create_lv_linear ( self - > vg , vgname , size ) ) = = NULL ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-17 12:55:25 -07:00
Py_DECREF ( lvobj ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
2012-10-17 12:55:25 -07:00
lvobj - > parent_vgobj = self ;
Py_INCREF ( lvobj - > parent_vgobj ) ;
return ( PyObject * ) lvobj ;
2012-10-12 02:08:47 +01:00
}
2013-05-03 19:37:52 -04:00
static PyObject *
liblvm_lvm_vg_create_lv_thinpool ( vgobject * self , PyObject * args )
{
const char * pool_name ;
uint64_t size = 0 ;
uint32_t chunk_size = 0 ;
uint64_t meta_size = 0 ;
int skip_zero = 0 ;
lvm_thin_discards_t discard = LVM_THIN_DISCARDS_PASSDOWN ;
lvobject * lvobj ;
lv_create_params_t lvp = NULL ;
struct lvm_property_value prop_value ;
VG_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " sK|kKii " , & pool_name , & size , & chunk_size ,
& meta_size , & discard , & skip_zero ) ) {
return NULL ;
}
if ( ( lvobj = PyObject_New ( lvobject , & LibLVMlvType ) ) = = NULL )
return NULL ;
/* Initialize the parent ptr in case lv create fails and we dealloc lvobj */
lvobj - > parent_vgobj = NULL ;
lvp = lvm_lv_params_create_thin_pool ( self - > vg , pool_name , size , chunk_size ,
meta_size , discard ) ;
if ( lvp ) {
if ( skip_zero ) {
prop_value = lvm_lv_params_get_property ( lvp , " skip_zero " ) ;
if ( prop_value . is_valid ) {
prop_value . value . integer = 1 ;
if ( - 1 = = lvm_lv_params_set_property ( lvp , " skip_zero " ,
& prop_value ) ) {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
Py_DECREF ( lvobj ) ;
return NULL ;
}
}
}
if ( ( lvobj - > lv = lvm_lv_create ( lvp ) ) = = NULL ) {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
Py_DECREF ( lvobj ) ;
return NULL ;
}
} else {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
Py_DECREF ( lvobj ) ;
return NULL ;
}
lvobj - > parent_vgobj = self ;
Py_INCREF ( lvobj - > parent_vgobj ) ;
return ( PyObject * ) lvobj ;
}
static PyObject *
liblvm_lvm_vg_create_lv_thin ( vgobject * self , PyObject * args )
{
const char * pool_name ;
const char * lv_name ;
uint64_t size = 0 ;
lvobject * lvobj ;
lv_create_params_t lvp = NULL ;
VG_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " ssK " , & pool_name , & lv_name , & size ) ) {
return NULL ;
}
if ( ( lvobj = PyObject_New ( lvobject , & LibLVMlvType ) ) = = NULL )
return NULL ;
/* Initialize the parent ptr in case lv create fails and we dealloc lvobj */
lvobj - > parent_vgobj = NULL ;
lvp = lvm_lv_params_create_thin ( self - > vg , pool_name , lv_name , size ) ;
if ( lvp ) {
if ( ( lvobj - > lv = lvm_lv_create ( lvp ) ) = = NULL ) {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
Py_DECREF ( lvobj ) ;
return NULL ;
}
} else {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
Py_DECREF ( lvobj ) ;
return NULL ;
}
lvobj - > parent_vgobj = self ;
Py_INCREF ( lvobj - > parent_vgobj ) ;
return ( PyObject * ) lvobj ;
}
2012-10-12 02:08:47 +01:00
static void
liblvm_lv_dealloc ( lvobject * self )
{
2012-10-25 17:31:11 -05:00
/* We can dealloc an object that didn't get fully created */
2012-12-14 10:17:29 -08:00
if ( self - > parent_vgobj ) {
2012-10-25 17:31:11 -05:00
Py_DECREF ( self - > parent_vgobj ) ;
2012-12-14 10:17:29 -08:00
}
2012-10-12 02:08:47 +01:00
PyObject_Del ( self ) ;
}
static PyObject *
2012-10-17 12:55:25 -07:00
liblvm_lvm_vg_list_pvs ( vgobject * self )
2012-10-12 02:08:47 +01:00
{
struct dm_list * pvs ;
struct lvm_pv_list * pvl ;
PyObject * pytuple ;
2012-10-17 12:55:25 -07:00
pvobject * pvobj ;
2012-10-12 02:08:47 +01:00
int i = 0 ;
2012-10-17 12:55:25 -07:00
VG_VALID ( self ) ;
2012-10-12 02:08:47 +01:00
/* unlike other LVM api calls, if there are no results, we get NULL */
2012-10-17 12:55:25 -07:00
pvs = lvm_vg_list_pvs ( self - > vg ) ;
2012-10-12 02:08:47 +01:00
if ( ! pvs )
return Py_BuildValue ( " () " ) ;
pytuple = PyTuple_New ( dm_list_size ( pvs ) ) ;
if ( ! pytuple )
return NULL ;
dm_list_iterate_items ( pvl , pvs ) {
/* Create and initialize the object */
2013-06-18 15:13:27 -04:00
pvobj = create_py_pv ( ) ;
2012-10-17 12:55:25 -07:00
if ( ! pvobj ) {
2012-10-12 02:08:47 +01:00
Py_DECREF ( pytuple ) ;
return NULL ;
}
2012-10-17 12:55:25 -07:00
pvobj - > parent_vgobj = self ;
Py_INCREF ( pvobj - > parent_vgobj ) ;
pvobj - > pv = pvl - > pv ;
PyTuple_SET_ITEM ( pytuple , i , ( PyObject * ) pvobj ) ;
2012-10-12 02:08:47 +01:00
i + + ;
}
return pytuple ;
}
typedef lv_t ( * lv_fetch_by_N ) ( vg_t vg , const char * id ) ;
typedef pv_t ( * pv_fetch_by_N ) ( vg_t vg , const char * id ) ;
static PyObject *
liblvm_lvm_lv_from_N ( vgobject * self , PyObject * arg , lv_fetch_by_N method )
{
const char * id ;
2012-10-17 12:55:25 -07:00
lvobject * lvobj ;
2012-10-12 02:08:47 +01:00
lv_t lv = NULL ;
VG_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( arg , " s " , & id ) )
return NULL ;
lv = method ( self - > vg , id ) ;
2012-10-15 13:34:43 -07:00
if ( ! lv ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
2012-10-17 12:55:25 -07:00
lvobj = PyObject_New ( lvobject , & LibLVMlvType ) ;
if ( ! lvobj ) {
2012-10-12 02:08:47 +01:00
return NULL ;
}
2012-10-17 12:55:25 -07:00
lvobj - > parent_vgobj = self ;
Py_INCREF ( lvobj - > parent_vgobj ) ;
lvobj - > lv = lv ;
return ( PyObject * ) lvobj ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_lv_from_name ( vgobject * self , PyObject * arg )
{
return liblvm_lvm_lv_from_N ( self , arg , lvm_lv_from_name ) ;
}
static PyObject *
liblvm_lvm_lv_from_uuid ( vgobject * self , PyObject * arg )
{
return liblvm_lvm_lv_from_N ( self , arg , lvm_lv_from_uuid ) ;
}
static PyObject *
liblvm_lvm_pv_from_N ( vgobject * self , PyObject * arg , pv_fetch_by_N method )
{
const char * id ;
pvobject * rc ;
pv_t pv = NULL ;
VG_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( arg , " s " , & id ) )
return NULL ;
pv = method ( self - > vg , id ) ;
2012-10-15 13:34:43 -07:00
if ( ! pv ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
2013-06-18 15:13:27 -04:00
rc = create_py_pv ( ) ;
2012-10-15 13:34:43 -07:00
if ( ! rc ) {
2012-10-12 02:08:47 +01:00
return NULL ;
}
2012-10-17 12:55:25 -07:00
Py_INCREF ( self ) ;
2012-10-12 02:08:47 +01:00
rc - > pv = pv ;
return ( PyObject * ) rc ;
}
static PyObject *
liblvm_lvm_pv_from_name ( vgobject * self , PyObject * arg )
{
return liblvm_lvm_pv_from_N ( self , arg , lvm_pv_from_name ) ;
}
static PyObject *
liblvm_lvm_pv_from_uuid ( vgobject * self , PyObject * arg )
{
return liblvm_lvm_pv_from_N ( self , arg , lvm_pv_from_uuid ) ;
}
static void
liblvm_pv_dealloc ( pvobject * self )
{
2013-03-19 17:37:04 -04:00
if ( self - > parent_vgobj ) {
Py_DECREF ( self - > parent_vgobj ) ;
}
if ( self - > parent_pvslistobj ) {
Py_DECREF ( self - > parent_pvslistobj ) ;
}
self - > parent_vgobj = NULL ;
self - > parent_pvslistobj = NULL ;
2012-10-12 02:08:47 +01:00
PyObject_Del ( self ) ;
}
/* LV Methods */
# define LV_VALID(lvobject) \
do { \
2012-10-17 12:55:25 -07:00
VG_VALID ( lvobject - > parent_vgobj ) ; \
2012-10-12 02:08:47 +01:00
if ( ! lvobject - > lv ) { \
PyErr_SetString ( PyExc_UnboundLocalError , " LV object invalid " ) ; \
return NULL ; \
} \
} while ( 0 )
2013-04-10 14:38:18 -04:00
static PyObject *
liblvm_lvm_lv_get_attr ( lvobject * self )
{
LV_VALID ( self ) ;
return Py_BuildValue ( " s " , lvm_lv_get_attr ( self - > lv ) ) ;
}
2012-10-12 02:08:47 +01:00
2013-04-11 16:49:08 -04:00
static PyObject *
liblvm_lvm_lv_get_origin ( lvobject * self )
{
LV_VALID ( self ) ;
return Py_BuildValue ( " s " , lvm_lv_get_origin ( self - > lv ) ) ;
}
2012-10-12 02:08:47 +01:00
static PyObject *
liblvm_lvm_lv_get_name ( lvobject * self )
{
LV_VALID ( self ) ;
return Py_BuildValue ( " s " , lvm_lv_get_name ( self - > lv ) ) ;
}
static PyObject *
liblvm_lvm_lv_get_uuid ( lvobject * self )
{
LV_VALID ( self ) ;
return Py_BuildValue ( " s " , lvm_lv_get_uuid ( self - > lv ) ) ;
}
static PyObject *
liblvm_lvm_lv_activate ( lvobject * self )
{
int rval ;
LV_VALID ( self ) ;
if ( ( rval = lvm_lv_activate ( self - > lv ) ) = = - 1 ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
liblvm_lvm_lv_deactivate ( lvobject * self )
{
int rval ;
LV_VALID ( self ) ;
if ( ( rval = lvm_lv_deactivate ( self - > lv ) ) = = - 1 ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
liblvm_lvm_vg_remove_lv ( lvobject * self )
{
int rval ;
LV_VALID ( self ) ;
if ( ( rval = lvm_vg_remove_lv ( self - > lv ) ) = = - 1 ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
self - > lv = NULL ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
/* This will return a tuple of (value, bool) with the value being a string or
integer and bool indicating if property is settable */
static PyObject *
2012-10-15 13:26:01 -07:00
liblvm_lvm_lv_get_property ( lvobject * self , PyObject * args )
2012-10-12 02:08:47 +01:00
{
const char * name ;
struct lvm_property_value prop_value ;
LV_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " s " , & name ) )
return NULL ;
prop_value = lvm_lv_get_property ( self - > lv , name ) ;
2012-10-15 13:26:01 -07:00
return get_property ( & prop_value ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_lv_get_size ( lvobject * self )
{
LV_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_lv_get_size ( self - > lv ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_lv_is_active ( lvobject * self )
{
PyObject * rval ;
LV_VALID ( self ) ;
rval = ( lvm_lv_is_active ( self - > lv ) = = 1 ) ? Py_True : Py_False ;
Py_INCREF ( rval ) ;
return rval ;
}
static PyObject *
liblvm_lvm_lv_is_suspended ( lvobject * self )
{
PyObject * rval ;
LV_VALID ( self ) ;
rval = ( lvm_lv_is_suspended ( self - > lv ) = = 1 ) ? Py_True : Py_False ;
Py_INCREF ( rval ) ;
return rval ;
}
static PyObject *
liblvm_lvm_lv_add_tag ( lvobject * self , PyObject * args )
{
const char * tag ;
int rval ;
LV_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " s " , & tag ) ) {
return NULL ;
}
if ( ( rval = lvm_lv_add_tag ( self - > lv , tag ) ) = = - 1 ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
liblvm_lvm_lv_remove_tag ( lvobject * self , PyObject * args )
{
const char * tag ;
int rval ;
LV_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " s " , & tag ) ) {
return NULL ;
}
if ( ( rval = lvm_lv_remove_tag ( self - > lv , tag ) ) = = - 1 ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
liblvm_lvm_lv_get_tags ( lvobject * self )
{
struct dm_list * tags ;
struct lvm_str_list * strl ;
PyObject * pytuple ;
int i = 0 ;
LV_VALID ( self ) ;
tags = lvm_lv_get_tags ( self - > lv ) ;
if ( ! tags ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
pytuple = PyTuple_New ( dm_list_size ( tags ) ) ;
if ( ! pytuple )
return NULL ;
dm_list_iterate_items ( strl , tags ) {
PyTuple_SET_ITEM ( pytuple , i , PyString_FromString ( strl - > str ) ) ;
i + + ;
}
return pytuple ;
}
static PyObject *
liblvm_lvm_lv_rename ( lvobject * self , PyObject * args )
{
const char * new_name ;
int rval ;
LV_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " s " , & new_name ) )
return NULL ;
if ( ( rval = lvm_lv_rename ( self - > lv , new_name ) ) = = - 1 ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
liblvm_lvm_lv_resize ( lvobject * self , PyObject * args )
{
uint64_t new_size ;
int rval ;
LV_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " l " , & new_size ) ) {
return NULL ;
}
if ( ( rval = lvm_lv_resize ( self - > lv , new_size ) ) = = - 1 ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
2012-10-17 12:55:25 -07:00
liblvm_lvm_lv_list_lvsegs ( lvobject * self )
2012-10-12 02:08:47 +01:00
{
2012-12-14 10:32:35 -08:00
struct dm_list * lvsegs ;
lvseg_list_t * lvsegl ;
2012-10-12 02:08:47 +01:00
PyObject * pytuple ;
2012-10-17 12:55:25 -07:00
lvsegobject * lvsegobj ;
2012-10-12 02:08:47 +01:00
int i = 0 ;
2012-10-17 12:55:25 -07:00
LV_VALID ( self ) ;
2012-10-12 02:08:47 +01:00
2012-10-17 12:55:25 -07:00
lvsegs = lvm_lv_list_lvsegs ( self - > lv ) ;
2012-10-15 13:34:43 -07:00
if ( ! lvsegs ) {
2012-10-12 02:08:47 +01:00
return Py_BuildValue ( " () " ) ;
}
pytuple = PyTuple_New ( dm_list_size ( lvsegs ) ) ;
if ( ! pytuple )
return NULL ;
dm_list_iterate_items ( lvsegl , lvsegs ) {
/* Create and initialize the object */
2012-10-17 12:55:25 -07:00
lvsegobj = PyObject_New ( lvsegobject , & LibLVMlvsegType ) ;
if ( ! lvsegobj ) {
2012-10-12 02:08:47 +01:00
Py_DECREF ( pytuple ) ;
return NULL ;
}
2012-10-17 12:55:25 -07:00
lvsegobj - > parent_lvobj = self ;
Py_INCREF ( lvsegobj - > parent_lvobj ) ;
lvsegobj - > lv_seg = lvsegl - > lvseg ;
PyTuple_SET_ITEM ( pytuple , i , ( PyObject * ) lvsegobj ) ;
2012-10-12 02:08:47 +01:00
i + + ;
}
return pytuple ;
}
2012-12-13 17:39:09 -08:00
static PyObject *
2012-12-14 10:17:29 -08:00
liblvm_lvm_lv_snapshot ( lvobject * self , PyObject * args )
2012-12-13 17:39:09 -08:00
{
2013-06-06 16:41:35 -04:00
const char * snap_name ;
uint64_t size = 0 ;
2012-12-13 17:39:09 -08:00
lvobject * lvobj ;
2013-06-06 16:41:35 -04:00
lv_create_params_t lvp = NULL ;
2012-12-13 17:39:09 -08:00
LV_VALID ( self ) ;
2013-06-06 16:41:35 -04:00
if ( ! PyArg_ParseTuple ( args , " s|K " , & snap_name , & size ) ) {
2012-12-13 17:39:09 -08:00
return NULL ;
}
if ( ( lvobj = PyObject_New ( lvobject , & LibLVMlvType ) ) = = NULL )
return NULL ;
2013-06-06 16:41:35 -04:00
lvobj - > parent_vgobj = NULL ;
lvp = lvm_lv_params_create_snapshot ( self - > lv , snap_name , size ) ;
if ( lvp ) {
if ( ( lvobj - > lv = lvm_lv_create ( lvp ) ) = = NULL ) {
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
Py_DECREF ( lvobj ) ;
return NULL ;
}
} else {
2012-12-13 17:39:09 -08:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2013-06-06 16:41:35 -04:00
Py_DECREF ( lvobj ) ;
return NULL ;
2012-12-13 17:39:09 -08:00
}
2012-12-14 10:17:29 -08:00
lvobj - > parent_vgobj = self - > parent_vgobj ;
2012-12-13 17:39:09 -08:00
Py_INCREF ( lvobj - > parent_vgobj ) ;
return ( PyObject * ) lvobj ;
}
2012-10-12 02:08:47 +01:00
/* PV Methods */
2013-03-19 17:37:04 -04:00
# define PV_VALID(pvobject) \
do { \
if ( pvobject - > parent_vgobj ) { \
VG_VALID ( pvobject - > parent_vgobj ) ; \
} \
if ( pvobject - > parent_pvslistobj ) { \
PVSLIST_VALID ( pvobject - > parent_pvslistobj ) ; \
} \
if ( ! pvobject - > pv ) { \
2012-10-12 02:08:47 +01:00
PyErr_SetString ( PyExc_UnboundLocalError , " PV object invalid " ) ; \
2013-03-19 17:37:04 -04:00
return NULL ; \
} \
2012-10-12 02:08:47 +01:00
} while ( 0 )
static PyObject *
liblvm_lvm_pv_get_name ( pvobject * self )
{
2012-10-17 12:55:25 -07:00
PV_VALID ( self ) ;
2012-10-12 02:08:47 +01:00
return Py_BuildValue ( " s " , lvm_pv_get_name ( self - > pv ) ) ;
}
static PyObject *
liblvm_lvm_pv_get_uuid ( pvobject * self )
{
2012-10-17 12:55:25 -07:00
PV_VALID ( self ) ;
2012-10-12 02:08:47 +01:00
return Py_BuildValue ( " s " , lvm_pv_get_uuid ( self - > pv ) ) ;
}
static PyObject *
liblvm_lvm_pv_get_mda_count ( pvobject * self )
{
2012-10-17 12:55:25 -07:00
PV_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_pv_get_mda_count ( self - > pv ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
2012-12-14 10:32:35 -08:00
liblvm_lvm_pv_get_property ( pvobject * self , PyObject * args )
2012-10-12 02:08:47 +01:00
{
const char * name ;
struct lvm_property_value prop_value ;
PV_VALID ( self ) ;
if ( ! PyArg_ParseTuple ( args , " s " , & name ) )
return NULL ;
prop_value = lvm_pv_get_property ( self - > pv , name ) ;
2012-10-15 13:26:01 -07:00
return get_property ( & prop_value ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_pv_get_dev_size ( pvobject * self )
{
2012-10-17 12:55:25 -07:00
PV_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_pv_get_dev_size ( self - > pv ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_pv_get_size ( pvobject * self )
{
2012-10-17 12:55:25 -07:00
PV_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_pv_get_size ( self - > pv ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_pv_get_free ( pvobject * self )
{
2012-10-17 12:55:25 -07:00
PV_VALID ( self ) ;
2012-12-05 16:31:30 -08:00
return Py_BuildValue ( " K " , ( unsigned long long ) lvm_pv_get_free ( self - > pv ) ) ;
2012-10-12 02:08:47 +01:00
}
static PyObject *
liblvm_lvm_pv_resize ( pvobject * self , PyObject * args )
{
uint64_t new_size ;
int rval ;
2012-10-17 12:55:25 -07:00
PV_VALID ( self ) ;
2012-10-12 02:08:47 +01:00
if ( ! PyArg_ParseTuple ( args , " l " , & new_size ) ) {
return NULL ;
}
if ( ( rval = lvm_pv_resize ( self - > pv , new_size ) ) = = - 1 ) {
2012-10-15 13:26:01 -07:00
PyErr_SetObject ( LibLVMError , liblvm_get_last_error ( ) ) ;
2012-10-12 02:08:47 +01:00
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject *
2012-10-17 12:55:25 -07:00
liblvm_lvm_pv_list_pvsegs ( pvobject * self )
2012-10-12 02:08:47 +01:00
{
struct dm_list * pvsegs ;
pvseg_list_t * pvsegl ;
PyObject * pytuple ;
2012-10-17 12:55:25 -07:00
pvsegobject * pvsegobj ;
2012-10-12 02:08:47 +01:00
int i = 0 ;
2012-10-17 12:55:25 -07:00
PV_VALID ( self ) ;
2012-10-12 02:08:47 +01:00
2012-10-17 12:55:25 -07:00
pvsegs = lvm_pv_list_pvsegs ( self - > pv ) ;
2012-10-15 13:34:43 -07:00
if ( ! pvsegs ) {
2012-10-12 02:08:47 +01:00
return Py_BuildValue ( " () " ) ;
}
pytuple = PyTuple_New ( dm_list_size ( pvsegs ) ) ;
if ( ! pytuple )
return NULL ;
dm_list_iterate_items ( pvsegl , pvsegs ) {
/* Create and initialize the object */
2012-10-17 12:55:25 -07:00
pvsegobj = PyObject_New ( pvsegobject , & LibLVMpvsegType ) ;
if ( ! pvsegobj ) {
2012-10-12 02:08:47 +01:00
Py_DECREF ( pytuple ) ;
return NULL ;
}
2012-10-17 12:55:25 -07:00
pvsegobj - > parent_pvobj = self ;
Py_INCREF ( pvsegobj - > parent_pvobj ) ;
pvsegobj - > pv_seg = pvsegl - > pvseg ;
PyTuple_SET_ITEM ( pytuple , i , ( PyObject * ) pvsegobj ) ;
2012-10-12 02:08:47 +01:00
i + + ;
}
return pytuple ;
}
/* LV seg methods */
2012-10-17 12:55:25 -07:00
/*
* No way to close / destroy an lvseg , just need to make sure parents are
* still good
*/
# define LVSEG_VALID(lvsegobject) LV_VALID(lvsegobject->parent_lvobj)
2012-10-12 02:08:47 +01:00
static void
liblvm_lvseg_dealloc ( lvsegobject * self )
{
2012-10-17 12:55:25 -07:00
Py_DECREF ( self - > parent_lvobj ) ;
2012-10-12 02:08:47 +01:00
PyObject_Del ( self ) ;
}
static PyObject *
2012-12-14 10:32:35 -08:00
liblvm_lvm_lvseg_get_property ( lvsegobject * self , PyObject * args )
2012-10-12 02:08:47 +01:00
{
const char * name ;
struct lvm_property_value prop_value ;
2012-10-17 12:55:25 -07:00
LVSEG_VALID ( self ) ;
2012-10-12 02:08:47 +01:00
if ( ! PyArg_ParseTuple ( args , " s " , & name ) )
return NULL ;
prop_value = lvm_lvseg_get_property ( self - > lv_seg , name ) ;
2012-10-15 13:26:01 -07:00
return get_property ( & prop_value ) ;
2012-10-12 02:08:47 +01:00
}
/* PV seg methods */
2012-10-17 12:55:25 -07:00
/*
* No way to close / destroy a pvseg , just need to make sure parents are
* still good
*/
# define PVSEG_VALID(pvsegobject) PV_VALID(pvsegobject->parent_pvobj)
2012-10-12 02:08:47 +01:00
static void
liblvm_pvseg_dealloc ( pvsegobject * self )
{
2012-10-17 12:55:25 -07:00
Py_DECREF ( self - > parent_pvobj ) ;
2012-10-12 02:08:47 +01:00
PyObject_Del ( self ) ;
}
static PyObject *
2012-12-14 10:32:35 -08:00
liblvm_lvm_pvseg_get_property ( pvsegobject * self , PyObject * args )
2012-10-12 02:08:47 +01:00
{
const char * name ;
struct lvm_property_value prop_value ;
2012-10-17 12:55:25 -07:00
PVSEG_VALID ( self ) ;
2012-10-12 02:08:47 +01:00
if ( ! PyArg_ParseTuple ( args , " s " , & name ) )
return NULL ;
prop_value = lvm_pvseg_get_property ( self - > pv_seg , name ) ;
2012-10-15 13:26:01 -07:00
return get_property ( & prop_value ) ;
2012-10-12 02:08:47 +01:00
}
/* ----------------------------------------------------------------------
* Method tables and other bureaucracy
*/
static PyMethodDef Liblvm_methods [ ] = {
/* LVM methods */
{ " getVersion " , ( PyCFunction ) liblvm_library_get_version , METH_NOARGS } ,
{ " vgOpen " , ( PyCFunction ) liblvm_lvm_vg_open , METH_VARARGS } ,
{ " vgCreate " , ( PyCFunction ) liblvm_lvm_vg_create , METH_VARARGS } ,
{ " configFindBool " , ( PyCFunction ) liblvm_lvm_config_find_bool , METH_VARARGS } ,
{ " configReload " , ( PyCFunction ) liblvm_lvm_config_reload , METH_NOARGS } ,
{ " configOverride " , ( PyCFunction ) liblvm_lvm_config_override , METH_VARARGS } ,
{ " scan " , ( PyCFunction ) liblvm_lvm_scan , METH_NOARGS } ,
{ " listVgNames " , ( PyCFunction ) liblvm_lvm_list_vg_names , METH_NOARGS } ,
{ " listVgUuids " , ( PyCFunction ) liblvm_lvm_list_vg_uuids , METH_NOARGS } ,
2013-03-19 17:37:04 -04:00
{ " listPvs " , ( PyCFunction ) liblvm_lvm_list_pvs , METH_NOARGS } ,
2013-04-03 17:54:12 -04:00
{ " pvCreate " , ( PyCFunction ) liblvm_lvm_pv_create , METH_VARARGS } ,
2013-04-02 16:10:57 -04:00
{ " pvRemove " , ( PyCFunction ) liblvm_lvm_pv_remove , METH_VARARGS } ,
2012-10-12 02:08:47 +01:00
{ " percentToFloat " , ( PyCFunction ) liblvm_lvm_percent_to_float , METH_VARARGS } ,
{ " vgNameFromPvid " , ( PyCFunction ) liblvm_lvm_vgname_from_pvid , METH_VARARGS } ,
{ " vgNameFromDevice " , ( PyCFunction ) liblvm_lvm_vgname_from_device , METH_VARARGS } ,
2012-12-14 10:32:35 -08:00
{ NULL , NULL } /* sentinel */
2012-10-12 02:08:47 +01:00
} ;
static PyMethodDef liblvm_vg_methods [ ] = {
/* vg methods */
{ " getName " , ( PyCFunction ) liblvm_lvm_vg_get_name , METH_NOARGS } ,
{ " getUuid " , ( PyCFunction ) liblvm_lvm_vg_get_uuid , METH_NOARGS } ,
{ " close " , ( PyCFunction ) liblvm_lvm_vg_close , METH_NOARGS } ,
{ " remove " , ( PyCFunction ) liblvm_lvm_vg_remove , METH_NOARGS } ,
{ " extend " , ( PyCFunction ) liblvm_lvm_vg_extend , METH_VARARGS } ,
{ " reduce " , ( PyCFunction ) liblvm_lvm_vg_reduce , METH_VARARGS } ,
{ " addTag " , ( PyCFunction ) liblvm_lvm_vg_add_tag , METH_VARARGS } ,
{ " removeTag " , ( PyCFunction ) liblvm_lvm_vg_remove_tag , METH_VARARGS } ,
{ " setExtentSize " , ( PyCFunction ) liblvm_lvm_vg_set_extent_size , METH_VARARGS } ,
{ " isClustered " , ( PyCFunction ) liblvm_lvm_vg_is_clustered , METH_NOARGS } ,
{ " isExported " , ( PyCFunction ) liblvm_lvm_vg_is_exported , METH_NOARGS } ,
{ " isPartial " , ( PyCFunction ) liblvm_lvm_vg_is_partial , METH_NOARGS } ,
{ " getSeqno " , ( PyCFunction ) liblvm_lvm_vg_get_seqno , METH_NOARGS } ,
{ " getSize " , ( PyCFunction ) liblvm_lvm_vg_get_size , METH_NOARGS } ,
{ " getFreeSize " , ( PyCFunction ) liblvm_lvm_vg_get_free_size , METH_NOARGS } ,
{ " getExtentSize " , ( PyCFunction ) liblvm_lvm_vg_get_extent_size , METH_NOARGS } ,
{ " getExtentCount " , ( PyCFunction ) liblvm_lvm_vg_get_extent_count , METH_NOARGS } ,
{ " getFreeExtentCount " , ( PyCFunction ) liblvm_lvm_vg_get_free_extent_count , METH_NOARGS } ,
{ " getProperty " , ( PyCFunction ) liblvm_lvm_vg_get_property , METH_VARARGS } ,
{ " setProperty " , ( PyCFunction ) liblvm_lvm_vg_set_property , METH_VARARGS } ,
{ " getPvCount " , ( PyCFunction ) liblvm_lvm_vg_get_pv_count , METH_NOARGS } ,
{ " getMaxPv " , ( PyCFunction ) liblvm_lvm_vg_get_max_pv , METH_NOARGS } ,
{ " getMaxLv " , ( PyCFunction ) liblvm_lvm_vg_get_max_lv , METH_NOARGS } ,
{ " listLVs " , ( PyCFunction ) liblvm_lvm_vg_list_lvs , METH_NOARGS } ,
{ " listPVs " , ( PyCFunction ) liblvm_lvm_vg_list_pvs , METH_NOARGS } ,
{ " lvFromName " , ( PyCFunction ) liblvm_lvm_lv_from_name , METH_VARARGS } ,
{ " lvFromUuid " , ( PyCFunction ) liblvm_lvm_lv_from_uuid , METH_VARARGS } ,
{ " pvFromName " , ( PyCFunction ) liblvm_lvm_pv_from_name , METH_VARARGS } ,
{ " pvFromUuid " , ( PyCFunction ) liblvm_lvm_pv_from_uuid , METH_VARARGS } ,
{ " getTags " , ( PyCFunction ) liblvm_lvm_vg_get_tags , METH_NOARGS } ,
{ " createLvLinear " , ( PyCFunction ) liblvm_lvm_vg_create_lv_linear , METH_VARARGS } ,
2013-05-03 19:37:52 -04:00
{ " createLvThinpool " , ( PyCFunction ) liblvm_lvm_vg_create_lv_thinpool , METH_VARARGS } ,
{ " createLvThin " , ( PyCFunction ) liblvm_lvm_vg_create_lv_thin , METH_VARARGS } ,
2012-12-14 10:32:35 -08:00
{ NULL , NULL } /* sentinel */
2012-10-12 02:08:47 +01:00
} ;
static PyMethodDef liblvm_lv_methods [ ] = {
/* lv methods */
2013-04-10 14:38:18 -04:00
{ " getAttr " , ( PyCFunction ) liblvm_lvm_lv_get_attr , METH_NOARGS } ,
2012-10-12 02:08:47 +01:00
{ " getName " , ( PyCFunction ) liblvm_lvm_lv_get_name , METH_NOARGS } ,
2013-04-11 16:49:08 -04:00
{ " getOrigin " , ( PyCFunction ) liblvm_lvm_lv_get_origin , METH_NOARGS } ,
2012-10-12 02:08:47 +01:00
{ " getUuid " , ( PyCFunction ) liblvm_lvm_lv_get_uuid , METH_NOARGS } ,
{ " activate " , ( PyCFunction ) liblvm_lvm_lv_activate , METH_NOARGS } ,
{ " deactivate " , ( PyCFunction ) liblvm_lvm_lv_deactivate , METH_NOARGS } ,
{ " remove " , ( PyCFunction ) liblvm_lvm_vg_remove_lv , METH_NOARGS } ,
{ " getProperty " , ( PyCFunction ) liblvm_lvm_lv_get_property , METH_VARARGS } ,
{ " getSize " , ( PyCFunction ) liblvm_lvm_lv_get_size , METH_NOARGS } ,
{ " isActive " , ( PyCFunction ) liblvm_lvm_lv_is_active , METH_NOARGS } ,
{ " isSuspended " , ( PyCFunction ) liblvm_lvm_lv_is_suspended , METH_NOARGS } ,
{ " addTag " , ( PyCFunction ) liblvm_lvm_lv_add_tag , METH_VARARGS } ,
{ " removeTag " , ( PyCFunction ) liblvm_lvm_lv_remove_tag , METH_VARARGS } ,
{ " getTags " , ( PyCFunction ) liblvm_lvm_lv_get_tags , METH_NOARGS } ,
{ " rename " , ( PyCFunction ) liblvm_lvm_lv_rename , METH_VARARGS } ,
{ " resize " , ( PyCFunction ) liblvm_lvm_lv_resize , METH_VARARGS } ,
{ " listLVsegs " , ( PyCFunction ) liblvm_lvm_lv_list_lvsegs , METH_NOARGS } ,
2012-12-14 10:17:29 -08:00
{ " snapshot " , ( PyCFunction ) liblvm_lvm_lv_snapshot , METH_VARARGS } ,
2012-12-14 10:32:35 -08:00
{ NULL , NULL } /* sentinel */
2012-10-12 02:08:47 +01:00
} ;
2013-03-19 17:37:04 -04:00
static PyMethodDef liblvm_pv_list_methods [ ] = {
/* pv list methods */
{ " __enter__ " , ( PyCFunction ) liblvm_lvm_pvlist_get , METH_VARARGS } ,
{ " __exit__ " , ( PyCFunction ) liblvm_lvm_pvlist_put , METH_VARARGS } ,
{ " open " , ( PyCFunction ) liblvm_lvm_pvlist_get , METH_VARARGS } ,
{ " close " , ( PyCFunction ) liblvm_lvm_pvlist_put , METH_VARARGS } ,
{ NULL , NULL }
} ;
2012-10-12 02:08:47 +01:00
static PyMethodDef liblvm_pv_methods [ ] = {
/* pv methods */
{ " getName " , ( PyCFunction ) liblvm_lvm_pv_get_name , METH_NOARGS } ,
{ " getUuid " , ( PyCFunction ) liblvm_lvm_pv_get_uuid , METH_NOARGS } ,
{ " getMdaCount " , ( PyCFunction ) liblvm_lvm_pv_get_mda_count , METH_NOARGS } ,
{ " getProperty " , ( PyCFunction ) liblvm_lvm_pv_get_property , METH_VARARGS } ,
{ " getSize " , ( PyCFunction ) liblvm_lvm_pv_get_size , METH_NOARGS } ,
{ " getDevSize " , ( PyCFunction ) liblvm_lvm_pv_get_dev_size , METH_NOARGS } ,
{ " getFree " , ( PyCFunction ) liblvm_lvm_pv_get_free , METH_NOARGS } ,
{ " resize " , ( PyCFunction ) liblvm_lvm_pv_resize , METH_VARARGS } ,
2012-10-17 12:55:25 -07:00
{ " listPVsegs " , ( PyCFunction ) liblvm_lvm_pv_list_pvsegs , METH_NOARGS } ,
2012-12-14 10:32:35 -08:00
{ NULL , NULL } /* sentinel */
2012-10-12 02:08:47 +01:00
} ;
static PyMethodDef liblvm_lvseg_methods [ ] = {
{ " getProperty " , ( PyCFunction ) liblvm_lvm_lvseg_get_property , METH_VARARGS } ,
2012-12-14 10:32:35 -08:00
{ NULL , NULL } /* sentinel */
2012-10-12 02:08:47 +01:00
} ;
static PyMethodDef liblvm_pvseg_methods [ ] = {
{ " getProperty " , ( PyCFunction ) liblvm_lvm_pvseg_get_property , METH_VARARGS } ,
2012-12-14 10:32:35 -08:00
{ NULL , NULL } /* sentinel */
2012-10-12 02:08:47 +01:00
} ;
static PyTypeObject LibLVMvgType = {
PyObject_HEAD_INIT ( & PyType_Type )
. tp_name = " liblvm.Liblvm_vg " ,
. tp_basicsize = sizeof ( vgobject ) ,
. tp_new = PyType_GenericNew ,
. tp_dealloc = ( destructor ) liblvm_vg_dealloc ,
. tp_flags = Py_TPFLAGS_DEFAULT ,
. tp_doc = " LVM Volume Group object " ,
. tp_methods = liblvm_vg_methods ,
} ;
static PyTypeObject LibLVMlvType = {
PyObject_HEAD_INIT ( & PyType_Type )
. tp_name = " liblvm.Liblvm_lv " ,
. tp_basicsize = sizeof ( lvobject ) ,
. tp_new = PyType_GenericNew ,
. tp_dealloc = ( destructor ) liblvm_lv_dealloc ,
. tp_flags = Py_TPFLAGS_DEFAULT ,
. tp_doc = " LVM Logical Volume object " ,
. tp_methods = liblvm_lv_methods ,
} ;
2013-03-19 17:37:04 -04:00
static PyTypeObject LibLVMpvlistType = {
PyObject_HEAD_INIT ( & PyType_Type )
. tp_name = " liblvm.Liblvm_pvlist " ,
. tp_basicsize = sizeof ( pvslistobject ) ,
. tp_new = PyType_GenericNew ,
. tp_dealloc = ( destructor ) liblvm_pvlist_dealloc ,
. tp_flags = Py_TPFLAGS_DEFAULT ,
. tp_doc = " LVM Physical Volume list object " ,
. tp_methods = liblvm_pv_list_methods ,
} ;
2012-10-12 02:08:47 +01:00
static PyTypeObject LibLVMpvType = {
PyObject_HEAD_INIT ( & PyType_Type )
. tp_name = " liblvm.Liblvm_pv " ,
. tp_basicsize = sizeof ( pvobject ) ,
. tp_new = PyType_GenericNew ,
. tp_dealloc = ( destructor ) liblvm_pv_dealloc ,
. tp_flags = Py_TPFLAGS_DEFAULT ,
. tp_doc = " LVM Physical Volume object " ,
. tp_methods = liblvm_pv_methods ,
} ;
static PyTypeObject LibLVMlvsegType = {
PyObject_HEAD_INIT ( & PyType_Type )
. tp_name = " liblvm.Liblvm_lvseg " ,
. tp_basicsize = sizeof ( lvsegobject ) ,
. tp_new = PyType_GenericNew ,
. tp_dealloc = ( destructor ) liblvm_lvseg_dealloc ,
. tp_flags = Py_TPFLAGS_DEFAULT ,
. tp_doc = " LVM Logical Volume Segment object " ,
. tp_methods = liblvm_lvseg_methods ,
} ;
static PyTypeObject LibLVMpvsegType = {
PyObject_HEAD_INIT ( & PyType_Type )
. tp_name = " liblvm.Liblvm_pvseg " ,
. tp_basicsize = sizeof ( pvsegobject ) ,
. tp_new = PyType_GenericNew ,
. tp_dealloc = ( destructor ) liblvm_pvseg_dealloc ,
. tp_flags = Py_TPFLAGS_DEFAULT ,
. tp_doc = " LVM Physical Volume Segment object " ,
. tp_methods = liblvm_pvseg_methods ,
} ;
2012-10-15 13:26:01 -07:00
static void
liblvm_cleanup ( void )
{
lvm_quit ( libh ) ;
libh = NULL ;
}
2012-10-12 02:08:47 +01:00
PyMODINIT_FUNC
initlvm ( void )
{
PyObject * m ;
2012-10-15 13:26:01 -07:00
libh = lvm_init ( NULL ) ;
2012-10-12 02:08:47 +01:00
if ( PyType_Ready ( & LibLVMvgType ) < 0 )
return ;
if ( PyType_Ready ( & LibLVMlvType ) < 0 )
return ;
if ( PyType_Ready ( & LibLVMpvType ) < 0 )
return ;
if ( PyType_Ready ( & LibLVMlvsegType ) < 0 )
return ;
if ( PyType_Ready ( & LibLVMpvsegType ) < 0 )
return ;
2013-03-19 17:37:04 -04:00
if ( PyType_Ready ( & LibLVMpvlistType ) < 0 )
return ;
2012-10-12 02:08:47 +01:00
m = Py_InitModule3 ( " lvm " , Liblvm_methods , " Liblvm module " ) ;
if ( m = = NULL )
return ;
2013-05-03 19:37:52 -04:00
if ( - 1 = = PyModule_AddIntConstant ( m , " THIN_DISCARDS_IGNORE " ,
LVM_THIN_DISCARDS_IGNORE ) ) {
return ;
}
if ( - 1 = = PyModule_AddIntConstant ( m , " THIN_DISCARDS_NO_PASSDOWN " ,
LVM_THIN_DISCARDS_NO_PASSDOWN ) ) {
return ;
}
if ( - 1 = = PyModule_AddIntConstant ( m , " THIN_DISCARDS_PASSDOWN " ,
LVM_THIN_DISCARDS_PASSDOWN ) ) {
return ;
}
2012-10-12 02:08:47 +01:00
LibLVMError = PyErr_NewException ( " Liblvm.LibLVMError " ,
NULL , NULL ) ;
if ( LibLVMError ) {
/* Each call to PyModule_AddObject decrefs it; compensate: */
Py_INCREF ( LibLVMError ) ;
Py_INCREF ( LibLVMError ) ;
PyModule_AddObject ( m , " error " , LibLVMError ) ;
PyModule_AddObject ( m , " LibLVMError " , LibLVMError ) ;
}
2012-10-15 13:26:01 -07:00
Py_AtExit ( liblvm_cleanup ) ;
2012-10-12 02:08:47 +01:00
}