#include "header-py.h"
#include "rpmfi-py.h"
-#include "debug.h"
-
struct rpmfiObject_s {
PyObject_HEAD
PyObject *md_dict; /*!< to look like PyModuleObject */
};
static PyObject *
-rpmfi_FC(rpmfiObject * s)
+rpmfi_FC(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("i", rpmfiFC(s->fi));
}
static PyObject *
-rpmfi_FX(rpmfiObject * s)
+rpmfi_FX(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("i", rpmfiFX(s->fi));
}
static PyObject *
-rpmfi_DC(rpmfiObject * s)
+rpmfi_DC(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("i", rpmfiDC(s->fi));
}
static PyObject *
-rpmfi_DX(rpmfiObject * s)
+rpmfi_DX(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("i", rpmfiDX(s->fi));
}
static PyObject *
-rpmfi_BN(rpmfiObject * s)
+rpmfi_BN(rpmfiObject * s, PyObject * unused)
{
- return Py_BuildValue("s", xstrdup(rpmfiBN(s->fi)));
+ return Py_BuildValue("s", rpmfiBN(s->fi));
}
static PyObject *
-rpmfi_DN(rpmfiObject * s)
+rpmfi_DN(rpmfiObject * s, PyObject * unused)
{
- return Py_BuildValue("s", xstrdup(rpmfiDN(s->fi)));
+ return Py_BuildValue("s", rpmfiDN(s->fi));
}
static PyObject *
-rpmfi_FN(rpmfiObject * s)
+rpmfi_FN(rpmfiObject * s, PyObject * unused)
{
- return Py_BuildValue("s", xstrdup(rpmfiFN(s->fi)));
+ return Py_BuildValue("s", rpmfiFN(s->fi));
}
static PyObject *
-rpmfi_FFlags(rpmfiObject * s)
+rpmfi_FFlags(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("i", rpmfiFFlags(s->fi));
}
static PyObject *
-rpmfi_VFlags(rpmfiObject * s)
+rpmfi_VFlags(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("i", rpmfiVFlags(s->fi));
}
static PyObject *
-rpmfi_FMode(rpmfiObject * s)
+rpmfi_FMode(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("i", rpmfiFMode(s->fi));
}
static PyObject *
-rpmfi_FState(rpmfiObject * s)
+rpmfi_FState(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("i", rpmfiFState(s->fi));
}
/* XXX rpmfiFDigest */
static PyObject *
-rpmfi_Digest(rpmfiObject * s)
+rpmfi_Digest(rpmfiObject * s, PyObject * unused)
{
char *digest = rpmfiFDigestHex(s->fi, NULL);
if (digest) {
}
static PyObject *
-rpmfi_FLink(rpmfiObject * s)
+rpmfi_FLink(rpmfiObject * s, PyObject * unused)
{
- return Py_BuildValue("s", xstrdup(rpmfiFLink(s->fi)));
+ return Py_BuildValue("s", rpmfiFLink(s->fi));
}
static PyObject *
-rpmfi_FSize(rpmfiObject * s)
+rpmfi_FSize(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("L", rpmfiFSize(s->fi));
}
static PyObject *
-rpmfi_FRdev(rpmfiObject * s)
+rpmfi_FRdev(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("i", rpmfiFRdev(s->fi));
}
static PyObject *
-rpmfi_FMtime(rpmfiObject * s)
+rpmfi_FMtime(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("i", rpmfiFMtime(s->fi));
}
static PyObject *
-rpmfi_FUser(rpmfiObject * s)
+rpmfi_FUser(rpmfiObject * s, PyObject * unused)
{
- return Py_BuildValue("s", xstrdup(rpmfiFUser(s->fi)));
+ return Py_BuildValue("s", rpmfiFUser(s->fi));
}
static PyObject *
-rpmfi_FGroup(rpmfiObject * s)
+rpmfi_FGroup(rpmfiObject * s, PyObject * unused)
{
- return Py_BuildValue("s", xstrdup(rpmfiFGroup(s->fi)));
+ return Py_BuildValue("s", rpmfiFGroup(s->fi));
}
static PyObject *
-rpmfi_FColor(rpmfiObject * s)
+rpmfi_FColor(rpmfiObject * s, PyObject * unused)
{
return Py_BuildValue("i", rpmfiFColor(s->fi));
}
static PyObject *
-rpmfi_FClass(rpmfiObject * s)
+rpmfi_FClass(rpmfiObject * s, PyObject * unused)
{
const char * FClass;
if ((FClass = rpmfiFClass(s->fi)) == NULL)
FClass = "";
- return Py_BuildValue("s", xstrdup(FClass));
+ return Py_BuildValue("s", FClass);
}
static PyObject *
PyTuple_SET_ITEM(result, 11, Py_None);
} else
PyTuple_SET_ITEM(result, 11, Py_BuildValue("s", FGroup));
- PyTuple_SET_ITEM(result, 12, rpmfi_Digest(s));
+ PyTuple_SET_ITEM(result, 12, rpmfi_Digest(s, NULL));
} else
s->active = 0;
static void
rpmfi_dealloc(rpmfiObject * s)
{
- if (s) {
- s->fi = rpmfiFree(s->fi);
- PyObject_Del(s);
- }
-}
-
-static int
-rpmfi_print(rpmfiObject * s, FILE * fp, int flags)
-{
- if (!(s && s->fi))
- return -1;
-
- s->fi = rpmfiInit(s->fi, 0);
- while (rpmfiNext(s->fi) >= 0)
- fprintf(fp, "%s\n", rpmfiFN(s->fi));
- return 0;
+ s->fi = rpmfiFree(s->fi);
+ Py_TYPE(s)->tp_free((PyObject *)s);
}
static int
ix = (int) PyInt_AsLong(key);
rpmfiSetFX(s->fi, ix);
- return Py_BuildValue("s", xstrdup(rpmfiFN(s->fi)));
+ return Py_BuildValue("s", rpmfiFN(s->fi));
}
static PyMappingMethods rpmfi_as_mapping = {
return 0;
}
-static void rpmfi_free(rpmfiObject * s)
-{
- s->fi = rpmfiFree(s->fi);
-
- PyObject_Del((PyObject *)s);
-}
-
static PyObject * rpmfi_new(PyTypeObject * subtype, PyObject *args, PyObject *kwds)
{
- hdrObject * ho = NULL;
PyObject * to = NULL;
+ Header h = NULL;
rpmfi fi = NULL;
- rpmTag tagN = RPMTAG_BASENAMES;
+ rpmTagVal tagN = RPMTAG_BASENAMES;
int flags = 0;
char * kwlist[] = {"header", "tag", "flags", NULL};
- if (!PyArg_ParseTupleAndKeywords(args, kwds, "O!|Oi:rpmfi_init", kwlist,
- &hdr_Type, &ho, &to, &flags))
+ if (!PyArg_ParseTupleAndKeywords(args, kwds, "O&|Oi:rpmfi_init", kwlist,
+ hdrFromPyObject, &h, &to, &flags))
return NULL;
- if (to != NULL) {
- tagN = tagNumFromPyObject(to);
- if (tagN == RPMTAG_NOT_FOUND) return NULL;
+ fi = rpmfiNew(NULL, h, tagN, flags);
+
+ if (fi == NULL) {
+ PyErr_SetString(PyExc_ValueError, "invalid file data in header");
+ return NULL;
}
- fi = rpmfiNew(NULL, hdrGetHeader(ho), tagN, flags);
- return rpmfi_Wrap(fi);
+ return rpmfi_Wrap(subtype, fi);
}
static char rpmfi_doc[] =
"";
PyTypeObject rpmfi_Type = {
- PyObject_HEAD_INIT(&PyType_Type)
- 0, /* ob_size */
+ PyVarObject_HEAD_INIT(&PyType_Type, 0)
"rpm.fi", /* tp_name */
sizeof(rpmfiObject), /* tp_basicsize */
0, /* tp_itemsize */
/* methods */
(destructor) rpmfi_dealloc, /* tp_dealloc */
- (printfunc) rpmfi_print, /* tp_print */
+ 0, /* tp_print */
(getattrfunc)0, /* tp_getattr */
(setattrfunc)0, /* tp_setattr */
- (cmpfunc)0, /* tp_compare */
+ 0, /* tp_compare */
(reprfunc)0, /* tp_repr */
0, /* tp_as_number */
0, /* tp_as_sequence */
PyObject_GenericGetAttr, /* tp_getattro */
PyObject_GenericSetAttr, /* tp_setattro */
0, /* tp_as_buffer */
- Py_TPFLAGS_DEFAULT, /* tp_flags */
+ Py_TPFLAGS_DEFAULT|Py_TPFLAGS_BASETYPE, /* tp_flags */
rpmfi_doc, /* tp_doc */
0, /* tp_traverse */
0, /* tp_clear */
(initproc) rpmfi_init, /* tp_init */
0, /* tp_alloc */
(newfunc) rpmfi_new, /* tp_new */
- (freefunc) rpmfi_free, /* tp_free */
+ 0, /* tp_free */
0, /* tp_is_gc */
};
return s->fi;
}
-PyObject * rpmfi_Wrap(rpmfi fi)
+PyObject * rpmfi_Wrap(PyTypeObject *subtype, rpmfi fi)
{
- rpmfiObject *s = PyObject_New(rpmfiObject, &rpmfi_Type);
- if (s == NULL) return PyErr_NoMemory();
+ rpmfiObject *s = (rpmfiObject *)subtype->tp_alloc(subtype, 0);
+ if (s == NULL) return NULL;
s->fi = fi;
s->active = 0;