1 /* PSPP - a program for statistical analysis.
2 Copyright (C) 2004, 2007, 2009, 2010, 2011, 2012, 2013 Free Software Foundation, Inc.
4 This program is free software: you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation, either version 3 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program. If not, see <http://www.gnu.org/licenses/>. */
17 #ifndef DATA_DICTIONARY_H
18 #define DATA_DICTIONARY_H 1
22 #include "data/case.h"
23 #include "data/dict-class.h"
28 /* Creating dictionaries. */
29 struct dictionary *dict_create (const char *encoding);
30 struct dictionary *dict_clone (const struct dictionary *) WARN_UNUSED_RESULT;
31 struct dictionary *dict_ref (struct dictionary *s) WARN_UNUSED_RESULT;
34 /* Clearing and destroying dictionaries. */
35 void dict_clear (struct dictionary *);
36 void dict_unref (struct dictionary *);
38 /* Common ways to access variables. */
39 struct variable *dict_lookup_var (const struct dictionary *, const char *);
40 struct variable *dict_lookup_var_assert (const struct dictionary *,
42 struct variable *dict_get_var (const struct dictionary *, size_t position);
43 size_t dict_get_n_vars (const struct dictionary *);
45 /* Other access to variables. */
46 bool dict_contains_var (const struct dictionary *, const struct variable *);
47 void dict_get_vars (const struct dictionary *,
48 const struct variable ***vars, size_t *n_vars,
49 enum dict_class exclude);
50 void dict_get_vars_mutable (const struct dictionary *,
51 struct variable ***vars, size_t *n_vars,
52 enum dict_class exclude);
54 /* Creating variables. */
55 struct variable *dict_create_var (struct dictionary *, const char *,
57 struct variable *dict_create_var_assert (struct dictionary *, const char *,
59 struct variable *dict_clone_var (struct dictionary *, const struct variable *);
60 struct variable *dict_clone_var_assert (struct dictionary *,
61 const struct variable *);
62 struct variable *dict_clone_var_as (struct dictionary *,
63 const struct variable *, const char *);
64 struct variable *dict_clone_var_as_assert (struct dictionary *,
65 const struct variable *,
68 struct variable *dict_clone_var_in_place_assert (struct dictionary *,
69 const struct variable *);
71 /* Deleting variables. */
72 void dict_delete_var (struct dictionary *, struct variable *);
73 void dict_delete_vars (struct dictionary *,
74 struct variable *const *, size_t count);
75 void dict_delete_consecutive_vars (struct dictionary *,
76 size_t idx, size_t count);
77 void dict_delete_scratch_vars (struct dictionary *);
79 /* Changing the order of variables. */
80 void dict_reorder_var (struct dictionary *, struct variable *,
82 void dict_reorder_vars (struct dictionary *,
83 struct variable *const *, size_t count);
86 bool dict_try_rename_var (struct dictionary *,
87 struct variable *, const char *);
88 void dict_rename_var (struct dictionary *, struct variable *, const char *);
89 bool dict_rename_vars (struct dictionary *,
90 struct variable **, char **new_names,
91 size_t count, char **err_name);
92 char *dict_make_unique_var_name (const struct dictionary *, const char *hint,
93 unsigned long int *num_start);
95 bool dict_get_names_must_be_ids (const struct dictionary *);
96 void dict_set_names_must_be_ids (struct dictionary *, bool);
98 /* Weight variable. */
99 double dict_get_case_weight (const struct dictionary *,
100 const struct ccase *, bool *);
101 double dict_get_rounded_case_weight (const struct dictionary *,
102 const struct ccase *, bool *);
103 struct variable *dict_get_weight (const struct dictionary *);
104 void dict_set_weight (struct dictionary *, struct variable *);
105 struct fmt_spec dict_get_weight_format (const struct dictionary *);
107 /* Filter variable. */
108 struct variable *dict_get_filter (const struct dictionary *);
109 void dict_set_filter (struct dictionary *, struct variable *);
111 /* Case limit (N OF CASES). */
112 casenumber dict_get_case_limit (const struct dictionary *);
113 void dict_set_case_limit (struct dictionary *, casenumber);
115 /* Size of cases for this dictionary. */
116 const struct caseproto *dict_get_proto (const struct dictionary *);
118 /* Making this dictionary's cases smaller (if some variables were
120 size_t dict_count_values (const struct dictionary *,
121 unsigned int exclude_classes);
122 void dict_compact_values (struct dictionary *);
123 struct caseproto *dict_get_compacted_proto (const struct dictionary *,
124 unsigned int exclude_classes);
126 /* SPLIT FILE variables.
128 SPLIT_NONE is used if and only if there are no split file variables. */
131 SPLIT_NONE, /* No split file variables. */
132 SPLIT_SEPARATE, /* Produce separate output for each split. */
133 SPLIT_LAYERED, /* Output splits in same table. */
136 const struct variable *const *dict_get_split_vars (const struct dictionary *);
137 size_t dict_get_n_splits (const struct dictionary *);
138 enum split_type dict_get_split_type (const struct dictionary *);
139 void dict_set_split_vars (struct dictionary *,
140 struct variable *const *, size_t n,
142 void dict_clear_split_vars (struct dictionary *);
145 const char *dict_get_label (const struct dictionary *);
146 void dict_set_label (struct dictionary *, const char *);
149 #define DOC_LINE_LENGTH 80 /* Fixed length of document lines. */
151 const struct string_array *dict_get_documents (const struct dictionary *);
152 void dict_set_documents (struct dictionary *, const struct string_array *);
153 void dict_set_documents_string (struct dictionary *, const char *);
154 void dict_clear_documents (struct dictionary *);
156 bool dict_add_document_line (struct dictionary *, const char *,
158 size_t dict_get_document_n_lines (const struct dictionary *);
159 const char *dict_get_document_line (const struct dictionary *, size_t);
162 bool dict_create_vector (struct dictionary *, const char *name,
163 struct variable **, size_t n);
164 void dict_create_vector_assert (struct dictionary *, const char *name,
165 struct variable **, size_t n);
166 const struct vector *dict_get_vector (const struct dictionary *, size_t idx);
167 size_t dict_get_n_vectors (const struct dictionary *);
168 const struct vector *dict_lookup_vector (const struct dictionary *,
170 void dict_clear_vectors (struct dictionary *);
172 /* Multiple response sets. */
173 const struct mrset *dict_get_mrset (const struct dictionary *, size_t idx);
174 size_t dict_get_n_mrsets (const struct dictionary *);
175 const struct mrset *dict_lookup_mrset (const struct dictionary *,
178 bool dict_add_mrset (struct dictionary *, struct mrset *);
179 bool dict_delete_mrset (struct dictionary *, const char *name);
180 void dict_clear_mrsets (struct dictionary *);
183 const struct varset *dict_get_varset (const struct dictionary *, size_t idx);
184 size_t dict_get_n_varsets (const struct dictionary *);
185 const struct varset *dict_lookup_varset (const struct dictionary *,
188 bool dict_add_varset (struct dictionary *, struct varset *);
189 bool dict_delete_varset (struct dictionary *, const char *name);
190 void dict_clear_varsets (struct dictionary *);
193 struct attrset *dict_get_attributes (const struct dictionary *);
194 void dict_set_attributes (struct dictionary *, const struct attrset *);
195 bool dict_has_attributes (const struct dictionary *);
198 const char *dict_get_encoding (const struct dictionary *d);
200 char *dict_id_is_valid__ (const struct dictionary *, const char *id)
202 bool dict_id_is_valid (const struct dictionary *, const char *id);
204 /* Internal variables. */
205 struct variable *dict_create_internal_var (int case_idx, int width);
206 void dict_destroy_internal_var (struct variable *);
208 /* Functions to be called upon dictionary changes. */
209 struct dict_callbacks
211 void (*var_added) (struct dictionary *, int, void *);
212 void (*var_deleted) (struct dictionary *, const struct variable *,
213 int dict_index, int case_index, void *);
214 void (*var_changed) (struct dictionary *, int, unsigned int, const struct variable *, void *);
215 void (*weight_changed) (struct dictionary *, int, void *);
216 void (*filter_changed) (struct dictionary *, int, void *);
217 void (*split_changed) (struct dictionary *, void *);
220 void dict_set_callbacks (struct dictionary *, const struct dict_callbacks *,
222 void dict_copy_callbacks (struct dictionary *, const struct dictionary *);
224 void dict_set_change_callback (struct dictionary *d,
225 void (*changed) (struct dictionary *, void*),
229 /* Debug use only. */
230 void dict_dump (const struct dictionary *);
232 #endif /* data/dictionary.h */