py_term.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. #ifndef _PY_TERM_OBJ_H
  2. #define _PY_TERM_OBJ_H
  3. #define PY_SSIZE_T_CLEAN
  4. #include <Python.h>
  5. #include <structmember.h>
  6. #include "term.h"
  7. typedef struct {
  8. PyObject_HEAD
  9. LSUP_Term * ob_struct;
  10. } TermObject;
  11. static int
  12. Term_init (TermObject *self, PyObject *args, PyObject *kwargs)
  13. {
  14. unsigned char term_type;
  15. char *data = NULL, *datatype = NULL, *lang = NULL;
  16. static char *kwlist[] = {"", "", "datatype", "lang", NULL};
  17. if (!PyArg_ParseTupleAndKeywords (
  18. args, kwargs, "bs|zz", kwlist,
  19. &term_type, &data, &datatype, &lang))
  20. return -1;
  21. self->ob_struct = LSUP_term_new ((LSUP_term_type)term_type, data, datatype, lang);
  22. if (!self->ob_struct) {
  23. PyErr_SetString (PyExc_ValueError, "Could not create term.");
  24. return -1;
  25. }
  26. return 0;
  27. }
  28. static void
  29. Term_dealloc (TermObject *self)
  30. {
  31. LSUP_term_free (self->ob_struct);
  32. Py_TYPE (self)->tp_free ((PyObject *) self);
  33. }
  34. static PyObject *
  35. Term_get_type (TermObject *self, void *closure)
  36. {
  37. PyObject *type = PyLong_FromLong (self->ob_struct->type);
  38. Py_INCREF (type);
  39. return type;
  40. }
  41. static PyObject *
  42. Term_get_data (TermObject *self, void *closure)
  43. {
  44. PyObject *data = PyUnicode_FromString (self->ob_struct->data);
  45. Py_INCREF (data);
  46. return data;
  47. }
  48. static PyObject *
  49. Term_get_datatype (TermObject *self, void *closure)
  50. {
  51. if (!self->ob_struct->datatype) Py_RETURN_NONE;
  52. PyObject *datatype = PyUnicode_FromString (self->ob_struct->datatype);
  53. Py_INCREF (datatype);
  54. return datatype;
  55. }
  56. static PyObject *
  57. Term_get_lang (TermObject *self, void *closure)
  58. {
  59. if (
  60. !self->ob_struct->datatype || !self->ob_struct->lang ||
  61. strlen (self->ob_struct->lang) == 0)
  62. Py_RETURN_NONE;
  63. PyObject *lang = PyUnicode_FromString (self->ob_struct->lang);
  64. Py_INCREF (lang);
  65. return lang;
  66. }
  67. static PyGetSetDef Term_getsetters[] = {
  68. {"type", (getter) Term_get_type, NULL, "Term type.", NULL},
  69. {"data", (getter) Term_get_data, NULL, "Term data.", NULL},
  70. {
  71. "datatype", (getter) Term_get_datatype,
  72. NULL, "Literal term data type.", NULL
  73. },
  74. {
  75. "lang", (getter) Term_get_lang,
  76. NULL, "Literal term language tag.", NULL
  77. },
  78. {NULL}
  79. };
  80. static PyObject *
  81. Term_richcmp (PyObject *obj1, PyObject *obj2, int op);
  82. static Py_hash_t
  83. Term_hash (PyObject *self)
  84. { return LSUP_term_hash (((TermObject *)self)->ob_struct); }
  85. PyTypeObject TermType = {
  86. PyVarObject_HEAD_INIT(NULL, 0)
  87. .tp_name = "term.Term",
  88. .tp_doc = "RDF term",
  89. .tp_basicsize = sizeof (TermObject),
  90. .tp_itemsize = 0,
  91. .tp_flags = Py_TPFLAGS_DEFAULT,
  92. .tp_new = PyType_GenericNew,
  93. .tp_init = (initproc) Term_init,
  94. .tp_dealloc = (destructor) Term_dealloc,
  95. .tp_getset = Term_getsetters,
  96. .tp_richcompare = Term_richcmp,
  97. .tp_hash = Term_hash,
  98. };
  99. static PyObject *
  100. Term_richcmp (PyObject *obj1, PyObject *obj2, int op)
  101. {
  102. PyObject *result = NULL;
  103. if (
  104. ! PyObject_TypeCheck (obj1, &TermType) ||
  105. ! PyObject_TypeCheck (obj2, &TermType)
  106. ) return NULL;
  107. int c = 0;
  108. LSUP_Term *t1 = ((TermObject *) obj1)->ob_struct;
  109. LSUP_Term *t2 = ((TermObject *) obj2)->ob_struct;
  110. switch (op) {
  111. case Py_LT: result = Py_NotImplemented; break;
  112. case Py_LE: result = Py_NotImplemented; break;
  113. case Py_EQ: c = LSUP_term_equals (t1, t2); break;
  114. case Py_NE: c = ! LSUP_term_equals (t1, t2); break;
  115. case Py_GT: result = Py_NotImplemented; break;
  116. case Py_GE: result = Py_NotImplemented; break;
  117. }
  118. if (!result) result = c ? Py_True : Py_False;
  119. Py_INCREF(result);
  120. return result;
  121. }
  122. // END _PY_TERM_OBJ_H
  123. #endif