diff options
Diffstat (limited to 'sys-apps/parted/files/parted-1.4.14-r1-python-gentoo.diff')
-rw-r--r-- | sys-apps/parted/files/parted-1.4.14-r1-python-gentoo.diff | 2336 |
1 files changed, 2336 insertions, 0 deletions
diff --git a/sys-apps/parted/files/parted-1.4.14-r1-python-gentoo.diff b/sys-apps/parted/files/parted-1.4.14-r1-python-gentoo.diff new file mode 100644 index 000000000000..068f351fb0f7 --- /dev/null +++ b/sys-apps/parted/files/parted-1.4.14-r1-python-gentoo.diff @@ -0,0 +1,2336 @@ +diff -urP parted-1.4.14/Makefile.am parted-1.4.14-python/Makefile.am +--- parted-1.4.14/Makefile.am Sat Apr 7 18:04:37 2001 ++++ parted-1.4.14-python/Makefile.am Tue Jun 5 16:59:14 2001 +@@ -1,4 +1,4 @@ +-SUBDIRS = intl po libparted parted include doc debug ++SUBDIRS = intl po libparted parted include doc debug @PYTHON_SUBDIR@ + + EXTRA_DIST = ABOUT-NLS \ + AUTHORS \ +diff -urP parted-1.4.14/configure.in parted-1.4.14-python/configure.in +--- parted-1.4.14/configure.in Wed May 30 06:42:20 2001 ++++ parted-1.4.14-python/configure.in Tue Jun 5 17:44:02 2001 +@@ -65,6 +65,12 @@ + fi + AC_SUBST(PARTED_LDFLAGS) + ++AC_ARG_WITH(python, ++ [ --with-python build python module], ++ with_python=$withval, ++ with_python=no ++) ++ + dnl make libc threadsafe (not required for us, but useful other users of + dnl libparted) + CFLAGS="$CFLAGS -D_REENTRANT" +@@ -174,6 +180,33 @@ + LIBS="$OLD_LIBS" + fi + ++dnl Check for python ++if test x$with_python = xyes; then ++ AC_PATH_PROG(PYTHON, python python2.1 python2.0 python1.6 python1.5, no) ++ if test x$PYTHON = xno; then ++ AC_MSG_ERROR( ++Python version 1.5 or higher could not be found which is required for ++the --with-python. Either disable readline support with ++--without-python or downloaded and install it from: ++ http://www.python.org ++ ) ++ fi ++ changequote(<<,>>)dnl ++ PYTHON_VERSION=`${PYTHON} -c "import sys; print sys.version[:3]"` ++ PYTHON_PREFIX=`${PYTHON} -c "import sys; print sys.prefix"` ++ PYTHON_EXEC_PREFIX=`${PYTHON} -c "import sys; print sys.exec_prefix"` ++ changequote([,])dnl ++ PYTHON_INCLUDES="-I${PYTHON_PREFIX}/include/python${PYTHON_VERSION} -I${PYTHON_PREFIX}/lib/python${PYTHON_VERSION}/config" ++ pydynmoduledir="${PYTHON_EXEC_PREFIX}/lib/python${PYTHON_VERSION}/site-packages" ++ PYTHON_SUBDIR=python ++fi ++AC_SUBST(PYTHON_PREFIX) ++AC_SUBST(PYTHON_EXEC_PREFIX) ++AC_SUBST(PYTHON_VERSION) ++AC_SUBST(PYTHON_INCLUDES) ++AC_SUBST(PYTHON_SUBDIR) ++AC_SUBST(pydynmoduledir) ++ + AC_SUBST(PARTED_LIBS) + + dnl One day, gettext might support libtool... +@@ -256,7 +289,7 @@ + LIBS="$OLD_LIBS" + fi + +-CFLAGS="$CFLAGS -W -Wall -Wno-unused -Wno-switch -Werror" ++CFLAGS="$CFLAGS -W -Wall -Wno-unused -Wno-switch" + + AC_OUTPUT([ + Makefile +@@ -271,6 +304,7 @@ + libparted/fs_reiserfs/Makefile + libparted/fs_ufs/Makefile + parted/Makefile ++python/Makefile + intl/Makefile + doc/Makefile + debug/Makefile +diff -urP parted-1.4.14/python/Makefile.am parted-1.4.14-python/python/Makefile.am +--- parted-1.4.14/python/Makefile.am Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/Makefile.am Tue Jun 5 15:52:16 2001 +@@ -0,0 +1,29 @@ ++AUTOMAKE_OPTIONS = 1.4 foreign ++ ++partedincludedir = -I$(top_srcdir)/include ++INCLUDES = $(partedincludedir) @PYTHON_INCLUDES@ @INTLINCS@ ++ ++noinst_LTLIBRARIES = libpartedmodule.la ++libpartedmodule_la_SOURCES = partedmodule.c \ ++ pydevice.c \ ++ pydisk.c \ ++ pygeometry.c \ ++ pyexception.c \ ++ pyfilesystem.c \ ++ pyconstraint.c \ ++ partedmodule.h \ ++ pyconstraint.h \ ++ pydevice.h \ ++ pydisk.h \ ++ pyexception.h \ ++ pyfilesystem.h \ ++ pygeometry.h ++ ++pythondir = $(pydynmoduledir) ++python_PROGRAMS = partedmodule.so ++partedmodule_so_SOURCES = ++partedmodule_so_LDFLAGS = $(top_builddir)/libparted/libparted.la \ ++ -shared -Wl,-soname,partedmodule.so ++ ++partedmodule.so: $(libpartedmodule_la_OBJECTS) ++ $(LINK) -g -o $@ $^ $(partedmodule_so_LDFLAGS); +diff -urP parted-1.4.14/python/partedmodule.c parted-1.4.14-python/python/partedmodule.c +--- parted-1.4.14/python/partedmodule.c Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/partedmodule.c Thu Apr 26 15:12:34 2001 +@@ -0,0 +1,334 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++#include <Python.h> ++ ++#include "parted/parted.h" ++ ++#include "partedmodule.h" ++#include "pydevice.h" ++#include "pydisk.h" ++#include "pyexception.h" ++#include "pygeometry.h" ++#include "pyfilesystem.h" ++#include "pyconstraint.h" ++ ++/* global error object */ ++PyObject *PyPartedError; ++ ++/* static global variables */ ++static PyObject *PyExceptionHandler; ++static char *py_exception_string = NULL; ++ ++/* common functions */ ++int ++py_ped_exception_string_check (void) ++{ ++ return (py_exception_string != NULL); ++} ++ ++ ++void ++py_ped_exception_string_clear (void) ++{ ++ if (py_exception_string != NULL) { ++ free (py_exception_string); ++ py_exception_string = NULL; ++ } ++} ++ ++void ++py_ped_set_error_from_ped_exception (void) ++{ ++ if (py_exception_string != NULL) { ++ PyErr_SetString(PyPartedError, py_exception_string); ++ py_ped_exception_string_clear (); ++ return; ++ } ++ PyErr_SetString(PyPartedError, "unknown error occured"); ++} ++ ++/* toplevel implementation */ ++ ++static PedExceptionOption ++py_exception_handler (PedException* ex) ++{ ++ PyObject * result, * args = NULL; ++ long rc; ++ char * type; ++ char * buf; ++ int len; ++ ++ if (py_exception_string != NULL) ++ free (py_exception_string); ++ ++ type = ped_exception_get_type_string (ex->type); ++ len = strlen (type) + strlen (ex->message) + 3; ++ buf = malloc (len); ++ snprintf (buf, len, "%s: %s", type, ex->message); ++ py_exception_string = buf; ++ ++ if (PyExceptionHandler == NULL) { ++ return PED_EXCEPTION_UNHANDLED; ++ } ++ ++ args = Py_BuildValue("(N)", (PyObject *) py_ped_exception_obj_new (ex)); ++ ++ result = PyEval_CallObject(PyExceptionHandler, args); ++ Py_XDECREF(args); ++ ++ if (result == NULL) { ++ PyErr_Print(); ++ PyErr_Clear(); ++ return PED_EXCEPTION_UNHANDLED; ++ } ++ ++ if (!PyInt_Check (result)) { ++ fprintf (stderr, ++ "ERROR: python exception handler did not " ++ "return expected int value\n"); ++ return PED_EXCEPTION_UNHANDLED; ++ } ++ ++ rc = PyInt_AsLong (result); ++ Py_DECREF (result); ++ return (PedExceptionOption) rc; ++} ++ ++static PyObject * ++py_ped_exception_set_handler (PyObject * self, PyObject * args) ++{ ++ PyObject *cb; ++ ++ /* if we already have a callback, releae it */ ++ if (PyExceptionHandler != NULL) { ++ Py_DECREF (PyExceptionHandler); ++ PyExceptionHandler = NULL; ++ } ++ ++ if (!PyArg_ParseTuple(args, "O", &cb)) ++ return NULL; ++ ++ if (!PyCallable_Check (cb)) { ++ PyErr_SetString(PyExc_TypeError, "parameter must be callable"); ++ return NULL; ++ } ++ Py_INCREF (cb); ++ PyExceptionHandler = cb; ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_device_get (PyObject * self, PyObject * args) ++{ ++ PyPedDevice *d; ++ PedDevice *dev; ++ char *path; ++ ++ if (!PyArg_ParseTuple(args, "s", &path)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ if ((dev = ped_device_get (path)) == NULL) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ d = (PyPedDevice *) PyObject_NEW(PyObject, &PyPedDeviceType); ++ d->dev = dev; ++ return (PyObject *) d; ++} ++ ++static PyObject * ++py_ped_file_system_type_get (PyObject * self, PyObject * args) ++{ ++ char *type; ++ PedFileSystemType *fst; ++ ++ if (!PyArg_ParseTuple(args, "s", &type)) { ++ return NULL; ++ } ++ ++ if ((fst = ped_file_system_type_get (type)) == NULL) { ++ PyErr_SetString(PyPartedError, "unknown file system type"); ++ return NULL; ++ } ++ ++ return (PyObject *) py_ped_file_system_type_obj_new (fst); ++} ++ ++static PyObject * ++py_ped_file_system_type_get_next (PyObject * self, PyObject * args) ++{ ++ PyPedFileSystemTypeObj *pyfst = NULL; ++ PedFileSystemType *fst; ++ ++ if (!PyArg_ParseTuple(args, "|O!", &PyPedFileSystemTypeType, &pyfst)) { ++ PyErr_SetString(PyExc_TypeError, ++ "optional parameter must be a " ++ "PedFileSystemType"); ++ return NULL; ++ } ++ ++ fst = ped_file_system_type_get_next (pyfst ? pyfst->fs_type : NULL); ++ if (fst) ++ return (PyObject *) py_ped_file_system_type_obj_new (fst); ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_partition_flag_next (PyObject *obj, PyObject * args) ++{ ++ int flag, next; ++ ++ if (!PyArg_ParseTuple(args, "i", &flag)) ++ return NULL; ++ ++ next = ped_partition_flag_next (flag); ++ ++ return PyInt_FromLong (next); ++} ++ ++static PyObject * ++py_ped_partition_flag_get_by_name (PyObject *obj, PyObject * args) ++{ ++ char *name; ++ int flag; ++ ++ if (!PyArg_ParseTuple(args, "s", &name)) ++ return NULL; ++ ++ flag = ped_partition_flag_get_by_name (name); ++ ++ return PyInt_FromLong (flag); ++} ++ ++static PyObject * ++py_ped_partition_flag_get_name (PyObject *obj, PyObject * args) ++{ ++ int flag; ++ const char *name; ++ ++ if (!PyArg_ParseTuple(args, "i", &flag)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ name = ped_partition_flag_get_name (flag); ++ if (py_ped_exception_string_check ()) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ return PyString_FromString (name); ++} ++ ++static struct PyMethodDef PyPedModuleMethods[] = { ++ { "device_get", ++ (PyCFunction) py_ped_device_get, METH_VARARGS, NULL }, ++ { "exception_set_handler", ++ (PyCFunction) py_ped_exception_set_handler, ++ METH_VARARGS, NULL }, ++ { "file_system_type_get", ++ (PyCFunction) py_ped_file_system_type_get, ++ METH_VARARGS, NULL }, ++ { "file_system_type_get_next", ++ (PyCFunction) py_ped_file_system_type_get_next, ++ METH_VARARGS, NULL }, ++ { "partition_flag_next", ++ (PyCFunction) py_ped_partition_flag_next, ++ METH_VARARGS, NULL }, ++ { "partition_flag_get_by_name", ++ (PyCFunction) py_ped_partition_flag_get_by_name, ++ METH_VARARGS, NULL }, ++ { "partition_flag_get_name", ++ (PyCFunction) py_ped_partition_flag_get_name, ++ METH_VARARGS, NULL }, ++ { NULL, NULL, 0, NULL } ++}; ++ ++void initparted(void) { ++ PyObject *m, *d, *o; ++ ++ if (!ped_init ()) ++ Py_FatalError("couldn't initialized parted"); ++ ++ m = Py_InitModule("parted", PyPedModuleMethods); ++ d = PyModule_GetDict(m); ++ ++ /* enum registration */ ++#define REGISTER_ENUM(val) \ ++ PyDict_SetItemString(d, #val, o=PyInt_FromLong(PED_ ## val)); \ ++ Py_DECREF(o); ++ ++ REGISTER_ENUM(DEVICE_UNKNOWN); ++ REGISTER_ENUM(DEVICE_SCSI); ++ REGISTER_ENUM(DEVICE_IDE); ++ REGISTER_ENUM(DEVICE_DAC960); ++ REGISTER_ENUM(DEVICE_CPQARRAY); ++ ++ REGISTER_ENUM(PARTITION_PRIMARY); ++ REGISTER_ENUM(PARTITION_LOGICAL); ++ REGISTER_ENUM(PARTITION_EXTENDED); ++ REGISTER_ENUM(PARTITION_FREESPACE); ++ REGISTER_ENUM(PARTITION_METADATA); ++ ++ REGISTER_ENUM(PARTITION_BOOT); ++ REGISTER_ENUM(PARTITION_ROOT); ++ REGISTER_ENUM(PARTITION_SWAP); ++ REGISTER_ENUM(PARTITION_HIDDEN); ++ REGISTER_ENUM(PARTITION_RAID); ++ REGISTER_ENUM(PARTITION_LVM); ++ REGISTER_ENUM(PARTITION_LBA); ++ ++ REGISTER_ENUM(PARTITION_FIRST_FLAG); ++ REGISTER_ENUM(PARTITION_LAST_FLAG); ++ ++ REGISTER_ENUM(DISK_TYPE_EXTENDED); ++ REGISTER_ENUM(DISK_TYPE_PARTITION_NAME); ++ ++ REGISTER_ENUM(EXCEPTION_INFORMATION); ++ REGISTER_ENUM(EXCEPTION_WARNING); ++ REGISTER_ENUM(EXCEPTION_ERROR); ++ REGISTER_ENUM(EXCEPTION_FATAL); ++ REGISTER_ENUM(EXCEPTION_BUG); ++ REGISTER_ENUM(EXCEPTION_NO_FEATURE); ++ ++ REGISTER_ENUM(EXCEPTION_UNHANDLED); ++ REGISTER_ENUM(EXCEPTION_YES); ++ REGISTER_ENUM(EXCEPTION_NO); ++ REGISTER_ENUM(EXCEPTION_OK); ++ REGISTER_ENUM(EXCEPTION_RETRY); ++ REGISTER_ENUM(EXCEPTION_IGNORE); ++ REGISTER_ENUM(EXCEPTION_CANCEL); ++ ++ REGISTER_ENUM(EXCEPTION_OK_CANCEL); ++ REGISTER_ENUM(EXCEPTION_YES_NO); ++ REGISTER_ENUM(EXCEPTION_YES_NO_CANCEL); ++ REGISTER_ENUM(EXCEPTION_IGNORE_CANCEL); ++ REGISTER_ENUM(EXCEPTION_RETRY_CANCEL); ++ REGISTER_ENUM(EXCEPTION_RETRY_IGNORE_CANCEL); ++ /* end enum registration */ ++ ++ /* register the exception handler marhaller function */ ++ ped_exception_set_handler (py_exception_handler); ++ ++ /* set up our exception class */ ++ PyPartedError = PyErr_NewException("parted.error", NULL, NULL); ++ PyDict_SetItemString(d, "error", PyPartedError); ++ Py_DECREF(PyPartedError); ++} +diff -urP parted-1.4.14/python/partedmodule.h parted-1.4.14-python/python/partedmodule.h +--- parted-1.4.14/python/partedmodule.h Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/partedmodule.h Thu Dec 7 09:45:26 2000 +@@ -0,0 +1,25 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++#ifndef PARTEDMODULE_H_INCLUDED ++#define PARTEDMODULE_H_INCLUDED ++ ++#include <Python.h> ++ ++extern PyObject *PyPartedError; ++int py_ped_exception_string_check (void); ++void py_ped_exception_string_clear (void); ++extern void py_ped_set_error_from_ped_exception (void); ++ ++#endif /* PARTEDMODULE_H_INCLUDED */ +diff -urP parted-1.4.14/python/pyconstraint.c parted-1.4.14-python/python/pyconstraint.c +--- parted-1.4.14/python/pyconstraint.c Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pyconstraint.c Fri Apr 27 15:03:38 2001 +@@ -0,0 +1,109 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ * ++*/ ++ ++#include "partedmodule.h" ++#include "pygeometry.h" ++#include "pyconstraint.h" ++ ++static void py_ped_constraint_dealloc (PyPedConstraint * c); ++static PyObject * py_ped_constraint_getattr (PyPedConstraint * c, char * name); ++ ++static char PyPedConstraintType__doc__[] = "This is the PartEd constraint " ++ "object"; ++PyTypeObject PyPedConstraintType = { ++ PyObject_HEAD_INIT(&PyType_Type) ++ 0, /* ob_size */ ++ "PedConstraint", /* tp_name */ ++ sizeof(PyPedConstraint), /* tp_size */ ++ 0, /* tp_itemsize */ ++ (destructor) py_ped_constraint_dealloc, /* tp_dealloc */ ++ 0, /* tp_print */ ++ (getattrfunc) py_ped_constraint_getattr, /* 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 */ ++ 0, /* tp_str */ ++ 0, /* tp_getattro */ ++ 0, /* tp_setattro */ ++ 0, /* tp_as_buffer */ ++ 0L, /* tp_flags */ ++ PyPedConstraintType__doc__, ++ 0L,0L,0L,0L ++}; ++ ++static PyObject * py_ped_constraint_duplicate (PyPedConstraint * c, ++ PyObject * args); ++ ++static struct PyMethodDef PyPedConstraintMethods[] = { ++ { "duplicate", ++ (PyCFunction) py_ped_constraint_duplicate, ++ METH_VARARGS, NULL }, ++ { NULL, NULL, 0, NULL } ++}; ++ ++static void ++py_ped_constraint_dealloc (PyPedConstraint * c) ++{ ++ if (!c->borrowed) ++ ped_constraint_destroy (c->constraint); ++ Py_XDECREF (c->disk); ++ PyMem_DEL(c); ++} ++ ++static PyObject * ++py_ped_constraint_duplicate (PyPedConstraint * c, PyObject * args) ++{ ++ PedConstraint *cst; ++ ++ cst = ped_constraint_duplicate (c->constraint); ++ return (PyObject *) py_ped_constraint_obj_new (cst, c->disk, 0); ++} ++ ++static PyObject * ++py_ped_constraint_getattr (PyPedConstraint * c, char * name) ++{ ++ if (!strcmp (name, "start_range")) ++ return (PyObject *) ++ py_ped_geometry_obj_new (c->constraint->start_range, ++ c->disk, 1); ++ if (!strcmp (name, "end_range")) ++ return (PyObject *) ++ py_ped_geometry_obj_new (c->constraint->end_range, ++ c->disk, 1); ++ if (!strcmp (name, "min_size")) ++ return (PyObject *) ++ PyLong_FromLongLong (c->constraint->min_size); ++ ++ return Py_FindMethod (PyPedConstraintMethods, (PyObject *) c, name); ++} ++ ++PyPedConstraint * ++py_ped_constraint_obj_new (PedConstraint *c, PyPedDisk *disk, int borrowed) ++{ ++ PyPedConstraint *con; ++ ++ con = (PyPedConstraint *) PyObject_NEW(PyObject, &PyPedConstraintType); ++ con->constraint = c; ++ con->borrowed = borrowed; ++ con->disk = disk; ++ Py_INCREF (disk); ++ ++ return con; ++} +diff -urP parted-1.4.14/python/pyconstraint.h parted-1.4.14-python/python/pyconstraint.h +--- parted-1.4.14/python/pyconstraint.h Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pyconstraint.h Thu Dec 7 17:55:09 2000 +@@ -0,0 +1,38 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ * ++*/ ++ ++#ifndef PYCONSTRAINT_H_INCLUDED ++#define PYCONSTRAINT_H_INCLUDED ++ ++#include <Python.h> ++#include "parted/constraint.h" ++#include "pydisk.h" ++ ++typedef struct _PyPedConstraint PyPedConstraint; ++ ++struct _PyPedConstraint { ++ PyObject_HEAD; ++ PedConstraint *constraint; ++ PyPedDisk *disk; ++ int borrowed; ++}; ++ ++extern PyTypeObject PyPedConstraintType; ++ ++extern PyPedConstraint * py_ped_constraint_obj_new (PedConstraint *c, ++ PyPedDisk *part, ++ int borrowed); ++ ++#endif /* PYCONSTRAINT_H_INCLUDED */ +diff -urP parted-1.4.14/python/pydevice.c parted-1.4.14-python/python/pydevice.c +--- parted-1.4.14/python/pydevice.c Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pydevice.c Thu Dec 7 09:45:26 2000 +@@ -0,0 +1,152 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++#include "partedmodule.h" ++#include "pydevice.h" ++#include "pydisk.h" ++ ++static void py_ped_device_dealloc (PyPedDevice * s); ++static PyObject * py_ped_device_getattr (PyPedDevice * s, char * name); ++ ++static char PyPedDeviceType__doc__[] = "This is the PartEd device object"; ++PyTypeObject PyPedDeviceType = { ++ PyObject_HEAD_INIT(&PyType_Type) ++ 0, /* ob_size */ ++ "PedDevice", /* tp_name */ ++ sizeof(PyPedDevice), /* tp_size */ ++ 0, /* tp_itemsize */ ++ (destructor) py_ped_device_dealloc, /* tp_dealloc */ ++ 0, /* tp_print */ ++ (getattrfunc) py_ped_device_getattr, /* 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 */ ++ 0, /* tp_str */ ++ 0, /* tp_getattro */ ++ 0, /* tp_setattro */ ++ 0, /* tp_as_buffer */ ++ 0L, /* tp_flags */ ++ PyPedDeviceType__doc__, ++ 0L,0L,0L,0L ++}; ++ ++static PyObject * py_ped_device_open (PyPedDevice * s, PyObject * args); ++static PyObject * py_ped_device_close (PyPedDevice * s, PyObject * args); ++static PyObject * py_ped_device_sync (PyPedDevice * s, PyObject * args); ++static PyObject * py_ped_disk_open (PyPedDevice * s, PyObject * args); ++ ++static struct PyMethodDef PyPedDeviceMethods[] = { ++ { "open", (PyCFunction) py_ped_device_open, METH_VARARGS, NULL }, ++ { "close", (PyCFunction) py_ped_device_close, METH_VARARGS, NULL }, ++ { "sync", (PyCFunction) py_ped_device_sync, METH_VARARGS, NULL }, ++ { "disk_open", (PyCFunction) py_ped_disk_open, METH_VARARGS, NULL }, ++ { NULL, NULL, 0, NULL } ++}; ++ ++/* device implementation */ ++ ++PyPedDevice * py_ped_device_new (PedDevice *dev) ++{ ++ PyPedDevice *d; ++ ++ d = (PyPedDevice *) PyObject_NEW(PyObject, &PyPedDeviceType); ++ d->dev = dev; ++ return d; ++} ++ ++static void ++py_ped_device_dealloc (PyPedDevice * s) ++{ ++ /* s->dev will be destroyed if ped_device_free_all() is called */ ++ /* ped_device_destroy (s->dev); */ ++ PyMem_DEL(s); ++} ++ ++static PyObject * ++py_ped_device_getattr (PyPedDevice * d, char * name) ++{ ++ if (!strcmp (name, "length")) ++ return PyLong_FromLongLong (d->dev->length); ++ else if (!strcmp (name, "model")) ++ return PyString_FromString (d->dev->model); ++ else if (!strcmp (name, "path")) ++ return PyString_FromString (d->dev->path); ++ else if (!strcmp (name, "sector_size")) ++ return PyInt_FromLong (d->dev->sector_size); ++ else if (!strcmp (name, "type")) ++ return PyInt_FromLong (d->dev->type); ++ return Py_FindMethod (PyPedDeviceMethods, (PyObject *) d, name); ++} ++ ++static PyObject * ++py_ped_device_open (PyPedDevice * s, PyObject * args) ++{ ++ py_ped_exception_string_clear (); ++ if (!ped_device_open (s->dev)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_device_close (PyPedDevice * s, PyObject * args) ++{ ++ py_ped_exception_string_clear (); ++ if (!ped_device_close (s->dev)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_device_sync (PyPedDevice * s, PyObject * args) ++{ ++ py_ped_exception_string_clear (); ++ if (!ped_device_sync (s->dev)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_disk_open (PyPedDevice * self, PyObject * args) ++{ ++ PyPedDevice *dev; ++ PyPedDisk *d; ++ PedDisk *disk; ++ ++ py_ped_exception_string_clear (); ++ if ((disk = ped_disk_open (self->dev)) == NULL) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ d = (PyPedDisk *) PyObject_NEW(PyObject, &PyPedDiskType); ++ d->disk = disk; ++ return (PyObject *) d; ++} ++ +diff -urP parted-1.4.14/python/pydevice.h parted-1.4.14-python/python/pydevice.h +--- parted-1.4.14/python/pydevice.h Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pydevice.h Thu Dec 7 09:45:26 2000 +@@ -0,0 +1,33 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++#ifndef PYDEVICE_H_INCLUDED ++#define PYDEVICE_H_INCLUDED ++ ++#include <Python.h> ++ ++#include "parted/device.h" ++ ++extern PyTypeObject PyPedDeviceType; ++typedef struct _PyPedDevice PyPedDevice; ++ ++struct _PyPedDevice { ++ PyObject_HEAD; ++ PedDevice *dev; ++}; ++ ++PyPedDevice * py_ped_device_new (PedDevice *dev); ++ ++#endif /* PYDEVICE_H_INCLUDED */ ++ +diff -urP parted-1.4.14/python/pydisk.c parted-1.4.14-python/python/pydisk.c +--- parted-1.4.14/python/pydisk.c Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pydisk.c Sun Apr 22 18:42:44 2001 +@@ -0,0 +1,631 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++#include "partedmodule.h" ++#include "pydisk.h" ++#include "pydevice.h" ++#include "pygeometry.h" ++#include "pyfilesystem.h" ++#include "pyconstraint.h" ++ ++/* disk python object */ ++static void py_ped_disk_dealloc (PyPedDisk * d); ++static PyObject * py_ped_disk_getattr (PyPedDisk * d, char * name); ++ ++static char PyPedDiskType__doc__[] = "This is the PartEd disk object"; ++PyTypeObject PyPedDiskType = { ++ PyObject_HEAD_INIT(&PyType_Type) ++ 0, /* ob_size */ ++ "PedDisk", /* tp_name */ ++ sizeof(PyPedDisk), /* tp_size */ ++ 0, /* tp_itemsize */ ++ (destructor) py_ped_disk_dealloc, /* tp_dealloc */ ++ 0, /* tp_print */ ++ (getattrfunc) py_ped_disk_getattr, /* 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 */ ++ 0, /* tp_str */ ++ 0, /* tp_getattro */ ++ 0, /* tp_setattro */ ++ 0, /* tp_as_buffer */ ++ 0L, /* tp_flags */ ++ PyPedDiskType__doc__, ++ 0L,0L,0L,0L ++}; ++ ++static PyObject * py_ped_disk_next_partition (PyPedDisk * d, PyObject * args); ++static PyObject * py_ped_disk_write (PyPedDisk * d, PyObject * args); ++static PyObject * py_ped_disk_read (PyPedDisk * d, PyObject * args); ++static PyObject * py_ped_disk_delete_partition (PyPedDisk * d, PyObject * args); ++static PyObject * py_ped_disk_delete_all (PyPedDisk * d, PyObject * args); ++static PyObject * py_ped_disk_add_partition (PyPedDisk * d, PyObject * args); ++static PyObject * py_ped_disk_get_partition (PyPedDisk * d, PyObject * args); ++static PyObject * py_ped_constraint_any (PyPedDisk * self, PyObject * args); ++static PyObject * py_ped_geometry_new (PyPedDisk * self, PyObject * args); ++static PyObject * py_ped_partition_new (PyPedDisk * self, PyObject * args); ++static PyObject * py_ped_disk_minimize_extended_partition (PyPedDisk * self, PyObject * args); ++static PyObject * py_ped_disk_maximize_partition (PyPedDisk * self, PyObject * args); ++static PyObject * py_ped_disk_is_busy (PyPedDisk * d, PyObject * args); ++ ++static struct PyMethodDef PyPedDiskMethods[] = { ++ { "next_partition", (PyCFunction) py_ped_disk_next_partition, METH_VARARGS, NULL }, ++ { "read", (PyCFunction) py_ped_disk_read, METH_VARARGS, NULL }, ++ { "write", (PyCFunction) py_ped_disk_write, METH_VARARGS, NULL }, ++ { "delete_partition", (PyCFunction) py_ped_disk_delete_partition, METH_VARARGS, NULL }, ++ { "delete_all", (PyCFunction) py_ped_disk_delete_all, METH_VARARGS, NULL }, ++ { "add_partition", (PyCFunction) py_ped_disk_add_partition, METH_VARARGS, NULL }, ++ { "get_partition", (PyCFunction) py_ped_disk_get_partition, METH_VARARGS, NULL }, ++ { "constraint_any", (PyCFunction) py_ped_constraint_any, METH_VARARGS, NULL }, ++ { "geometry_new", (PyCFunction) py_ped_geometry_new, METH_VARARGS, NULL }, ++ { "partition_new", (PyCFunction) py_ped_partition_new, METH_VARARGS, NULL }, ++ { "minimize_extended_partition", (PyCFunction) py_ped_disk_minimize_extended_partition, METH_VARARGS, NULL }, ++ { "maximize_partition", (PyCFunction) py_ped_disk_maximize_partition, METH_VARARGS, NULL }, ++ { "is_busy", (PyCFunction) py_ped_disk_is_busy, METH_VARARGS, NULL }, ++ { NULL, NULL, 0, NULL } ++}; ++ ++/* partition python object */ ++ ++static void py_ped_partition_dealloc (PyPedPartition * p); ++static PyObject * py_ped_partition_getattr (PyPedPartition * p, char * name); ++ ++static char PyPedPartitionType__doc__[] = "This is the PartEd partition object"; ++PyTypeObject PyPedPartitionType = { ++ PyObject_HEAD_INIT(&PyType_Type) ++ 0, /* ob_size */ ++ "PedPartition", /* tp_name */ ++ sizeof(PyPedPartition), /* tp_size */ ++ 0, /* tp_itemsize */ ++ (destructor) py_ped_partition_dealloc, /* tp_dealloc */ ++ 0, /* tp_print */ ++ (getattrfunc) py_ped_partition_getattr, /* 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 */ ++ 0, /* tp_str */ ++ 0, /* tp_getattro */ ++ 0, /* tp_setattro */ ++ 0, /* tp_as_buffer */ ++ 0L, /* tp_flags */ ++ PyPedPartitionType__doc__, ++ 0L,0L,0L,0L ++}; ++ ++static PyObject * py_ped_partition_is_flag_available (PyPedPartition *p, PyObject * args); ++static PyObject * py_ped_partition_set_flag (PyPedPartition * self, PyObject * args); ++static PyObject * py_ped_partition_get_flag (PyPedPartition * self, PyObject * args); ++static PyObject * py_ped_partition_is_active (PyPedPartition * self, PyObject * args); ++static PyObject * py_ped_partition_set_system (PyPedPartition * self, PyObject * args); ++static PyObject * py_ped_partition_set_name (PyPedPartition * self, PyObject * args); ++static PyObject * py_ped_partition_get_name (PyPedPartition * self, PyObject * args); ++static PyObject * py_ped_partition_is_busy (PyPedPartition * self, PyObject * args); ++ ++static struct PyMethodDef PyPedPartitionMethods[] = { ++ { "is_flag_available", (PyCFunction) py_ped_partition_is_flag_available, METH_VARARGS, NULL }, ++ { "get_flag", (PyCFunction) py_ped_partition_get_flag, METH_VARARGS, NULL }, ++ { "set_flag", (PyCFunction) py_ped_partition_set_flag, METH_VARARGS, NULL }, ++ { "is_active", (PyCFunction) py_ped_partition_is_active, METH_VARARGS, NULL }, ++ { "set_system", (PyCFunction) py_ped_partition_set_system, METH_VARARGS, NULL }, ++ { "set_name", (PyCFunction) py_ped_partition_set_name, METH_VARARGS, NULL }, ++ { "get_name", (PyCFunction) py_ped_partition_get_name, METH_VARARGS, NULL }, ++ { "is_busy", (PyCFunction) py_ped_partition_is_busy, METH_VARARGS, NULL }, ++ { NULL, NULL, 0, NULL } ++}; ++ ++/* disk implementation */ ++ ++static void ++py_ped_disk_dealloc (PyPedDisk * d) ++{ ++ ped_disk_close (d->disk); ++ PyMem_DEL(d); ++} ++ ++static PyObject * ++py_ped_disk_getattr (PyPedDisk * d, char * name) ++{ ++ if (!strcmp (name, "dev")) ++ return (PyObject *) py_ped_device_new (d->disk->dev); ++ if (!strcmp (name, "max_primary_partition_count")) { ++ int num; ++ ++ py_ped_exception_string_clear (); ++ num = ped_disk_get_max_primary_partition_count (d->disk); ++ if (num == 0) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ return PyInt_FromLong (num); ++ } ++ if (!strcmp (name, "extended_partition")) { ++ PedPartition *ppart; ++ ++ py_ped_exception_string_clear (); ++ ppart = ped_disk_extended_partition (d->disk); ++ if (ppart != NULL) ++ return (PyObject *) py_ped_partition_obj_new (ppart, d, 1); ++ ++ if (py_ped_exception_string_check ()) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ Py_INCREF(Py_None); ++ return Py_None; ++ } ++ ++ return Py_FindMethod (PyPedDiskMethods, (PyObject *) d, name); ++} ++ ++static PyObject * ++py_ped_disk_next_partition (PyPedDisk * d, PyObject * args) ++{ ++ PyPedPartition *part = NULL; ++ PedPartition *ppart; ++ ++ if (!PyArg_ParseTuple(args, "|O!", &PyPedPartitionType, &part)) { ++ PyErr_SetString(PyExc_TypeError, ++ "optional parameter must be a PedPartition"); ++ return NULL; ++ } ++ ++ ppart = ped_disk_next_partition (d->disk, part ? part->part : NULL); ++ if (ppart != NULL) ++ return (PyObject *) py_ped_partition_obj_new (ppart, d, 1); ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_disk_read (PyPedDisk * d, PyObject * args) ++{ ++ py_ped_exception_string_clear (); ++ if (!ped_disk_write (d->disk)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_disk_write (PyPedDisk * d, PyObject * args) ++{ ++ py_ped_exception_string_clear (); ++ if (!ped_disk_write (d->disk)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_disk_delete_partition (PyPedDisk * d, PyObject * args) ++{ ++ PyPedPartition *part; ++ ++ if (!PyArg_ParseTuple(args, "O!", &PyPedPartitionType, &part)) { ++ PyErr_SetString(PyExc_TypeError, "PedPartition expected"); ++ return NULL; ++ } ++ ++ py_ped_exception_string_clear (); ++ if (!ped_disk_delete_partition (d->disk, part->part)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ /* the partition structure is freed as part of the ++ delete_partition call. Protect from the double free ++ by marking it borrowed */ ++ part->borrowed = 1; ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++ ++static PyObject * ++py_ped_disk_delete_all (PyPedDisk * d, PyObject * args) ++{ ++ py_ped_exception_string_clear (); ++ if (!ped_disk_delete_all (d->disk)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_disk_add_partition (PyPedDisk * d, PyObject * args) ++{ ++ PyPedPartition *part; ++ PyPedConstraint *constraint; ++ ++ if (!PyArg_ParseTuple(args, "O!O!", &PyPedPartitionType, &part, ++ &PyPedConstraintType, &constraint)) { ++ PyErr_SetString(PyExc_TypeError, "bad argument"); ++ return NULL; ++ } ++ ++ py_ped_exception_string_clear (); ++ if (!ped_disk_add_partition (d->disk, part->part, ++ constraint->constraint)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ /* the disk takes ownership of the data in this partition ++ when added, protect from double free */ ++ part->borrowed = 1; ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_disk_get_partition_by_sector (PyPedDisk * d, PyObject * args) ++{ ++ PedPartition *part; ++ PedSector sect; ++ ++ if (!PyArg_ParseTuple(args, "L", §)) ++ return NULL; ++ ++ if ((part = ped_disk_get_partition_by_sector (d->disk, sect)) == NULL) { ++ PyErr_SetString(PyPartedError, "partition not found"); ++ return NULL; ++ } ++ ++ return (PyObject *) py_ped_partition_obj_new (part, d, 1); ++} ++ ++static PyObject * ++py_ped_disk_get_partition (PyPedDisk * d, PyObject * args) ++{ ++ PedPartition *part; ++ int num; ++ ++ if (!PyArg_ParseTuple(args, "i", &num)) ++ return NULL; ++ ++ if ((part = ped_disk_get_partition (d->disk, num)) == NULL) { ++ PyErr_SetString(PyPartedError, "partition not found"); ++ return NULL; ++ } ++ ++ return (PyObject *) py_ped_partition_obj_new (part, d, 1); ++} ++ ++static PyObject * ++py_ped_partition_new (PyPedDisk * self, PyObject * args) ++{ ++ PyPedFileSystemTypeObj *fs_type; ++ PedSector start, end; ++ PedPartition *part; ++ PedPartitionType type; ++ PyPedPartition *pypart; ++ ++ if (!PyArg_ParseTuple(args, "iO!LL", ++ &type, ++ &PyPedFileSystemTypeType, &fs_type, ++ &start, &end)) { ++ return NULL; ++ } ++ ++ py_ped_exception_string_clear (); ++ part = ped_partition_new (self->disk, type, fs_type->fs_type, ++ start, end); ++ if (part == NULL) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ pypart = py_ped_partition_obj_new (part, self, 0); ++ ++ return (PyObject *) pypart; ++} ++ ++static PyObject * ++py_ped_constraint_any (PyPedDisk * self, PyObject * args) ++{ ++ PyPedDisk *disk; ++ PedConstraint *constraint; ++ PyPedConstraint *pyconstraint; ++ ++ py_ped_exception_string_clear (); ++ constraint = ped_constraint_any (self->disk); ++ if (constraint == NULL) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ pyconstraint = py_ped_constraint_obj_new (constraint, self, 0); ++ ++ return (PyObject *) pyconstraint; ++} ++ ++static PyObject * ++py_ped_geometry_new (PyPedDisk * self, PyObject * args) ++{ ++ PedSector start, length; ++ PedGeometry *geom; ++ PyPedGeometry *pygeom; ++ ++ if (!PyArg_ParseTuple(args, "LL", &start, &length)) { ++ return NULL; ++ } ++ ++ py_ped_exception_string_clear (); ++ geom = ped_geometry_new (self->disk, start, length); ++ if (geom == NULL) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ pygeom = py_ped_geometry_obj_new (geom, self, 0); ++ pygeom->disk = self; ++ Py_INCREF (self); ++ ++ return (PyObject *) pygeom; ++} ++ ++static PyObject * ++py_ped_disk_minimize_extended_partition (PyPedDisk * self, PyObject * args) ++{ ++ py_ped_exception_string_clear (); ++ if (!ped_disk_minimize_extended_partition (self->disk)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ Py_INCREF(Py_None); ++ return Py_None; ++ ++} ++ ++static PyObject * ++py_ped_disk_maximize_partition (PyPedDisk * self, PyObject * args) ++{ ++ PyPedPartition *part; ++ PyPedConstraint *constraint; ++ ++ if (!PyArg_ParseTuple(args, "O!O!", &PyPedPartitionType, &part, ++ &PyPedConstraintType, &constraint)) { ++ return NULL; ++ } ++ ++ py_ped_exception_string_clear (); ++ if (!ped_disk_maximize_partition (self->disk, part->part, ++ constraint->constraint)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_disk_is_busy (PyPedDisk *d, PyObject * args) ++{ ++ int state; ++ ++ py_ped_exception_string_clear (); ++ state = ped_disk_is_busy (d->disk); ++ if (py_ped_exception_string_check ()) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ return PyInt_FromLong (state); ++} ++ ++/* partition implementation */ ++ ++PyPedPartition * ++py_ped_partition_obj_new (PedPartition *part, PyPedDisk *disk, int borrowed) ++{ ++ PyPedPartition *p; ++ ++ p = (PyPedPartition *) PyObject_NEW(PyObject, &PyPedPartitionType); ++ p->part = part; ++ p->borrowed = borrowed; ++ p->disk = disk; ++ Py_INCREF (disk); ++ ++ return p; ++} ++ ++static void ++py_ped_partition_dealloc (PyPedPartition * p) ++{ ++ if (!p->borrowed) ++ ped_partition_destroy (p->part); ++ Py_XDECREF (p->disk); ++ PyMem_DEL(p); ++} ++ ++static PyObject * ++py_ped_partition_getattr (PyPedPartition * p, char * name) ++{ ++ if (!strcmp (name, "num")) ++ return PyInt_FromLong (p->part->num); ++ if (!strcmp (name, "type")) ++ return PyInt_FromLong (p->part->type); ++ if (!strcmp (name, "type_name")) ++ return PyString_FromString ( ++ ped_partition_type_get_name (p->part->type)); ++ if (!strcmp (name, "geom")) ++ return (PyObject *) py_ped_geometry_obj_new (&p->part->geom, p->disk, 1); ++ if (!strcmp (name, "fs_type")) { ++ if (p->part->fs_type) ++ return (PyObject *) ++ py_ped_file_system_type_obj_new (p->part->fs_type); ++ Py_INCREF(Py_None); ++ return Py_None; ++ } ++ return Py_FindMethod (PyPedPartitionMethods, (PyObject *) p, name); ++} ++ ++static PyObject * ++py_ped_partition_is_flag_available (PyPedPartition *p, PyObject * args) ++{ ++ int av, flag; ++ ++ if (!PyArg_ParseTuple(args, "i", &flag)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ av = ped_partition_is_flag_available (p->part, flag); ++ if (py_ped_exception_string_check ()) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ return PyInt_FromLong (av); ++} ++ ++static PyObject * ++py_ped_partition_set_flag (PyPedPartition *p, PyObject * args) ++{ ++ int flag, state; ++ ++ if (!PyArg_ParseTuple(args, "ii", &flag, &state)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ if (!ped_partition_set_flag (p->part, flag, state)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_partition_get_flag (PyPedPartition *p, PyObject * args) ++{ ++ int flag, state; ++ ++ if (!PyArg_ParseTuple(args, "i", &flag)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ state = ped_partition_get_flag (p->part, flag); ++ if (py_ped_exception_string_check ()) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ return PyInt_FromLong (state); ++} ++ ++ ++static PyObject * ++py_ped_partition_is_active (PyPedPartition *p, PyObject * args) ++{ ++ int state; ++ ++ py_ped_exception_string_clear (); ++ state = ped_partition_is_active (p->part); ++ if (py_ped_exception_string_check ()) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ return PyInt_FromLong (state); ++} ++ ++static PyObject * ++py_ped_partition_set_system (PyPedPartition *p, PyObject * args) ++{ ++ PyPedFileSystemTypeObj *fs_type; ++ ++ if (!PyArg_ParseTuple(args, "O!", ++ &PyPedFileSystemTypeType, &fs_type)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ if (!ped_partition_set_system (p->part, fs_type->fs_type)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++ ++static PyObject * ++py_ped_partition_set_name (PyPedPartition *p, PyObject * args) ++{ ++ char *name; ++ ++ if (!PyArg_ParseTuple(args, "s", &name)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ if (!ped_partition_set_name (p->part, name)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_partition_get_name (PyPedPartition *p, PyObject * args) ++{ ++ const char *name; ++ ++ py_ped_exception_string_clear (); ++ if ((name = ped_partition_get_name (p->part)) == NULL) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ return PyString_FromString (name); ++} ++ ++ ++static PyObject * ++py_ped_partition_is_busy (PyPedPartition *p, PyObject * args) ++{ ++ int state; ++ ++ py_ped_exception_string_clear (); ++ state = ped_partition_is_busy (p->part); ++ if (py_ped_exception_string_check ()) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ return PyInt_FromLong (state); ++} +diff -urP parted-1.4.14/python/pydisk.h parted-1.4.14-python/python/pydisk.h +--- parted-1.4.14/python/pydisk.h Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pydisk.h Thu Dec 7 17:55:09 2000 +@@ -0,0 +1,45 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++#ifndef PYDISK_H_INCLUDED ++#define PYDISK_H_INCLUDED ++ ++#include <Python.h> ++ ++#include "parted/disk.h" ++ ++typedef struct _PyPedDisk PyPedDisk; ++ ++struct _PyPedDisk { ++ PyObject_HEAD; ++ PedDisk *disk; ++}; ++ ++extern PyTypeObject PyPedDiskType; ++ ++typedef struct _PyPedPartition PyPedPartition; ++ ++struct _PyPedPartition { ++ PyObject_HEAD; ++ PedPartition *part; ++ PyPedDisk *disk; ++ int borrowed; ++}; ++ ++extern PyTypeObject PyPedPartitionType; ++ ++extern PyPedPartition * py_ped_partition_obj_new (PedPartition *part, PyPedDisk *disk, ++ int borrowed); ++ ++#endif /* PYDISK_H_INCLUDED */ +diff -urP parted-1.4.14/python/pyexception.c parted-1.4.14-python/python/pyexception.c +--- parted-1.4.14/python/pyexception.c Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pyexception.c Tue Dec 5 17:31:50 2000 +@@ -0,0 +1,78 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++#include "pyexception.h" ++ ++static void py_ped_exception_dealloc (PyPedException * s); ++static PyObject * py_ped_exception_getattr (PyPedException * s, char * name); ++ ++static char PyPedExceptionType__doc__[] = "This is the PartEd exception object"; ++PyTypeObject PyPedExceptionType = { ++ PyObject_HEAD_INIT(&PyType_Type) ++ 0, /* ob_size */ ++ "PedException", /* tp_name */ ++ sizeof(PyPedException), /* tp_size */ ++ 0, /* tp_itemsize */ ++ (destructor) py_ped_exception_dealloc, /* tp_dealloc */ ++ 0, /* tp_print */ ++ (getattrfunc) py_ped_exception_getattr, /* 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*/ ++ 0, /*tp_str*/ ++ 0, /*tp_getattro*/ ++ 0, /*tp_setattro*/ ++ 0, /*tp_as_buffer*/ ++ 0L, /*tp_flags*/ ++ PyPedExceptionType__doc__, ++ 0L,0L,0L,0L ++}; ++ ++ ++/* exception implementation */ ++ ++static void ++py_ped_exception_dealloc (PyPedException * s) ++{ ++ PyMem_DEL(s); ++} ++ ++static PyObject * ++py_ped_exception_getattr (PyPedException * e, char * name) ++{ ++ if (!strcmp (name, "message")) ++ return PyString_FromString (e->ex->message); ++ else if (!strcmp (name, "type")) ++ return PyInt_FromLong (e->ex->type); ++ else if (!strcmp (name, "type_string")) ++ return PyString_FromString (ped_exception_get_type_string (e->ex->type)); ++ else if (!strcmp (name, "options")) ++ return PyInt_FromLong (e->ex->options); ++ return NULL; ++} ++ ++PyPedException * ++py_ped_exception_obj_new (PedException *ex) ++{ ++ PyPedException *e; ++ ++ e = (PyPedException *) PyObject_NEW(PyObject, &PyPedExceptionType); ++ e->ex = ex; ++ return e; ++} +diff -urP parted-1.4.14/python/pyexception.h parted-1.4.14-python/python/pyexception.h +--- parted-1.4.14/python/pyexception.h Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pyexception.h Thu Dec 7 09:45:26 2000 +@@ -0,0 +1,35 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++#ifndef PYEXCEPTION_H_INCLUDED ++#define PYEXCEPTION_H_INCLUDED ++ ++#include <Python.h> ++ ++#include "parted/exception.h" ++ ++extern PyTypeObject PyPedExceptionType; ++ ++typedef struct _PyPedException PyPedException; ++ ++struct _PyPedException { ++ PyObject_HEAD; ++ PedException *ex; ++}; ++ ++PyPedException * ++py_ped_exception_obj_new (PedException *ex); ++ ++#endif /* PYEXCEPTION_H_INCLUDED */ ++ +diff -urP parted-1.4.14/python/pyfilesystem.c parted-1.4.14-python/python/pyfilesystem.c +--- parted-1.4.14/python/pyfilesystem.c Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pyfilesystem.c Thu Dec 7 17:55:09 2000 +@@ -0,0 +1,228 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++#include "partedmodule.h" ++ ++#include "pyfilesystem.h" ++#include "pyconstraint.h" ++#include "pygeometry.h" ++ ++/* filesystem python object */ ++ ++static void py_ped_file_system_dealloc (PyPedFileSystem* fs); ++static PyObject * py_ped_file_system_getattr (PyPedFileSystem * fs, char * name); ++ ++static char PyPedFileSystemType__doc__[] = "This is the PartEd filesystem object"; ++PyTypeObject PyPedFileSystemType = { ++ PyObject_HEAD_INIT(&PyType_Type) ++ 0, /* ob_size */ ++ "PedFileSystem", /* tp_name */ ++ sizeof(PyPedFileSystem), /* tp_size */ ++ 0, /* tp_itemsize */ ++ (destructor) py_ped_file_system_dealloc, /* tp_dealloc */ ++ 0, /* tp_print */ ++ (getattrfunc) py_ped_file_system_getattr, /* 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 */ ++ 0, /* tp_str */ ++ 0, /* tp_getattro */ ++ 0, /* tp_setattro */ ++ 0, /* tp_as_buffer */ ++ 0L, /* tp_flags */ ++ PyPedFileSystemType__doc__, ++ 0L,0L,0L,0L ++}; ++ ++static PyObject * py_ped_file_system_check (PyPedFileSystem * fs, PyObject * args); ++static PyObject * py_ped_file_system_copy (PyPedFileSystem * fs, PyObject * args); ++static PyObject * py_ped_file_system_resize (PyPedFileSystem * fs, PyObject * args); ++static PyObject * py_ped_file_system_get_resize_constraint (PyPedFileSystem * fs, PyObject * args); ++ ++static struct PyMethodDef PyPedFileSystemMethods[] = { ++ { "check", (PyCFunction) py_ped_file_system_check, METH_VARARGS, NULL }, ++ { "copy", (PyCFunction) py_ped_file_system_copy, METH_VARARGS, NULL }, ++ { "resize", (PyCFunction) py_ped_file_system_resize, METH_VARARGS, NULL }, ++ { "get_resize_constraint", (PyCFunction) py_ped_file_system_get_resize_constraint, METH_VARARGS, NULL }, ++ { NULL, NULL, 0, NULL } ++}; ++ ++ ++/* file system type python object */ ++ ++static void py_ped_file_system_type_dealloc (PyPedFileSystemTypeObj* fst); ++static PyObject * py_ped_file_system_type_getattr (PyPedFileSystemTypeObj* fst, char * name); ++ ++static char PyPedFileSystemTypeType__doc__[] = "This is the PartEd filesystem object"; ++PyTypeObject PyPedFileSystemTypeType = { ++ PyObject_HEAD_INIT(&PyType_Type) ++ 0, /* ob_size */ ++ "PedFileSystemType", /* tp_name */ ++ sizeof(PyPedFileSystemType), /* tp_size */ ++ 0, /* tp_itemsize */ ++ (destructor) py_ped_file_system_type_dealloc, /* tp_dealloc */ ++ 0, /* tp_print */ ++ (getattrfunc) py_ped_file_system_type_getattr, /* 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 */ ++ 0, /* tp_str */ ++ 0, /* tp_getattro */ ++ 0, /* tp_setattro */ ++ 0, /* tp_as_buffer */ ++ 0L, /* tp_flags */ ++ PyPedFileSystemTypeType__doc__, ++ 0L,0L,0L,0L ++}; ++ ++static struct PyMethodDef PyPedFileSystemTypeMethods[] = { ++ { NULL, NULL, 0, NULL } ++}; ++ ++/* ++ * filesystem implementation ++ */ ++ ++PyPedFileSystem * ++py_ped_file_system_obj_new (PedFileSystem *filesys, ++ PyPedGeometry *geom) ++{ ++ PyPedFileSystem *fs; ++ ++ fs = (PyPedFileSystem *) PyObject_NEW(PyObject, &PyPedFileSystemType); ++ fs->fs = filesys; ++ fs->geom = geom; ++ Py_INCREF (geom); ++ return fs; ++} ++ ++static void ++py_ped_file_system_dealloc (PyPedFileSystem * fs) ++{ ++ ped_file_system_close (fs->fs); ++ Py_XDECREF (fs->geom); ++ PyMem_DEL(fs); ++} ++ ++static PyObject * ++py_ped_file_system_getattr (PyPedFileSystem * fs, char * name) ++{ ++ if (!strcmp (name, "type")) ++ return PyString_FromString (fs->fs->type->name); ++ if (!strcmp (name, "geom")) ++ return (PyObject *) py_ped_geometry_obj_new (fs->fs->geom, fs->geom->disk, 1); ++ return Py_FindMethod (PyPedFileSystemMethods, (PyObject *) fs, name); ++} ++ ++static PyObject * ++py_ped_file_system_check (PyPedFileSystem * fs, PyObject * args) ++{ ++ py_ped_exception_string_clear (); ++ if (!ped_file_system_check (fs->fs)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_file_system_copy (PyPedFileSystem * fs, PyObject * args) ++{ ++ PyPedGeometry *geom; ++ ++ if (!PyArg_ParseTuple(args, "O!", &PyPedGeometryType, &geom)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ if (!ped_file_system_copy (fs->fs, geom->geom)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_file_system_resize (PyPedFileSystem * fs, PyObject * args) ++{ ++ PyPedGeometry *geom; ++ ++ if (!PyArg_ParseTuple(args, "O!", &PyPedGeometryType, &geom)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ if (!ped_file_system_resize (fs->fs, geom->geom)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_file_system_get_resize_constraint (PyPedFileSystem * fs, PyObject * args) ++{ ++ PedConstraint *constraint; ++ ++ py_ped_exception_string_clear (); ++ if ((constraint = ped_file_system_get_resize_constraint (fs->fs)) == NULL) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ return (PyObject *) py_ped_constraint_obj_new (constraint, fs->geom->disk, 0); ++} ++ ++/* ++ * file system type implementation ++ */ ++ ++ ++PyPedFileSystemTypeObj * ++py_ped_file_system_type_obj_new (const PedFileSystemType *fs_type) ++{ ++ PyPedFileSystemTypeObj *fst; ++ ++ fst = (PyPedFileSystemTypeObj *) PyObject_NEW(PyObject, &PyPedFileSystemTypeType); ++ fst->fs_type = fs_type; ++ return fst; ++} ++ ++static void ++py_ped_file_system_type_dealloc (PyPedFileSystemTypeObj* fst) ++{ ++ PyMem_DEL(fst); ++} ++ ++static PyObject * ++py_ped_file_system_type_getattr (PyPedFileSystemTypeObj * fst, char * name) ++{ ++ if (!strcmp (name, "name")) ++ return PyString_FromString (fst->fs_type->name); ++ return NULL; ++} +diff -urP parted-1.4.14/python/pyfilesystem.h parted-1.4.14-python/python/pyfilesystem.h +--- parted-1.4.14/python/pyfilesystem.h Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pyfilesystem.h Thu Dec 7 17:55:09 2000 +@@ -0,0 +1,49 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++#ifndef PYFILESYSTEM_H_INCLUDED ++#define PYFILESYSTEM_H_INCLUDED ++ ++#include <Python.h> ++#include "parted/disk.h" ++#include "pygeometry.h" ++ ++typedef struct _PyPedFileSystem PyPedFileSystem; ++ ++struct _PyPedFileSystem { ++ PyObject_HEAD; ++ PedFileSystem* fs; ++ PyPedGeometry *geom; ++}; ++ ++extern PyTypeObject PyPedFileSystemType; ++ ++PyPedFileSystem * ++py_ped_file_system_obj_new (PedFileSystem* fs, ++ PyPedGeometry *geom); ++ ++typedef struct _PyPedFileSystemTypeObj PyPedFileSystemTypeObj; ++ ++struct _PyPedFileSystemTypeObj { ++ PyObject_HEAD; ++ const PedFileSystemType* fs_type; ++}; ++ ++extern PyTypeObject PyPedFileSystemTypeType; ++ ++PyPedFileSystemTypeObj* ++py_ped_file_system_type_obj_new (const PedFileSystemType* fs_type); ++ ++#endif /* PYFILESYSTEM_H_INCLUDED */ ++ +diff -urP parted-1.4.14/python/pygeometry.c parted-1.4.14-python/python/pygeometry.c +--- parted-1.4.14/python/pygeometry.c Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pygeometry.c Thu Apr 26 12:46:24 2001 +@@ -0,0 +1,245 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++#include "partedmodule.h" ++#include "pygeometry.h" ++#include "pyfilesystem.h" ++ ++static void py_ped_geometry_dealloc (PyPedGeometry * g); ++static PyObject * py_ped_geometry_getattr (PyPedGeometry * g, char * name); ++static int py_ped_geometry_setattr (PyPedGeometry * g, char * name, PyObject *value); ++ ++static char PyPedGeometryType__doc__[] = "This is the PartEd geometry object"; ++PyTypeObject PyPedGeometryType = { ++ PyObject_HEAD_INIT(&PyType_Type) ++ 0, /* ob_size */ ++ "PedGeometry", /* tp_name */ ++ sizeof(PyPedGeometry), /* tp_size */ ++ 0, /* tp_itemsize */ ++ (destructor) py_ped_geometry_dealloc, /* tp_dealloc */ ++ 0, /* tp_print */ ++ (getattrfunc) py_ped_geometry_getattr, /* tp_getattr */ ++ (setattrfunc) py_ped_geometry_setattr, /* 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 */ ++ 0, /* tp_str */ ++ 0, /* tp_getattro */ ++ 0, /* tp_setattro */ ++ 0, /* tp_as_buffer */ ++ 0L, /* tp_flags */ ++ PyPedGeometryType__doc__, ++ 0L,0L,0L,0L ++}; ++ ++/* geometry implementation */ ++ ++PyPedGeometry * ++py_ped_geometry_obj_new (PedGeometry* geom, PyPedDisk *disk, int borrowed) ++{ ++ PyPedGeometry *g; ++ ++ g = (PyPedGeometry *) PyObject_NEW (PyObject, &PyPedGeometryType); ++ g->geom = geom; ++ g->borrowed = borrowed; ++ g->disk = disk; ++ Py_INCREF (disk); ++ return g; ++} ++ ++static void ++py_ped_geometry_dealloc (PyPedGeometry * g) ++{ ++ if (!g->borrowed) ++ ped_geometry_destroy (g->geom); ++ Py_XDECREF (g->disk); ++ PyMem_DEL(g); ++} ++ ++static PyObject * ++py_ped_file_system_open (PyPedGeometry * self, PyObject * args) ++{ ++ PedFileSystem *fs; ++ PyPedFileSystem *pyfs; ++ ++ py_ped_exception_string_clear (); ++ if ((fs = ped_file_system_open (self->geom)) == NULL) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ pyfs = py_ped_file_system_obj_new (fs, self); ++ return (PyObject *) pyfs; ++} ++ ++static PyObject * ++py_ped_file_system_probe (PyPedGeometry * self, PyObject * args) ++{ ++ PedFileSystemType *fst; ++ ++ py_ped_exception_string_clear (); ++ if ((fst = ped_file_system_probe (self->geom)) == NULL) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ return (PyObject *) py_ped_file_system_type_obj_new (fst); ++} ++ ++static PyObject * ++py_ped_file_system_create (PyPedGeometry * self, PyObject * args) ++{ ++ PedFileSystem *fs; ++ PyPedFileSystemTypeObj *fs_type; ++ PyPedFileSystem *pyfs; ++ ++ if (!PyArg_ParseTuple(args, "O!", ++ &PyPedFileSystemTypeType, &fs_type)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ if ((fs = ped_file_system_create (self->geom, fs_type->fs_type)) == NULL) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ pyfs = py_ped_file_system_obj_new (fs, self); ++ return (PyObject *) pyfs; ++} ++ ++ ++static PyObject * ++py_ped_file_system_clobber (PyPedGeometry * self, PyObject * args) ++{ ++ py_ped_exception_string_clear (); ++ if (!ped_file_system_clobber (self->geom)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_geometry_set_end (PyPedGeometry * self, PyObject * args) ++{ ++ PedSector end; ++ ++ if (!PyArg_ParseTuple(args, "L", &end)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ if (!ped_geometry_set_end (self->geom, end)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++ ++static PyObject * ++py_ped_geometry_set_start (PyPedGeometry * self, PyObject * args) ++{ ++ PedSector start; ++ ++ if (!PyArg_ParseTuple(args, "L", &start)) ++ return NULL; ++ ++ py_ped_exception_string_clear (); ++ if (!ped_geometry_set_start (self->geom, start)) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ Py_INCREF(Py_None); ++ return Py_None; ++} ++ ++static PyObject * ++py_ped_geometry_duplicate (PyPedGeometry * self, PyObject * args) ++{ ++ PedGeometry *geom; ++ ++ py_ped_exception_string_clear (); ++ if ((geom = ped_geometry_duplicate (self->geom)) == NULL) { ++ py_ped_set_error_from_ped_exception (); ++ return NULL; ++ } ++ ++ return (PyObject *) py_ped_geometry_obj_new (geom, self->disk, 0); ++} ++ ++static struct PyMethodDef PyPedGeometryMethods[] = { ++ { "file_system_open", ++ (PyCFunction) py_ped_file_system_open, METH_VARARGS, NULL }, ++ { "file_system_probe", ++ (PyCFunction) py_ped_file_system_probe, METH_VARARGS, NULL }, ++ { "file_system_create", ++ (PyCFunction) py_ped_file_system_create, METH_VARARGS, NULL }, ++ { "file_system_clobber", ++ (PyCFunction) py_ped_file_system_clobber, METH_VARARGS, NULL }, ++ { "set_start", ++ (PyCFunction) py_ped_geometry_set_start, METH_VARARGS, NULL }, ++ { "set_end", ++ (PyCFunction) py_ped_geometry_set_end, METH_VARARGS, NULL }, ++ { "duplicate", ++ (PyCFunction) py_ped_geometry_duplicate, METH_VARARGS, NULL }, ++ ++ { NULL, NULL, 0, NULL } ++}; ++ ++static PyObject * ++py_ped_geometry_getattr (PyPedGeometry * g, char * name) ++{ ++ ++#define RETURN_GEOM_VALUE(var) \ ++ if (!strcmp (name, #var)) \ ++ return PyLong_FromLongLong (g->geom->var) ++ ++ RETURN_GEOM_VALUE(start); ++ RETURN_GEOM_VALUE(end); ++ RETURN_GEOM_VALUE(length); ++ ++ return Py_FindMethod (PyPedGeometryMethods, (PyObject *) g, name); ++} ++ ++static int ++py_ped_geometry_setattr (PyPedGeometry * g, char * name, PyObject *value) ++{ ++#define SET_GEOM_VALUE(var) \ ++ if (!strcmp (name, #var)) { \ ++ if (!PyLong_Check (value)) { \ ++ PyErr_SetString(PyExc_TypeError, \ ++ "expected long long"); \ ++ return -1; \ ++ } \ ++ g->geom->var = PyLong_AsLongLong (value); \ ++ return 0; \ ++ } ++ SET_GEOM_VALUE(start); ++ SET_GEOM_VALUE(end); ++ SET_GEOM_VALUE(length); ++ ++ PyErr_SetString( PyExc_AttributeError, "unknown attribute" ); ++ return -1; ++} ++ ++ +diff -urP parted-1.4.14/python/pygeometry.h parted-1.4.14-python/python/pygeometry.h +--- parted-1.4.14/python/pygeometry.h Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/pygeometry.h Thu Dec 7 17:55:09 2000 +@@ -0,0 +1,37 @@ ++/* -*- Mode: c; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- ++ * Matt Wilson <msw@redhat.com> ++ * ++ * Copyright 2000 Red Hat, Inc. ++ * ++ * This software may be freely redistributed under the terms of the GNU ++ * library public license. ++ * ++ * You should have received a copy of the GNU Library Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++#ifndef PYGEOMETRY_H_INCLUDED ++#define PYGEOMETRY_H_INCLUDED ++ ++#include <Python.h> ++ ++#include "pydisk.h" ++ ++typedef struct _PyPedGeometry PyPedGeometry; ++ ++struct _PyPedGeometry { ++ PyObject_HEAD; ++ PedGeometry* geom; ++ PyPedDisk *disk; ++ int borrowed; ++}; ++ ++extern PyTypeObject PyPedGeometryType; ++ ++PyPedGeometry * ++py_ped_geometry_obj_new (PedGeometry* geom, PyPedDisk *disk, int borrowed); ++ ++#endif /* PYGEOMETRY_H_INCLUDED */ ++ +diff -urP parted-1.4.14/python/test.py parted-1.4.14-python/python/test.py +--- parted-1.4.14/python/test.py Wed Dec 31 19:00:00 1969 ++++ parted-1.4.14-python/python/test.py Thu Apr 19 16:10:26 2001 +@@ -0,0 +1,128 @@ ++#!/usr/bin/env python ++ ++import sys ++for dir in ('.', ''): ++ try: ++ sys.path.remove(dir) ++ except ValueError: ++ pass ++sys.path = [ ".libs" ] + sys.path ++ ++import parted ++ ++def get_flags (part): ++ string="" ++ if not part.is_active (): ++ return string ++ first=1 ++ flag = parted.partition_flag_next (0) ++ while flag: ++ if part.get_flag (flag): ++ string = string + parted.partition_flag_get_name (flag) ++ if first: ++ first = 0 ++ else: ++ string = string + ", " ++ flag = parted.partition_flag_next (flag) ++ return string ++ ++def do_print (disk): ++ goodparts = { parted.PARTITION_PRIMARY : None, ++ parted.PARTITION_EXTENDED : None, ++ parted.PARTITION_LOGICAL : None, ++ parted.PARTITION_FREESPACE : None } ++ ++ print ("%s: %s length %ld, maximum " ++ "primary partitions: %d" % (disk.dev.path, disk.dev.model, ++ disk.dev.length, disk.max_primary_partition_count)) ++ ++ part = disk.next_partition() ++ if part: ++ print "Device Type Filesystem Start End Length Flags" ++ print "------ ---- ---------- ----- --- ------ -----" ++ while part: ++ if goodparts.has_key(part.type): ++ device = "" ++ fs_type_name = "" ++ if part.num > 0: ++ device = "%s%d" % (disk.dev.path, ++ part.num) ++ if part.fs_type: ++ fs_type_name = part.fs_type.name ++ flags = get_flags (part) ++ print ("%-9s %-12s %-12s %-10ld %-10ld %-10ld %7s" ++ % (device, part.type_name, fs_type_name, ++ part.geom.start, part.geom.end, part.geom.length, ++ flags)) ++ part = disk.next_partition(part) ++ print ++ ++def exception_handler(exception): ++ print "%s: %s" % (exception.type_string, exception.message) ++ return parted.EXCEPTION_UNHANDLED ++ ++parted.exception_set_handler (exception_handler) ++dev = parted.device_get ('/tmp/fstest') ++disk = dev.disk_open () ++ ++do_print (disk) ++part = disk.get_partition (0) ++fst = part.geom.file_system_probe () ++print "%s filesystem probed on device %s%d" % (fst.name, ++ disk.dev.path, ++ part.num) ++ ++fs = part.geom.file_system_open () ++fs.check() ++const = fs.get_resize_constraint() ++print "minimum size for this filesystem is %d sectors" % const.min_size ++print "start range from %d to %d" % (const.start_range.start, const.start_range.end) ++print "end range from %d to %d" % (const.end_range.start, const.end_range.end) ++ ++new_end = fs.geom.duplicate() ++#new_end.set_end (const.min_size + 512) ++new_end.set_end (const.end_range.end) ++fs.resize (new_end) ++ ++def foo(): ++ disk.delete_all () ++ do_print (disk) ++ ++ fs_type = parted.file_system_type_get ("ext2") ++ ++ sections = disk.dev.length / 4 ++ ++ # add a partition ++ newp = disk.partition_new (parted.PARTITION_PRIMARY, ++ fs_type, 0L, sections - 1) ++ newp.set_flag (parted.PARTITION_RAID, 1) ++ constraint = disk.constraint_any () ++ disk.add_partition (newp, constraint) ++ do_print (disk) ++ ++ # add another... ++ newp = disk.partition_new (parted.PARTITION_PRIMARY, ++ fs_type, sections, 2 * sections - 1) ++ newp.set_flag (parted.PARTITION_RAID, 1) ++ constraint = disk.constraint_any () ++ disk.add_partition (newp, constraint) ++ do_print (disk) ++ ++ # another ++ newp = disk.partition_new (parted.PARTITION_PRIMARY, ++ fs_type, 2 * sections, 3 * sections - 1) ++ newp.set_flag (parted.PARTITION_RAID, 1) ++ constraint = disk.constraint_any () ++ disk.add_partition (newp, constraint) ++ do_print (disk) ++ ++ # another... ++ newp = disk.partition_new (parted.PARTITION_PRIMARY, ++ fs_type, 3 * sections, 4 * sections - 1) ++ newp.set_flag (parted.PARTITION_RAID, 1) ++ constraint = disk.constraint_any () ++ disk.add_partition (newp, constraint) ++ do_print (disk) ++ ++ disk.write() ++ |