]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - usr.bin/sort/coll.h
cdn-patch: offer option to mount /etc/keys before attaching geli devices
[FreeBSD/FreeBSD.git] / usr.bin / sort / coll.h
1 /*      $FreeBSD$       */
2
3 /*-
4  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
5  *
6  * Copyright (C) 2009 Gabor Kovesdan <gabor@FreeBSD.org>
7  * Copyright (C) 2012 Oleg Moskalenko <mom040267@gmail.com>
8  * All rights reserved.
9  *
10  * Redistribution and use in source and binary forms, with or without
11  * modification, are permitted provided that the following conditions
12  * are met:
13  * 1. Redistributions of source code must retain the above copyright
14  *    notice, this list of conditions and the following disclaimer.
15  * 2. Redistributions in binary form must reproduce the above copyright
16  *    notice, this list of conditions and the following disclaimer in the
17  *    documentation and/or other materials provided with the distribution.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
20  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
23  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29  * SUCH DAMAGE.
30  */
31
32 #if !defined(__COLL_H__)
33 #define __COLL_H__
34
35 #include "bwstring.h"
36 #include "sort.h"
37
38 /*
39  * Sort hint data for -n
40  */
41 struct n_hint
42 {
43         unsigned long long       n1;
44         unsigned char            si;
45         bool                     empty;
46         bool                     neg;
47 };
48
49 /*
50  * Sort hint data for -g
51  */
52 struct g_hint
53 {
54         double                   d;
55         bool                     nan;
56         bool                     notnum;
57 };
58
59 /*
60  * Sort hint data for -M
61  */
62 struct M_hint
63 {
64         int                      m;
65 };
66
67 /*
68  * Status of a sort hint object
69  */
70 typedef enum
71 {
72         HS_ERROR = -1, HS_UNINITIALIZED = 0, HS_INITIALIZED = 1
73 } hint_status;
74
75 /*
76  * Sort hint object
77  */
78 struct key_hint
79 {
80         hint_status             status;
81         union
82         {
83                 struct n_hint           nh;
84                 struct g_hint           gh;
85                 struct M_hint           Mh;
86         }                       v;
87 };
88
89 /*
90  * Key value
91  */
92 struct key_value
93 {
94         struct bwstring         *k; /* key string */
95         struct key_hint          hint[0]; /* key sort hint */
96 } __packed;
97
98 /*
99  * Set of keys container object.
100  */
101 struct keys_array
102 {
103         struct key_value         key[0];
104 };
105
106 /*
107  * Parsed -k option data
108  */
109 struct key_specs
110 {
111         struct sort_mods         sm;
112         size_t                   c1;
113         size_t                   c2;
114         size_t                   f1;
115         size_t                   f2;
116         bool                     pos1b;
117         bool                     pos2b;
118 };
119
120 /*
121  * Single entry in sort list.
122  */
123 struct sort_list_item
124 {
125         struct bwstring         *str;
126         struct keys_array        ka;
127 };
128
129 /*
130  * Function type, used to compare two list objects
131  */
132 typedef int (*listcoll_t)(struct sort_list_item **ss1, struct sort_list_item **ss2);
133
134 extern struct key_specs *keys;
135 extern size_t keys_num;
136
137 /*
138  * Main localised symbols. These must be wint_t as they may hold WEOF.
139  */
140 extern wint_t symbol_decimal_point;
141 extern wint_t symbol_thousands_sep;
142 extern wint_t symbol_negative_sign;
143 extern wint_t symbol_positive_sign;
144
145 /* funcs */
146
147 cmpcoll_t get_sort_func(struct sort_mods *sm);
148
149 struct keys_array *keys_array_alloc(void);
150 size_t keys_array_size(void);
151 struct key_value *get_key_from_keys_array(struct keys_array *ka, size_t ind);
152 void set_key_on_keys_array(struct keys_array *ka, struct bwstring *s, size_t ind);
153 void clean_keys_array(const struct bwstring *s, struct keys_array *ka);
154
155 struct sort_list_item *sort_list_item_alloc(void);
156 void sort_list_item_set(struct sort_list_item *si, struct bwstring *str);
157 void sort_list_item_clean(struct sort_list_item *si);
158 size_t sort_list_item_size(struct sort_list_item *si);
159
160 int preproc(struct bwstring *s, struct keys_array *ka);
161 int top_level_str_coll(const struct bwstring *, const struct bwstring *);
162 int key_coll(struct keys_array *ks1, struct keys_array *ks2, size_t offset);
163 int str_list_coll(struct bwstring *str1, struct sort_list_item **ss2);
164 int list_coll_by_str_only(struct sort_list_item **ss1, struct sort_list_item **ss2);
165 int list_coll(struct sort_list_item **ss1, struct sort_list_item **ss2);
166 int list_coll_offset(struct sort_list_item **ss1, struct sort_list_item **ss2, size_t offset);
167
168 listcoll_t get_list_call_func(size_t offset);
169
170 #endif /* __COLL_H__ */