Thu, 25 Aug 2022 21:34:53 -0500
Port the invite dialog to GTK4
Testing Done:
Opened the dialog via conversations -> invite and made sure it worked as expected.
Reviewed at https://reviews.imfreedom.org/r/1644/
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
1 | /* |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
2 | * Purple |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
3 | * |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
4 | * Purple is the legal property of its developers, whose names are too |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
5 | * numerous to list here. Please refer to the COPYRIGHT file distributed |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
6 | * with this source distribution |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
7 | * |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
8 | * This program is free software; you can redistribute it and/or modify |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
9 | * it under the terms of the GNU General Public License as published by |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
10 | * the Free Software Foundation; either version 2 of the License, or (at |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
11 | * your option) any later version. |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
12 | * |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
13 | * This program is distributed in the hope that it will be useful, but |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
14 | * WITHOUT ANY WARRANTY; without even the implied warranty of |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
16 | * General Public License for more details. |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
17 | * |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
18 | * You should have received a copy of the GNU General Public License |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
19 | * along with this program; if not, write to the Free Software |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
20 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
21 | */ |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
22 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
23 | #include "trie.h" |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
24 | |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
25 | #include <string.h> |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
26 | |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
27 | #include "debug.h" |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
28 | #include "memorypool.h" |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
29 | |
|
35667
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
30 | /* A single internal (that don't have any children) consists |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
31 | * of 256 + 4 pointers. That's 1040 bytes on 32-bit machine or 2080 bytes |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
32 | * on 64-bit. |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
33 | * |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
34 | * Thus, in 10500-byte pool block we can hold about 5-10 internal states. |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
35 | * Threshold of 100 states means, we'd need 10-20 "small" blocks before |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
36 | * switching to ~1-2 large blocks. |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
37 | */ |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
38 | #define PURPLE_TRIE_LARGE_THRESHOLD 100 |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
39 | #define PURPLE_TRIE_STATES_SMALL_POOL_BLOCK_SIZE 10880 |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
40 | #define PURPLE_TRIE_STATES_LARGE_POOL_BLOCK_SIZE 102400 |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
41 | |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
42 | typedef struct _PurpleTrieRecord PurpleTrieRecord; |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
43 | typedef struct _PurpleTrieState PurpleTrieState; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
44 | typedef struct _PurpleTrieRecordList PurpleTrieRecordList; |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
45 | |
|
39544
8e488a91262f
Use G_DECLARE_FINAL_TYPE for PurpleTrie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39364
diff
changeset
|
46 | struct _PurpleTrie |
|
8e488a91262f
Use G_DECLARE_FINAL_TYPE for PurpleTrie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39364
diff
changeset
|
47 | { |
|
8e488a91262f
Use G_DECLARE_FINAL_TYPE for PurpleTrie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39364
diff
changeset
|
48 | GObject parent; |
|
8e488a91262f
Use G_DECLARE_FINAL_TYPE for PurpleTrie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39364
diff
changeset
|
49 | }; |
|
8e488a91262f
Use G_DECLARE_FINAL_TYPE for PurpleTrie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39364
diff
changeset
|
50 | |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
51 | typedef struct |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
52 | { |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
53 | gboolean reset_on_match; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
54 | |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
55 | PurpleMemoryPool *records_str_mempool; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
56 | PurpleMemoryPool *records_obj_mempool; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
57 | PurpleTrieRecordList *records; |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
58 | GHashTable *records_map; |
|
35667
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
59 | gsize records_total_size; |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
60 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
61 | PurpleMemoryPool *states_mempool; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
62 | PurpleTrieState *root_state; |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
63 | } PurpleTriePrivate; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
64 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
65 | struct _PurpleTrieRecord |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
66 | { |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
67 | gchar *word; |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
68 | guint word_len; |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
69 | gpointer data; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
70 | }; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
71 | |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
72 | struct _PurpleTrieRecordList |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
73 | { |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
74 | PurpleTrieRecord *rec; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
75 | PurpleTrieRecordList *next; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
76 | PurpleTrieRecordList *prev; |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
77 | |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
78 | gpointer extra_data; |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
79 | }; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
80 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
81 | struct _PurpleTrieState |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
82 | { |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
83 | PurpleTrieState *parent; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
84 | PurpleTrieState **children; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
85 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
86 | PurpleTrieState *longest_suffix; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
87 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
88 | PurpleTrieRecord *found_word; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
89 | }; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
90 | |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
91 | typedef struct |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
92 | { |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
93 | PurpleTrieState *state; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
94 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
95 | PurpleTrieState *root_state; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
96 | gboolean reset_on_match; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
97 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
98 | PurpleTrieReplaceCb replace_cb; |
|
35756
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
99 | PurpleTrieFindCb find_cb; |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
100 | gpointer user_data; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
101 | } PurpleTrieMachine; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
102 | |
|
35668
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
103 | /* TODO: an option to make it eager or lazy (now, it's eager) */ |
|
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
104 | enum |
|
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
105 | { |
|
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
106 | PROP_ZERO, |
|
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
107 | PROP_RESET_ON_MATCH, |
|
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
108 | PROP_LAST |
|
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
109 | }; |
|
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
110 | |
|
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
111 | static GParamSpec *properties[PROP_LAST]; |
|
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
112 | |
|
39364
54439db24429
libpurple: Port self-contained code from g_type_class_add_private()
Mike Ruprecht <cmaiku@gmail.com>
parents:
38813
diff
changeset
|
113 | G_DEFINE_TYPE_WITH_PRIVATE(PurpleTrie, purple_trie, G_TYPE_OBJECT); |
|
35668
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
114 | |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
115 | /******************************************************************************* |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
116 | * Records list |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
117 | ******************************************************************************/ |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
118 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
119 | static PurpleTrieRecordList * |
|
35654
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
120 | purple_record_list_new(PurpleMemoryPool *mpool, PurpleTrieRecord *rec) |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
121 | { |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
122 | PurpleTrieRecordList *node; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
123 | |
|
35662
33bfffdb9e63
Trie, memory pool: fix and make them actually working
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35659
diff
changeset
|
124 | node = purple_memory_pool_alloc0(mpool, |
|
35654
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
125 | sizeof(PurpleTrieRecordList), sizeof(gpointer)); |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
126 | g_return_val_if_fail(node != NULL, NULL); |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
127 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
128 | node->rec = rec; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
129 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
130 | return node; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
131 | } |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
132 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
133 | static PurpleTrieRecordList * |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
134 | purple_record_list_prepend(PurpleMemoryPool *mpool, |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
135 | PurpleTrieRecordList *old_head, PurpleTrieRecord *rec) |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
136 | { |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
137 | PurpleTrieRecordList *new_head; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
138 | |
|
35654
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
139 | new_head = purple_record_list_new(mpool, rec); |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
140 | g_return_val_if_fail(new_head != NULL, NULL); |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
141 | |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
142 | new_head->next = old_head; |
|
35662
33bfffdb9e63
Trie, memory pool: fix and make them actually working
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35659
diff
changeset
|
143 | if (old_head) |
|
33bfffdb9e63
Trie, memory pool: fix and make them actually working
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35659
diff
changeset
|
144 | old_head->prev = new_head; |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
145 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
146 | return new_head; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
147 | } |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
148 | |
|
35654
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
149 | static PurpleTrieRecordList * |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
150 | purple_record_list_copy(PurpleMemoryPool *mpool, |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
151 | const PurpleTrieRecordList *head) |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
152 | { |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
153 | PurpleTrieRecordList *new_head = NULL, *new_tail = NULL; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
154 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
155 | while (head) { |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
156 | PurpleTrieRecordList *node; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
157 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
158 | node = purple_record_list_new(mpool, head->rec); |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
159 | g_return_val_if_fail(node != NULL, NULL); /* there is no leak */ |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
160 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
161 | node->prev = new_tail; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
162 | if (new_tail) |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
163 | new_tail->next = node; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
164 | new_tail = node; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
165 | if (!new_head) |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
166 | new_head = node; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
167 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
168 | head = head->next; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
169 | } |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
170 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
171 | return new_head; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
172 | } |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
173 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
174 | static PurpleTrieRecordList * |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
175 | purple_record_list_remove(PurpleTrieRecordList *head, |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
176 | PurpleTrieRecordList *node) |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
177 | { |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
178 | g_return_val_if_fail(head != NULL, NULL); |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
179 | g_return_val_if_fail(node != NULL, head); |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
180 | g_return_val_if_fail(head->prev == NULL, NULL); |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
181 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
182 | if (head == node) { |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
183 | if (head->next != NULL) |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
184 | head->next->prev = NULL; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
185 | return head->next; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
186 | } else { |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
187 | g_return_val_if_fail(node->prev != NULL, NULL); |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
188 | node->prev->next = node->next; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
189 | if (node->next != NULL) |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
190 | node->next->prev = node->prev; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
191 | return head; |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
192 | } |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
193 | } |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
194 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
195 | |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
196 | /******************************************************************************* |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
197 | * States management |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
198 | ******************************************************************************/ |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
199 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
200 | static void |
|
39774
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
201 | purple_trie_states_cleanup(PurpleTriePrivate *priv) |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
202 | { |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
203 | if (priv->root_state != NULL) { |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
204 | purple_memory_pool_cleanup(priv->states_mempool); |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
205 | priv->root_state = NULL; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
206 | } |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
207 | } |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
208 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
209 | /* Allocates a state and binds it to the parent. */ |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
210 | static PurpleTrieState * |
|
39774
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
211 | purple_trie_state_new(PurpleTriePrivate *priv, PurpleTrieState *parent, |
|
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
212 | guchar character) |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
213 | { |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
214 | PurpleTrieState *state; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
215 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
216 | state = purple_memory_pool_alloc0(priv->states_mempool, |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
217 | sizeof(PurpleTrieState), sizeof(gpointer)); |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
218 | g_return_val_if_fail(state != NULL, NULL); |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
219 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
220 | if (parent == NULL) |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
221 | return state; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
222 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
223 | state->parent = parent; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
224 | if (parent->children == NULL) { |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
225 | parent->children = purple_memory_pool_alloc0( |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
226 | priv->states_mempool, |
|
35662
33bfffdb9e63
Trie, memory pool: fix and make them actually working
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35659
diff
changeset
|
227 | /* PurpleTrieState *children[G_MAXUCHAR + 1] */ |
|
33bfffdb9e63
Trie, memory pool: fix and make them actually working
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35659
diff
changeset
|
228 | 256 * sizeof(gpointer), |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
229 | sizeof(gpointer)); |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
230 | } |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
231 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
232 | if (parent->children == NULL) { |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
233 | purple_memory_pool_free(priv->states_mempool, state); |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
234 | g_warn_if_reached(); |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
235 | return NULL; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
236 | } |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
237 | |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
238 | parent->children[character] = state; |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
239 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
240 | return state; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
241 | } |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
242 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
243 | static gboolean |
|
39774
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
244 | purple_trie_states_build(PurpleTriePrivate *priv) |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
245 | { |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
246 | PurpleTrieState *root; |
|
35654
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
247 | PurpleMemoryPool *reclist_mpool; |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
248 | PurpleTrieRecordList *reclist, *it; |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
249 | gulong cur_len; |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
250 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
251 | if (priv->root_state != NULL) |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
252 | return TRUE; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
253 | |
|
35667
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
254 | if (priv->records_total_size < PURPLE_TRIE_LARGE_THRESHOLD) { |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
255 | purple_memory_pool_set_block_size(priv->states_mempool, |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
256 | PURPLE_TRIE_STATES_SMALL_POOL_BLOCK_SIZE); |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
257 | } else { |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
258 | purple_memory_pool_set_block_size(priv->states_mempool, |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
259 | PURPLE_TRIE_STATES_LARGE_POOL_BLOCK_SIZE); |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
260 | } |
|
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
261 | |
|
39774
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
262 | priv->root_state = root = purple_trie_state_new(priv, NULL, '\0'); |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
263 | g_return_val_if_fail(root != NULL, FALSE); |
|
35663
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
264 | g_assert(root->longest_suffix == NULL); |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
265 | |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
266 | /* reclist is a list of words not yet added to the trie. Shorter words |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
267 | * are removed from the list, when they are fully added to the trie. */ |
|
35654
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
268 | reclist_mpool = purple_memory_pool_new(); |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
269 | reclist = purple_record_list_copy(reclist_mpool, priv->records); |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
270 | |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
271 | /* extra_data on every element of reclist will be a pointer to a trie |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
272 | * node -- the prefix of the word with len of cur_len */ |
|
35663
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
273 | for (it = reclist; it != NULL; it = it->next) { |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
274 | it->extra_data = root; |
|
35663
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
275 | } |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
276 | |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
277 | /* Iterate over indexes of words -- every loop iteration checks certain |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
278 | * index of all remaining words. Loop finishes when there are no words |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
279 | * longer than cur_len. */ |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
280 | for (cur_len = 0; reclist != NULL; cur_len++) { |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
281 | for (it = reclist; it; it = it->next) { |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
282 | PurpleTrieRecord *rec = it->rec; |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
283 | guchar character = rec->word[cur_len]; |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
284 | PurpleTrieState *prefix = it->extra_data; |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
285 | PurpleTrieState *lon_suf_parent; |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
286 | |
|
35664
4a2cf3314f4b
The empty word case was a bad idea
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35663
diff
changeset
|
287 | g_assert(character != '\0'); |
|
35663
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
288 | |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
289 | if (prefix->children && prefix->children[character]) { |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
290 | /* Word's prefix is already in the trie, added |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
291 | * by the other word. */ |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
292 | prefix = prefix->children[character]; |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
293 | } else { |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
294 | /* We need to create a new branch of trie. */ |
|
39774
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
295 | prefix = purple_trie_state_new(priv, prefix, |
|
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
296 | character); |
|
35663
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
297 | if (!prefix) { |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
298 | g_warn_if_reached(); |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
299 | g_object_unref(reclist_mpool); |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
300 | return FALSE; |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
301 | } |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
302 | } |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
303 | it->extra_data = prefix; |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
304 | /* prefix is now of length increased by one character. */ |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
305 | |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
306 | /* The whole word is now added to the trie. */ |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
307 | if (rec->word[cur_len + 1] == '\0') { |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
308 | if (prefix->found_word == NULL) |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
309 | prefix->found_word = rec; |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
310 | else { |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
311 | purple_debug_warning("trie", "found " |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
312 | "a collision of \"%s\" words", |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
313 | rec->word); |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
314 | } |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
315 | |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
316 | /* "it" is not modified here, so it->next is |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
317 | * still valid */ |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
318 | reclist = purple_record_list_remove(reclist, it); |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
319 | } |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
320 | |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
321 | /* We need to fill the longest_suffix field -- a longest |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
322 | * complete suffix of the prefix we created. We look for |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
323 | * that suffix in any path starting in root and ending |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
324 | * in the (cur_len - 1) level of trie. */ |
|
35663
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
325 | if (prefix->longest_suffix != NULL) |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
326 | continue; |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
327 | lon_suf_parent = prefix->parent->longest_suffix; |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
328 | while (lon_suf_parent) { |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
329 | if (lon_suf_parent->children && |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
330 | lon_suf_parent->children[character]) |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
331 | { |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
332 | prefix->longest_suffix = lon_suf_parent-> |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
333 | children[character]; |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
334 | break; |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
335 | } |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
336 | lon_suf_parent = lon_suf_parent->longest_suffix; |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
337 | } |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
338 | if (prefix->longest_suffix == NULL) |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
339 | prefix->longest_suffix = root; |
|
35663
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
340 | if (prefix->found_word == NULL) { |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
341 | prefix->found_word = |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
342 | prefix->longest_suffix->found_word; |
|
6527214c491e
Add testsuite for PurpleTrie and fix found bugs
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35662
diff
changeset
|
343 | } |
|
35655
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
344 | } |
|
94f0de42866d
Trie: building the trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35654
diff
changeset
|
345 | } |
|
35654
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
346 | |
|
d8f3b538d6db
Trie: PurpleTrieRecordList manipulation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
347 | g_object_unref(reclist_mpool); |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
348 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
349 | return TRUE; |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
350 | } |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
351 | |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
352 | /******************************************************************************* |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
353 | * Searching |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
354 | ******************************************************************************/ |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
355 | |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
356 | static void |
|
35756
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
357 | purple_trie_advance(PurpleTrieMachine *m, const guchar character) |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
358 | { |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
359 | /* change state after processing a character */ |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
360 | while (TRUE) { |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
361 | /* Perfect fit - next character is the same, as the child of the |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
362 | * prefix we reached so far. */ |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
363 | if (m->state->children && m->state->children[character]) { |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
364 | m->state = m->state->children[character]; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
365 | break; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
366 | } |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
367 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
368 | /* We reached root, that's a pity. */ |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
369 | if (m->state == m->root_state) |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
370 | break; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
371 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
372 | /* Let's try a bit shorter suffix. */ |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
373 | m->state = m->state->longest_suffix; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
374 | } |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
375 | } |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
376 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
377 | static gboolean |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
378 | purple_trie_replace_do_replacement(PurpleTrieMachine *m, GString *out) |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
379 | { |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
380 | gboolean was_replaced = FALSE; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
381 | gsize str_old_len; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
382 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
383 | /* if we reached a "found" state, let's process it */ |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
384 | if (!m->state->found_word) |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
385 | return FALSE; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
386 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
387 | /* let's get back to the beginning of the word */ |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
388 | g_assert(out->len >= m->state->found_word->word_len - 1); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
389 | str_old_len = out->len; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
390 | out->len -= m->state->found_word->word_len - 1; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
391 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
392 | was_replaced = m->replace_cb(out, m->state->found_word->word, |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
393 | m->state->found_word->data, m->user_data); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
394 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
395 | /* output was untouched, revert to the previous position */ |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
396 | if (!was_replaced) |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
397 | out->len = str_old_len; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
398 | |
|
35756
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
399 | /* XXX */ |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
400 | if (was_replaced || m->reset_on_match) |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
401 | m->state = m->root_state; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
402 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
403 | return was_replaced; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
404 | } |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
405 | |
|
35756
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
406 | static gboolean |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
407 | purple_trie_find_do_discovery(PurpleTrieMachine *m) |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
408 | { |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
409 | gboolean was_accepted; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
410 | |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
411 | /* if we reached a "found" state, let's process it */ |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
412 | if (!m->state->found_word) |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
413 | return FALSE; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
414 | |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
415 | if (m->find_cb) { |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
416 | was_accepted = m->find_cb(m->state->found_word->word, |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
417 | m->state->found_word->data, m->user_data); |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
418 | } else { |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
419 | was_accepted = TRUE; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
420 | } |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
421 | |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
422 | if (was_accepted && m->reset_on_match) |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
423 | m->state = m->root_state; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
424 | |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
425 | return was_accepted; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
426 | } |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
427 | |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
428 | gchar * |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
429 | purple_trie_replace(PurpleTrie *trie, const gchar *src, |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
430 | PurpleTrieReplaceCb replace_cb, gpointer user_data) |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
431 | { |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
432 | PurpleTriePrivate *priv = NULL; |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
433 | PurpleTrieMachine machine; |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
434 | GString *out; |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
435 | gsize i; |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
436 | |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
437 | if (src == NULL) |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
438 | return NULL; |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
439 | |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
440 | g_return_val_if_fail(replace_cb != NULL, g_strdup(src)); |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
441 | g_return_val_if_fail(PURPLE_IS_TRIE(trie), NULL); |
|
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
442 | |
|
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
443 | priv = purple_trie_get_instance_private(trie); |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
444 | |
|
39774
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
445 | purple_trie_states_build(priv); |
|
35662
33bfffdb9e63
Trie, memory pool: fix and make them actually working
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35659
diff
changeset
|
446 | |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
447 | machine.state = priv->root_state; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
448 | machine.root_state = priv->root_state; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
449 | machine.reset_on_match = priv->reset_on_match; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
450 | machine.replace_cb = replace_cb; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
451 | machine.user_data = user_data; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
452 | |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
453 | out = g_string_new(NULL); |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
454 | i = 0; |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
455 | while (src[i] != '\0') { |
|
35662
33bfffdb9e63
Trie, memory pool: fix and make them actually working
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35659
diff
changeset
|
456 | guchar character = src[i++]; |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
457 | gboolean was_replaced; |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
458 | |
|
35756
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
459 | purple_trie_advance(&machine, character); |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
460 | was_replaced = purple_trie_replace_do_replacement(&machine, out); |
|
35659
f97feb9a67f2
Trie: better comments, fix a small flaw in algorithm
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35658
diff
changeset
|
461 | |
|
f97feb9a67f2
Trie: better comments, fix a small flaw in algorithm
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35658
diff
changeset
|
462 | /* We skipped a character without finding any records, |
|
f97feb9a67f2
Trie: better comments, fix a small flaw in algorithm
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35658
diff
changeset
|
463 | * let's just copy it to the output. */ |
|
35662
33bfffdb9e63
Trie, memory pool: fix and make them actually working
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35659
diff
changeset
|
464 | if (!was_replaced) |
|
35659
f97feb9a67f2
Trie: better comments, fix a small flaw in algorithm
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35658
diff
changeset
|
465 | g_string_append_c(out, character); |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
466 | } |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
467 | |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
468 | return g_string_free(out, FALSE); |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
469 | } |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
470 | |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
471 | gchar * |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
472 | purple_trie_multi_replace(const GSList *tries, const gchar *src, |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
473 | PurpleTrieReplaceCb replace_cb, gpointer user_data) |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
474 | { |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
475 | guint tries_count, m_idx; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
476 | PurpleTrieMachine *machines; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
477 | GString *out; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
478 | gsize i; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
479 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
480 | if (src == NULL) |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
481 | return NULL; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
482 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
483 | g_return_val_if_fail(replace_cb != NULL, g_strdup(src)); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
484 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
485 | tries_count = g_slist_length((GSList*)tries); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
486 | if (tries_count == 0) |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
487 | return g_strdup(src); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
488 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
489 | /* Initialize all machines. */ |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
490 | machines = g_new(PurpleTrieMachine, tries_count); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
491 | for (i = 0; i < tries_count; i++, tries = tries->next) { |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
492 | PurpleTrie *trie = tries->data; |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
493 | PurpleTriePrivate *priv = NULL; |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
494 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
495 | if (!PURPLE_TRIE(trie)) { |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
496 | g_warn_if_reached(); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
497 | g_free(machines); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
498 | return NULL; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
499 | } |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
500 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
501 | priv = purple_trie_get_instance_private(trie); |
|
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
502 | |
|
39774
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
503 | purple_trie_states_build(priv); |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
504 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
505 | machines[i].state = priv->root_state; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
506 | machines[i].root_state = priv->root_state; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
507 | machines[i].reset_on_match = priv->reset_on_match; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
508 | machines[i].replace_cb = replace_cb; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
509 | machines[i].user_data = user_data; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
510 | } |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
511 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
512 | out = g_string_new(NULL); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
513 | i = 0; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
514 | while (src[i] != '\0') { |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
515 | guchar character = src[i++]; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
516 | gboolean was_replaced = FALSE; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
517 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
518 | /* Advance every machine and possibly perform a replacement. */ |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
519 | for (m_idx = 0; m_idx < tries_count; m_idx++) { |
|
35756
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
520 | purple_trie_advance(&machines[m_idx], character); |
|
35665
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
521 | if (was_replaced) |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
522 | continue; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
523 | was_replaced = purple_trie_replace_do_replacement( |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
524 | &machines[m_idx], out); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
525 | } |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
526 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
527 | /* We skipped a character without finding any records, |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
528 | * let's just copy it to the output. */ |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
529 | if (!was_replaced) |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
530 | g_string_append_c(out, character); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
531 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
532 | /* If we replaced a word, reset _all_ machines */ |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
533 | if (was_replaced) { |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
534 | for (m_idx = 0; m_idx < tries_count; m_idx++) { |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
535 | machines[m_idx].state = |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
536 | machines[m_idx].root_state; |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
537 | } |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
538 | } |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
539 | } |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
540 | |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
541 | g_free(machines); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
542 | return g_string_free(out, FALSE); |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
543 | } |
|
f1310093e434
Implement and test multi-trie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35664
diff
changeset
|
544 | |
|
35756
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
545 | gulong |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
546 | purple_trie_find(PurpleTrie *trie, const gchar *src, |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
547 | PurpleTrieFindCb find_cb, gpointer user_data) |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
548 | { |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
549 | PurpleTriePrivate *priv = NULL; |
|
35756
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
550 | PurpleTrieMachine machine; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
551 | gulong found_count = 0; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
552 | gsize i; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
553 | |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
554 | if (src == NULL) |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
555 | return 0; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
556 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
557 | g_return_val_if_fail(PURPLE_IS_TRIE(trie), 0); |
|
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
558 | |
|
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
559 | priv = purple_trie_get_instance_private(trie); |
|
35756
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
560 | |
|
39774
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
561 | purple_trie_states_build(priv); |
|
35756
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
562 | |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
563 | machine.state = priv->root_state; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
564 | machine.root_state = priv->root_state; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
565 | machine.reset_on_match = priv->reset_on_match; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
566 | machine.find_cb = find_cb; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
567 | machine.user_data = user_data; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
568 | |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
569 | i = 0; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
570 | while (src[i] != '\0') { |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
571 | guchar character = src[i++]; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
572 | gboolean was_found; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
573 | |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
574 | purple_trie_advance(&machine, character); |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
575 | |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
576 | was_found = purple_trie_find_do_discovery(&machine); |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
577 | |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
578 | if (was_found) |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
579 | found_count++; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
580 | } |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
581 | |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
582 | return found_count; |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
583 | } |
|
fe6aba70046e
Custom smileys: make it possible to find them by prpl
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35730
diff
changeset
|
584 | |
|
35790
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
585 | gulong |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
586 | purple_trie_multi_find(const GSList *tries, const gchar *src, |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
587 | PurpleTrieFindCb find_cb, gpointer user_data) |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
588 | { |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
589 | guint tries_count, m_idx; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
590 | PurpleTrieMachine *machines; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
591 | gulong found_count = 0; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
592 | gsize i; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
593 | |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
594 | if (src == NULL) |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
595 | return 0; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
596 | |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
597 | tries_count = g_slist_length((GSList*)tries); |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
598 | if (tries_count == 0) |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
599 | return 0; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
600 | |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
601 | /* Initialize all machines. */ |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
602 | machines = g_new(PurpleTrieMachine, tries_count); |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
603 | for (i = 0; i < tries_count; i++, tries = tries->next) { |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
604 | PurpleTrie *trie = tries->data; |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
605 | PurpleTriePrivate *priv = NULL; |
|
35790
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
606 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
607 | if (!PURPLE_IS_TRIE(trie)) { |
|
35790
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
608 | g_warn_if_reached(); |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
609 | g_free(machines); |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
610 | return 0; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
611 | } |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
612 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
613 | priv = purple_trie_get_instance_private(trie); |
|
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
614 | |
|
39774
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
615 | purple_trie_states_build(priv); |
|
35790
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
616 | |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
617 | machines[i].state = priv->root_state; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
618 | machines[i].root_state = priv->root_state; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
619 | machines[i].reset_on_match = priv->reset_on_match; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
620 | machines[i].find_cb = find_cb; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
621 | machines[i].user_data = user_data; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
622 | } |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
623 | |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
624 | i = 0; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
625 | while (src[i] != '\0') { |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
626 | guchar character = src[i++]; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
627 | gboolean was_found = FALSE; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
628 | |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
629 | /* Advance every machine and possibly perform a replacement. */ |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
630 | for (m_idx = 0; m_idx < tries_count; m_idx++) { |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
631 | purple_trie_advance(&machines[m_idx], character); |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
632 | if (was_found) |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
633 | continue; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
634 | was_found = |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
635 | purple_trie_find_do_discovery(&machines[m_idx]); |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
636 | if (was_found) |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
637 | found_count++; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
638 | } |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
639 | |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
640 | /* If we replaced a word, reset _all_ machines */ |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
641 | if (was_found) { |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
642 | for (m_idx = 0; m_idx < tries_count; m_idx++) { |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
643 | if (!machines[m_idx].reset_on_match) |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
644 | continue; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
645 | machines[m_idx].state = |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
646 | machines[m_idx].root_state; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
647 | } |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
648 | } |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
649 | } |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
650 | |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
651 | g_free(machines); |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
652 | return found_count; |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
653 | } |
|
3118fb87573e
Trie: implement purple_trie_multi_find
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
654 | |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
655 | |
|
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
656 | /******************************************************************************* |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
657 | * Records |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
658 | ******************************************************************************/ |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
659 | |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
660 | gboolean |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
661 | purple_trie_add(PurpleTrie *trie, const gchar *word, gpointer data) |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
662 | { |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
663 | PurpleTriePrivate *priv = NULL; |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
664 | PurpleTrieRecord *rec; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
665 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
666 | g_return_val_if_fail(PURPLE_IS_TRIE(trie), FALSE); |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
667 | g_return_val_if_fail(word != NULL, FALSE); |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
668 | g_return_val_if_fail(word[0] != '\0', FALSE); |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
669 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
670 | priv = purple_trie_get_instance_private(trie); |
|
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
671 | |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
672 | if (g_hash_table_lookup(priv->records_map, word) != NULL) { |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
673 | purple_debug_warning("trie", "record exists: %s", word); |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
674 | return FALSE; |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
675 | } |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
676 | |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
677 | /* Every change in a trie invalidates longest_suffix map. |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
678 | * These prefixes could be updated instead of cleaning the whole graph. |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
679 | */ |
|
39774
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
680 | purple_trie_states_cleanup(priv); |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
681 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
682 | rec = purple_memory_pool_alloc(priv->records_obj_mempool, |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
683 | sizeof(PurpleTrieRecord), sizeof(gpointer)); |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
684 | rec->word = purple_memory_pool_strdup(priv->records_str_mempool, word); |
|
35658
799b62769bd3
Trie: implement search-and-replace (not yet tested)
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35655
diff
changeset
|
685 | rec->word_len = strlen(word); |
|
35664
4a2cf3314f4b
The empty word case was a bad idea
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35663
diff
changeset
|
686 | g_assert(rec->word_len > 0); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
687 | rec->data = data; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
688 | |
|
35667
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
689 | priv->records_total_size += rec->word_len; |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
690 | priv->records = purple_record_list_prepend(priv->records_obj_mempool, |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
691 | priv->records, rec); |
|
35730
07185c85c64c
PurpleTrie: Fix a test
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35717
diff
changeset
|
692 | g_hash_table_insert(priv->records_map, rec->word, priv->records); |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
693 | |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
694 | return TRUE; |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
695 | } |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
696 | |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
697 | void |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
698 | purple_trie_remove(PurpleTrie *trie, const gchar *word) |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
699 | { |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
700 | PurpleTriePrivate *priv = NULL; |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
701 | PurpleTrieRecordList *it; |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
702 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
703 | g_return_if_fail(PURPLE_IS_TRIE(trie)); |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
704 | g_return_if_fail(word != NULL); |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
705 | g_return_if_fail(word[0] != '\0'); |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
706 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
707 | priv = purple_trie_get_instance_private(trie); |
|
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
708 | |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
709 | it = g_hash_table_lookup(priv->records_map, word); |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
710 | if (it == NULL) |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
711 | return; |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
712 | |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
713 | /* see purple_trie_add */ |
|
39774
b1a2525b7af9
Remove extra checks in trie.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39544
diff
changeset
|
714 | purple_trie_states_cleanup(priv); |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
715 | |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
716 | priv->records_total_size -= it->rec->word_len; |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
717 | priv->records = purple_record_list_remove(priv->records, it); |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
718 | g_hash_table_remove(priv->records_map, it->rec->word); |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
719 | |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
720 | purple_memory_pool_free(priv->records_str_mempool, it->rec->word); |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
721 | purple_memory_pool_free(priv->records_obj_mempool, it->rec); |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
722 | purple_memory_pool_free(priv->records_obj_mempool, it); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
723 | } |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
724 | |
|
35717
45bde03f86a6
Custom smileys: simplify storage implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35711
diff
changeset
|
725 | guint |
|
45bde03f86a6
Custom smileys: simplify storage implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35711
diff
changeset
|
726 | purple_trie_get_size(PurpleTrie *trie) |
|
45bde03f86a6
Custom smileys: simplify storage implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35711
diff
changeset
|
727 | { |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
728 | PurpleTriePrivate *priv = NULL; |
|
35717
45bde03f86a6
Custom smileys: simplify storage implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35711
diff
changeset
|
729 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
730 | g_return_val_if_fail(PURPLE_IS_TRIE(trie), 0); |
|
35717
45bde03f86a6
Custom smileys: simplify storage implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35711
diff
changeset
|
731 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
732 | priv = purple_trie_get_instance_private(trie); |
|
35717
45bde03f86a6
Custom smileys: simplify storage implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35711
diff
changeset
|
733 | return g_hash_table_size(priv->records_map); |
|
45bde03f86a6
Custom smileys: simplify storage implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35711
diff
changeset
|
734 | } |
|
45bde03f86a6
Custom smileys: simplify storage implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35711
diff
changeset
|
735 | |
|
45bde03f86a6
Custom smileys: simplify storage implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35711
diff
changeset
|
736 | |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
737 | /******************************************************************************* |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
738 | * API implementation |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
739 | ******************************************************************************/ |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
740 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
741 | gboolean |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
742 | purple_trie_get_reset_on_match(PurpleTrie *trie) |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
743 | { |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
744 | PurpleTriePrivate *priv = NULL; |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
745 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
746 | g_return_val_if_fail(PURPLE_IS_TRIE(trie), FALSE); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
747 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
748 | priv = purple_trie_get_instance_private(trie); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
749 | return priv->reset_on_match; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
750 | } |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
751 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
752 | void |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
753 | purple_trie_set_reset_on_match(PurpleTrie *trie, gboolean reset) |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
754 | { |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
755 | PurpleTriePrivate *priv = NULL; |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
756 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
757 | g_return_if_fail(PURPLE_IS_TRIE(trie)); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
758 | |
|
39782
db027c5e1463
Fix broken `priv != NULL` checks in libpurple.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
39774
diff
changeset
|
759 | priv = purple_trie_get_instance_private(trie); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
760 | priv->reset_on_match = reset; |
|
35668
ba76659ea73e
Trie: add g_object_notify_by_pspec to the setter
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35667
diff
changeset
|
761 | g_object_notify_by_pspec(G_OBJECT(trie), properties[PROP_RESET_ON_MATCH]); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
762 | } |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
763 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
764 | /******************************************************************************* |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
765 | * Object stuff |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
766 | ******************************************************************************/ |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
767 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
768 | PurpleTrie * |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
769 | purple_trie_new(void) |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
770 | { |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
771 | return g_object_new(PURPLE_TYPE_TRIE, NULL); |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
772 | } |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
773 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
774 | static void |
|
39364
54439db24429
libpurple: Port self-contained code from g_type_class_add_private()
Mike Ruprecht <cmaiku@gmail.com>
parents:
38813
diff
changeset
|
775 | purple_trie_init(PurpleTrie *trie) |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
776 | { |
|
39364
54439db24429
libpurple: Port self-contained code from g_type_class_add_private()
Mike Ruprecht <cmaiku@gmail.com>
parents:
38813
diff
changeset
|
777 | PurpleTriePrivate *priv = purple_trie_get_instance_private(trie); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
778 | |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
779 | priv->records_obj_mempool = purple_memory_pool_new(); |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
780 | priv->records_str_mempool = purple_memory_pool_new(); |
|
35666
ca4afaddaffa
Memory pool: fix some issues
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35665
diff
changeset
|
781 | priv->states_mempool = purple_memory_pool_new(); |
|
ca4afaddaffa
Memory pool: fix some issues
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35665
diff
changeset
|
782 | purple_memory_pool_set_block_size(priv->states_mempool, |
|
35667
e198bddf2ef9
Trie: lower memory usage for smaller collections
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
783 | PURPLE_TRIE_STATES_SMALL_POOL_BLOCK_SIZE); |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
784 | |
|
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
785 | priv->records_map = g_hash_table_new(g_str_hash, g_str_equal); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
786 | } |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
787 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
788 | static void |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
789 | purple_trie_finalize(GObject *obj) |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
790 | { |
|
39364
54439db24429
libpurple: Port self-contained code from g_type_class_add_private()
Mike Ruprecht <cmaiku@gmail.com>
parents:
38813
diff
changeset
|
791 | PurpleTriePrivate *priv = |
|
54439db24429
libpurple: Port self-contained code from g_type_class_add_private()
Mike Ruprecht <cmaiku@gmail.com>
parents:
38813
diff
changeset
|
792 | purple_trie_get_instance_private(PURPLE_TRIE(obj)); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
793 | |
|
35700
a032063e50c7
Trie: implement purple_trie_remove
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35668
diff
changeset
|
794 | g_hash_table_destroy(priv->records_map); |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
795 | g_object_unref(priv->records_obj_mempool); |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
796 | g_object_unref(priv->records_str_mempool); |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
797 | g_object_unref(priv->states_mempool); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
798 | |
|
39364
54439db24429
libpurple: Port self-contained code from g_type_class_add_private()
Mike Ruprecht <cmaiku@gmail.com>
parents:
38813
diff
changeset
|
799 | G_OBJECT_CLASS(purple_trie_parent_class)->finalize(obj); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
800 | } |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
801 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
802 | static void |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
803 | purple_trie_get_property(GObject *obj, guint param_id, GValue *value, |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
804 | GParamSpec *pspec) |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
805 | { |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
806 | PurpleTrie *trie = PURPLE_TRIE(obj); |
|
39364
54439db24429
libpurple: Port self-contained code from g_type_class_add_private()
Mike Ruprecht <cmaiku@gmail.com>
parents:
38813
diff
changeset
|
807 | PurpleTriePrivate *priv = purple_trie_get_instance_private(trie); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
808 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
809 | switch (param_id) { |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
810 | case PROP_RESET_ON_MATCH: |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
811 | g_value_set_boolean(value, priv->reset_on_match); |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
812 | break; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
813 | default: |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
814 | G_OBJECT_WARN_INVALID_PROPERTY_ID(obj, param_id, pspec); |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
815 | } |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
816 | } |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
817 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
818 | static void |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
819 | purple_trie_set_property(GObject *obj, guint param_id, |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
820 | const GValue *value, GParamSpec *pspec) |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
821 | { |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
822 | PurpleTrie *trie = PURPLE_TRIE(obj); |
|
39364
54439db24429
libpurple: Port self-contained code from g_type_class_add_private()
Mike Ruprecht <cmaiku@gmail.com>
parents:
38813
diff
changeset
|
823 | PurpleTriePrivate *priv = purple_trie_get_instance_private(trie); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
824 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
825 | switch (param_id) { |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
826 | case PROP_RESET_ON_MATCH: |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
827 | priv->reset_on_match = g_value_get_boolean(value); |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
828 | break; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
829 | default: |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
830 | G_OBJECT_WARN_INVALID_PROPERTY_ID(obj, param_id, pspec); |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
831 | } |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
832 | } |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
833 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
834 | static void |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
835 | purple_trie_class_init(PurpleTrieClass *klass) |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
836 | { |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
837 | GObjectClass *obj_class = G_OBJECT_CLASS(klass); |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
838 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
839 | obj_class->finalize = purple_trie_finalize; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
840 | obj_class->get_property = purple_trie_get_property; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
841 | obj_class->set_property = purple_trie_set_property; |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
842 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
843 | properties[PROP_RESET_ON_MATCH] = g_param_spec_boolean("reset-on-match", |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
844 | "Reset on match", "Determines, if the search state machine " |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
845 | "should be reset to the initial state on every match. This " |
|
35773
8c63d334ad44
Comments: PurpleTrie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35756
diff
changeset
|
846 | "ensures, that every match is distinct from each other. " |
|
8c63d334ad44
Comments: PurpleTrie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35756
diff
changeset
|
847 | "Please note, that it's not well-defined for a replace " |
|
8c63d334ad44
Comments: PurpleTrie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35756
diff
changeset
|
848 | "operation, so it's better to leave this value default, unless " |
|
8c63d334ad44
Comments: PurpleTrie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35756
diff
changeset
|
849 | "you perform only find operations.", TRUE, |
|
35711
e27d0d775826
Trie: add missing G_PARAM_CONSTRUCT flag
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35700
diff
changeset
|
850 | G_PARAM_READWRITE | G_PARAM_CONSTRUCT | G_PARAM_STATIC_STRINGS); |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
851 | |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
852 | g_object_class_install_properties(obj_class, PROP_LAST, properties); |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
853 | } |