Generated by Cython 0.16 on Thu Jun 7 12:13:17 2012
Raw output: cfuzzyset.c
1: # encoding: utf-8
2:
3: import re
/* "cfuzzyset.pyx":3 * # encoding: utf-8 * * import re #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* import math * import cython */ __pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__re), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 3; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (PyObject_SetAttr(__pyx_m, __pyx_n_s__re, __pyx_t_1)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 3; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
4: import math
/* "cfuzzyset.pyx":4 * * import re * import math #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* import cython * import operator */ __pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__math), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (PyObject_SetAttr(__pyx_m, __pyx_n_s__math, __pyx_t_1)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
5: import cython
6: import operator
/* "cfuzzyset.pyx":6 * import math * import cython * import operator #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* import collections * import Levenshtein */ __pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__operator), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 6; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (PyObject_SetAttr(__pyx_m, __pyx_n_s__operator, __pyx_t_1)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 6; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
7: import collections
/* "cfuzzyset.pyx":7 * import cython * import operator * import collections #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* import Levenshtein * */ __pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__collections), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 7; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (PyObject_SetAttr(__pyx_m, __pyx_n_s__collections, __pyx_t_1)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 7; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
8: import Levenshtein
/* "cfuzzyset.pyx":8 * import operator * import collections * import Levenshtein #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * __version__ = (0, 0, 6) */ __pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__Levenshtein), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 8; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (PyObject_SetAttr(__pyx_m, __pyx_n_s__Levenshtein, __pyx_t_1)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 8; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
9:
10: __version__ = (0, 0, 6)
/* "cfuzzyset.pyx":10 * import Levenshtein * * __version__ = (0, 0, 6) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * from libc.math cimport sqrt */ if (PyObject_SetAttr(__pyx_m, __pyx_n_s____version__, ((PyObject *)__pyx_k_tuple_6))<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 10; __pyx_clineno = __LINE__; goto __pyx_L1_error;} /* "cfuzzyset.pyx":10 * import Levenshtein * * __version__ = (0, 0, 6) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * from libc.math cimport sqrt */ __pyx_k_tuple_6 = PyTuple_New(3); if (unlikely(!__pyx_k_tuple_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 10; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_6); __Pyx_INCREF(__pyx_int_0); PyTuple_SET_ITEM(__pyx_k_tuple_6, 0, __pyx_int_0); __Pyx_GIVEREF(__pyx_int_0); __Pyx_INCREF(__pyx_int_0); PyTuple_SET_ITEM(__pyx_k_tuple_6, 1, __pyx_int_0); __Pyx_GIVEREF(__pyx_int_0); __Pyx_INCREF(__pyx_int_6); PyTuple_SET_ITEM(__pyx_k_tuple_6, 2, __pyx_int_6); __Pyx_GIVEREF(__pyx_int_6); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_6));
11:
12: from libc.math cimport sqrt
13:
14: cdef _non_word_re = re.compile(r'[^\w, ]+')
/* "cfuzzyset.pyx":14 * from libc.math cimport sqrt * * cdef _non_word_re = re.compile(r'[^\w, ]+') #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * cdef class cFuzzySet: */ __pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__re); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 14; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__compile); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 14; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_k_tuple_8), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 14; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_XGOTREF(__pyx_v_9cfuzzyset__non_word_re); __Pyx_DECREF(__pyx_v_9cfuzzyset__non_word_re); __Pyx_GIVEREF(__pyx_t_1); __pyx_v_9cfuzzyset__non_word_re = __pyx_t_1; __pyx_t_1 = 0;
15:
16: cdef class cFuzzySet:
/* "cfuzzyset.pyx":16 * cdef _non_word_re = re.compile(r'[^\w, ]+') * * cdef class cFuzzySet: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* " Fuzzily match a string " * */ struct __pyx_obj_9cfuzzyset_cFuzzySet { PyObject_HEAD struct __pyx_vtabstruct_9cfuzzyset_cFuzzySet *__pyx_vtab; PyObject *exact_set; PyObject *match_dict; PyObject *items; int gram_size_lower; int gram_size_upper; int use_levenshtein; }; struct __pyx_vtabstruct_9cfuzzyset_cFuzzySet { PyObject *(*_add)(struct __pyx_obj_9cfuzzyset_cFuzzySet *, PyObject *, int, int __pyx_skip_dispatch); PyObject *(*_get)(struct __pyx_obj_9cfuzzyset_cFuzzySet *, PyObject *, int, int __pyx_skip_dispatch); }; static struct __pyx_vtabstruct_9cfuzzyset_cFuzzySet *__pyx_vtabptr_9cfuzzyset_cFuzzySet;
17: " Fuzzily match a string "
18:
19: cdef dict exact_set
20: cdef dict match_dict
21: cdef dict items
22: cdef int gram_size_lower
23: cdef int gram_size_upper
24: cdef int use_levenshtein
25:
26: def __cinit__(self, iterable=(), int gram_size_lower=2, int gram_size_upper=3, int use_levenshtein=True):
/* "cfuzzyset.pyx":26 * cdef int use_levenshtein * * def __cinit__(self, iterable=(), int gram_size_lower=2, int gram_size_upper=3, int use_levenshtein=True): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* assert gram_size_upper<
4 and gram_size_upper > 0 * assert gram_size_lower<
4 and gram_size_lower > 0 */ values[0] = ((PyObject *)__pyx_empty_tuple); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3); case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__iterable); if (value) { values[0] = value; kw_args--; } } case 1: if (kw_args > 0) { PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__gram_size_lower); if (value) { values[1] = value; kw_args--; } } case 2: if (kw_args > 0) { PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__gram_size_upper); if (value) { values[2] = value; kw_args--; } } case 3: if (kw_args > 0) { PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__use_levenshtein); if (value) { values[3] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "__cinit__")<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 26; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } if (values[1]) { } else { __pyx_v_gram_size_lower = ((int)2); } if (values[2]) { } else { __pyx_v_gram_size_upper = ((int)3); } if (values[3]) { } else { __pyx_v_use_levenshtein = ((int)1); } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3); case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_iterable = values[0]; if (values[1]) { __pyx_v_gram_size_lower = __Pyx_PyInt_AsInt(values[1]); if (unlikely((__pyx_v_gram_size_lower == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 26; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } else { __pyx_v_gram_size_lower = ((int)2); } if (values[2]) { __pyx_v_gram_size_upper = __Pyx_PyInt_AsInt(values[2]); if (unlikely((__pyx_v_gram_size_upper == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 26; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } else { __pyx_v_gram_size_upper = ((int)3); } if (values[3]) { __pyx_v_use_levenshtein = __Pyx_PyInt_AsInt(values[3]); if (unlikely((__pyx_v_use_levenshtein == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 26; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } else { __pyx_v_use_levenshtein = ((int)1); } } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("__cinit__", 0, 0, 4, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 26; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("cfuzzyset.cFuzzySet.__cinit__", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return -1; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_9cfuzzyset_9cFuzzySet___cinit__(((struct __pyx_obj_9cfuzzyset_cFuzzySet *)__pyx_v_self), __pyx_v_iterable, __pyx_v_gram_size_lower, __pyx_v_gram_size_upper, __pyx_v_use_levenshtein); __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_9cfuzzyset_9cFuzzySet___cinit__(struct __pyx_obj_9cfuzzyset_cFuzzySet *__pyx_v_self, PyObject *__pyx_v_iterable, int __pyx_v_gram_size_lower, int __pyx_v_gram_size_upper, int __pyx_v_use_levenshtein) { int __pyx_v_i; PyObject *__pyx_v_value = NULL; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__cinit__", 0);
27: assert gram_size_upper < 4 and gram_size_upper > 0
/* "cfuzzyset.pyx":27 * * def __cinit__(self, iterable=(), int gram_size_lower=2, int gram_size_upper=3, int use_levenshtein=True): * assert gram_size_upper<
4 and gram_size_upper > 0 #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* assert gram_size_lower<
4 and gram_size_lower > 0 * assert gram_size_lower<
= gram_size_upper */ #ifndef CYTHON_WITHOUT_ASSERTIONS __pyx_t_1 = (__pyx_v_gram_size_upper<
4); if (__pyx_t_1) { __pyx_t_2 = (__pyx_v_gram_size_upper > 0); __pyx_t_3 = __pyx_t_2; } else { __pyx_t_3 = __pyx_t_1; } if (unlikely(!__pyx_t_3)) { PyErr_SetNone(PyExc_AssertionError); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 27; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } #endif
28: assert gram_size_lower < 4 and gram_size_lower > 0
/* "cfuzzyset.pyx":28 * def __cinit__(self, iterable=(), int gram_size_lower=2, int gram_size_upper=3, int use_levenshtein=True): * assert gram_size_upper<
4 and gram_size_upper > 0 * assert gram_size_lower<
4 and gram_size_lower > 0 #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* assert gram_size_lower<
= gram_size_upper * self.exact_set = {} */ #ifndef CYTHON_WITHOUT_ASSERTIONS __pyx_t_3 = (__pyx_v_gram_size_lower<
4); if (__pyx_t_3) { __pyx_t_1 = (__pyx_v_gram_size_lower > 0); __pyx_t_2 = __pyx_t_1; } else { __pyx_t_2 = __pyx_t_3; } if (unlikely(!__pyx_t_2)) { PyErr_SetNone(PyExc_AssertionError); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 28; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } #endif
29: assert gram_size_lower <= gram_size_upper
/* "cfuzzyset.pyx":29 * assert gram_size_upper<
4 and gram_size_upper > 0 * assert gram_size_lower<
4 and gram_size_lower > 0 * assert gram_size_lower<
= gram_size_upper #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* self.exact_set = {} * self.match_dict = {} */ #ifndef CYTHON_WITHOUT_ASSERTIONS if (unlikely(!(__pyx_v_gram_size_lower<
= __pyx_v_gram_size_upper))) { PyErr_SetNone(PyExc_AssertionError); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } #endif
30: self.exact_set = {}
/* "cfuzzyset.pyx":30 * assert gram_size_lower<
4 and gram_size_lower > 0 * assert gram_size_lower<
= gram_size_upper * self.exact_set = {} #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* self.match_dict = {} * self.items = {} */ __pyx_t_4 = PyDict_New(); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 30; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_4)); __Pyx_GIVEREF(((PyObject *)__pyx_t_4)); __Pyx_GOTREF(__pyx_v_self->exact_set); __Pyx_DECREF(((PyObject *)__pyx_v_self->exact_set)); __pyx_v_self->exact_set = __pyx_t_4; __pyx_t_4 = 0;
31: self.match_dict = {}
/* "cfuzzyset.pyx":31 * assert gram_size_lower<
= gram_size_upper * self.exact_set = {} * self.match_dict = {} #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* self.items = {} * cdef int i */ __pyx_t_4 = PyDict_New(); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 31; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_4)); __Pyx_GIVEREF(((PyObject *)__pyx_t_4)); __Pyx_GOTREF(__pyx_v_self->match_dict); __Pyx_DECREF(((PyObject *)__pyx_v_self->match_dict)); __pyx_v_self->match_dict = __pyx_t_4; __pyx_t_4 = 0;
32: self.items = {}
/* "cfuzzyset.pyx":32 * self.exact_set = {} * self.match_dict = {} * self.items = {} #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef int i * for i in range(gram_size_lower, gram_size_upper + 1): */ __pyx_t_4 = PyDict_New(); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 32; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_4)); __Pyx_GIVEREF(((PyObject *)__pyx_t_4)); __Pyx_GOTREF(__pyx_v_self->items); __Pyx_DECREF(((PyObject *)__pyx_v_self->items)); __pyx_v_self->items = __pyx_t_4; __pyx_t_4 = 0;
33: cdef int i
34: for i in range(gram_size_lower, gram_size_upper + 1):
/* "cfuzzyset.pyx":34 * self.items = {} * cdef int i * for i in range(gram_size_lower, gram_size_upper + 1): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* self.items[i] = [] * self.gram_size_lower = gram_size_lower */ __pyx_t_5 = (__pyx_v_gram_size_upper + 1); for (__pyx_t_6 = __pyx_v_gram_size_lower; __pyx_t_6<
__pyx_t_5; __pyx_t_6+=1) { __pyx_v_i = __pyx_t_6;
35: self.items[i] = []
/* "cfuzzyset.pyx":35 * cdef int i * for i in range(gram_size_lower, gram_size_upper + 1): * self.items[i] = [] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* self.gram_size_lower = gram_size_lower * self.gram_size_upper = gram_size_upper */ __pyx_t_4 = PyList_New(0); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 35; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); if (__Pyx_SetItemInt(((PyObject *)__pyx_v_self->items), __pyx_v_i, ((PyObject *)__pyx_t_4), sizeof(int), PyInt_FromLong)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 35; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0; }
36: self.gram_size_lower = gram_size_lower
/* "cfuzzyset.pyx":36 * for i in range(gram_size_lower, gram_size_upper + 1): * self.items[i] = [] * self.gram_size_lower = gram_size_lower #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* self.gram_size_upper = gram_size_upper * self.use_levenshtein = use_levenshtein */ __pyx_v_self->gram_size_lower = __pyx_v_gram_size_lower;
37: self.gram_size_upper = gram_size_upper
/* "cfuzzyset.pyx":37 * self.items[i] = [] * self.gram_size_lower = gram_size_lower * self.gram_size_upper = gram_size_upper #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* self.use_levenshtein = use_levenshtein * for value in iterable: */ __pyx_v_self->gram_size_upper = __pyx_v_gram_size_upper;
38: self.use_levenshtein = use_levenshtein
/* "cfuzzyset.pyx":38 * self.gram_size_lower = gram_size_lower * self.gram_size_upper = gram_size_upper * self.use_levenshtein = use_levenshtein #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for value in iterable: * self.add(value) */ __pyx_v_self->use_levenshtein = __pyx_v_use_levenshtein;
39: for value in iterable:
/* "cfuzzyset.pyx":39 * self.gram_size_upper = gram_size_upper * self.use_levenshtein = use_levenshtein * for value in iterable: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* self.add(value) * */ if (PyList_CheckExact(__pyx_v_iterable) || PyTuple_CheckExact(__pyx_v_iterable)) { __pyx_t_4 = __pyx_v_iterable; __Pyx_INCREF(__pyx_t_4); __pyx_t_7 = 0; __pyx_t_8 = NULL; } else { __pyx_t_7 = -1; __pyx_t_4 = PyObject_GetIter(__pyx_v_iterable); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 39; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_8 = Py_TYPE(__pyx_t_4)->tp_iternext; } for (;;) { if (!__pyx_t_8 && PyList_CheckExact(__pyx_t_4)) { if (__pyx_t_7 >= PyList_GET_SIZE(__pyx_t_4)) break; __pyx_t_9 = PyList_GET_ITEM(__pyx_t_4, __pyx_t_7); __Pyx_INCREF(__pyx_t_9); __pyx_t_7++; } else if (!__pyx_t_8 && PyTuple_CheckExact(__pyx_t_4)) { if (__pyx_t_7 >= PyTuple_GET_SIZE(__pyx_t_4)) break; __pyx_t_9 = PyTuple_GET_ITEM(__pyx_t_4, __pyx_t_7); __Pyx_INCREF(__pyx_t_9); __pyx_t_7++; } else { __pyx_t_9 = __pyx_t_8(__pyx_t_4); if (unlikely(!__pyx_t_9)) { if (PyErr_Occurred()) { if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear(); else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 39; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } break; } __Pyx_GOTREF(__pyx_t_9); } __Pyx_XDECREF(__pyx_v_value); __pyx_v_value = __pyx_t_9; __pyx_t_9 = 0;
40: self.add(value)
/* "cfuzzyset.pyx":40 * self.use_levenshtein = use_levenshtein * for value in iterable: * self.add(value) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * def add(self, object in_val): */ __pyx_t_9 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__add); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 40; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __pyx_t_10 = PyTuple_New(1); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 40; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_10); __Pyx_INCREF(__pyx_v_value); PyTuple_SET_ITEM(__pyx_t_10, 0, __pyx_v_value); __Pyx_GIVEREF(__pyx_v_value); __pyx_t_11 = PyObject_Call(__pyx_t_9, ((PyObject *)__pyx_t_10), NULL); if (unlikely(!__pyx_t_11)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 40; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_11); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_10)); __pyx_t_10 = 0; __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; } __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_9); __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_11); __Pyx_AddTraceback("cfuzzyset.cFuzzySet.__cinit__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_XDECREF(__pyx_v_value); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_3add(PyObject *__pyx_v_self, PyObject *__pyx_v_in_val); /*proto*/ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_3add(PyObject *__pyx_v_self, PyObject *__pyx_v_in_val) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("add (wrapper)", 0); __pyx_r = __pyx_pf_9cfuzzyset_9cFuzzySet_2add(((struct __pyx_obj_9cfuzzyset_cFuzzySet *)__pyx_v_self), ((PyObject *)__pyx_v_in_val)); __Pyx_RefNannyFinishContext(); return __pyx_r; }
41:
42: def add(self, object in_val):
/* "cfuzzyset.pyx":42 * self.add(value) * * def add(self, object in_val): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* value = _convert_val(in_val) * cdef unicode lvalue */ static PyObject *__pyx_pf_9cfuzzyset_9cFuzzySet_2add(struct __pyx_obj_9cfuzzyset_cFuzzySet *__pyx_v_self, PyObject *__pyx_v_in_val) { PyObject *__pyx_v_value = NULL; PyObject *__pyx_v_lvalue = 0; int __pyx_v_i; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("add", 0);
43: value = _convert_val(in_val)
/* "cfuzzyset.pyx":43 * * def add(self, object in_val): * value = _convert_val(in_val) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef unicode lvalue * with cython.nonecheck(True): */ __pyx_t_1 = ((PyObject *)__pyx_f_9cfuzzyset__convert_val(__pyx_v_in_val)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 43; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_v_value = ((PyObject*)__pyx_t_1); __pyx_t_1 = 0;
44: cdef unicode lvalue
45: with cython.nonecheck(True):
46: lvalue = value.lower()
/* "cfuzzyset.pyx":46 * cdef unicode lvalue * with cython.nonecheck(True): * lvalue = value.lower() #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* if lvalue in self.exact_set: * return */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_value), __pyx_n_s__lower); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 46; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 46; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (!(likely(PyUnicode_CheckExact(__pyx_t_2))||((__pyx_t_2) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected unicode, got %.200s", Py_TYPE(__pyx_t_2)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 46; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_lvalue = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
47: if lvalue in self.exact_set:
/* "cfuzzyset.pyx":47 * with cython.nonecheck(True): * lvalue = value.lower() * if lvalue in self.exact_set: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* return * cdef int i */ if (unlikely(((PyObject *)__pyx_v_self->exact_set) == Py_None)) { PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 47; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_3 = ((PyDict_Contains(((PyObject *)__pyx_v_self->exact_set), ((PyObject *)__pyx_v_lvalue)))); if (unlikely(__pyx_t_3<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 47; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__pyx_t_3) {
48: return
/* "cfuzzyset.pyx":48 * lvalue = value.lower() * if lvalue in self.exact_set: * return #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef int i * for i in range(self.gram_size_lower, self.gram_size_upper + 1): */ __Pyx_XDECREF(__pyx_r); __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; goto __pyx_L3; } __pyx_L3:;
49: cdef int i
50: for i in range(self.gram_size_lower, self.gram_size_upper + 1):
/* "cfuzzyset.pyx":50 * return * cdef int i * for i in range(self.gram_size_lower, self.gram_size_upper + 1): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* self._add(value, i) * */ __pyx_t_4 = (__pyx_v_self->gram_size_upper + 1); for (__pyx_t_5 = __pyx_v_self->gram_size_lower; __pyx_t_5<
__pyx_t_4; __pyx_t_5+=1) { __pyx_v_i = __pyx_t_5;
51: self._add(value, i)
/* "cfuzzyset.pyx":51 * cdef int i * for i in range(self.gram_size_lower, self.gram_size_upper + 1): * self._add(value, i) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * @cython.nonecheck(False) */ __pyx_t_2 = ((struct __pyx_vtabstruct_9cfuzzyset_cFuzzySet *)__pyx_v_self->__pyx_vtab)->_add(__pyx_v_self, __pyx_v_value, __pyx_v_i, 0); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 51; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; } __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cfuzzyset.cFuzzySet.add", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_value); __Pyx_XDECREF(__pyx_v_lvalue); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
52:
53: @cython.nonecheck(False)
54: cpdef _add(self, unicode value, int gram_size):
/* "cfuzzyset.pyx":54 * * @cython.nonecheck(False) * cpdef _add(self, unicode value, int gram_size): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef unicode lvalue = value.lower() * cdef list items = self.items[gram_size] */ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_5_add(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_f_9cfuzzyset_9cFuzzySet__add(struct __pyx_obj_9cfuzzyset_cFuzzySet *__pyx_v_self, PyObject *__pyx_v_value, int __pyx_v_gram_size, int __pyx_skip_dispatch) { PyObject *__pyx_v_lvalue = 0; PyObject *__pyx_v_items = 0; int __pyx_v_idx; PyObject *__pyx_v_grams = 0; double __pyx_v_total; int __pyx_v_i; int __pyx_v_tmp; PyObject *__pyx_v_values = 0; double __pyx_v_norm; PyObject *__pyx_v_new_val = 0; PyObject *__pyx_v_gram = NULL; PyObject *__pyx_v_occ = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_add", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overriden in Python */ else if (unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0)) { __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s___add); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (!PyCFunction_Check(__pyx_t_1) || (PyCFunction_GET_FUNCTION(__pyx_t_1) != (PyCFunction)__pyx_pw_9cfuzzyset_9cFuzzySet_5_add)) { __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_gram_size); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_INCREF(((PyObject *)__pyx_v_value)); PyTuple_SET_ITEM(__pyx_t_3, 0, ((PyObject *)__pyx_v_value)); __Pyx_GIVEREF(((PyObject *)__pyx_v_value)); PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; } /* "cfuzzyset.pyx":54 * * @cython.nonecheck(False) * cpdef _add(self, unicode value, int gram_size): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef unicode lvalue = value.lower() * cdef list items = self.items[gram_size] */ static PyObject *__pyx_pf_9cfuzzyset_9cFuzzySet_4_add(struct __pyx_obj_9cfuzzyset_cFuzzySet *__pyx_v_self, PyObject *__pyx_v_value, int __pyx_v_gram_size) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_add", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = ((struct __pyx_vtabstruct_9cfuzzyset_cFuzzySet *)__pyx_v_self->__pyx_vtab)->_add(__pyx_v_self, __pyx_v_value, __pyx_v_gram_size, 1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cfuzzyset.cFuzzySet._add", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_7__getitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_in_val); /*proto*/ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_7__getitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_in_val) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getitem__ (wrapper)", 0); __pyx_r = __pyx_pf_9cfuzzyset_9cFuzzySet_6__getitem__(((struct __pyx_obj_9cfuzzyset_cFuzzySet *)__pyx_v_self), ((PyObject *)__pyx_v_in_val)); __Pyx_RefNannyFinishContext(); return __pyx_r; }
55: cdef unicode lvalue = value.lower()
/* "cfuzzyset.pyx":55 * @cython.nonecheck(False) * cpdef _add(self, unicode value, int gram_size): * cdef unicode lvalue = value.lower() #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef list items = self.items[gram_size] * cdef int idx = len(items) */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_value), __pyx_n_s__lower); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 55; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 55; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (!(likely(PyUnicode_CheckExact(__pyx_t_2))||((__pyx_t_2) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected unicode, got %.200s", Py_TYPE(__pyx_t_2)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 55; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_lvalue = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
56: cdef list items = self.items[gram_size]
/* "cfuzzyset.pyx":56 * cpdef _add(self, unicode value, int gram_size): * cdef unicode lvalue = value.lower() * cdef list items = self.items[gram_size] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef int idx = len(items) * items.append(0) */ __pyx_t_2 = __Pyx_GetItemInt(((PyObject *)__pyx_v_self->items), __pyx_v_gram_size, sizeof(int), PyInt_FromLong); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 56; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); if (!(likely(PyList_CheckExact(__pyx_t_2))||((__pyx_t_2) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected list, got %.200s", Py_TYPE(__pyx_t_2)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 56; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_items = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
57: cdef int idx = len(items)
/* "cfuzzyset.pyx":57 * cdef unicode lvalue = value.lower() * cdef list items = self.items[gram_size] * cdef int idx = len(items) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* items.append(0) * cdef dict grams = _gram_counter(lvalue, gram_size) */ if (unlikely(((PyObject *)__pyx_v_items) == Py_None)) { PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 57; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_4 = PyList_GET_SIZE(((PyObject *)__pyx_v_items)); __pyx_v_idx = __pyx_t_4;
58: items.append(0)
/* "cfuzzyset.pyx":58 * cdef list items = self.items[gram_size] * cdef int idx = len(items) * items.append(0) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef dict grams = _gram_counter(lvalue, gram_size) * cdef double total = 0 */ if (unlikely(((PyObject *)__pyx_v_items) == Py_None)) { PyErr_Format(PyExc_AttributeError, "'NoneType' object has no attribute '%s'", "append"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 58; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_5 = PyList_Append(__pyx_v_items, __pyx_int_0); if (unlikely(__pyx_t_5 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 58; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
59: cdef dict grams = _gram_counter(lvalue, gram_size)
/* "cfuzzyset.pyx":59 * cdef int idx = len(items) * items.append(0) * cdef dict grams = _gram_counter(lvalue, gram_size) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef double total = 0 * cdef int i */ __pyx_t_6.__pyx_n = 1; __pyx_t_6.gram_size = __pyx_v_gram_size; __pyx_t_2 = ((PyObject *)__pyx_f_9cfuzzyset__gram_counter(__pyx_v_lvalue, &__pyx_t_6)); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 59; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_v_grams = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
60: cdef double total = 0
/* "cfuzzyset.pyx":60 * items.append(0) * cdef dict grams = _gram_counter(lvalue, gram_size) * cdef double total = 0 #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef int i * cdef int tmp */ __pyx_v_total = 0.0;
61: cdef int i
62: cdef int tmp
63: cdef list values = grams.values()
/* "cfuzzyset.pyx":63 * cdef int i * cdef int tmp * cdef list values = grams.values() #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* with cython.boundscheck(False): * for i in range(len(values)): */ if (unlikely(((PyObject *)__pyx_v_grams) == Py_None)) { PyErr_Format(PyExc_AttributeError, "'NoneType' object has no attribute '%s'", "values"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 63; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_2 = PyDict_Values(__pyx_v_grams); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 63; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); if (!(likely(PyList_CheckExact(__pyx_t_2))||((__pyx_t_2) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected list, got %.200s", Py_TYPE(__pyx_t_2)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 63; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_values = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
64: with cython.boundscheck(False):
65: for i in range(len(values)):
/* "cfuzzyset.pyx":65 * cdef list values = grams.values() * with cython.boundscheck(False): * for i in range(len(values)): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* tmp = values[i] * total += tmp * tmp */ if (unlikely(((PyObject *)__pyx_v_values) == Py_None)) { PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 65; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_4 = PyList_GET_SIZE(((PyObject *)__pyx_v_values)); for (__pyx_t_7 = 0; __pyx_t_7<
__pyx_t_4; __pyx_t_7+=1) { __pyx_v_i = __pyx_t_7;
66: tmp = values[i]
/* "cfuzzyset.pyx":66 * with cython.boundscheck(False): * for i in range(len(values)): * tmp = values[i] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* total += tmp * tmp * cdef double norm = sqrt(total) */ __pyx_t_2 = __Pyx_GetItemInt_List(((PyObject *)__pyx_v_values), __pyx_v_i, sizeof(int), PyInt_FromLong); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 66; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_8 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_8 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 66; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_tmp = __pyx_t_8;
67: total += tmp * tmp
/* "cfuzzyset.pyx":67 * for i in range(len(values)): * tmp = values[i] * total += tmp * tmp #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef double norm = sqrt(total) * items[idx] = (norm, lvalue) */ __pyx_v_total = (__pyx_v_total + (__pyx_v_tmp * __pyx_v_tmp)); }
68: cdef double norm = sqrt(total)
/* "cfuzzyset.pyx":68 * tmp = values[i] * total += tmp * tmp * cdef double norm = sqrt(total) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* items[idx] = (norm, lvalue) * cdef tuple new_val */ __pyx_v_norm = sqrt(__pyx_v_total);
69: items[idx] = (norm, lvalue)
/* "cfuzzyset.pyx":69 * total += tmp * tmp * cdef double norm = sqrt(total) * items[idx] = (norm, lvalue) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef tuple new_val * for gram, occ in grams.items(): */ __pyx_t_2 = PyFloat_FromDouble(__pyx_v_norm); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 69; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 69; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __Pyx_INCREF(((PyObject *)__pyx_v_lvalue)); PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_v_lvalue)); __Pyx_GIVEREF(((PyObject *)__pyx_v_lvalue)); __pyx_t_2 = 0; if (__Pyx_SetItemInt(((PyObject *)__pyx_v_items), __pyx_v_idx, ((PyObject *)__pyx_t_1), sizeof(int), PyInt_FromLong)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 69; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
70: cdef tuple new_val
71: for gram, occ in grams.items():
/* "cfuzzyset.pyx":71 * items[idx] = (norm, lvalue) * cdef tuple new_val * for gram, occ in grams.items(): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* new_val = (idx, occ) * if gram in self.match_dict: */ if (unlikely(((PyObject *)__pyx_v_grams) == Py_None)) { PyErr_Format(PyExc_AttributeError, "'NoneType' object has no attribute '%s'", "items"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_1 = PyDict_Items(__pyx_v_grams); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (PyList_CheckExact(__pyx_t_1) || PyTuple_CheckExact(__pyx_t_1)) { __pyx_t_2 = __pyx_t_1; __Pyx_INCREF(__pyx_t_2); __pyx_t_4 = 0; __pyx_t_9 = NULL; } else { __pyx_t_4 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_9 = Py_TYPE(__pyx_t_2)->tp_iternext; } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; for (;;) { if (!__pyx_t_9 && PyList_CheckExact(__pyx_t_2)) { if (__pyx_t_4 >= PyList_GET_SIZE(__pyx_t_2)) break; __pyx_t_1 = PyList_GET_ITEM(__pyx_t_2, __pyx_t_4); __Pyx_INCREF(__pyx_t_1); __pyx_t_4++; } else if (!__pyx_t_9 && PyTuple_CheckExact(__pyx_t_2)) { if (__pyx_t_4 >= PyTuple_GET_SIZE(__pyx_t_2)) break; __pyx_t_1 = PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_4); __Pyx_INCREF(__pyx_t_1); __pyx_t_4++; } else { __pyx_t_1 = __pyx_t_9(__pyx_t_2); if (unlikely(!__pyx_t_1)) { if (PyErr_Occurred()) { if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear(); else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } break; } __Pyx_GOTREF(__pyx_t_1); } if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) { PyObject* sequence = __pyx_t_1; if (likely(PyTuple_CheckExact(sequence))) { if (unlikely(PyTuple_GET_SIZE(sequence) != 2)) { if (PyTuple_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyTuple_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_3 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_10 = PyTuple_GET_ITEM(sequence, 1); } else { if (unlikely(PyList_GET_SIZE(sequence) != 2)) { if (PyList_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyList_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_3 = PyList_GET_ITEM(sequence, 0); __pyx_t_10 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx_t_10); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; } else { Py_ssize_t index = -1; __pyx_t_11 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_11)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_11); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_12 = Py_TYPE(__pyx_t_11)->tp_iternext; index = 0; __pyx_t_3 = __pyx_t_12(__pyx_t_11); if (unlikely(!__pyx_t_3)) goto __pyx_L7_unpacking_failed; __Pyx_GOTREF(__pyx_t_3); index = 1; __pyx_t_10 = __pyx_t_12(__pyx_t_11); if (unlikely(!__pyx_t_10)) goto __pyx_L7_unpacking_failed; __Pyx_GOTREF(__pyx_t_10); if (__Pyx_IternextUnpackEndCheck(__pyx_t_12(__pyx_t_11), 2)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; goto __pyx_L8_unpacking_done; __pyx_L7_unpacking_failed:; __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; if (PyErr_Occurred() && PyErr_ExceptionMatches(PyExc_StopIteration)) PyErr_Clear(); if (!PyErr_Occurred()) __Pyx_RaiseNeedMoreValuesError(index); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_L8_unpacking_done:; } __Pyx_XDECREF(__pyx_v_gram); __pyx_v_gram = __pyx_t_3; __pyx_t_3 = 0; __Pyx_XDECREF(__pyx_v_occ); __pyx_v_occ = __pyx_t_10; __pyx_t_10 = 0;
72: new_val = (idx, occ)
/* "cfuzzyset.pyx":72 * cdef tuple new_val * for gram, occ in grams.items(): * new_val = (idx, occ) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* if gram in self.match_dict: * self.match_dict[gram].append(new_val) */ __pyx_t_1 = PyInt_FromLong(__pyx_v_idx); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 72; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_10 = PyTuple_New(2); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 72; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_10); PyTuple_SET_ITEM(__pyx_t_10, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_1); __Pyx_INCREF(__pyx_v_occ); PyTuple_SET_ITEM(__pyx_t_10, 1, __pyx_v_occ); __Pyx_GIVEREF(__pyx_v_occ); __pyx_t_1 = 0; __Pyx_XDECREF(((PyObject *)__pyx_v_new_val)); __pyx_v_new_val = __pyx_t_10; __pyx_t_10 = 0;
73: if gram in self.match_dict:
/* "cfuzzyset.pyx":73 * for gram, occ in grams.items(): * new_val = (idx, occ) * if gram in self.match_dict: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* self.match_dict[gram].append(new_val) * else: */ if (unlikely(((PyObject *)__pyx_v_self->match_dict) == Py_None)) { PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 73; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_13 = ((PyDict_Contains(((PyObject *)__pyx_v_self->match_dict), __pyx_v_gram))); if (unlikely(__pyx_t_13<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 73; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__pyx_t_13) {
74: self.match_dict[gram].append(new_val)
/* "cfuzzyset.pyx":74 * new_val = (idx, occ) * if gram in self.match_dict: * self.match_dict[gram].append(new_val) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* else: * self.match_dict[gram] = [new_val] */ __pyx_t_10 = __Pyx_PyDict_GetItem(((PyObject *)__pyx_v_self->match_dict), __pyx_v_gram); if (!__pyx_t_10) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 74; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_10); __pyx_t_1 = __Pyx_PyObject_Append(__pyx_t_10, ((PyObject *)__pyx_v_new_val)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 74; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L9; } /*else*/ {
75: else:
76: self.match_dict[gram] = [new_val]
/* "cfuzzyset.pyx":76 * self.match_dict[gram].append(new_val) * else: * self.match_dict[gram] = [new_val] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* self.exact_set[lvalue] = value * */ __pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(((PyObject *)__pyx_v_new_val)); PyList_SET_ITEM(__pyx_t_1, 0, ((PyObject *)__pyx_v_new_val)); __Pyx_GIVEREF(((PyObject *)__pyx_v_new_val)); if (PyDict_SetItem(((PyObject *)__pyx_v_self->match_dict), __pyx_v_gram, ((PyObject *)__pyx_t_1))<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; } __pyx_L9:; } __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
77: self.exact_set[lvalue] = value
/* "cfuzzyset.pyx":77 * else: * self.match_dict[gram] = [new_val] * self.exact_set[lvalue] = value #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * @cython.nonecheck(False) */ if (PyDict_SetItem(((PyObject *)__pyx_v_self->exact_set), ((PyObject *)__pyx_v_lvalue), ((PyObject *)__pyx_v_value))<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 77; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_11); __Pyx_AddTraceback("cfuzzyset.cFuzzySet._add", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_lvalue); __Pyx_XDECREF(__pyx_v_items); __Pyx_XDECREF(__pyx_v_grams); __Pyx_XDECREF(__pyx_v_values); __Pyx_XDECREF(__pyx_v_new_val); __Pyx_XDECREF(__pyx_v_gram); __Pyx_XDECREF(__pyx_v_occ); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_5_add(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_5_add(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_value = 0; int __pyx_v_gram_size; static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__value,&__pyx_n_s__gram_size,0}; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_add (wrapper)", 0); { PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__value); if (likely(values[0])) kw_args--; else goto __pyx_L5_argtuple_error; case 1: values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__gram_size); if (likely(values[1])) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_add", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_add")<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_value = ((PyObject*)values[0]); __pyx_v_gram_size = __Pyx_PyInt_AsInt(values[1]); if (unlikely((__pyx_v_gram_size == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_add", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("cfuzzyset.cFuzzySet._add", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_value), (&PyUnicode_Type), 1, "value", 1))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 54; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_r = __pyx_pf_9cfuzzyset_9cFuzzySet_4_add(((struct __pyx_obj_9cfuzzyset_cFuzzySet *)__pyx_v_self), __pyx_v_value, __pyx_v_gram_size); goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
78:
79: @cython.nonecheck(False)
80: @cython.boundscheck(False)
81: def __getitem__(self, object in_val):
/* "cfuzzyset.pyx":81 * @cython.nonecheck(False) * @cython.boundscheck(False) * def __getitem__(self, object in_val): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef unicode value = _convert_val(in_val) * cdef unicode lvalue */ static PyObject *__pyx_pf_9cfuzzyset_9cFuzzySet_6__getitem__(struct __pyx_obj_9cfuzzyset_cFuzzySet *__pyx_v_self, PyObject *__pyx_v_in_val) { PyObject *__pyx_v_value = 0; PyObject *__pyx_v_lvalue = 0; int __pyx_v_i; PyObject *__pyx_v_results = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getitem__", 0);
82: cdef unicode value = _convert_val(in_val)
/* "cfuzzyset.pyx":82 * @cython.boundscheck(False) * def __getitem__(self, object in_val): * cdef unicode value = _convert_val(in_val) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef unicode lvalue * with cython.nonecheck(True): */ __pyx_t_1 = ((PyObject *)__pyx_f_9cfuzzyset__convert_val(__pyx_v_in_val)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 82; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_v_value = ((PyObject*)__pyx_t_1); __pyx_t_1 = 0;
83: cdef unicode lvalue
84: with cython.nonecheck(True):
85: lvalue = value.lower()
/* "cfuzzyset.pyx":85 * cdef unicode lvalue * with cython.nonecheck(True): * lvalue = value.lower() #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* if lvalue in self.exact_set: * return [(1, self.exact_set[lvalue])] */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_value), __pyx_n_s__lower); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 85; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 85; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (!(likely(PyUnicode_CheckExact(__pyx_t_2))||((__pyx_t_2) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected unicode, got %.200s", Py_TYPE(__pyx_t_2)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 85; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_lvalue = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
86: if lvalue in self.exact_set:
/* "cfuzzyset.pyx":86 * with cython.nonecheck(True): * lvalue = value.lower() * if lvalue in self.exact_set: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* return [(1, self.exact_set[lvalue])] * cdef int i */ if (unlikely(((PyObject *)__pyx_v_self->exact_set) == Py_None)) { PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_3 = ((PyDict_Contains(((PyObject *)__pyx_v_self->exact_set), ((PyObject *)__pyx_v_lvalue)))); if (unlikely(__pyx_t_3<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__pyx_t_3) {
87: return [(1, self.exact_set[lvalue])]
/* "cfuzzyset.pyx":87 * lvalue = value.lower() * if lvalue in self.exact_set: * return [(1, self.exact_set[lvalue])] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef int i * results = None */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = __Pyx_PyDict_GetItem(((PyObject *)__pyx_v_self->exact_set), ((PyObject *)__pyx_v_lvalue)); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 87; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 87; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_int_1); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_int_1); __Pyx_GIVEREF(__pyx_int_1); PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 87; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); PyList_SET_ITEM(__pyx_t_2, 0, ((PyObject *)__pyx_t_1)); __Pyx_GIVEREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; __pyx_r = ((PyObject *)__pyx_t_2); __pyx_t_2 = 0; goto __pyx_L0; goto __pyx_L3; } __pyx_L3:;
88: cdef int i
89: results = None
/* "cfuzzyset.pyx":89 * return [(1, self.exact_set[lvalue])] * cdef int i * results = None #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for i in range(self.gram_size_upper, self.gram_size_lower - 1, -1): * results = self._get(value, i) */ __Pyx_INCREF(Py_None); __pyx_v_results = Py_None;
90: for i in range(self.gram_size_upper, self.gram_size_lower - 1, -1):
/* "cfuzzyset.pyx":90 * cdef int i * results = None * for i in range(self.gram_size_upper, self.gram_size_lower - 1, -1): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* results = self._get(value, i) * if results is not None: */ __pyx_t_4 = (__pyx_v_self->gram_size_lower - 1); for (__pyx_t_5 = __pyx_v_self->gram_size_upper; __pyx_t_5 > __pyx_t_4; __pyx_t_5-=1) { __pyx_v_i = __pyx_t_5;
91: results = self._get(value, i)
/* "cfuzzyset.pyx":91 * results = None * for i in range(self.gram_size_upper, self.gram_size_lower - 1, -1): * results = self._get(value, i) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* if results is not None: * return results */ __pyx_t_2 = ((struct __pyx_vtabstruct_9cfuzzyset_cFuzzySet *)__pyx_v_self->__pyx_vtab)->_get(__pyx_v_self, __pyx_v_value, __pyx_v_i, 0); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 91; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_v_results); __pyx_v_results = __pyx_t_2; __pyx_t_2 = 0;
92: if results is not None:
/* "cfuzzyset.pyx":92 * for i in range(self.gram_size_upper, self.gram_size_lower - 1, -1): * results = self._get(value, i) * if results is not None: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* return results * raise KeyError(in_val) */ __pyx_t_3 = (__pyx_v_results != Py_None); if (__pyx_t_3) {
93: return results
/* "cfuzzyset.pyx":93 * results = self._get(value, i) * if results is not None: * return results #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* raise KeyError(in_val) * */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_results); __pyx_r = __pyx_v_results; goto __pyx_L0; goto __pyx_L6; } __pyx_L6:; }
94: raise KeyError(in_val)
/* "cfuzzyset.pyx":94 * if results is not None: * return results * raise KeyError(in_val) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * @cython.nonecheck(False) */ __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 94; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_v_in_val); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_v_in_val); __Pyx_GIVEREF(__pyx_v_in_val); __pyx_t_1 = PyObject_Call(__pyx_builtin_KeyError, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 94; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0; __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; {__pyx_filename = __pyx_f[0]; __pyx_lineno = 94; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cfuzzyset.cFuzzySet.__getitem__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_value); __Pyx_XDECREF(__pyx_v_lvalue); __Pyx_XDECREF(__pyx_v_results); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
95:
96: @cython.nonecheck(False)
97: @cython.boundscheck(False)
98: cpdef _get(self, unicode value, int gram_size):
/* "cfuzzyset.pyx":98 * @cython.nonecheck(False) * @cython.boundscheck(False) * cpdef _get(self, unicode value, int gram_size): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef unicode lvalue = value.lower() * cdef dict matches = {} */ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_9_get(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_f_9cfuzzyset_9cFuzzySet__get(struct __pyx_obj_9cfuzzyset_cFuzzySet *__pyx_v_self, PyObject *__pyx_v_value, int __pyx_v_gram_size, int __pyx_skip_dispatch) { PyObject *__pyx_v_lvalue = 0; PyObject *__pyx_v_matches = 0; PyObject *__pyx_v_grams = 0; double __pyx_v_norm; int __pyx_v_tmp; PyObject *__pyx_v_values = 0; int __pyx_v_idx; int __pyx_v_other_occ; int __pyx_v_occ; int __pyx_v_match_score; PyObject *__pyx_v_gram = 0; PyObject *__pyx_v_items = 0; PyObject *__pyx_v_results = 0; CYTHON_UNUSED PyObject *__pyx_v__ = NULL; PyObject *__pyx_v_matched = NULL; PyObject *__pyx_v_score = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_get", 0); __Pyx_INCREF(__pyx_v_value); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overriden in Python */ else if (unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0)) { __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s___get); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (!PyCFunction_Check(__pyx_t_1) || (PyCFunction_GET_FUNCTION(__pyx_t_1) != (PyCFunction)__pyx_pw_9cfuzzyset_9cFuzzySet_9_get)) { __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_gram_size); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_INCREF(((PyObject *)__pyx_v_value)); PyTuple_SET_ITEM(__pyx_t_3, 0, ((PyObject *)__pyx_v_value)); __Pyx_GIVEREF(((PyObject *)__pyx_v_value)); PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; } /* "cfuzzyset.pyx":98 * @cython.nonecheck(False) * @cython.boundscheck(False) * cpdef _get(self, unicode value, int gram_size): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef unicode lvalue = value.lower() * cdef dict matches = {} */ static PyObject *__pyx_pf_9cfuzzyset_9cFuzzySet_8_get(struct __pyx_obj_9cfuzzyset_cFuzzySet *__pyx_v_self, PyObject *__pyx_v_value, int __pyx_v_gram_size) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_get", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = ((struct __pyx_vtabstruct_9cfuzzyset_cFuzzySet *)__pyx_v_self->__pyx_vtab)->_get(__pyx_v_self, __pyx_v_value, __pyx_v_gram_size, 1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cfuzzyset.cFuzzySet._get", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_11get(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_11get(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_key = 0; PyObject *__pyx_v_default = 0; static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__key,&__pyx_n_s__default,0}; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("get (wrapper)", 0); { PyObject* values[2] = {0,0};
99: cdef unicode lvalue = value.lower()
/* "cfuzzyset.pyx":99 * @cython.boundscheck(False) * cpdef _get(self, unicode value, int gram_size): * cdef unicode lvalue = value.lower() #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef dict matches = {} * cdef dict grams = _gram_counter(lvalue, gram_size) */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_value), __pyx_n_s__lower); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 99; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 99; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (!(likely(PyUnicode_CheckExact(__pyx_t_2))||((__pyx_t_2) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected unicode, got %.200s", Py_TYPE(__pyx_t_2)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 99; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_lvalue = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
100: cdef dict matches = {}
/* "cfuzzyset.pyx":100 * cpdef _get(self, unicode value, int gram_size): * cdef unicode lvalue = value.lower() * cdef dict matches = {} #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef dict grams = _gram_counter(lvalue, gram_size) * cdef double norm = 0 */ __pyx_t_2 = PyDict_New(); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 100; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_2)); __pyx_v_matches = __pyx_t_2; __pyx_t_2 = 0;
101: cdef dict grams = _gram_counter(lvalue, gram_size)
/* "cfuzzyset.pyx":101 * cdef unicode lvalue = value.lower() * cdef dict matches = {} * cdef dict grams = _gram_counter(lvalue, gram_size) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef double norm = 0 * cdef int tmp */ __pyx_t_4.__pyx_n = 1; __pyx_t_4.gram_size = __pyx_v_gram_size; __pyx_t_2 = ((PyObject *)__pyx_f_9cfuzzyset__gram_counter(__pyx_v_lvalue, &__pyx_t_4)); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 101; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_v_grams = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
102: cdef double norm = 0
/* "cfuzzyset.pyx":102 * cdef dict matches = {} * cdef dict grams = _gram_counter(lvalue, gram_size) * cdef double norm = 0 #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef int tmp * cdef list values = grams.values() */ __pyx_v_norm = 0.0;
103: cdef int tmp
104: cdef list values = grams.values()
/* "cfuzzyset.pyx":104 * cdef double norm = 0 * cdef int tmp * cdef list values = grams.values() #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for tmp in values: * norm += tmp * tmp */ if (unlikely(((PyObject *)__pyx_v_grams) == Py_None)) { PyErr_Format(PyExc_AttributeError, "'NoneType' object has no attribute '%s'", "values"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 104; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_2 = PyDict_Values(__pyx_v_grams); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 104; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); if (!(likely(PyList_CheckExact(__pyx_t_2))||((__pyx_t_2) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected list, got %.200s", Py_TYPE(__pyx_t_2)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 104; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_values = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
105: for tmp in values:
/* "cfuzzyset.pyx":105 * cdef int tmp * cdef list values = grams.values() * for tmp in values: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* norm += tmp * tmp * norm = sqrt(norm) */ if (unlikely(((PyObject *)__pyx_v_values) == Py_None)) { PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 105; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_2 = ((PyObject *)__pyx_v_values); __Pyx_INCREF(__pyx_t_2); __pyx_t_5 = 0; for (;;) { if (__pyx_t_5 >= PyList_GET_SIZE(__pyx_t_2)) break; __pyx_t_1 = PyList_GET_ITEM(__pyx_t_2, __pyx_t_5); __Pyx_INCREF(__pyx_t_1); __pyx_t_5++; __pyx_t_6 = __Pyx_PyInt_AsInt(__pyx_t_1); if (unlikely((__pyx_t_6 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 105; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_v_tmp = __pyx_t_6;
106: norm += tmp * tmp
/* "cfuzzyset.pyx":106 * cdef list values = grams.values() * for tmp in values: * norm += tmp * tmp #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* norm = sqrt(norm) * cdef int idx */ __pyx_v_norm = (__pyx_v_norm + (__pyx_v_tmp * __pyx_v_tmp)); } __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
107: norm = sqrt(norm)
/* "cfuzzyset.pyx":107 * for tmp in values: * norm += tmp * tmp * norm = sqrt(norm) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef int idx * cdef int other_occ */ __pyx_v_norm = sqrt(__pyx_v_norm);
108: cdef int idx
109: cdef int other_occ
110: cdef int occ
111: cdef int match_score
112: cdef unicode gram
113: cdef list items = self.items[gram_size]
/* "cfuzzyset.pyx":113 * cdef int match_score * cdef unicode gram * cdef list items = self.items[gram_size] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * for gram, occ in grams.items(): */ __pyx_t_2 = __Pyx_GetItemInt(((PyObject *)__pyx_v_self->items), __pyx_v_gram_size, sizeof(int), PyInt_FromLong); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); if (!(likely(PyList_CheckExact(__pyx_t_2))||((__pyx_t_2) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected list, got %.200s", Py_TYPE(__pyx_t_2)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_items = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
114:
115: for gram, occ in grams.items():
/* "cfuzzyset.pyx":115 * cdef list items = self.items[gram_size] * * for gram, occ in grams.items(): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* if gram in self.match_dict: * for idx, other_occ in self.match_dict[gram]: */ if (unlikely(((PyObject *)__pyx_v_grams) == Py_None)) { PyErr_Format(PyExc_AttributeError, "'NoneType' object has no attribute '%s'", "items"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_2 = PyDict_Items(__pyx_v_grams); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); if (PyList_CheckExact(__pyx_t_2) || PyTuple_CheckExact(__pyx_t_2)) { __pyx_t_1 = __pyx_t_2; __Pyx_INCREF(__pyx_t_1); __pyx_t_5 = 0; __pyx_t_7 = NULL; } else { __pyx_t_5 = -1; __pyx_t_1 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_7 = Py_TYPE(__pyx_t_1)->tp_iternext; } __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; for (;;) { if (!__pyx_t_7 && PyList_CheckExact(__pyx_t_1)) { if (__pyx_t_5 >= PyList_GET_SIZE(__pyx_t_1)) break; __pyx_t_2 = PyList_GET_ITEM(__pyx_t_1, __pyx_t_5); __Pyx_INCREF(__pyx_t_2); __pyx_t_5++; } else if (!__pyx_t_7 && PyTuple_CheckExact(__pyx_t_1)) { if (__pyx_t_5 >= PyTuple_GET_SIZE(__pyx_t_1)) break; __pyx_t_2 = PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_5); __Pyx_INCREF(__pyx_t_2); __pyx_t_5++; } else { __pyx_t_2 = __pyx_t_7(__pyx_t_1); if (unlikely(!__pyx_t_2)) { if (PyErr_Occurred()) { if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear(); else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } break; } __Pyx_GOTREF(__pyx_t_2); } if ((likely(PyTuple_CheckExact(__pyx_t_2))) || (PyList_CheckExact(__pyx_t_2))) { PyObject* sequence = __pyx_t_2; if (likely(PyTuple_CheckExact(sequence))) { if (unlikely(PyTuple_GET_SIZE(sequence) != 2)) { if (PyTuple_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyTuple_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_3 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_8 = PyTuple_GET_ITEM(sequence, 1); } else { if (unlikely(PyList_GET_SIZE(sequence) != 2)) { if (PyList_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyList_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_3 = PyList_GET_ITEM(sequence, 0); __pyx_t_8 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; } else { Py_ssize_t index = -1; __pyx_t_9 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_10 = Py_TYPE(__pyx_t_9)->tp_iternext; index = 0; __pyx_t_3 = __pyx_t_10(__pyx_t_9); if (unlikely(!__pyx_t_3)) goto __pyx_L7_unpacking_failed; __Pyx_GOTREF(__pyx_t_3); index = 1; __pyx_t_8 = __pyx_t_10(__pyx_t_9); if (unlikely(!__pyx_t_8)) goto __pyx_L7_unpacking_failed; __Pyx_GOTREF(__pyx_t_8); if (__Pyx_IternextUnpackEndCheck(__pyx_t_10(__pyx_t_9), 2)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; goto __pyx_L8_unpacking_done; __pyx_L7_unpacking_failed:; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyErr_Occurred() && PyErr_ExceptionMatches(PyExc_StopIteration)) PyErr_Clear(); if (!PyErr_Occurred()) __Pyx_RaiseNeedMoreValuesError(index); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_L8_unpacking_done:; } if (!(likely(PyUnicode_CheckExact(__pyx_t_3))||((__pyx_t_3) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected unicode, got %.200s", Py_TYPE(__pyx_t_3)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_t_6 = __Pyx_PyInt_AsInt(__pyx_t_8); if (unlikely((__pyx_t_6 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 115; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_XDECREF(((PyObject *)__pyx_v_gram)); __pyx_v_gram = ((PyObject*)__pyx_t_3); __pyx_t_3 = 0; __pyx_v_occ = __pyx_t_6;
116: if gram in self.match_dict:
/* "cfuzzyset.pyx":116 * * for gram, occ in grams.items(): * if gram in self.match_dict: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for idx, other_occ in self.match_dict[gram]: * if idx in matches: */ if (unlikely(((PyObject *)__pyx_v_self->match_dict) == Py_None)) { PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 116; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_11 = ((PyDict_Contains(((PyObject *)__pyx_v_self->match_dict), ((PyObject *)__pyx_v_gram)))); if (unlikely(__pyx_t_11<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 116; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__pyx_t_11) {
117: for idx, other_occ in self.match_dict[gram]:
/* "cfuzzyset.pyx":117 * for gram, occ in grams.items(): * if gram in self.match_dict: * for idx, other_occ in self.match_dict[gram]: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* if idx in matches: * matches[idx] += occ * other_occ */ __pyx_t_2 = __Pyx_PyDict_GetItem(((PyObject *)__pyx_v_self->match_dict), ((PyObject *)__pyx_v_gram)); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 117; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); if (PyList_CheckExact(__pyx_t_2) || PyTuple_CheckExact(__pyx_t_2)) { __pyx_t_8 = __pyx_t_2; __Pyx_INCREF(__pyx_t_8); __pyx_t_12 = 0; __pyx_t_13 = NULL; } else { __pyx_t_12 = -1; __pyx_t_8 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 117; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); __pyx_t_13 = Py_TYPE(__pyx_t_8)->tp_iternext; } __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; for (;;) { if (!__pyx_t_13 && PyList_CheckExact(__pyx_t_8)) { if (__pyx_t_12 >= PyList_GET_SIZE(__pyx_t_8)) break; __pyx_t_2 = PyList_GET_ITEM(__pyx_t_8, __pyx_t_12); __Pyx_INCREF(__pyx_t_2); __pyx_t_12++; } else if (!__pyx_t_13 && PyTuple_CheckExact(__pyx_t_8)) { if (__pyx_t_12 >= PyTuple_GET_SIZE(__pyx_t_8)) break; __pyx_t_2 = PyTuple_GET_ITEM(__pyx_t_8, __pyx_t_12); __Pyx_INCREF(__pyx_t_2); __pyx_t_12++; } else { __pyx_t_2 = __pyx_t_13(__pyx_t_8); if (unlikely(!__pyx_t_2)) { if (PyErr_Occurred()) { if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear(); else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 117; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } break; } __Pyx_GOTREF(__pyx_t_2); } if ((likely(PyTuple_CheckExact(__pyx_t_2))) || (PyList_CheckExact(__pyx_t_2))) { PyObject* sequence = __pyx_t_2; if (likely(PyTuple_CheckExact(sequence))) { if (unlikely(PyTuple_GET_SIZE(sequence) != 2)) { if (PyTuple_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyTuple_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 117; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_3 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_9 = PyTuple_GET_ITEM(sequence, 1); } else { if (unlikely(PyList_GET_SIZE(sequence) != 2)) { if (PyList_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyList_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 117; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_3 = PyList_GET_ITEM(sequence, 0); __pyx_t_9 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; } else { Py_ssize_t index = -1; __pyx_t_14 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_14)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 117; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_14); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_10 = Py_TYPE(__pyx_t_14)->tp_iternext; index = 0; __pyx_t_3 = __pyx_t_10(__pyx_t_14); if (unlikely(!__pyx_t_3)) goto __pyx_L12_unpacking_failed; __Pyx_GOTREF(__pyx_t_3); index = 1; __pyx_t_9 = __pyx_t_10(__pyx_t_14); if (unlikely(!__pyx_t_9)) goto __pyx_L12_unpacking_failed; __Pyx_GOTREF(__pyx_t_9); if (__Pyx_IternextUnpackEndCheck(__pyx_t_10(__pyx_t_14), 2)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 117; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; goto __pyx_L13_unpacking_done; __pyx_L12_unpacking_failed:; __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; if (PyErr_Occurred() && PyErr_ExceptionMatches(PyExc_StopIteration)) PyErr_Clear(); if (!PyErr_Occurred()) __Pyx_RaiseNeedMoreValuesError(index); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 117; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_L13_unpacking_done:; } __pyx_t_6 = __Pyx_PyInt_AsInt(__pyx_t_3); if (unlikely((__pyx_t_6 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 117; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_15 = __Pyx_PyInt_AsInt(__pyx_t_9); if (unlikely((__pyx_t_15 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 117; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_v_idx = __pyx_t_6; __pyx_v_other_occ = __pyx_t_15;
118: if idx in matches:
/* "cfuzzyset.pyx":118 * if gram in self.match_dict: * for idx, other_occ in self.match_dict[gram]: * if idx in matches: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* matches[idx] += occ * other_occ * else: */ __pyx_t_2 = PyInt_FromLong(__pyx_v_idx); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 118; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_11 = ((PyDict_Contains(((PyObject *)__pyx_v_matches), __pyx_t_2))); if (unlikely(__pyx_t_11<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 118; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (__pyx_t_11) {
119: matches[idx] += occ * other_occ
/* "cfuzzyset.pyx":119 * for idx, other_occ in self.match_dict[gram]: * if idx in matches: * matches[idx] += occ * other_occ #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* else: * matches[idx] = occ * other_occ */ __pyx_t_15 = __pyx_v_idx; __pyx_t_2 = __Pyx_GetItemInt(((PyObject *)__pyx_v_matches), __pyx_t_15, sizeof(int), PyInt_FromLong); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 119; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_9 = PyInt_FromLong((__pyx_v_occ * __pyx_v_other_occ)); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 119; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __pyx_t_3 = PyNumber_InPlaceAdd(__pyx_t_2, __pyx_t_9); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 119; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (__Pyx_SetItemInt(((PyObject *)__pyx_v_matches), __pyx_t_15, __pyx_t_3, sizeof(int), PyInt_FromLong)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 119; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; goto __pyx_L14; } /*else*/ {
120: else:
121: matches[idx] = occ * other_occ
/* "cfuzzyset.pyx":121 * matches[idx] += occ * other_occ * else: * matches[idx] = occ * other_occ #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * if not matches: */ __pyx_t_3 = PyInt_FromLong((__pyx_v_occ * __pyx_v_other_occ)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 121; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemInt(((PyObject *)__pyx_v_matches), __pyx_v_idx, __pyx_t_3, sizeof(int), PyInt_FromLong)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 121; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; } __pyx_L14:; } __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; goto __pyx_L9; } __pyx_L9:; } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
122:
123: if not matches:
/* "cfuzzyset.pyx":123 * matches[idx] = occ * other_occ * * if not matches: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* return None * */ __pyx_t_11 = __Pyx_PyObject_IsTrue(((PyObject *)__pyx_v_matches)); if (unlikely(__pyx_t_11<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 123; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_t_16 = (!__pyx_t_11); if (__pyx_t_16) {
124: return None
/* "cfuzzyset.pyx":124 * * if not matches: * return None #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * # cosine similarity */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(Py_None); __pyx_r = Py_None; goto __pyx_L0; goto __pyx_L15; } __pyx_L15:;
125:
126: # cosine similarity
127: cdef list results = [(match_score / items[idx][0], items[idx][1])
/* "cfuzzyset.pyx":127 * * # cosine similarity * cdef list results = [(match_score / items[idx][0], items[idx][1]) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for idx, match_score in matches.items()] * results.sort(reverse=True, key=operator.itemgetter(0)) */ __pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); /* "cfuzzyset.pyx":127 * * # cosine similarity * cdef list results = [(match_score / items[idx][0], items[idx][1]) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for idx, match_score in matches.items()] * results.sort(reverse=True, key=operator.itemgetter(0)) */ __pyx_t_8 = PyInt_FromLong(__pyx_v_match_score); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); __pyx_t_2 = __Pyx_GetItemInt_List(((PyObject *)__pyx_v_items), __pyx_v_idx, sizeof(int), PyInt_FromLong); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_9 = __Pyx_GetItemInt(__pyx_t_2, 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_9) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_PyNumber_Divide(__pyx_t_8, __pyx_t_9); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_9 = __Pyx_GetItemInt_List(((PyObject *)__pyx_v_items), __pyx_v_idx, sizeof(int), PyInt_FromLong); if (!__pyx_t_9) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __pyx_t_8 = __Pyx_GetItemInt(__pyx_t_9, 1, sizeof(long), PyInt_FromLong); if (!__pyx_t_8) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_9 = PyTuple_New(2); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_8); __Pyx_GIVEREF(__pyx_t_8); __pyx_t_2 = 0; __pyx_t_8 = 0; if (unlikely(PyList_Append(__pyx_t_1, (PyObject*)__pyx_t_9))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 127; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(((PyObject *)__pyx_t_9)); __pyx_t_9 = 0; } __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_INCREF(((PyObject *)__pyx_t_1)); __pyx_v_results = __pyx_t_1; __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
128: for idx, match_score in matches.items()]
/* "cfuzzyset.pyx":128 * # cosine similarity * cdef list results = [(match_score / items[idx][0], items[idx][1]) * for idx, match_score in matches.items()] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* results.sort(reverse=True, key=operator.itemgetter(0)) * */ __pyx_t_8 = PyDict_Items(__pyx_v_matches); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); if (PyList_CheckExact(__pyx_t_8) || PyTuple_CheckExact(__pyx_t_8)) { __pyx_t_3 = __pyx_t_8; __Pyx_INCREF(__pyx_t_3); __pyx_t_5 = 0; __pyx_t_7 = NULL; } else { __pyx_t_5 = -1; __pyx_t_3 = PyObject_GetIter(__pyx_t_8); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_7 = Py_TYPE(__pyx_t_3)->tp_iternext; } __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; for (;;) { if (!__pyx_t_7 && PyList_CheckExact(__pyx_t_3)) { if (__pyx_t_5 >= PyList_GET_SIZE(__pyx_t_3)) break; __pyx_t_8 = PyList_GET_ITEM(__pyx_t_3, __pyx_t_5); __Pyx_INCREF(__pyx_t_8); __pyx_t_5++; } else if (!__pyx_t_7 && PyTuple_CheckExact(__pyx_t_3)) { if (__pyx_t_5 >= PyTuple_GET_SIZE(__pyx_t_3)) break; __pyx_t_8 = PyTuple_GET_ITEM(__pyx_t_3, __pyx_t_5); __Pyx_INCREF(__pyx_t_8); __pyx_t_5++; } else { __pyx_t_8 = __pyx_t_7(__pyx_t_3); if (unlikely(!__pyx_t_8)) { if (PyErr_Occurred()) { if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear(); else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } break; } __Pyx_GOTREF(__pyx_t_8); } if ((likely(PyTuple_CheckExact(__pyx_t_8))) || (PyList_CheckExact(__pyx_t_8))) { PyObject* sequence = __pyx_t_8; if (likely(PyTuple_CheckExact(sequence))) { if (unlikely(PyTuple_GET_SIZE(sequence) != 2)) { if (PyTuple_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyTuple_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_9 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_2 = PyTuple_GET_ITEM(sequence, 1); } else { if (unlikely(PyList_GET_SIZE(sequence) != 2)) { if (PyList_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyList_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_9 = PyList_GET_ITEM(sequence, 0); __pyx_t_2 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_9); __Pyx_INCREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; } else { Py_ssize_t index = -1; __pyx_t_14 = PyObject_GetIter(__pyx_t_8); if (unlikely(!__pyx_t_14)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_14); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_10 = Py_TYPE(__pyx_t_14)->tp_iternext; index = 0; __pyx_t_9 = __pyx_t_10(__pyx_t_14); if (unlikely(!__pyx_t_9)) goto __pyx_L18_unpacking_failed; __Pyx_GOTREF(__pyx_t_9); index = 1; __pyx_t_2 = __pyx_t_10(__pyx_t_14); if (unlikely(!__pyx_t_2)) goto __pyx_L18_unpacking_failed; __Pyx_GOTREF(__pyx_t_2); if (__Pyx_IternextUnpackEndCheck(__pyx_t_10(__pyx_t_14), 2)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; goto __pyx_L19_unpacking_done; __pyx_L18_unpacking_failed:; __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; if (PyErr_Occurred() && PyErr_ExceptionMatches(PyExc_StopIteration)) PyErr_Clear(); if (!PyErr_Occurred()) __Pyx_RaiseNeedMoreValuesError(index); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_L19_unpacking_done:; } __pyx_t_15 = __Pyx_PyInt_AsInt(__pyx_t_9); if (unlikely((__pyx_t_15 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_6 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_6 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 128; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_idx = __pyx_t_15; __pyx_v_match_score = __pyx_t_6;
129: results.sort(reverse=True, key=operator.itemgetter(0))
/* "cfuzzyset.pyx":129 * cdef list results = [(match_score / items[idx][0], items[idx][1]) * for idx, match_score in matches.items()] * results.sort(reverse=True, key=operator.itemgetter(0)) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * if self.use_levenshtein: */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_results), __pyx_n_s__sort); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_3 = PyDict_New(); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_3)); __pyx_t_9 = __Pyx_PyBool_FromLong(1); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_3, ((PyObject *)__pyx_n_s__reverse), __pyx_t_9)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_9 = __Pyx_GetName(__pyx_m, __pyx_n_s__operator); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __pyx_t_8 = PyObject_GetAttr(__pyx_t_9, __pyx_n_s__itemgetter); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_9 = PyObject_Call(__pyx_t_8, ((PyObject *)__pyx_k_tuple_1), NULL); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_3, ((PyObject *)__pyx_n_s__key), __pyx_t_9)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_9 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), ((PyObject *)__pyx_t_3)); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; /* "cfuzzyset.pyx":129 * cdef list results = [(match_score / items[idx][0], items[idx][1]) * for idx, match_score in matches.items()] * results.sort(reverse=True, key=operator.itemgetter(0)) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * if self.use_levenshtein: */ __pyx_k_tuple_1 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_1); __Pyx_INCREF(__pyx_int_0); PyTuple_SET_ITEM(__pyx_k_tuple_1, 0, __pyx_int_0); __Pyx_GIVEREF(__pyx_int_0); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_1));
130:
131: if self.use_levenshtein:
/* "cfuzzyset.pyx":131 * results.sort(reverse=True, key=operator.itemgetter(0)) * * if self.use_levenshtein: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* results = [(distance(matched, value), matched) * for _, matched in results[:50]] */ if (__pyx_v_self->use_levenshtein) {
132: results = [(distance(matched, value), matched)
/* "cfuzzyset.pyx":132 * * if self.use_levenshtein: * results = [(distance(matched, value), matched) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for _, matched in results[:50]] * results.sort(reverse=True, key=operator.itemgetter(0)) */ __pyx_t_9 = PyList_New(0); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 132; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); /* "cfuzzyset.pyx":132 * * if self.use_levenshtein: * results = [(distance(matched, value), matched) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for _, matched in results[:50]] * results.sort(reverse=True, key=operator.itemgetter(0)) */ if (!(likely(PyUnicode_CheckExact(__pyx_v_matched))||((__pyx_v_matched) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected unicode, got %.200s", Py_TYPE(__pyx_v_matched)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 132; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_t_3 = __pyx_v_matched; __Pyx_INCREF(__pyx_t_3); __pyx_t_2 = PyFloat_FromDouble(__pyx_f_9cfuzzyset_distance(((PyObject*)__pyx_t_3), __pyx_v_value)); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 132; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 132; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __Pyx_INCREF(__pyx_v_matched); PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_v_matched); __Pyx_GIVEREF(__pyx_v_matched); __pyx_t_2 = 0; if (unlikely(PyList_Append(__pyx_t_9, (PyObject*)__pyx_t_3))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 132; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_INCREF(((PyObject *)__pyx_t_9)); __Pyx_DECREF(((PyObject *)__pyx_v_results)); __pyx_v_results = __pyx_t_9; __Pyx_DECREF(((PyObject *)__pyx_t_9)); __pyx_t_9 = 0;
133: for _, matched in results[:50]]
/* "cfuzzyset.pyx":133 * if self.use_levenshtein: * results = [(distance(matched, value), matched) * for _, matched in results[:50]] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* results.sort(reverse=True, key=operator.itemgetter(0)) * */ __pyx_t_3 = __Pyx_PySequence_GetSlice(((PyObject *)__pyx_v_results), 0, 50); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_3)); if (unlikely(((PyObject *)__pyx_t_3) == Py_None)) { PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_1 = ((PyObject *)__pyx_t_3); __Pyx_INCREF(__pyx_t_1); __pyx_t_5 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; for (;;) { if (__pyx_t_5 >= PyList_GET_SIZE(__pyx_t_1)) break; __pyx_t_3 = PyList_GET_ITEM(__pyx_t_1, __pyx_t_5); __Pyx_INCREF(__pyx_t_3); __pyx_t_5++; if ((likely(PyTuple_CheckExact(__pyx_t_3))) || (PyList_CheckExact(__pyx_t_3))) { PyObject* sequence = __pyx_t_3; if (likely(PyTuple_CheckExact(sequence))) { if (unlikely(PyTuple_GET_SIZE(sequence) != 2)) { if (PyTuple_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyTuple_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_8 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_2 = PyTuple_GET_ITEM(sequence, 1); } else { if (unlikely(PyList_GET_SIZE(sequence) != 2)) { if (PyList_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyList_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_8 = PyList_GET_ITEM(sequence, 0); __pyx_t_2 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_8); __Pyx_INCREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; } else { Py_ssize_t index = -1; __pyx_t_14 = PyObject_GetIter(__pyx_t_3); if (unlikely(!__pyx_t_14)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_14); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_10 = Py_TYPE(__pyx_t_14)->tp_iternext; index = 0; __pyx_t_8 = __pyx_t_10(__pyx_t_14); if (unlikely(!__pyx_t_8)) goto __pyx_L23_unpacking_failed; __Pyx_GOTREF(__pyx_t_8); index = 1; __pyx_t_2 = __pyx_t_10(__pyx_t_14); if (unlikely(!__pyx_t_2)) goto __pyx_L23_unpacking_failed; __Pyx_GOTREF(__pyx_t_2); if (__Pyx_IternextUnpackEndCheck(__pyx_t_10(__pyx_t_14), 2)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; goto __pyx_L24_unpacking_done; __pyx_L23_unpacking_failed:; __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; if (PyErr_Occurred() && PyErr_ExceptionMatches(PyExc_StopIteration)) PyErr_Clear(); if (!PyErr_Occurred()) __Pyx_RaiseNeedMoreValuesError(index); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 133; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_L24_unpacking_done:; } __Pyx_XDECREF(__pyx_v__); __pyx_v__ = __pyx_t_8; __pyx_t_8 = 0; __Pyx_XDECREF(__pyx_v_matched); __pyx_v_matched = __pyx_t_2; __pyx_t_2 = 0;
134: results.sort(reverse=True, key=operator.itemgetter(0))
/* "cfuzzyset.pyx":134 * results = [(distance(matched, value), matched) * for _, matched in results[:50]] * results.sort(reverse=True, key=operator.itemgetter(0)) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * return [(score, self.exact_set[value]) */ __pyx_t_9 = PyObject_GetAttr(((PyObject *)__pyx_v_results), __pyx_n_s__sort); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __pyx_t_1 = PyDict_New(); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_1)); __pyx_t_3 = __Pyx_PyBool_FromLong(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); if (PyDict_SetItem(__pyx_t_1, ((PyObject *)__pyx_n_s__reverse), __pyx_t_3)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__operator); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_2 = PyObject_GetAttr(__pyx_t_3, __pyx_n_s__itemgetter); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_k_tuple_2), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_1, ((PyObject *)__pyx_n_s__key), __pyx_t_3)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyObject_Call(__pyx_t_9, ((PyObject *)__pyx_empty_tuple), ((PyObject *)__pyx_t_1)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "cfuzzyset.pyx":134 * results = [(distance(matched, value), matched) * for _, matched in results[:50]] * results.sort(reverse=True, key=operator.itemgetter(0)) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * return [(score, self.exact_set[value]) */ __pyx_k_tuple_2 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 134; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_2); __Pyx_INCREF(__pyx_int_0); PyTuple_SET_ITEM(__pyx_k_tuple_2, 0, __pyx_int_0); __Pyx_GIVEREF(__pyx_int_0); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_2));
135:
136: return [(score, self.exact_set[value])
/* "cfuzzyset.pyx":136 * results.sort(reverse=True, key=operator.itemgetter(0)) * * return [(score, self.exact_set[value]) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for score, value in results * if score == results[0][0]] */ __Pyx_XDECREF(__pyx_r); __pyx_t_3 = PyList_New(0); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); /* "cfuzzyset.pyx":136 * results.sort(reverse=True, key=operator.itemgetter(0)) * * return [(score, self.exact_set[value]) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for score, value in results * if score == results[0][0]] */ __pyx_t_8 = __Pyx_PyDict_GetItem(((PyObject *)__pyx_v_self->exact_set), ((PyObject *)__pyx_v_value)); if (!__pyx_t_8) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); __pyx_t_9 = PyTuple_New(2); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __Pyx_INCREF(__pyx_v_score); PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_v_score); __Pyx_GIVEREF(__pyx_v_score); PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_8); __Pyx_GIVEREF(__pyx_t_8); __pyx_t_8 = 0; if (unlikely(PyList_Append(__pyx_t_3, (PyObject*)__pyx_t_9))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 136; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(((PyObject *)__pyx_t_9)); __pyx_t_9 = 0; goto __pyx_L29; } __pyx_L29:; } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_INCREF(((PyObject *)__pyx_t_3)); __pyx_r = ((PyObject *)__pyx_t_3); __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; goto __pyx_L0; goto __pyx_L20; } /*else*/ {
137: for score, value in results
/* "cfuzzyset.pyx":137 * * return [(score, self.exact_set[value]) * for score, value in results #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* if score == results[0][0]] * else: */ if (__pyx_t_5 >= PyList_GET_SIZE(__pyx_t_1)) break; __pyx_t_9 = PyList_GET_ITEM(__pyx_t_1, __pyx_t_5); __Pyx_INCREF(__pyx_t_9); __pyx_t_5++; if ((likely(PyTuple_CheckExact(__pyx_t_9))) || (PyList_CheckExact(__pyx_t_9))) { PyObject* sequence = __pyx_t_9; if (likely(PyTuple_CheckExact(sequence))) { if (unlikely(PyTuple_GET_SIZE(sequence) != 2)) { if (PyTuple_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyTuple_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 137; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_2 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_8 = PyTuple_GET_ITEM(sequence, 1); } else { if (unlikely(PyList_GET_SIZE(sequence) != 2)) { if (PyList_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyList_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 137; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_2 = PyList_GET_ITEM(sequence, 0); __pyx_t_8 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_2); __Pyx_INCREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; } else { Py_ssize_t index = -1; __pyx_t_14 = PyObject_GetIter(__pyx_t_9); if (unlikely(!__pyx_t_14)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 137; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_14); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_10 = Py_TYPE(__pyx_t_14)->tp_iternext; index = 0; __pyx_t_2 = __pyx_t_10(__pyx_t_14); if (unlikely(!__pyx_t_2)) goto __pyx_L27_unpacking_failed; __Pyx_GOTREF(__pyx_t_2); index = 1; __pyx_t_8 = __pyx_t_10(__pyx_t_14); if (unlikely(!__pyx_t_8)) goto __pyx_L27_unpacking_failed; __Pyx_GOTREF(__pyx_t_8); if (__Pyx_IternextUnpackEndCheck(__pyx_t_10(__pyx_t_14), 2)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 137; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; goto __pyx_L28_unpacking_done; __pyx_L27_unpacking_failed:; __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; if (PyErr_Occurred() && PyErr_ExceptionMatches(PyExc_StopIteration)) PyErr_Clear(); if (!PyErr_Occurred()) __Pyx_RaiseNeedMoreValuesError(index); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 137; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_L28_unpacking_done:; } if (!(likely(PyUnicode_CheckExact(__pyx_t_8))||((__pyx_t_8) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected unicode, got %.200s", Py_TYPE(__pyx_t_8)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 137; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_XDECREF(__pyx_v_score); __pyx_v_score = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(((PyObject *)__pyx_v_value)); __pyx_v_value = ((PyObject*)__pyx_t_8); __pyx_t_8 = 0;
138: if score == results[0][0]]
/* "cfuzzyset.pyx":138 * return [(score, self.exact_set[value]) * for score, value in results * if score == results[0][0]] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* else: * return [(score / norm, self.exact_set[value]) */ __pyx_t_1 = ((PyObject *)__pyx_v_results); __Pyx_INCREF(__pyx_t_1); __pyx_t_5 = 0; for (;;) { /* "cfuzzyset.pyx":138 * return [(score, self.exact_set[value]) * for score, value in results * if score == results[0][0]] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* else: * return [(score / norm, self.exact_set[value]) */ __pyx_t_9 = __Pyx_GetItemInt(PyList_GET_ITEM(__pyx_v_results, 0), 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_9) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 138; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __pyx_t_8 = PyObject_RichCompare(__pyx_v_score, __pyx_t_9, Py_EQ); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 138; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_16 = __Pyx_PyObject_IsTrue(__pyx_t_8); if (unlikely(__pyx_t_16<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 138; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (__pyx_t_16) {
139: else:
140: return [(score / norm, self.exact_set[value])
/* "cfuzzyset.pyx":140 * if score == results[0][0]] * else: * return [(score / norm, self.exact_set[value]) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for score, value in results * if score == results[0][0]] */ __Pyx_XDECREF(__pyx_r); __pyx_t_3 = PyList_New(0); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 140; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); /* "cfuzzyset.pyx":140 * if score == results[0][0]] * else: * return [(score / norm, self.exact_set[value]) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* for score, value in results * if score == results[0][0]] */ __pyx_t_2 = PyFloat_FromDouble(__pyx_v_norm); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 140; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_9 = __Pyx_PyNumber_Divide(__pyx_v_score, __pyx_t_2); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 140; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_PyDict_GetItem(((PyObject *)__pyx_v_self->exact_set), ((PyObject *)__pyx_v_value)); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 140; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_8 = PyTuple_New(2); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 140; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_9); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __pyx_t_9 = 0; __pyx_t_2 = 0; if (unlikely(PyList_Append(__pyx_t_3, (PyObject*)__pyx_t_8))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 140; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(((PyObject *)__pyx_t_8)); __pyx_t_8 = 0; goto __pyx_L34; } __pyx_L34:; } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_INCREF(((PyObject *)__pyx_t_3)); __pyx_r = ((PyObject *)__pyx_t_3); __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; goto __pyx_L0; } __pyx_L20:; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_8); __Pyx_XDECREF(__pyx_t_9); __Pyx_XDECREF(__pyx_t_14); __Pyx_AddTraceback("cfuzzyset.cFuzzySet._get", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_lvalue); __Pyx_XDECREF(__pyx_v_matches); __Pyx_XDECREF(__pyx_v_grams); __Pyx_XDECREF(__pyx_v_values); __Pyx_XDECREF(__pyx_v_gram); __Pyx_XDECREF(__pyx_v_items); __Pyx_XDECREF(__pyx_v_results); __Pyx_XDECREF(__pyx_v__); __Pyx_XDECREF(__pyx_v_matched); __Pyx_XDECREF(__pyx_v_score); __Pyx_XDECREF(__pyx_v_value); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_9_get(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_9cfuzzyset_9cFuzzySet_9_get(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_value = 0; int __pyx_v_gram_size; static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__value,&__pyx_n_s__gram_size,0}; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_get (wrapper)", 0); { PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__value); if (likely(values[0])) kw_args--; else goto __pyx_L5_argtuple_error; case 1: values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__gram_size); if (likely(values[1])) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_get", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_get")<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_value = ((PyObject*)values[0]); __pyx_v_gram_size = __Pyx_PyInt_AsInt(values[1]); if (unlikely((__pyx_v_gram_size == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_get", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("cfuzzyset.cFuzzySet._get", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_value), (&PyUnicode_Type), 1, "value", 1))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_r = __pyx_pf_9cfuzzyset_9cFuzzySet_8_get(((struct __pyx_obj_9cfuzzyset_cFuzzySet *)__pyx_v_self), __pyx_v_value, __pyx_v_gram_size); goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
141: for score, value in results
/* "cfuzzyset.pyx":141 * else: * return [(score / norm, self.exact_set[value]) * for score, value in results #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* if score == results[0][0]] * */ if (__pyx_t_5 >= PyList_GET_SIZE(__pyx_t_1)) break; __pyx_t_9 = PyList_GET_ITEM(__pyx_t_1, __pyx_t_5); __Pyx_INCREF(__pyx_t_9); __pyx_t_5++; if ((likely(PyTuple_CheckExact(__pyx_t_9))) || (PyList_CheckExact(__pyx_t_9))) { PyObject* sequence = __pyx_t_9; if (likely(PyTuple_CheckExact(sequence))) { if (unlikely(PyTuple_GET_SIZE(sequence) != 2)) { if (PyTuple_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyTuple_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_8 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_2 = PyTuple_GET_ITEM(sequence, 1); } else { if (unlikely(PyList_GET_SIZE(sequence) != 2)) { if (PyList_GET_SIZE(sequence) > 2) __Pyx_RaiseTooManyValuesError(2); else __Pyx_RaiseNeedMoreValuesError(PyList_GET_SIZE(sequence)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_8 = PyList_GET_ITEM(sequence, 0); __pyx_t_2 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_8); __Pyx_INCREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; } else { Py_ssize_t index = -1; __pyx_t_14 = PyObject_GetIter(__pyx_t_9); if (unlikely(!__pyx_t_14)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_14); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_10 = Py_TYPE(__pyx_t_14)->tp_iternext; index = 0; __pyx_t_8 = __pyx_t_10(__pyx_t_14); if (unlikely(!__pyx_t_8)) goto __pyx_L32_unpacking_failed; __Pyx_GOTREF(__pyx_t_8); index = 1; __pyx_t_2 = __pyx_t_10(__pyx_t_14); if (unlikely(!__pyx_t_2)) goto __pyx_L32_unpacking_failed; __Pyx_GOTREF(__pyx_t_2); if (__Pyx_IternextUnpackEndCheck(__pyx_t_10(__pyx_t_14), 2)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; goto __pyx_L33_unpacking_done; __pyx_L32_unpacking_failed:; __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; if (PyErr_Occurred() && PyErr_ExceptionMatches(PyExc_StopIteration)) PyErr_Clear(); if (!PyErr_Occurred()) __Pyx_RaiseNeedMoreValuesError(index); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_L33_unpacking_done:; } if (!(likely(PyUnicode_CheckExact(__pyx_t_2))||((__pyx_t_2) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected unicode, got %.200s", Py_TYPE(__pyx_t_2)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_XDECREF(__pyx_v_score); __pyx_v_score = __pyx_t_8; __pyx_t_8 = 0; __Pyx_DECREF(((PyObject *)__pyx_v_value)); __pyx_v_value = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
142: if score == results[0][0]]
/* "cfuzzyset.pyx":142 * return [(score / norm, self.exact_set[value]) * for score, value in results * if score == results[0][0]] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * def get(self, object key, object default=None): */ __pyx_t_1 = ((PyObject *)__pyx_v_results); __Pyx_INCREF(__pyx_t_1); __pyx_t_5 = 0; for (;;) { /* "cfuzzyset.pyx":142 * return [(score / norm, self.exact_set[value]) * for score, value in results * if score == results[0][0]] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * def get(self, object key, object default=None): */ __pyx_t_9 = __Pyx_GetItemInt(PyList_GET_ITEM(__pyx_v_results, 0), 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_9) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 142; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_9); __pyx_t_2 = PyObject_RichCompare(__pyx_v_score, __pyx_t_9, Py_EQ); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 142; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_16 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely(__pyx_t_16<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 142; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (__pyx_t_16) {
143:
144: def get(self, object key, object default=None):
/* "cfuzzyset.pyx":144 * if score == results[0][0]] * * def get(self, object key, object default=None): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* try: * return self[key] */ values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__key); if (likely(values[0])) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (kw_args > 0) { PyObject* value = PyDict_GetItem(__pyx_kwds, __pyx_n_s__default); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "get")<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 144; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_key = values[0]; __pyx_v_default = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("get", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 144; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("cfuzzyset.cFuzzySet.get", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_9cfuzzyset_9cFuzzySet_10get(((struct __pyx_obj_9cfuzzyset_cFuzzySet *)__pyx_v_self), __pyx_v_key, __pyx_v_default); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9cfuzzyset_9cFuzzySet_10get(struct __pyx_obj_9cfuzzyset_cFuzzySet *__pyx_v_self, PyObject *__pyx_v_key, PyObject *__pyx_v_default) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("get", 0);
145: try:
/* "cfuzzyset.pyx":145 * * def get(self, object key, object default=None): * try: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* return self[key] * except KeyError: */ { __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3); __Pyx_XGOTREF(__pyx_t_1); __Pyx_XGOTREF(__pyx_t_2); __Pyx_XGOTREF(__pyx_t_3); /*try:*/ {
146: return self[key]
/* "cfuzzyset.pyx":146 * def get(self, object key, object default=None): * try: * return self[key] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* except KeyError: * return default */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = PyObject_GetItem(((PyObject *)__pyx_v_self), __pyx_v_key); if (!__pyx_t_4) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 146; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L7_try_return; } __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; goto __pyx_L10_try_end; __pyx_L7_try_return:; __Pyx_XGIVEREF(__pyx_t_1); __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); goto __pyx_L0; __pyx_L3_error:; __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
147: except KeyError:
/* "cfuzzyset.pyx":147 * try: * return self[key] * except KeyError: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* return default * */ __pyx_t_5 = PyErr_ExceptionMatches(__pyx_builtin_KeyError); if (__pyx_t_5) { __Pyx_AddTraceback("cfuzzyset.cFuzzySet.get", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_4, &__pyx_t_6, &__pyx_t_7)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 147; __pyx_clineno = __LINE__; goto __pyx_L5_except_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_GOTREF(__pyx_t_6); __Pyx_GOTREF(__pyx_t_7);
148: return default
/* "cfuzzyset.pyx":148 * return self[key] * except KeyError: * return default #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * @cython.boundscheck(False) */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_default); __pyx_r = __pyx_v_default; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; goto __pyx_L6_except_return; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; goto __pyx_L4_exception_handled; } __pyx_L5_except_error:; __Pyx_XGIVEREF(__pyx_t_1); __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); goto __pyx_L1_error; __pyx_L6_except_return:; __Pyx_XGIVEREF(__pyx_t_1); __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); goto __pyx_L0; __pyx_L4_exception_handled:; __Pyx_XGIVEREF(__pyx_t_1); __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); __pyx_L10_try_end:; } __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_AddTraceback("cfuzzyset.cFuzzySet.get", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
149:
150: @cython.boundscheck(False)
151: cdef dict _gram_counter(unicode value, int gram_size=2):
/* "cfuzzyset.pyx":151 * * @cython.boundscheck(False) * cdef dict _gram_counter(unicode value, int gram_size=2): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef dict results = {} * cdef list grams = _iterate_grams(value, gram_size) */ static PyObject *__pyx_f_9cfuzzyset__gram_counter(PyObject *__pyx_v_value, struct __pyx_opt_args_9cfuzzyset__gram_counter *__pyx_optional_args) { int __pyx_v_gram_size = ((int)2); PyObject *__pyx_v_results = 0; PyObject *__pyx_v_grams = 0; PyObject *__pyx_v_gram = 0; int __pyx_v_i; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_gram_counter", 0); if (__pyx_optional_args) { if (__pyx_optional_args->__pyx_n > 0) { __pyx_v_gram_size = __pyx_optional_args->gram_size; } } /* "cfuzzyset.pyx":151 * * @cython.boundscheck(False) * cdef dict _gram_counter(unicode value, int gram_size=2): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef dict results = {} * cdef list grams = _iterate_grams(value, gram_size) */ struct __pyx_opt_args_9cfuzzyset__gram_counter { int __pyx_n; int gram_size; };
152: cdef dict results = {}
/* "cfuzzyset.pyx":152 * @cython.boundscheck(False) * cdef dict _gram_counter(unicode value, int gram_size=2): * cdef dict results = {} #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef list grams = _iterate_grams(value, gram_size) * cdef unicode gram */ __pyx_t_1 = PyDict_New(); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_1)); __pyx_v_results = __pyx_t_1; __pyx_t_1 = 0;
153: cdef list grams = _iterate_grams(value, gram_size)
/* "cfuzzyset.pyx":153 * cdef dict _gram_counter(unicode value, int gram_size=2): * cdef dict results = {} * cdef list grams = _iterate_grams(value, gram_size) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef unicode gram * cdef int i */ __pyx_t_2.__pyx_n = 1; __pyx_t_2.gram_size = __pyx_v_gram_size; __pyx_t_1 = ((PyObject *)__pyx_f_9cfuzzyset__iterate_grams(__pyx_v_value, &__pyx_t_2)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 153; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_v_grams = ((PyObject*)__pyx_t_1); __pyx_t_1 = 0;
154: cdef unicode gram
155: cdef int i
156: for i in range(len(grams)):
/* "cfuzzyset.pyx":156 * cdef unicode gram * cdef int i * for i in range(len(grams)): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* gram = grams[i] * if gram not in results: */ if (unlikely(((PyObject *)__pyx_v_grams) == Py_None)) { PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 156; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_3 = PyList_GET_SIZE(((PyObject *)__pyx_v_grams)); for (__pyx_t_4 = 0; __pyx_t_4<
__pyx_t_3; __pyx_t_4+=1) { __pyx_v_i = __pyx_t_4;
157: gram = grams[i]
/* "cfuzzyset.pyx":157 * cdef int i * for i in range(len(grams)): * gram = grams[i] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* if gram not in results: * results[gram] = 1 */ __pyx_t_1 = __Pyx_GetItemInt_List(((PyObject *)__pyx_v_grams), __pyx_v_i, sizeof(int), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 157; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (!(likely(PyUnicode_CheckExact(__pyx_t_1))||((__pyx_t_1) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected unicode, got %.200s", Py_TYPE(__pyx_t_1)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 157; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_XDECREF(((PyObject *)__pyx_v_gram)); __pyx_v_gram = ((PyObject*)__pyx_t_1); __pyx_t_1 = 0;
158: if gram not in results:
/* "cfuzzyset.pyx":158 * for i in range(len(grams)): * gram = grams[i] * if gram not in results: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* results[gram] = 1 * else: */ __pyx_t_5 = (__Pyx_NegateNonNeg(PyDict_Contains(((PyObject *)__pyx_v_results), ((PyObject *)__pyx_v_gram)))); if (unlikely(__pyx_t_5<
0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 158; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__pyx_t_5) {
159: results[gram] = 1
/* "cfuzzyset.pyx":159 * gram = grams[i] * if gram not in results: * results[gram] = 1 #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* else: * results[gram] += 1 */ if (PyDict_SetItem(((PyObject *)__pyx_v_results), ((PyObject *)__pyx_v_gram), __pyx_int_1)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 159; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L5; } /*else*/ {
160: else:
161: results[gram] += 1
/* "cfuzzyset.pyx":161 * results[gram] = 1 * else: * results[gram] += 1 #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* return results * */ __Pyx_INCREF(((PyObject *)__pyx_v_gram)); __pyx_t_6 = __pyx_v_gram; __pyx_t_1 = __Pyx_PyDict_GetItem(((PyObject *)__pyx_v_results), ((PyObject *)__pyx_t_6)); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 161; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_7 = PyNumber_InPlaceAdd(__pyx_t_1, __pyx_int_1); if (unlikely(!__pyx_t_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 161; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem(((PyObject *)__pyx_v_results), ((PyObject *)__pyx_t_6), __pyx_t_7)<
0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 161; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_6)); __pyx_t_6 = 0; } __pyx_L5:; }
162: return results
/* "cfuzzyset.pyx":162 * else: * results[gram] += 1 * return results #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * cdef unicode hyphens = u'-----------' */ __Pyx_XDECREF(((PyObject *)__pyx_r)); __Pyx_INCREF(((PyObject *)__pyx_v_results)); __pyx_r = __pyx_v_results; goto __pyx_L0; __pyx_r = ((PyObject*)Py_None); __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(((PyObject *)__pyx_t_6)); __Pyx_XDECREF(__pyx_t_7); __Pyx_AddTraceback("cfuzzyset._gram_counter", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_results); __Pyx_XDECREF(__pyx_v_grams); __Pyx_XDECREF(__pyx_v_gram); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
163:
164: cdef unicode hyphens = u'-----------'
/* "cfuzzyset.pyx":164 * return results * * cdef unicode hyphens = u'-----------' #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * cdef list _iterate_grams(unicode value, int gram_size=2): */ __Pyx_INCREF(((PyObject *)__pyx_kp_u_9)); __Pyx_XGOTREF(((PyObject *)__pyx_v_9cfuzzyset_hyphens)); __Pyx_DECREF(((PyObject *)__pyx_v_9cfuzzyset_hyphens)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_u_9)); __pyx_v_9cfuzzyset_hyphens = __pyx_kp_u_9;
165:
166: cdef list _iterate_grams(unicode value, int gram_size=2):
/* "cfuzzyset.pyx":166 * cdef unicode hyphens = u'-----------' * * cdef list _iterate_grams(unicode value, int gram_size=2): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef unicode simplified = u'-' + _non_word_re.sub('', value) + u'-' * cdef int len_diff = gram_size - len(simplified) */ static PyObject *__pyx_f_9cfuzzyset__iterate_grams(PyObject *__pyx_v_value, struct __pyx_opt_args_9cfuzzyset__iterate_grams *__pyx_optional_args) { int __pyx_v_gram_size = ((int)2); PyObject *__pyx_v_simplified = 0; int __pyx_v_len_diff; PyObject *__pyx_v_result = 0; int __pyx_v_iterations; int __pyx_v_i; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_iterate_grams", 0); if (__pyx_optional_args) { if (__pyx_optional_args->__pyx_n > 0) { __pyx_v_gram_size = __pyx_optional_args->gram_size; } } __Pyx_INCREF(__pyx_v_value); /* "cfuzzyset.pyx":166 * cdef unicode hyphens = u'-----------' * * cdef list _iterate_grams(unicode value, int gram_size=2): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef unicode simplified = u'-' + _non_word_re.sub('', value) + u'-' * cdef int len_diff = gram_size - len(simplified) */ struct __pyx_opt_args_9cfuzzyset__iterate_grams { int __pyx_n; int gram_size; };
167: cdef unicode simplified = u'-' + _non_word_re.sub('', value) + u'-'
/* "cfuzzyset.pyx":167 * * cdef list _iterate_grams(unicode value, int gram_size=2): * cdef unicode simplified = u'-' + _non_word_re.sub('', value) + u'-' #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef int len_diff = gram_size - len(simplified) * cdef list result = [] */ __pyx_t_1 = PyObject_GetAttr(__pyx_v_9cfuzzyset__non_word_re, __pyx_n_s__sub); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(((PyObject *)__pyx_kp_s_4)); PyTuple_SET_ITEM(__pyx_t_2, 0, ((PyObject *)__pyx_kp_s_4)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_4)); __Pyx_INCREF(((PyObject *)__pyx_v_value)); PyTuple_SET_ITEM(__pyx_t_2, 1, ((PyObject *)__pyx_v_value)); __Pyx_GIVEREF(((PyObject *)__pyx_v_value)); __pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0; __pyx_t_2 = PyNumber_Add(((PyObject *)__pyx_kp_u_3), __pyx_t_3); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyNumber_Add(__pyx_t_2, ((PyObject *)__pyx_kp_u_3)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (!(likely(PyUnicode_CheckExact(__pyx_t_3))||((__pyx_t_3) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected unicode, got %.200s", Py_TYPE(__pyx_t_3)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_simplified = ((PyObject*)__pyx_t_3); __pyx_t_3 = 0;
168: cdef int len_diff = gram_size - len(simplified)
/* "cfuzzyset.pyx":168 * cdef list _iterate_grams(unicode value, int gram_size=2): * cdef unicode simplified = u'-' + _non_word_re.sub('', value) + u'-' * cdef int len_diff = gram_size - len(simplified) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef list result = [] * with cython.boundscheck(False): */ if (unlikely(((PyObject *)__pyx_v_simplified) == Py_None)) { PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 168; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_4 = __Pyx_PyUnicode_GET_LENGTH(((PyObject *)__pyx_v_simplified)); __pyx_v_len_diff = (__pyx_v_gram_size - __pyx_t_4);
169: cdef list result = []
/* "cfuzzyset.pyx":169 * cdef unicode simplified = u'-' + _non_word_re.sub('', value) + u'-' * cdef int len_diff = gram_size - len(simplified) * cdef list result = [] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* with cython.boundscheck(False): * if len_diff > 0: */ __pyx_t_3 = PyList_New(0); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 169; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_v_result = __pyx_t_3; __pyx_t_3 = 0;
170: with cython.boundscheck(False):
171: if len_diff > 0:
/* "cfuzzyset.pyx":171 * cdef list result = [] * with cython.boundscheck(False): * if len_diff > 0: #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* value += hyphens[:len_diff] * cdef int iterations = len(simplified) - gram_size + 1 */ __pyx_t_5 = (__pyx_v_len_diff > 0); if (__pyx_t_5) {
172: value += hyphens[:len_diff]
/* "cfuzzyset.pyx":172 * with cython.boundscheck(False): * if len_diff > 0: * value += hyphens[:len_diff] #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef int iterations = len(simplified) - gram_size + 1 * cdef int i */ __pyx_t_3 = __Pyx_PySequence_GetSlice(((PyObject *)__pyx_v_9cfuzzyset_hyphens), 0, __pyx_v_len_diff); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 172; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_3)); __pyx_t_2 = PyNumber_InPlaceAdd(((PyObject *)__pyx_v_value), ((PyObject *)__pyx_t_3)); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 172; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_2)); __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; __Pyx_DECREF(((PyObject *)__pyx_v_value)); __pyx_v_value = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L3; } __pyx_L3:;
173: cdef int iterations = len(simplified) - gram_size + 1
/* "cfuzzyset.pyx":173 * if len_diff > 0: * value += hyphens[:len_diff] * cdef int iterations = len(simplified) - gram_size + 1 #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef int i * with cython.boundscheck(False): */ if (unlikely(((PyObject *)__pyx_v_simplified) == Py_None)) { PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 173; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_4 = __Pyx_PyUnicode_GET_LENGTH(((PyObject *)__pyx_v_simplified)); __pyx_v_iterations = ((__pyx_t_4 - __pyx_v_gram_size) + 1);
174: cdef int i
175: with cython.boundscheck(False):
176: for i in range(iterations):
/* "cfuzzyset.pyx":176 * cdef int i * with cython.boundscheck(False): * for i in range(iterations): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* result.append(simplified[i:i + gram_size]) * return result */ __pyx_t_6 = __pyx_v_iterations; for (__pyx_t_7 = 0; __pyx_t_7<
__pyx_t_6; __pyx_t_7+=1) { __pyx_v_i = __pyx_t_7;
177: result.append(simplified[i:i + gram_size])
/* "cfuzzyset.pyx":177 * with cython.boundscheck(False): * for i in range(iterations): * result.append(simplified[i:i + gram_size]) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* return result * */ __pyx_t_2 = __Pyx_PySequence_GetSlice(((PyObject *)__pyx_v_simplified), __pyx_v_i, (__pyx_v_i + __pyx_v_gram_size)); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 177; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_2)); __pyx_t_8 = PyList_Append(__pyx_v_result, ((PyObject *)__pyx_t_2)); if (unlikely(__pyx_t_8 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 177; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0; }
178: return result
/* "cfuzzyset.pyx":178 * for i in range(iterations): * result.append(simplified[i:i + gram_size]) * return result #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * cdef unicode _convert_val(object value): */ __Pyx_XDECREF(((PyObject *)__pyx_r)); __Pyx_INCREF(((PyObject *)__pyx_v_result)); __pyx_r = __pyx_v_result; goto __pyx_L0; __pyx_r = ((PyObject*)Py_None); __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cfuzzyset._iterate_grams", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_simplified); __Pyx_XDECREF(__pyx_v_result); __Pyx_XDECREF(__pyx_v_value); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
179:
180: cdef unicode _convert_val(object value):
/* "cfuzzyset.pyx":180 * return result * * cdef unicode _convert_val(object value): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* if isinstance(value, unicode): * return value */ static PyObject *__pyx_f_9cfuzzyset__convert_val(PyObject *__pyx_v_value) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_convert_val", 0);
181: if isinstance(value, unicode):
/* "cfuzzyset.pyx":181 * * cdef unicode _convert_val(object value): * if isinstance(value, unicode): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* return value * elif isinstance(value, str): */ __pyx_t_1 = ((PyObject *)((PyObject*)(&PyUnicode_Type))); __Pyx_INCREF(__pyx_t_1); __pyx_t_2 = __Pyx_TypeCheck(__pyx_v_value, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_2) {
182: return value
/* "cfuzzyset.pyx":182 * cdef unicode _convert_val(object value): * if isinstance(value, unicode): * return value #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* elif isinstance(value, str): * return unicode(value) */ __Pyx_XDECREF(((PyObject *)__pyx_r)); if (!(likely(PyUnicode_CheckExact(__pyx_v_value))||((__pyx_v_value) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected unicode, got %.200s", Py_TYPE(__pyx_v_value)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 182; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_INCREF(__pyx_v_value); __pyx_r = ((PyObject*)__pyx_v_value); goto __pyx_L0; goto __pyx_L3; }
183: elif isinstance(value, str):
/* "cfuzzyset.pyx":183 * if isinstance(value, unicode): * return value * elif isinstance(value, str): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* return unicode(value) * else: */ __pyx_t_1 = ((PyObject *)((PyObject*)(&PyString_Type))); __Pyx_INCREF(__pyx_t_1); __pyx_t_2 = __Pyx_TypeCheck(__pyx_v_value, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_2) {
184: return unicode(value)
/* "cfuzzyset.pyx":184 * return value * elif isinstance(value, str): * return unicode(value) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* else: * raise TypeError("Expecting string or unicode, received " + value) */ __Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 184; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_v_value); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_value); __Pyx_GIVEREF(__pyx_v_value); __pyx_t_3 = PyObject_Call(((PyObject *)((PyObject*)(&PyUnicode_Type))), ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 184; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; __pyx_r = ((PyObject*)__pyx_t_3); __pyx_t_3 = 0; goto __pyx_L0; goto __pyx_L3; } /*else*/ {
185: else:
186: raise TypeError("Expecting string or unicode, received " + value)
/* "cfuzzyset.pyx":186 * return unicode(value) * else: * raise TypeError("Expecting string or unicode, received " + value) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* * cdef double distance(unicode str1, unicode str2): */ __pyx_t_3 = PyNumber_Add(((PyObject *)__pyx_kp_s_5), __pyx_v_value); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_3); __Pyx_GIVEREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyObject_Call(__pyx_builtin_TypeError, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_L3:; __pyx_r = ((PyObject*)Py_None); __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cfuzzyset._convert_val", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
187:
188: cdef double distance(unicode str1, unicode str2):
/* "cfuzzyset.pyx":188 * raise TypeError("Expecting string or unicode, received " + value) * * cdef double distance(unicode str1, unicode str2): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* cdef double result = Levenshtein.distance(str1, str2) * if len(str1) > len(str2): */ static double __pyx_f_9cfuzzyset_distance(PyObject *__pyx_v_str1, PyObject *__pyx_v_str2) { double __pyx_v_result; double __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("distance", 0);
189: cdef double result = Levenshtein.distance(str1, str2)
/* "cfuzzyset.pyx":189 * * cdef double distance(unicode str1, unicode str2): * cdef double result = Levenshtein.distance(str1, str2) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* if len(str1) > len(str2): * return 1 - result / len(str1) */ __pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__Levenshtein); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 189; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__distance); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 189; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 189; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(((PyObject *)__pyx_v_str1)); PyTuple_SET_ITEM(__pyx_t_1, 0, ((PyObject *)__pyx_v_str1)); __Pyx_GIVEREF(((PyObject *)__pyx_v_str1)); __Pyx_INCREF(((PyObject *)__pyx_v_str2)); PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_v_str2)); __Pyx_GIVEREF(((PyObject *)__pyx_v_str2)); __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 189; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; __pyx_t_4 = __pyx_PyFloat_AsDouble(__pyx_t_3); if (unlikely((__pyx_t_4 == (double)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 189; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_v_result = __pyx_t_4;
190: if len(str1) > len(str2):
/* "cfuzzyset.pyx":190 * cdef double distance(unicode str1, unicode str2): * cdef double result = Levenshtein.distance(str1, str2) * if len(str1) > len(str2): #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* return 1 - result / len(str1) * else: */ if (unlikely(((PyObject *)__pyx_v_str1) == Py_None)) { PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 190; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_5 = __Pyx_PyUnicode_GET_LENGTH(((PyObject *)__pyx_v_str1)); if (unlikely(((PyObject *)__pyx_v_str2) == Py_None)) { PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 190; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_6 = __Pyx_PyUnicode_GET_LENGTH(((PyObject *)__pyx_v_str2)); __pyx_t_7 = (__pyx_t_5 > __pyx_t_6); if (__pyx_t_7) {
191: return 1 - result / len(str1)
/* "cfuzzyset.pyx":191 * cdef double result = Levenshtein.distance(str1, str2) * if len(str1) > len(str2): * return 1 - result / len(str1) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
* else: * return 1 - result / len(str2) */ if (unlikely(((PyObject *)__pyx_v_str1) == Py_None)) { PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 191; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_6 = __Pyx_PyUnicode_GET_LENGTH(((PyObject *)__pyx_v_str1)); if (unlikely(__pyx_t_6 == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "float division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 191; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_r = (1.0 - (__pyx_v_result / __pyx_t_6)); goto __pyx_L0; goto __pyx_L3; } /*else*/ {
192: else:
193: return 1 - result / len(str2)
/* "cfuzzyset.pyx":193 * return 1 - result / len(str1) * else: * return 1 - result / len(str2) #<
<
<
<
<
<
<
<
<
<
<
<
<
<
*/ if (unlikely(((PyObject *)__pyx_v_str2) == Py_None)) { PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 193; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_6 = __Pyx_PyUnicode_GET_LENGTH(((PyObject *)__pyx_v_str2)); if (unlikely(__pyx_t_6 == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "float division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 193; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_r = (1.0 - (__pyx_v_result / __pyx_t_6)); goto __pyx_L0; } __pyx_L3:; __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_WriteUnraisable("cfuzzyset.distance", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }