Show More
@@ -41,10 +41,10 b' typedef struct {' | |||
|
41 | 41 | */ |
|
42 | 42 | typedef struct { |
|
43 | 43 | nodetreenode *nodes; |
|
44 |
unsigned |
|
|
45 |
unsigned |
|
|
46 |
int |
|
|
47 |
int |
|
|
44 | unsigned length; /* # nodes in use */ | |
|
45 | unsigned capacity; /* # nodes allocated */ | |
|
46 | int depth; /* maximum depth of tree */ | |
|
47 | int splits; /* # splits performed */ | |
|
48 | 48 | } nodetree; |
|
49 | 49 | |
|
50 | 50 | /* |
@@ -372,10 +372,10 b' static PyObject *index_stats(indexObject' | |||
|
372 | 372 | istat(ntmisses, "node trie misses"); |
|
373 | 373 | istat(ntrev, "node trie last rev scanned"); |
|
374 | 374 | if (self->nt) { |
|
375 |
istat(nt-> |
|
|
376 |
istat(nt-> |
|
|
377 |
istat(nt-> |
|
|
378 |
istat(nt-> |
|
|
375 | istat(nt->capacity, "node trie capacity"); | |
|
376 | istat(nt->depth, "node trie depth"); | |
|
377 | istat(nt->length, "node trie count"); | |
|
378 | istat(nt->splits, "node trie splits"); | |
|
379 | 379 | } |
|
380 | 380 | |
|
381 | 381 | #undef istat |
@@ -1018,23 +1018,23 b' static int nt_find(indexObject *self, co' | |||
|
1018 | 1018 | static int nt_new(indexObject *self) |
|
1019 | 1019 | { |
|
1020 | 1020 | nodetree *nt = self->nt; |
|
1021 |
if (nt-> |
|
|
1022 |
if (nt-> |
|
|
1021 | if (nt->length == nt->capacity) { | |
|
1022 | if (nt->capacity >= INT_MAX / (sizeof(nodetreenode) * 2)) { | |
|
1023 | 1023 | PyErr_SetString(PyExc_MemoryError, |
|
1024 | 1024 | "overflow in nt_new"); |
|
1025 | 1025 | return -1; |
|
1026 | 1026 | } |
|
1027 |
nt-> |
|
|
1027 | nt->capacity *= 2; | |
|
1028 | 1028 | nt->nodes = realloc(nt->nodes, |
|
1029 |
nt-> |
|
|
1029 | nt->capacity * sizeof(nodetreenode)); | |
|
1030 | 1030 | if (nt->nodes == NULL) { |
|
1031 | 1031 | PyErr_SetString(PyExc_MemoryError, "out of memory"); |
|
1032 | 1032 | return -1; |
|
1033 | 1033 | } |
|
1034 |
memset(&nt->nodes[nt-> |
|
|
1035 |
sizeof(nodetreenode) * (nt-> |
|
|
1034 | memset(&nt->nodes[nt->length], 0, | |
|
1035 | sizeof(nodetreenode) * (nt->capacity - nt->length)); | |
|
1036 | 1036 | } |
|
1037 |
return nt-> |
|
|
1037 | return nt->length++; | |
|
1038 | 1038 | } |
|
1039 | 1039 | |
|
1040 | 1040 | static int nt_insert(indexObject *self, const char *node, int rev) |
@@ -1072,9 +1072,9 b' static int nt_insert(indexObject *self, ' | |||
|
1072 | 1072 | off = noff; |
|
1073 | 1073 | n = &self->nt->nodes[off]; |
|
1074 | 1074 | n->children[nt_level(oldnode, ++level)] = v; |
|
1075 |
if (level > self->nt-> |
|
|
1076 |
self->nt-> |
|
|
1077 |
self->nt-> |
|
|
1075 | if (level > self->nt->depth) | |
|
1076 | self->nt->depth = level; | |
|
1077 | self->nt->splits += 1; | |
|
1078 | 1078 | } else { |
|
1079 | 1079 | level += 1; |
|
1080 | 1080 | off = v; |
@@ -1102,10 +1102,10 b' static int nt_init(indexObject *self)' | |||
|
1102 | 1102 | PyErr_SetString(PyExc_ValueError, "overflow in nt_init"); |
|
1103 | 1103 | return -1; |
|
1104 | 1104 | } |
|
1105 |
self->nt-> |
|
|
1105 | self->nt->capacity = self->raw_length < 4 | |
|
1106 | 1106 | ? 4 : (int)self->raw_length / 2; |
|
1107 | 1107 | |
|
1108 |
self->nt->nodes = calloc(self->nt-> |
|
|
1108 | self->nt->nodes = calloc(self->nt->capacity, sizeof(nodetreenode)); | |
|
1109 | 1109 | if (self->nt->nodes == NULL) { |
|
1110 | 1110 | free(self->nt); |
|
1111 | 1111 | self->nt = NULL; |
@@ -1115,9 +1115,9 b' static int nt_init(indexObject *self)' | |||
|
1115 | 1115 | self->ntrev = (int)index_length(self); |
|
1116 | 1116 | self->ntlookups = 1; |
|
1117 | 1117 | self->ntmisses = 0; |
|
1118 |
self->nt-> |
|
|
1119 |
self->nt-> |
|
|
1120 |
self->nt-> |
|
|
1118 | self->nt->depth = 0; | |
|
1119 | self->nt->splits = 0; | |
|
1120 | self->nt->length = 1; | |
|
1121 | 1121 | if (nt_insert(self, nullid, -1) == -1) { |
|
1122 | 1122 | free(self->nt->nodes); |
|
1123 | 1123 | free(self->nt); |
General Comments 0
You need to be logged in to leave comments.
Login now