Qore CsvUtil Module Reference 1.11
Loading...
Searching...
No Matches
AbstractCsvWriter.qc.dox.h
1// -*- mode: c++; indent-tabs-mode: nil -*-
2// Qore AbstractCsvWriter class definition
3
4/* AbstractCsvWriter.qc Copyright 2012 - 2024 Qore Technologies, s.r.o.
5
6 Permission is hereby granted, free of charge, to any person obtaining a
7 copy of this software and associated documentation files (the "Software"),
8 to deal in the Software without restriction, including without limitation
9 the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 and/or sell copies of the Software, and to permit persons to whom the
11 Software is furnished to do so, subject to the following conditions:
12
13 The above copyright notice and this permission notice shall be included in
14 all copies or substantial portions of the Software.
15
16 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22 DEALINGS IN THE SOFTWARE.
23*/
24
25// assume local var scope, do not use "$" for vars, members, and method calls
26
28namespace CsvUtil {
30
139class AbstractCsvWriter : protected CsvHelper {
140
141public:
142protected:
144 const Options = ...;
145
146
148 string encoding;
149
151 string separator = ",";
152
154 string quote = "\"";
155
157 string m_quoteEscapeChar = "\\";
158
160 string eol = EOL_UNIX;
161
163 bool checkElementCounts = False;
164
166 int lineNo = 0;
167
169 int block = 1000;
170
173
175 bool write_headers = True;
176
178 bool optimal_quotes = True;
179
181 *code info_log;
182
185
188
189public:
190
192
198 constructor(string n_errname, *hash<auto> n_opts);
199
200
202
210 constructor(string n_errname, hash<auto> spec, hash<auto> n_opts);
211
212
214 *hash<string, AbstractDataField> getRecordType();
215
216
218protected:
219 processCommonOptions(*hash<auto> n_opts, int C_OPTx);
220public:
221
222
224protected:
226public:
227
228
230protected:
232public:
233
234
236
241 writeLine(list<auto> values);
242
243
245
250 writeLine(hash<auto> values);
251
252
254
260 writeLine(string type, list<auto> values);
261
262
264
270 writeLine(string type, hash<auto> values);
271
272
274
284
285
287
295
296
298
305 write(list<auto> l);
306
307
309protected:
310 abstract writeRawLine(list<auto> values);
311public:
312
314
319protected:
320 string prepareRawLine(list<auto> values);
321public:
322
323
324protected:
325 string prepareRawLineIntern(list<auto> values);
326public:
327
328
329 }; // AbstractCsvWriter class
330}; // CsvUtil namespace
The AbstractCsvWriter class provides a parent for all CSV writers.
Definition AbstractCsvWriter.qc.dox.h:139
string baseTemplate
base template for value format
Definition AbstractCsvWriter.qc.dox.h:172
write(Qore::AbstractIterator iterator)
Stream an iterator into the output.
abstract writeRawLine(list< auto > values)
This method must be overridden in child classes to provide the output implementation.
writeLine(hash< auto > values)
Write a line with headers-values hash.
writeLine(string type, hash< auto > values)
Write a line for a specific record from a hash to the output.
string prepareRawLine(list< auto > values)
Prepare a string (line with EOF) with formatting and escaping.
constructor(string n_errname, hash< auto > spec, hash< auto > n_opts)
Creates the AbstractCsvWriter in single-type mode.
write(list< auto > l)
Stream the contents of the list into the output.
write(Qore::SQL::SQLStatement iterator)
Stream an iterator into the output.
int block
block size for bulk DML
Definition AbstractCsvWriter.qc.dox.h:169
*hash< string, AbstractDataField > getRecordType()
Returns the description of the record type, if any.
string encoding
output file character encoding
Definition AbstractCsvWriter.qc.dox.h:148
hash m_out_by_name
mapping output field by name
Definition AbstractCsvWriter.qc.dox.h:184
string quote
field content delimiter
Definition AbstractCsvWriter.qc.dox.h:154
string eol
end of line sequence
Definition AbstractCsvWriter.qc.dox.h:160
writeHeaders()
Write csv headers.
bool write_headers
this flag determines if any stored headers are output
Definition AbstractCsvWriter.qc.dox.h:175
*code info_log
a closure/call reference for informational logging when using write(SQLStatement)
Definition AbstractCsvWriter.qc.dox.h:181
bool optimal_quotes
stores the optimal quotes option
Definition AbstractCsvWriter.qc.dox.h:178
string m_quoteEscapeChar
quote escape character
Definition AbstractCsvWriter.qc.dox.h:157
const Options
valid options for the object (a hash for quick lookups of valid keys)
Definition AbstractCsvWriter.qc.dox.h:144
bool checkElementCounts
verify the column count for every row; if a row does not match, then throw a CSVFILEITERATOR-DATA-ERR...
Definition AbstractCsvWriter.qc.dox.h:163
string separator
field separator
Definition AbstractCsvWriter.qc.dox.h:151
int lineNo
the latest line number
Definition AbstractCsvWriter.qc.dox.h:166
constructor(string n_errname, *hash< auto > n_opts)
Creates the AbstractCsvWriter in single-type mode.
hash m_out_by_idx
mapping output field by index
Definition AbstractCsvWriter.qc.dox.h:187
writeLine(string type, list< auto > values)
Write a line with headers-values list.
writeLine(list< auto > values)
Write a line with a list of values; data are checked against column rules.
processCommonOptions(*hash< auto > n_opts, int C_OPTx)
Process options and set internal variables.
processSpec()
Process specification and set internal variable for mapping.
the CsvUtil namespace. All classes used in the CsvUtil module should be inside this namespace
Definition AbstractCsvIterator.qc.dox.h:28
const EOL_UNIX
Unix end of line character sequence (for new OS X too)
Definition CsvUtil.qm.dox.h:395