py_term.h 3.8 KB

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