Fri, 23 May 2025 12:44:24 +0200
make test-compile depend on both static and shared
the shared lib is not needed for the tests,
but when run with coverage, gcov will be confused
when outdated line information is available from
a previous shared build
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
1 | /* |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
2 | * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
3 | * |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
4 | * Copyright 2024 Mike Becker, Olaf Wintermann All rights reserved. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
5 | * |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
6 | * Redistribution and use in source and binary forms, with or without |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
7 | * modification, are permitted provided that the following conditions are met: |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
8 | * |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
9 | * 1. Redistributions of source code must retain the above copyright |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
10 | * notice, this list of conditions and the following disclaimer. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
11 | * |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
12 | * 2. Redistributions in binary form must reproduce the above copyright |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
13 | * notice, this list of conditions and the following disclaimer in the |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
14 | * documentation and/or other materials provided with the distribution. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
15 | * |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
16 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
17 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
18 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
19 | * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
20 | * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
21 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
22 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
23 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
24 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
25 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
26 | * POSSIBILITY OF SUCH DAMAGE. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
27 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
28 | /** |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
29 | * @file properties.h |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
30 | * @brief Interface for parsing data from properties files. |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
31 | * @author Mike Becker |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
32 | * @author Olaf Wintermann |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
33 | * @copyright 2-Clause BSD License |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
34 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
35 | |
1069
6565e7ef5ee3
fix include guard for properties.h
Mike Becker <universe@uap-core.de>
parents:
1059
diff
changeset
|
36 | #ifndef UCX_PROPERTIES_H |
6565e7ef5ee3
fix include guard for properties.h
Mike Becker <universe@uap-core.de>
parents:
1059
diff
changeset
|
37 | #define UCX_PROPERTIES_H |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
38 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
39 | #include "common.h" |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
40 | #include "string.h" |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
41 | #include "map.h" |
1031
8a90552bba29
rework of properties parser - fixes #529 and resolves #458
Mike Becker <universe@uap-core.de>
parents:
1013
diff
changeset
|
42 | #include "buffer.h" |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
43 | |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
44 | #include <stdio.h> |
972
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
45 | #include <string.h> |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
46 | |
932
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
47 | #ifdef __cplusplus |
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
48 | extern "C" { |
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
49 | #endif |
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
50 | |
1036
6d29532a76c3
add missing documentation for struct cx_properties_config_s
Mike Becker <universe@uap-core.de>
parents:
1031
diff
changeset
|
51 | /** |
6d29532a76c3
add missing documentation for struct cx_properties_config_s
Mike Becker <universe@uap-core.de>
parents:
1031
diff
changeset
|
52 | * Configures the expected characters for the properties parser. |
6d29532a76c3
add missing documentation for struct cx_properties_config_s
Mike Becker <universe@uap-core.de>
parents:
1031
diff
changeset
|
53 | */ |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
54 | struct cx_properties_config_s { |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
55 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
56 | * The key/value delimiter that shall be used. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
57 | * This is '=' by default. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
58 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
59 | char delimiter; |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
60 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
61 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
62 | * The first comment character. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
63 | * This is '#' by default. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
64 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
65 | char comment1; |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
66 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
67 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
68 | * The second comment character. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
69 | * This is not set by default. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
70 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
71 | char comment2; |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
72 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
73 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
74 | * The third comment character. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
75 | * This is not set by default. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
76 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
77 | char comment3; |
1193
cfa44f3f5e3b
last minute fixes for issue #548
Mike Becker <universe@uap-core.de>
parents:
1180
diff
changeset
|
78 | |
cfa44f3f5e3b
last minute fixes for issue #548
Mike Becker <universe@uap-core.de>
parents:
1180
diff
changeset
|
79 | /* |
cfa44f3f5e3b
last minute fixes for issue #548
Mike Becker <universe@uap-core.de>
parents:
1180
diff
changeset
|
80 | * The character, when appearing at the end of a line, continues that line. |
cfa44f3f5e3b
last minute fixes for issue #548
Mike Becker <universe@uap-core.de>
parents:
1180
diff
changeset
|
81 | * This is '\' by default. |
cfa44f3f5e3b
last minute fixes for issue #548
Mike Becker <universe@uap-core.de>
parents:
1180
diff
changeset
|
82 | */ |
cfa44f3f5e3b
last minute fixes for issue #548
Mike Becker <universe@uap-core.de>
parents:
1180
diff
changeset
|
83 | /** |
cfa44f3f5e3b
last minute fixes for issue #548
Mike Becker <universe@uap-core.de>
parents:
1180
diff
changeset
|
84 | * Reserved for future use. |
cfa44f3f5e3b
last minute fixes for issue #548
Mike Becker <universe@uap-core.de>
parents:
1180
diff
changeset
|
85 | */ |
cfa44f3f5e3b
last minute fixes for issue #548
Mike Becker <universe@uap-core.de>
parents:
1180
diff
changeset
|
86 | char continuation; |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
87 | }; |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
88 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
89 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
90 | * Typedef for the properties config. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
91 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
92 | typedef struct cx_properties_config_s CxPropertiesConfig; |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
93 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
94 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
95 | * Default properties configuration. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
96 | */ |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
97 | cx_attr_export |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
98 | extern const CxPropertiesConfig cx_properties_config_default; |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
99 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
100 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
101 | * Status codes for the properties interface. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
102 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
103 | enum cx_properties_status { |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
104 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
105 | * Everything is fine. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
106 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
107 | CX_PROPERTIES_NO_ERROR, |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
108 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
109 | * The input buffer does not contain more data. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
110 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
111 | CX_PROPERTIES_NO_DATA, |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
112 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
113 | * The input ends unexpectedly. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
114 | * |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
115 | * This either happens when the last line does not terminate with a line |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
116 | * break, or when the input ends with a parsed key but no value. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
117 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
118 | CX_PROPERTIES_INCOMPLETE_DATA, |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
119 | /** |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
120 | * Not used as a status and never returned by any function. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
121 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
122 | * You can use this enumerator to check for all "good" status results |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
123 | * by checking if the status is less than @c CX_PROPERTIES_OK. |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
124 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
125 | * A "good" status means, that you can refill data and continue parsing. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
126 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
127 | CX_PROPERTIES_OK, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
128 | /** |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
129 | * Input buffer is @c NULL. |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
130 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
131 | CX_PROPERTIES_NULL_INPUT, |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
132 | /** |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
133 | * The line contains a delimiter, but no key. |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
134 | */ |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
135 | CX_PROPERTIES_INVALID_EMPTY_KEY, |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
136 | /** |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
137 | * The line contains data, but no delimiter. |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
138 | */ |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
139 | CX_PROPERTIES_INVALID_MISSING_DELIMITER, |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
140 | /** |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
141 | * More internal buffer was needed, but could not be allocated. |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
142 | */ |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
143 | CX_PROPERTIES_BUFFER_ALLOC_FAILED, |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
144 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
145 | * Initializing the properties source failed. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
146 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
147 | * @see cx_properties_read_init_func |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
148 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
149 | CX_PROPERTIES_READ_INIT_FAILED, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
150 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
151 | * Reading from a properties source failed. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
152 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
153 | * @see cx_properties_read_func |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
154 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
155 | CX_PROPERTIES_READ_FAILED, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
156 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
157 | * Sinking a k/v-pair failed. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
158 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
159 | * @see cx_properties_sink_func |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
160 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
161 | CX_PROPERTIES_SINK_FAILED, |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
162 | }; |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
163 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
164 | /** |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
165 | * Typedef for the properties status enum. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
166 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
167 | typedef enum cx_properties_status CxPropertiesStatus; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
168 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
169 | /** |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
170 | * Interface for working with properties data. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
171 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
172 | struct cx_properties_s { |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
173 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
174 | * The configuration. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
175 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
176 | CxPropertiesConfig config; |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
177 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
178 | /** |
1031
8a90552bba29
rework of properties parser - fixes #529 and resolves #458
Mike Becker <universe@uap-core.de>
parents:
1013
diff
changeset
|
179 | * The text input buffer. |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
180 | */ |
1031
8a90552bba29
rework of properties parser - fixes #529 and resolves #458
Mike Becker <universe@uap-core.de>
parents:
1013
diff
changeset
|
181 | CxBuffer input; |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
182 | |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
183 | /** |
1031
8a90552bba29
rework of properties parser - fixes #529 and resolves #458
Mike Becker <universe@uap-core.de>
parents:
1013
diff
changeset
|
184 | * Internal buffer. |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
185 | */ |
1031
8a90552bba29
rework of properties parser - fixes #529 and resolves #458
Mike Becker <universe@uap-core.de>
parents:
1013
diff
changeset
|
186 | CxBuffer buffer; |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
187 | }; |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
188 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
189 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
190 | * Typedef for the properties interface. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
191 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
192 | typedef struct cx_properties_s CxProperties; |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
193 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
194 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
195 | /** |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
196 | * Typedef for a properties sink. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
197 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
198 | typedef struct cx_properties_sink_s CxPropertiesSink; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
199 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
200 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
201 | * A function that consumes a k/v-pair in a sink. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
202 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
203 | * The sink could be e.g. a map and the sink function would be calling |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
204 | * a map function to store the k/v-pair. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
205 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
206 | * @param prop the properties interface that wants to sink a k/v-pair |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
207 | * @param sink the sink |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
208 | * @param key the key |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
209 | * @param value the value |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
210 | * @retval zero success |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
211 | * @retval non-zero sinking the k/v-pair failed |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
212 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
213 | cx_attr_nonnull |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
214 | typedef int(*cx_properties_sink_func)( |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
215 | CxProperties *prop, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
216 | CxPropertiesSink *sink, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
217 | cxstring key, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
218 | cxstring value |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
219 | ); |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
220 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
221 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
222 | * Defines a sink for k/v-pairs. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
223 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
224 | struct cx_properties_sink_s { |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
225 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
226 | * The sink object. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
227 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
228 | void *sink; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
229 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
230 | * Optional custom data. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
231 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
232 | void *data; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
233 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
234 | * A function for consuming k/v-pairs into the sink. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
235 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
236 | cx_properties_sink_func sink_func; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
237 | }; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
238 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
239 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
240 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
241 | * Typedef for a properties source. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
242 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
243 | typedef struct cx_properties_source_s CxPropertiesSource; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
244 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
245 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
246 | * A function that reads data from a source. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
247 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
248 | * When the source is depleted, implementations SHALL provide an empty |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
249 | * string in the @p target and return zero. |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
250 | * A non-zero return value is only permitted in case of an error. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
251 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
252 | * The meaning of the optional parameters is implementation-dependent. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
253 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
254 | * @param prop the properties interface that wants to read from the source |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
255 | * @param src the source |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
256 | * @param target a string buffer where the read data shall be stored |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
257 | * @retval zero success |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
258 | * @retval non-zero reading the data failed |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
259 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
260 | cx_attr_nonnull |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
261 | typedef int(*cx_properties_read_func)( |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
262 | CxProperties *prop, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
263 | CxPropertiesSource *src, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
264 | cxstring *target |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
265 | ); |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
266 | |
932
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
267 | /** |
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
268 | * A function that may initialize additional memory for the source. |
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
269 | * |
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
270 | * @param prop the properties interface that wants to read from the source |
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
271 | * @param src the source |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
272 | * @retval zero initialization was successful |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
273 | * @retval non-zero otherwise |
932
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
274 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
275 | cx_attr_nonnull |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
276 | typedef int(*cx_properties_read_init_func)( |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
277 | CxProperties *prop, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
278 | CxPropertiesSource *src |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
279 | ); |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
280 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
281 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
282 | * A function that cleans memory initialized by the read_init_func. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
283 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
284 | * @param prop the properties interface that wants to read from the source |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
285 | * @param src the source |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
286 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
287 | cx_attr_nonnull |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
288 | typedef void(*cx_properties_read_clean_func)( |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
289 | CxProperties *prop, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
290 | CxPropertiesSource *src |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
291 | ); |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
292 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
293 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
294 | * Defines a properties source. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
295 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
296 | struct cx_properties_source_s { |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
297 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
298 | * The source object. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
299 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
300 | * For example a file stream or a string. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
301 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
302 | void *src; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
303 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
304 | * Optional additional data pointer. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
305 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
306 | void *data_ptr; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
307 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
308 | * Optional size information. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
309 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
310 | size_t data_size; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
311 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
312 | * A function that reads data from the source. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
313 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
314 | cx_properties_read_func read_func; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
315 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
316 | * Optional function that may prepare the source for reading data. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
317 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
318 | cx_properties_read_init_func read_init_func; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
319 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
320 | * Optional function that cleans additional memory allocated by the |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
321 | * read_init_func. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
322 | */ |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
323 | cx_properties_read_clean_func read_clean_func; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
324 | }; |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
325 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
326 | /** |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
327 | * Initialize a properties interface. |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
328 | * |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
329 | * @param prop the properties interface |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
330 | * @param config the properties configuration |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
331 | * @see cxPropertiesInitDefault() |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
332 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
333 | cx_attr_nonnull |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
334 | cx_attr_export |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
335 | void cxPropertiesInit(CxProperties *prop, CxPropertiesConfig config); |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
336 | |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
337 | /** |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
338 | * Destroys the properties interface. |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
339 | * |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
340 | * @note Even when you are certain that you did not use the interface in a |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
341 | * way that caused a memory allocation, you should call this function anyway. |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
342 | * Future versions of the library might add features that need additional memory |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
343 | * and you really don't want to search the entire code where you might need |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
344 | * add call to this function. |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
345 | * |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
346 | * @param prop the properties interface |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
347 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
348 | cx_attr_nonnull |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
349 | cx_attr_export |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
350 | void cxPropertiesDestroy(CxProperties *prop); |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
351 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
352 | /** |
1013
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
353 | * Destroys and re-initializes the properties interface. |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
354 | * |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
355 | * You might want to use this, to reset the parser after |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
356 | * encountering a syntax error. |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
357 | * |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
358 | * @param prop the properties interface |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
359 | */ |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
360 | cx_attr_nonnull |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
361 | static inline void cxPropertiesReset(CxProperties *prop) { |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
362 | CxPropertiesConfig config = prop->config; |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
363 | cxPropertiesDestroy(prop); |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
364 | cxPropertiesInit(prop, config); |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
365 | } |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
366 | |
add8358fc3c3
add cxJsonReset() and cxPropertiesReset()
Mike Becker <universe@uap-core.de>
parents:
988
diff
changeset
|
367 | /** |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
368 | * Initialize a properties parser with the default configuration. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
369 | * |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
370 | * @param prop (@c CxProperties*) the properties interface |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
371 | * @see cxPropertiesInit() |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
372 | */ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
373 | #define cxPropertiesInitDefault(prop) \ |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
374 | cxPropertiesInit(prop, cx_properties_config_default) |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
375 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
376 | /** |
972
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
377 | * Fills the input buffer with data. |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
378 | * |
1038
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
379 | * After calling this function, you can parse the data by calling |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
380 | * cxPropertiesNext(). |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
381 | * |
1058
d347f74ce7d1
downgrades the severity of the advice in cxPropertiesFilln() from attention to remark
Mike Becker <universe@uap-core.de>
parents:
1038
diff
changeset
|
382 | * @remark The properties interface tries to avoid allocations. |
1038
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
383 | * When you use this function and cxPropertiesNext() interleaving, |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
384 | * no allocations are performed. However, you must not free the |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
385 | * pointer to the data in that case. When you invoke the fill |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
386 | * function more than once before calling cxPropertiesNext(), |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
387 | * the additional data is appended - inevitably leading to |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
388 | * an allocation of a new buffer and copying the previous contents. |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
389 | * |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
390 | * @param prop the properties interface |
1038
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
391 | * @param buf a pointer to the data |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
392 | * @param len the length of the data |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
393 | * @retval zero success |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
394 | * @retval non-zero a memory allocation was necessary but failed |
1059
154eb64ce746
add references between both variants of the properties fill function
Mike Becker <universe@uap-core.de>
parents:
1058
diff
changeset
|
395 | * @see cxPropertiesFill() |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
396 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
397 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
398 | cx_attr_access_r(2, 3) |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
399 | cx_attr_export |
972
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
400 | int cxPropertiesFilln( |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
401 | CxProperties *prop, |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
402 | const char *buf, |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
403 | size_t len |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
404 | ); |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
405 | |
988
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
406 | #ifdef __cplusplus |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
407 | } // extern "C" |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
408 | cx_attr_nonnull |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
409 | static inline int cxPropertiesFill( |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
410 | CxProperties *prop, |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
411 | cxstring str |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
412 | ) { |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
413 | return cxPropertiesFilln(prop, str.ptr, str.length); |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
414 | } |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
415 | |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
416 | cx_attr_nonnull |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
417 | static inline int cxPropertiesFill( |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
418 | CxProperties *prop, |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
419 | cxmutstr str |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
420 | ) { |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
421 | return cxPropertiesFilln(prop, str.ptr, str.length); |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
422 | } |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
423 | |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
424 | cx_attr_nonnull |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
425 | cx_attr_cstr_arg(2) |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
426 | static inline int cxPropertiesFill( |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
427 | CxProperties *prop, |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
428 | const char *str |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
429 | ) { |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
430 | return cxPropertiesFilln(prop, str, strlen(str)); |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
431 | } |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
432 | |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
433 | extern "C" { |
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
434 | #else // __cplusplus |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
435 | /** |
1038
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
436 | * Fills the input buffer with data. |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
437 | * |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
438 | * After calling this function, you can parse the data by calling |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
439 | * cxPropertiesNext(). |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
440 | * |
1038
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
441 | * @attention The properties interface tries to avoid allocations. |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
442 | * When you use this function and cxPropertiesNext() interleaving, |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
443 | * no allocations are performed. However, you must not free the |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
444 | * pointer to the data in that case. When you invoke the fill |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
445 | * function more than once before calling cxPropertiesNext(), |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
446 | * the additional data is appended - inevitably leading to |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
447 | * an allocation of a new buffer and copying the previous contents. |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
448 | * |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
449 | * @param prop the properties interface |
1038
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
450 | * @param str the text to fill in |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
451 | * @retval zero success |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
452 | * @retval non-zero a memory allocation was necessary but failed |
1059
154eb64ce746
add references between both variants of the properties fill function
Mike Becker <universe@uap-core.de>
parents:
1058
diff
changeset
|
453 | * @see cxPropertiesFilln() |
972
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
454 | */ |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
455 | #define cxPropertiesFill(prop, str) _Generic((str), \ |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
456 | cxstring: cx_properties_fill_cxstr, \ |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
457 | cxmutstr: cx_properties_fill_mutstr, \ |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
458 | char*: cx_properties_fill_str, \ |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
459 | const char*: cx_properties_fill_str) \ |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
460 | (prop, str) |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
461 | |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
462 | /** |
1038
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
463 | * @copydoc cxPropertiesFill() |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
464 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
465 | cx_attr_nonnull |
972
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
466 | static inline int cx_properties_fill_cxstr( |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
467 | CxProperties *prop, |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
468 | cxstring str |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
469 | ) { |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
470 | return cxPropertiesFilln(prop, str.ptr, str.length); |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
471 | } |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
472 | |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
473 | /** |
1038
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
474 | * @copydoc cxPropertiesFill() |
972
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
475 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
476 | cx_attr_nonnull |
972
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
477 | static inline int cx_properties_fill_mutstr( |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
478 | CxProperties *prop, |
972
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
479 | cxmutstr str |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
480 | ) { |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
481 | return cxPropertiesFilln(prop, str.ptr, str.length); |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
482 | } |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
483 | |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
484 | /** |
1038
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
485 | * @copydoc cxPropertiesFill() |
972
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
486 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
487 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
488 | cx_attr_cstr_arg(2) |
972
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
489 | static inline int cx_properties_fill_str( |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
490 | CxProperties *prop, |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
491 | const char *str |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
492 | ) { |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
493 | return cxPropertiesFilln(prop, str, strlen(str)); |
a9a1d07a6840
add support for UCX strings in cxPropertiesFill()
Mike Becker <universe@uap-core.de>
parents:
932
diff
changeset
|
494 | } |
988
15b3ca7ee33f
make ucx C++ compatible again (and add tests for it) - fixes #486
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
495 | #endif |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
496 | |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
497 | /** |
1031
8a90552bba29
rework of properties parser - fixes #529 and resolves #458
Mike Becker <universe@uap-core.de>
parents:
1013
diff
changeset
|
498 | * Specifies stack memory that shall be used as internal buffer. |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
499 | * |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
500 | * @param prop the properties interface |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
501 | * @param buf a pointer to stack memory |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
502 | * @param capacity the capacity of the stack memory |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
503 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
504 | cx_attr_nonnull |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
505 | cx_attr_export |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
506 | void cxPropertiesUseStack( |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
507 | CxProperties *prop, |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
508 | char *buf, |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
509 | size_t capacity |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
510 | ); |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
511 | |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
512 | /** |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
513 | * Retrieves the next key/value-pair. |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
514 | * |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
515 | * This function returns zero as long as there are key/value-pairs found. |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
516 | * If no more key/value-pairs are found, #CX_PROPERTIES_NO_DATA is returned. |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
517 | * |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
518 | * When an incomplete line is encountered, #CX_PROPERTIES_INCOMPLETE_DATA is |
1038
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
519 | * returned, and you can add more data with #cxPropertiesFill(). |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
520 | * |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
521 | * @remark The incomplete line will be stored in an internal buffer, which is |
1038
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
522 | * allocated on the heap, by default. If you want to avoid allocations, |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
523 | * you can specify sufficient space with cxPropertiesUseStack() after |
8cab3d8e0af4
fix outdated documentation in properties.h
Mike Becker <universe@uap-core.de>
parents:
1036
diff
changeset
|
524 | * initialization with cxPropertiesInit(). |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
525 | * |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
526 | * @attention The returned strings will point into a buffer that might not be |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
527 | * available later. It is strongly recommended to copy the strings for further |
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
528 | * use. |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
529 | * |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
530 | * @param prop the properties interface |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
531 | * @param key a pointer to the cxstring that shall contain the property name |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
532 | * @param value a pointer to the cxstring that shall contain the property value |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
533 | * @retval CX_PROPERTIES_NO_ERROR (zero) a key/value pair was found |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
534 | * @retval CX_PROPERTIES_NO_DATA there is no (more) data in the input buffer |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
535 | * @retval CX_PROPERTIES_INCOMPLETE_DATA the data in the input buffer is incomplete |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
536 | * (fill more data and try again) |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
537 | * @retval CX_PROPERTIES_NULL_INPUT the input buffer was never filled |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
538 | * @retval CX_PROPERTIES_INVALID_EMPTY_KEY the properties data contains an illegal empty key |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
539 | * @retval CX_PROPERTIES_INVALID_MISSING_DELIMITER the properties data contains a line without delimiter |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
540 | * @retval CX_PROPERTIES_BUFFER_ALLOC_FAILED an internal allocation was necessary but failed |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
541 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
542 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
543 | cx_attr_nodiscard |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
544 | cx_attr_export |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
545 | CxPropertiesStatus cxPropertiesNext( |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
546 | CxProperties *prop, |
924
3c90dfc35f06
add implementation for the properties parser
Mike Becker <universe@uap-core.de>
parents:
923
diff
changeset
|
547 | cxstring *key, |
923
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
548 | cxstring *value |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
549 | ); |
45da884269c8
add ucx2.1 style interface for a properties parser
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
550 | |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
551 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
552 | * Creates a properties sink for an UCX map. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
553 | * |
1232
781bd188f1c0
complete the properties documentation
Mike Becker <universe@uap-core.de>
parents:
1193
diff
changeset
|
554 | * The values stored in the map will be pointers to freshly allocated, |
781bd188f1c0
complete the properties documentation
Mike Becker <universe@uap-core.de>
parents:
1193
diff
changeset
|
555 | * zero-terminated C strings (@c char*), which means the @p map should have been |
781bd188f1c0
complete the properties documentation
Mike Becker <universe@uap-core.de>
parents:
1193
diff
changeset
|
556 | * created with #CX_STORE_POINTERS. |
781bd188f1c0
complete the properties documentation
Mike Becker <universe@uap-core.de>
parents:
1193
diff
changeset
|
557 | * |
1318
12fa1d37fe48
allow changing the cxDefaultAllocator - resolves #669
Mike Becker <universe@uap-core.de>
parents:
1232
diff
changeset
|
558 | * The cxDefaultAllocator will be used unless you specify a custom |
1232
781bd188f1c0
complete the properties documentation
Mike Becker <universe@uap-core.de>
parents:
1193
diff
changeset
|
559 | * allocator in the optional @c data field of the returned sink. |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
560 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
561 | * @param map the map that shall consume the k/v-pairs. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
562 | * @return the sink |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
563 | * @see cxPropertiesLoad() |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
564 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
565 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
566 | cx_attr_nodiscard |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
567 | cx_attr_export |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
568 | CxPropertiesSink cxPropertiesMapSink(CxMap *map); |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
569 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
570 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
571 | * Creates a properties source based on an UCX string. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
572 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
573 | * @param str the string |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
574 | * @return the properties source |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
575 | * @see cxPropertiesLoad() |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
576 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
577 | cx_attr_nodiscard |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
578 | cx_attr_export |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
579 | CxPropertiesSource cxPropertiesStringSource(cxstring str); |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
580 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
581 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
582 | * Creates a properties source based on C string with the specified length. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
583 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
584 | * @param str the string |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
585 | * @param len the length |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
586 | * @return the properties source |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
587 | * @see cxPropertiesLoad() |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
588 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
589 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
590 | cx_attr_nodiscard |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
591 | cx_attr_access_r(1, 2) |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
592 | cx_attr_export |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
593 | CxPropertiesSource cxPropertiesCstrnSource(const char *str, size_t len); |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
594 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
595 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
596 | * Creates a properties source based on a C string. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
597 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
598 | * The length will be determined with strlen(), so the string MUST be |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
599 | * zero-terminated. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
600 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
601 | * @param str the string |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
602 | * @return the properties source |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
603 | * @see cxPropertiesLoad() |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
604 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
605 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
606 | cx_attr_nodiscard |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
607 | cx_attr_cstr_arg(1) |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
608 | cx_attr_export |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
609 | CxPropertiesSource cxPropertiesCstrSource(const char *str); |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
610 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
611 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
612 | * Creates a properties source based on an FILE. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
613 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
614 | * @param file the file |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
615 | * @param chunk_size how many bytes may be read in one operation |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
616 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
617 | * @return the properties source |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
618 | * @see cxPropertiesLoad() |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
619 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
620 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
621 | cx_attr_nodiscard |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
622 | cx_attr_access_r(1) |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
623 | cx_attr_export |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
624 | CxPropertiesSource cxPropertiesFileSource(FILE *file, size_t chunk_size); |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
625 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
626 | |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
627 | /** |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
628 | * Loads properties data from a source and transfers it to a sink. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
629 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
630 | * This function tries to read as much data from the source as possible. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
631 | * When the source was completely consumed and at least on k/v-pair was found, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
632 | * the return value will be #CX_PROPERTIES_NO_ERROR. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
633 | * When the source was consumed but no k/v-pairs were found, the return value |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
634 | * will be #CX_PROPERTIES_NO_DATA. |
1124
fcd5d86c472f
fix wrong status of cxPropertiesLoad() when data is incomplete - fixes #560
Mike Becker <universe@uap-core.de>
parents:
1106
diff
changeset
|
635 | * In case the source data ends unexpectedly, the #CX_PROPERTIES_INCOMPLETE_DATA |
fcd5d86c472f
fix wrong status of cxPropertiesLoad() when data is incomplete - fixes #560
Mike Becker <universe@uap-core.de>
parents:
1106
diff
changeset
|
636 | * is returned. In that case you should call this function again with the same |
fcd5d86c472f
fix wrong status of cxPropertiesLoad() when data is incomplete - fixes #560
Mike Becker <universe@uap-core.de>
parents:
1106
diff
changeset
|
637 | * sink and either an updated source or the same source if the source is able to |
fcd5d86c472f
fix wrong status of cxPropertiesLoad() when data is incomplete - fixes #560
Mike Becker <universe@uap-core.de>
parents:
1106
diff
changeset
|
638 | * yield the missing data. |
fcd5d86c472f
fix wrong status of cxPropertiesLoad() when data is incomplete - fixes #560
Mike Becker <universe@uap-core.de>
parents:
1106
diff
changeset
|
639 | * |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
640 | * The other result codes apply, according to their description. |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
641 | * |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
642 | * @param prop the properties interface |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
643 | * @param sink the sink |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
644 | * @param source the source |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
645 | * @retval CX_PROPERTIES_NO_ERROR (zero) a key/value pair was found |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
646 | * @retval CX_PROPERTIES_READ_INIT_FAILED initializing the source failed |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
647 | * @retval CX_PROPERTIES_READ_FAILED reading from the source failed |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
648 | * @retval CX_PROPERTIES_SINK_FAILED sinking the properties into the sink failed |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
649 | * @retval CX_PROPERTIES_NO_DATA the source did not provide any key/value pairs |
1124
fcd5d86c472f
fix wrong status of cxPropertiesLoad() when data is incomplete - fixes #560
Mike Becker <universe@uap-core.de>
parents:
1106
diff
changeset
|
650 | * @retval CX_PROPERTIES_INCOMPLETE_DATA the source did not provide enough data |
1106
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
651 | * @retval CX_PROPERTIES_INVALID_EMPTY_KEY the properties data contains an illegal empty key |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
652 | * @retval CX_PROPERTIES_INVALID_MISSING_DELIMITER the properties data contains a line without delimiter |
0480f8600fb7
refine docs for properties.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
1069
diff
changeset
|
653 | * @retval CX_PROPERTIES_BUFFER_ALLOC_FAILED an internal allocation was necessary but failed |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
654 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
980
diff
changeset
|
655 | cx_attr_nonnull |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1124
diff
changeset
|
656 | cx_attr_export |
928
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
657 | CxPropertiesStatus cxPropertiesLoad( |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
658 | CxProperties *prop, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
659 | CxPropertiesSink sink, |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
660 | CxPropertiesSource source |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
661 | ); |
d2d42cb1d59e
add source/sink facility for properties - fixes #430
Mike Becker <universe@uap-core.de>
parents:
924
diff
changeset
|
662 | |
932
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
663 | #ifdef __cplusplus |
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
664 | } // extern "C" |
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
665 | #endif |
484dab606292
add extern "C" to properties.h
Mike Becker <universe@uap-core.de>
parents:
928
diff
changeset
|
666 | |
1069
6565e7ef5ee3
fix include guard for properties.h
Mike Becker <universe@uap-core.de>
parents:
1059
diff
changeset
|
667 | #endif // UCX_PROPERTIES_H |