quasardb 3.14.2.dev3__cp39-cp39-win_amd64.whl → 3.14.2.dev5__cp39-cp39-win_amd64.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of quasardb might be problematic. Click here for more details.
- quasardb/INSTALL.vcxproj +5 -4
- quasardb/__init__.py +21 -7
- quasardb/cmake_install.cmake +6 -0
- quasardb/date/ALL_BUILD.vcxproj +9 -8
- quasardb/date/CMakeFiles/Export/df49adab93b9e0c10c64f72458b31971/dateTargets.cmake +2 -2
- quasardb/date/CMakeFiles/generate.stamp.depend +4 -4
- quasardb/date/INSTALL.vcxproj +5 -4
- quasardb/date/cmake_install.cmake +6 -0
- quasardb/date/dateTargets.cmake +2 -2
- quasardb/extensions/writer.py +59 -61
- quasardb/firehose.py +24 -22
- quasardb/numpy/__init__.py +181 -120
- quasardb/pandas/__init__.py +145 -95
- quasardb/pool.py +13 -2
- quasardb/pybind11/ALL_BUILD.vcxproj +9 -8
- quasardb/pybind11/CMakeFiles/generate.stamp.depend +14 -14
- quasardb/pybind11/INSTALL.vcxproj +5 -4
- quasardb/pybind11/cmake_install.cmake +6 -0
- quasardb/qdb_api.dll +0 -0
- quasardb/quasardb.cp39-win_amd64.pyd +0 -0
- quasardb/range-v3/ALL_BUILD.vcxproj +9 -8
- quasardb/range-v3/CMakeFiles/Export/d94ef200eca10a819b5858b33e808f5b/range-v3-targets.cmake +2 -2
- quasardb/range-v3/CMakeFiles/generate.stamp.depend +11 -11
- quasardb/range-v3/INSTALL.vcxproj +5 -4
- quasardb/range-v3/cmake_install.cmake +6 -0
- quasardb/range-v3/range-v3-config.cmake +2 -2
- quasardb/range-v3/range.v3.headers.vcxproj +9 -8
- quasardb/stats.py +92 -80
- quasardb/table_cache.py +5 -1
- {quasardb-3.14.2.dev3.dist-info → quasardb-3.14.2.dev5.dist-info}/METADATA +13 -8
- quasardb-3.14.2.dev5.dist-info/RECORD +54 -0
- {quasardb-3.14.2.dev3.dist-info → quasardb-3.14.2.dev5.dist-info}/WHEEL +1 -1
- quasardb/CMakeLists.txt +0 -517
- quasardb/batch_column.hpp +0 -80
- quasardb/batch_inserter.hpp +0 -248
- quasardb/blob.hpp +0 -150
- quasardb/cluster.cpp +0 -102
- quasardb/cluster.hpp +0 -593
- quasardb/concepts.hpp +0 -322
- quasardb/continuous.cpp +0 -199
- quasardb/continuous.hpp +0 -109
- quasardb/convert/array.hpp +0 -299
- quasardb/convert/point.hpp +0 -330
- quasardb/convert/range.hpp +0 -282
- quasardb/convert/unicode.hpp +0 -598
- quasardb/convert/util.hpp +0 -22
- quasardb/convert/value.hpp +0 -782
- quasardb/convert.hpp +0 -38
- quasardb/detail/invoke.hpp +0 -0
- quasardb/detail/qdb_resource.hpp +0 -129
- quasardb/detail/retry.cpp +0 -30
- quasardb/detail/retry.hpp +0 -147
- quasardb/detail/sleep.hpp +0 -53
- quasardb/detail/ts_column.hpp +0 -224
- quasardb/detail/writer.cpp +0 -440
- quasardb/detail/writer.hpp +0 -550
- quasardb/direct_blob.hpp +0 -108
- quasardb/direct_handle.hpp +0 -83
- quasardb/direct_integer.hpp +0 -94
- quasardb/dispatch.hpp +0 -157
- quasardb/double.hpp +0 -87
- quasardb/entry.hpp +0 -273
- quasardb/error.hpp +0 -393
- quasardb/handle.cpp +0 -29
- quasardb/handle.hpp +0 -98
- quasardb/integer.hpp +0 -88
- quasardb/logger.cpp +0 -106
- quasardb/logger.hpp +0 -228
- quasardb/masked_array.hpp +0 -658
- quasardb/metrics.cpp +0 -103
- quasardb/metrics.hpp +0 -112
- quasardb/module.cpp +0 -92
- quasardb/module.hpp +0 -24
- quasardb/node.hpp +0 -132
- quasardb/numpy.cpp +0 -6
- quasardb/numpy.hpp +0 -489
- quasardb/object_tracker.hpp +0 -282
- quasardb/options.hpp +0 -273
- quasardb/perf.hpp +0 -336
- quasardb/properties.cpp +0 -41
- quasardb/properties.hpp +0 -85
- quasardb/pytypes.hpp +0 -221
- quasardb/query.cpp +0 -420
- quasardb/query.hpp +0 -92
- quasardb/reader.cpp +0 -282
- quasardb/reader.hpp +0 -256
- quasardb/remove_cvref.hpp +0 -31
- quasardb/string.hpp +0 -160
- quasardb/table.cpp +0 -257
- quasardb/table.hpp +0 -366
- quasardb/tag.hpp +0 -77
- quasardb/timestamp.hpp +0 -97
- quasardb/traits.hpp +0 -642
- quasardb/ts_iterator.hpp +0 -193
- quasardb/utils/blob_deque.hpp +0 -96
- quasardb/utils/ostream.hpp +0 -17
- quasardb/utils/permutation.hpp +0 -50
- quasardb/utils/stable_sort.hpp +0 -25
- quasardb/utils/unzip_view.hpp +0 -89
- quasardb/utils.cpp +0 -28
- quasardb/utils.hpp +0 -174
- quasardb/writer.hpp +0 -354
- quasardb-3.14.2.dev3.dist-info/RECORD +0 -124
- {quasardb-3.14.2.dev3.dist-info → quasardb-3.14.2.dev5.dist-info}/LICENSE.md +0 -0
- {quasardb-3.14.2.dev3.dist-info → quasardb-3.14.2.dev5.dist-info}/top_level.txt +0 -0
quasardb/writer.hpp
DELETED
|
@@ -1,354 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
*
|
|
3
|
-
* Official Python API
|
|
4
|
-
*
|
|
5
|
-
* Copyright (c) 2009-2024, quasardb SAS. All rights reserved.
|
|
6
|
-
* All rights reserved.
|
|
7
|
-
*
|
|
8
|
-
* Redistribution and use in source and binary forms, with or without
|
|
9
|
-
* modification, are permitted provided that the following conditions are met:
|
|
10
|
-
*
|
|
11
|
-
* * Redistributions of source code must retain the above copyright
|
|
12
|
-
* notice, this list of conditions and the following disclaimer.
|
|
13
|
-
* * Redistributions in binary form must reproduce the above copyright
|
|
14
|
-
* notice, this list of conditions and the following disclaimer in the
|
|
15
|
-
* documentation and/or other materials provided with the distribution.
|
|
16
|
-
* * Neither the name of quasardb nor the names of its contributors may
|
|
17
|
-
* be used to endorse or promote products derived from this software
|
|
18
|
-
* without specific prior written permission.
|
|
19
|
-
*
|
|
20
|
-
* THIS SOFTWARE IS PROVIDED BY QUASARDB AND CONTRIBUTORS ``AS IS'' AND ANY
|
|
21
|
-
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
22
|
-
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
23
|
-
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS AND CONTRIBUTORS BE LIABLE FOR ANY
|
|
24
|
-
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
25
|
-
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
26
|
-
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
27
|
-
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
28
|
-
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
29
|
-
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
30
|
-
*/
|
|
31
|
-
#pragma once
|
|
32
|
-
|
|
33
|
-
#include "concepts.hpp"
|
|
34
|
-
#include "error.hpp"
|
|
35
|
-
#include "logger.hpp"
|
|
36
|
-
#include "metrics.hpp"
|
|
37
|
-
#include "object_tracker.hpp"
|
|
38
|
-
#include "detail/writer.hpp"
|
|
39
|
-
#include <vector>
|
|
40
|
-
|
|
41
|
-
namespace qdb
|
|
42
|
-
{
|
|
43
|
-
class writer
|
|
44
|
-
{
|
|
45
|
-
|
|
46
|
-
using int64_column = detail::int64_column;
|
|
47
|
-
using double_column = detail::double_column;
|
|
48
|
-
using timestamp_column = detail::timestamp_column;
|
|
49
|
-
using blob_column = detail::blob_column;
|
|
50
|
-
using string_column = detail::string_column;
|
|
51
|
-
using any_column = detail::any_column;
|
|
52
|
-
|
|
53
|
-
public:
|
|
54
|
-
public:
|
|
55
|
-
writer(qdb::handle_ptr h)
|
|
56
|
-
: _logger("quasardb.writer")
|
|
57
|
-
, _handle{h}
|
|
58
|
-
{}
|
|
59
|
-
|
|
60
|
-
// prevent copy because of the table object, use a unique_ptr of the batch in cluster
|
|
61
|
-
// to return the object
|
|
62
|
-
writer(const writer &) = delete;
|
|
63
|
-
|
|
64
|
-
~writer()
|
|
65
|
-
{}
|
|
66
|
-
|
|
67
|
-
const std::vector<qdb_exp_batch_push_column_t> & prepare_columns();
|
|
68
|
-
|
|
69
|
-
template < //
|
|
70
|
-
qdb::concepts::writer_push_strategy PushStrategy, //
|
|
71
|
-
qdb::concepts::sleep_strategy SleepStrategy> //
|
|
72
|
-
void push(detail::writer_data const & data, py::kwargs kwargs)
|
|
73
|
-
{
|
|
74
|
-
qdb::object_tracker::scoped_capture capture{_object_tracker};
|
|
75
|
-
|
|
76
|
-
// We always want to have a push mode at this point
|
|
77
|
-
kwargs = detail::batch_push_mode::ensure(kwargs);
|
|
78
|
-
|
|
79
|
-
_push_impl<PushStrategy, SleepStrategy>( //
|
|
80
|
-
detail::staged_tables::index(data), //
|
|
81
|
-
kwargs //
|
|
82
|
-
); //
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
template < //
|
|
86
|
-
qdb::concepts::writer_push_strategy PushStrategy, //
|
|
87
|
-
qdb::concepts::sleep_strategy SleepStrategy> //
|
|
88
|
-
void push_async(detail::writer_data const & data, py::kwargs kwargs)
|
|
89
|
-
{
|
|
90
|
-
_logger.warn("writer.push_async() is deprecated, please invoke writer.push() directly and "
|
|
91
|
-
"provide the push mode as a kwarg");
|
|
92
|
-
|
|
93
|
-
return push<PushStrategy, SleepStrategy>(
|
|
94
|
-
data, detail::batch_push_mode::set(kwargs, qdb_exp_batch_push_async));
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
template < //
|
|
98
|
-
qdb::concepts::writer_push_strategy PushStrategy, //
|
|
99
|
-
qdb::concepts::sleep_strategy SleepStrategy> //
|
|
100
|
-
void push_fast(detail::writer_data const & data, py::kwargs kwargs)
|
|
101
|
-
{
|
|
102
|
-
_logger.warn("writer.push_fast() is deprecated, please invoke writer.push() directly and "
|
|
103
|
-
"provide the push mode as a kwarg");
|
|
104
|
-
|
|
105
|
-
return push<PushStrategy, SleepStrategy>(
|
|
106
|
-
data, detail::batch_push_mode::set(kwargs, qdb_exp_batch_push_fast));
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
template < //
|
|
110
|
-
qdb::concepts::writer_push_strategy PushStrategy, //
|
|
111
|
-
qdb::concepts::sleep_strategy SleepStrategy> //
|
|
112
|
-
void push_truncate(detail::writer_data const & data, py::kwargs kwargs)
|
|
113
|
-
{
|
|
114
|
-
_logger.warn("writer.push_fast() is deprecated, please invoke writer.push() directly and "
|
|
115
|
-
"provide the push mode as a kwarg");
|
|
116
|
-
|
|
117
|
-
return push<PushStrategy, SleepStrategy>(
|
|
118
|
-
data, detail::batch_push_mode::set(kwargs, qdb_exp_batch_push_truncate));
|
|
119
|
-
|
|
120
|
-
// qdb::object_tracker::scoped_capture capture{_object_tracker};
|
|
121
|
-
// auto idx = detail::staged_tables::index(data);
|
|
122
|
-
|
|
123
|
-
// // As we are actively removing data, let's add an additional check to ensure the user
|
|
124
|
-
// // doesn't accidentally truncate his whole database without inserting anything.
|
|
125
|
-
// if (data.empty()) [[unlikely]]
|
|
126
|
-
// {
|
|
127
|
-
// throw qdb::invalid_argument_exception{
|
|
128
|
-
// "Writer is empty: you did not provide any rows to push."};
|
|
129
|
-
// }
|
|
130
|
-
|
|
131
|
-
// qdb_ts_range_t tr;
|
|
132
|
-
|
|
133
|
-
// if (kwargs.contains("range"))
|
|
134
|
-
// {
|
|
135
|
-
// tr = convert::value<py::tuple, qdb_ts_range_t>(py::cast<py::tuple>(kwargs["range"]));
|
|
136
|
-
// }
|
|
137
|
-
// else
|
|
138
|
-
// {
|
|
139
|
-
// // TODO(leon): support multiple tables for push truncate
|
|
140
|
-
// if (idx.size() != 1) [[unlikely]]
|
|
141
|
-
// {
|
|
142
|
-
// throw qdb::invalid_argument_exception{"Writer push truncate only supports a single "
|
|
143
|
-
// "table unless an explicit range is provided:
|
|
144
|
-
// you " "provided more than one table without" "
|
|
145
|
-
// an explicit range."};
|
|
146
|
-
// }
|
|
147
|
-
|
|
148
|
-
// detail::staged_table const & staged_table = idx.first();
|
|
149
|
-
// tr = staged_table.time_range();
|
|
150
|
-
// }
|
|
151
|
-
|
|
152
|
-
// const qdb_exp_batch_options_t options = {
|
|
153
|
-
// .mode = qdb_exp_batch_push_truncate, //
|
|
154
|
-
// .push_flags = detail::batch_push_flags::from_kwargs(kwargs) //
|
|
155
|
-
// };
|
|
156
|
-
|
|
157
|
-
// _push_impl<PushStrategy, SleepStrategy>( //
|
|
158
|
-
// std::move(idx), //
|
|
159
|
-
// options, //
|
|
160
|
-
// kwargs, //
|
|
161
|
-
// &tr //
|
|
162
|
-
// ); //
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
private:
|
|
166
|
-
template < //
|
|
167
|
-
concepts::writer_push_strategy PushStrategy, //
|
|
168
|
-
concepts::sleep_strategy SleepStrategy> //
|
|
169
|
-
void _push_impl( //
|
|
170
|
-
detail::staged_tables && idx, //
|
|
171
|
-
py::kwargs kwargs) //
|
|
172
|
-
{
|
|
173
|
-
_handle->check_open();
|
|
174
|
-
|
|
175
|
-
// Ensure some default variables that are set
|
|
176
|
-
kwargs = detail::batch_push_flags::ensure(kwargs);
|
|
177
|
-
|
|
178
|
-
std::vector<qdb_ts_range_t> truncate_ranges{};
|
|
179
|
-
|
|
180
|
-
if (detail::batch_push_mode::from_kwargs(kwargs) == qdb_exp_batch_push_truncate)
|
|
181
|
-
[[unlikely]] // Unlikely because truncate isn't used much
|
|
182
|
-
{
|
|
183
|
-
kwargs = detail::batch_truncate_ranges::ensure(kwargs, idx);
|
|
184
|
-
truncate_ranges = detail::batch_truncate_ranges::from_kwargs(kwargs);
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
qdb_exp_batch_options_t options = detail::batch_options::from_kwargs(kwargs);
|
|
188
|
-
|
|
189
|
-
if (idx.empty()) [[unlikely]]
|
|
190
|
-
{
|
|
191
|
-
throw qdb::invalid_argument_exception{"No data written to batch writer."};
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
auto deduplicate_options = detail::deduplicate_options::from_kwargs(kwargs);
|
|
195
|
-
|
|
196
|
-
std::vector<qdb_exp_batch_push_table_t> batch;
|
|
197
|
-
batch.assign(idx.size(), qdb_exp_batch_push_table_t());
|
|
198
|
-
|
|
199
|
-
qdb_ts_range_t * truncate_ranges_{nullptr};
|
|
200
|
-
if (truncate_ranges.empty() == false) [[unlikely]]
|
|
201
|
-
{
|
|
202
|
-
truncate_ranges_ = truncate_ranges.data();
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
int cur = 0;
|
|
206
|
-
|
|
207
|
-
for (auto pos = idx.begin(); pos != idx.end(); ++pos)
|
|
208
|
-
{
|
|
209
|
-
std::string const & table_name = pos->first;
|
|
210
|
-
detail::staged_table & staged_table = pos->second;
|
|
211
|
-
auto & batch_table = batch.at(cur++);
|
|
212
|
-
|
|
213
|
-
staged_table.prepare_batch( //
|
|
214
|
-
options.mode, //
|
|
215
|
-
deduplicate_options, //
|
|
216
|
-
truncate_ranges_, //
|
|
217
|
-
batch_table);
|
|
218
|
-
|
|
219
|
-
if (batch_table.data.column_count == 0) [[unlikely]]
|
|
220
|
-
{
|
|
221
|
-
throw qdb::invalid_argument_exception{
|
|
222
|
-
"Writer is empty: you did not provide any columns to push."};
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
_logger.debug("Pushing %d rows with %d columns in %s", batch_table.data.row_count,
|
|
226
|
-
batch_table.data.column_count, table_name);
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
_do_push<PushStrategy, SleepStrategy>( //
|
|
230
|
-
options, //
|
|
231
|
-
batch, //
|
|
232
|
-
PushStrategy::from_kwargs(kwargs), //
|
|
233
|
-
detail::retry_options::from_kwargs(kwargs) //
|
|
234
|
-
); //
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
template < //
|
|
238
|
-
concepts::writer_push_strategy PushStrategy, //
|
|
239
|
-
concepts::sleep_strategy SleepStrategy> //
|
|
240
|
-
void _do_push(qdb_exp_batch_options_t const & options,
|
|
241
|
-
std::vector<qdb_exp_batch_push_table_t> const & batch,
|
|
242
|
-
PushStrategy push_strategy,
|
|
243
|
-
detail::retry_options const & retry_options)
|
|
244
|
-
{
|
|
245
|
-
qdb_error_t err{qdb_e_ok};
|
|
246
|
-
|
|
247
|
-
{
|
|
248
|
-
// Make sure to measure the time it takes to do the actual push.
|
|
249
|
-
// This is in its own scoped block so that we only actually measure
|
|
250
|
-
// the push time, not e.g. retry time.
|
|
251
|
-
qdb::metrics::scoped_capture capture{"qdb_batch_push"};
|
|
252
|
-
|
|
253
|
-
err = push_strategy( //
|
|
254
|
-
*_handle, //
|
|
255
|
-
&options, //
|
|
256
|
-
batch.data(), //
|
|
257
|
-
nullptr, //
|
|
258
|
-
batch.size()); //
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
if (retry_options.should_retry(err))
|
|
262
|
-
[[unlikely]] // Unlikely, because err is most likely to be qdb_e_ok
|
|
263
|
-
{
|
|
264
|
-
if (err == qdb_e_async_pipe_full) [[likely]]
|
|
265
|
-
{
|
|
266
|
-
_logger.info("Async pipelines are currently full");
|
|
267
|
-
}
|
|
268
|
-
else
|
|
269
|
-
{
|
|
270
|
-
_logger.warn("A temporary error occurred");
|
|
271
|
-
}
|
|
272
|
-
|
|
273
|
-
std::chrono::milliseconds delay = retry_options.delay;
|
|
274
|
-
_logger.info("Sleeping for %d milliseconds", delay.count());
|
|
275
|
-
|
|
276
|
-
SleepStrategy::sleep(delay);
|
|
277
|
-
|
|
278
|
-
// Now try again -- easier way to go about this is to enter recursion. Note how
|
|
279
|
-
// we permutate the retry_options, which automatically adjusts the amount of retries
|
|
280
|
-
// left and the next sleep duration.
|
|
281
|
-
_logger.warn("Retrying push operation, retries left: %d", retry_options.retries_left);
|
|
282
|
-
return _do_push<PushStrategy, SleepStrategy>(
|
|
283
|
-
options, batch, push_strategy, retry_options.next());
|
|
284
|
-
}
|
|
285
|
-
|
|
286
|
-
qdb::qdb_throw_if_error(*_handle, err);
|
|
287
|
-
}
|
|
288
|
-
|
|
289
|
-
private:
|
|
290
|
-
qdb::logger _logger;
|
|
291
|
-
qdb::handle_ptr _handle;
|
|
292
|
-
|
|
293
|
-
qdb::object_tracker::scoped_repository _object_tracker;
|
|
294
|
-
|
|
295
|
-
public:
|
|
296
|
-
// the 'legacy' API needs some state attached to the pinned writer; monkey patching
|
|
297
|
-
// the pinned writer purely in python for this is possible, but annoying to do right;
|
|
298
|
-
// it's much easier to just have it live here (for now), until the batch writer is
|
|
299
|
-
// fully deprecated.
|
|
300
|
-
py::dict legacy_state_;
|
|
301
|
-
};
|
|
302
|
-
|
|
303
|
-
// don't use shared_ptr, let Python do the reference counting, otherwise you will have an undefined
|
|
304
|
-
// behavior
|
|
305
|
-
using writer_ptr = std::unique_ptr<writer>;
|
|
306
|
-
|
|
307
|
-
template < //
|
|
308
|
-
qdb::concepts::writer_push_strategy PushStrategy, //
|
|
309
|
-
qdb::concepts::sleep_strategy SleepStrategy> //
|
|
310
|
-
static void register_writer(py::module_ & m)
|
|
311
|
-
{
|
|
312
|
-
using PS = PushStrategy;
|
|
313
|
-
using SS = SleepStrategy;
|
|
314
|
-
|
|
315
|
-
namespace py = pybind11;
|
|
316
|
-
|
|
317
|
-
// Writer data
|
|
318
|
-
auto writer_data_c = py::class_<qdb::detail::writer_data>{m, "WriterData"};
|
|
319
|
-
writer_data_c.def(py::init())
|
|
320
|
-
.def("append", &qdb::detail::writer_data::append, py::arg("table"), py::arg("index"),
|
|
321
|
-
py::arg("column_data"), "Append new data")
|
|
322
|
-
.def("empty", &qdb::detail::writer_data::empty, "Returns true if underlying data is empty");
|
|
323
|
-
|
|
324
|
-
// Different push modes, makes it easy to convert to<>from native types, as we accept the push
|
|
325
|
-
// mode as a kwarg.
|
|
326
|
-
py::enum_<qdb_exp_batch_push_mode_t>{m, "WriterPushMode", py::arithmetic(), "Push Mode"} //
|
|
327
|
-
.value("Transactional", qdb_exp_batch_push_transactional) //
|
|
328
|
-
.value("Fast", qdb_exp_batch_push_fast) //
|
|
329
|
-
.value("Truncate", qdb_exp_batch_push_truncate) //
|
|
330
|
-
.value("Async", qdb_exp_batch_push_fast); //
|
|
331
|
-
|
|
332
|
-
// And the actual pinned writer
|
|
333
|
-
auto writer_c = py::class_<qdb::writer>{m, "Writer"};
|
|
334
|
-
|
|
335
|
-
// basic interface
|
|
336
|
-
writer_c.def(py::init<qdb::handle_ptr>()); //
|
|
337
|
-
|
|
338
|
-
writer_c.def_readwrite("_legacy_state", &qdb::writer::legacy_state_);
|
|
339
|
-
|
|
340
|
-
// push functions
|
|
341
|
-
writer_c
|
|
342
|
-
.def("push", &qdb::writer::push<PS, SS>, "Regular batch push") //
|
|
343
|
-
.def("push_async", &qdb::writer::push_async<PS, SS>,
|
|
344
|
-
"Asynchronous batch push that buffers data inside the QuasarDB daemon") //
|
|
345
|
-
.def("push_fast", &qdb::writer::push_fast<PS, SS>,
|
|
346
|
-
"Fast, in-place batch push that is efficient when doing lots of small, incremental "
|
|
347
|
-
"pushes.") //
|
|
348
|
-
.def("push_truncate", &qdb::writer::push_truncate<PS, SS>,
|
|
349
|
-
"Before inserting data, truncates any existing data. This is useful when you want your "
|
|
350
|
-
"insertions to be idempotent, e.g. in "
|
|
351
|
-
"case of a retry.");
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
} // namespace qdb
|
|
@@ -1,124 +0,0 @@
|
|
|
1
|
-
quasardb/CMakeLists.txt,sha256=I7mgv_65OInJ3mgMDHpkt8LEZXRafy0UuteZC1piTNw,15645
|
|
2
|
-
quasardb/INSTALL.vcxproj,sha256=eOm3S4Jaiu5K3XLMPnLeYfWk9rw3pj0Q-wA0F8xU_O4,10833
|
|
3
|
-
quasardb/INSTALL.vcxproj.filters,sha256=Zi6Rf6BuzpXIana9k87Eha4xNbqM5Scj8SMuy1cBI7k,564
|
|
4
|
-
quasardb/__init__.py,sha256=20wagayMPRncEbfEbAu0y8sbMRKj-Lyc_0LB8dMdysM,4670
|
|
5
|
-
quasardb/batch_column.hpp,sha256=RrFVpLVrzSLmmqy6FTNyilwRpOz8vhpAEDobnRGP-vo,3388
|
|
6
|
-
quasardb/batch_inserter.hpp,sha256=qoxVvfpEL4UmOpvFAC2kVWLyhuJ311nXAbQnThu2Rhg,9803
|
|
7
|
-
quasardb/blob.hpp,sha256=kHt1UTVkaZkyHBiqJ28bGzqKFn0f5PA-XyDKfgY1_Rs,5846
|
|
8
|
-
quasardb/cluster.cpp,sha256=XqQZDNsvDgM5zXwMm4i_92SGBsdRJhKRqVksJYWQ7RM,2824
|
|
9
|
-
quasardb/cluster.hpp,sha256=n1rHGPHzAE3Q7pWwSyER0iCQjenjhM_6fM4sefAqFAM,21183
|
|
10
|
-
quasardb/cmake_install.cmake,sha256=xWyEkkQzuazTRxgmMiJa6JJ3UtWPMsU8oNIwF96u3WY,1500
|
|
11
|
-
quasardb/concepts.hpp,sha256=qpG1Y72n4kJSWo5FBBDWOoAgLuRbRkiacSOLOiSH1hE,11333
|
|
12
|
-
quasardb/continuous.cpp,sha256=1v8dq8w0CsiVUh_5QYk8pnNap7zzaa38W62lS4D_6AY,6437
|
|
13
|
-
quasardb/continuous.hpp,sha256=_kQuhA_9f0luIESW5rBzjtTgByICjg_lruXICyrePjs,4355
|
|
14
|
-
quasardb/convert.hpp,sha256=hOvbpYuop0_FDaBpot38Ey7X5NhXRV9OFqRcom_hMsI,1830
|
|
15
|
-
quasardb/direct_blob.hpp,sha256=8ISBiRG1uIxb5xkEkp4FKSIgMgdpnPYDWQjbLjN2vYM,3917
|
|
16
|
-
quasardb/direct_handle.hpp,sha256=OYRI3VsCoHyQCWLE-yogDq59hhVhoLSD4ZMGgEgVptw,2782
|
|
17
|
-
quasardb/direct_integer.hpp,sha256=b-T56JjsHFn4VxRZ6Bmp4uE1-Wc-bPO_erKSZPW3r3w,3333
|
|
18
|
-
quasardb/dispatch.hpp,sha256=YWqTq9ehXWpphJ9piWwrKUzy3IgA5d9An0loAYQsUlg,5508
|
|
19
|
-
quasardb/double.hpp,sha256=vQkhqX5gal-PK8XAzTx4KJnoWt4xbCK4ivMgidUsJ4Q,3239
|
|
20
|
-
quasardb/entry.hpp,sha256=thYPRN6uFe1yfJyf7-5Gk1M8O6oJGjTipqNetbo1-I0,9451
|
|
21
|
-
quasardb/error.hpp,sha256=JvmysvbRvfrpULgRCUdYHm_NH5cXuK7apgEensS_yio,13327
|
|
22
|
-
quasardb/firehose.py,sha256=DHYsew-aL1j5PKZonH30CrhXnwHEX1XIAhGbPrzd4PY,3593
|
|
23
|
-
quasardb/handle.cpp,sha256=oyhzAj1k8UFhpLhwU5RL4cbdqt82KZexWacMFz5uXA0,536
|
|
24
|
-
quasardb/handle.hpp,sha256=eXBx7TwCyfGKRS3XDKvnF9kwmqcqb89ZJ8_riTmM75c,3051
|
|
25
|
-
quasardb/integer.hpp,sha256=fAS8JOm_vJooVIv9kZ71fwV2rxFCnYuCLdkZRleb_lY,3304
|
|
26
|
-
quasardb/logger.cpp,sha256=UThEO2V6UI-tbpG9suud7olmMjIMfHr3tNt-nM48DIE,3056
|
|
27
|
-
quasardb/logger.hpp,sha256=Cf6bcK3Mpu_INsZ8R621BRSNLZ8FQSYDZdmhyfcC0v4,7278
|
|
28
|
-
quasardb/masked_array.hpp,sha256=JZFGdN-4VlZWZS6jq7TR6Rigcejl6sF3o_zKFNWAAeo,19229
|
|
29
|
-
quasardb/metrics.cpp,sha256=NuEBVYlIHQRgmPy4g9Eosq1Q28Z1jySSZHKDAMLURIA,2942
|
|
30
|
-
quasardb/metrics.hpp,sha256=xcotK6Jer53joky9gZHos0i_nhVB4GEjZ9F7lwq7iuc,3533
|
|
31
|
-
quasardb/module.cpp,sha256=t4VrelZCR25Kr0p4aucWVMqmoqN477d3XeUh_DNlA08,2761
|
|
32
|
-
quasardb/module.hpp,sha256=-zRcQ_lgVz4IEP3tokX4AeA33DYJ3jsq8vWX6OnE0Ic,604
|
|
33
|
-
quasardb/node.hpp,sha256=Wj3weOriUieQvIX6wSH5TijXVyCKz5VhkyV1UA1IJOQ,5120
|
|
34
|
-
quasardb/numpy.cpp,sha256=0brRs6lnIpsCNvpu3twIcjizy3lMOvCBT0O4rjKAn0I,189
|
|
35
|
-
quasardb/numpy.hpp,sha256=CBmKbI2TdoxNYcJnfQAUwBfbKq1Enf3pISyv1pfUgFE,15668
|
|
36
|
-
quasardb/object_tracker.hpp,sha256=vNfYAqNIoTbRI_Re9J_uKPq5E6rZIR3xfGuS7HMNt44,7646
|
|
37
|
-
quasardb/options.hpp,sha256=Fw-exfIMEHBVpN6LbrTD21xBekSyfCwkn_hR-ztuet4,11160
|
|
38
|
-
quasardb/perf.hpp,sha256=XZx6CJGwAqFBJhNQVtyEY72R3devrcFXEXrI2rVesow,11364
|
|
39
|
-
quasardb/pool.py,sha256=lqVZPFejmNHU7EdyeoPkl7yy_-N3BRyuLhNTzIdtg8g,8743
|
|
40
|
-
quasardb/properties.cpp,sha256=TT9xLvt7IukD59afRmotCp7sGEJnATRd6JbNWiYaKXY,985
|
|
41
|
-
quasardb/properties.hpp,sha256=krmoLE4a0EfzayCWr3_Dr72ZEVEQxo4OzvsxgzwYBjc,2843
|
|
42
|
-
quasardb/pytypes.hpp,sha256=wQKTfIk1xdUt1xkq8oi-LNpYzF4RKAx0LjY9WjD2nu0,6894
|
|
43
|
-
quasardb/qdb_api.dll,sha256=jmTsFjV0aAT-hrOt0WNqa7lqmHW80Fv5S-0bFvLqp-E,18250240
|
|
44
|
-
quasardb/quasardb.cp39-win_amd64.pyd,sha256=Ebegjgak1Y3dDserrbpwZW5NcGNuq1LEvF8oh0hEtu0,1284608
|
|
45
|
-
quasardb/query.cpp,sha256=IWU7oQLIvdI4tydmwlc_3zNhng4OdKXBNcO0qtqa1Dg,12752
|
|
46
|
-
quasardb/query.hpp,sha256=lb-NXbLD-L1f4XYDQ67WlthaMrzg0miLFw-nEQCnlUk,3357
|
|
47
|
-
quasardb/reader.cpp,sha256=OjCK0gSGw2O0HK5pc1GXg4zWGn-5IXDMwvOT1EYchZo,11044
|
|
48
|
-
quasardb/reader.hpp,sha256=Qv_8_dFC14u5RQieW-14HMHjXoAt-gLda40j1_vrniA,8350
|
|
49
|
-
quasardb/remove_cvref.hpp,sha256=vKUecNoA2-BIiZeP8NuO3GgBOMF-OVSn_43LJCuDozA,611
|
|
50
|
-
quasardb/stats.py,sha256=LDV4F5KTpEXa5sS_syFo_TYn9_W2X1D32Eb43GLutOs,7620
|
|
51
|
-
quasardb/string.hpp,sha256=UV7rgEstnf-atcEsbq6I7iqN-E_h_5njE6g9kf7_H70,6071
|
|
52
|
-
quasardb/table.cpp,sha256=zFU5yEga7GKWAJw0vo3nNU_U_cvAbLufTjPwKNvFdE0,9490
|
|
53
|
-
quasardb/table.hpp,sha256=C0HHuqVuU76leruCUdm1DgTdVR3ixY3hFABffO784XU,14798
|
|
54
|
-
quasardb/table_cache.py,sha256=t7FFQkms7pFlYDkOhCcLnLS8bWglZjlzX3Qs6gyBG6Q,1559
|
|
55
|
-
quasardb/tag.hpp,sha256=nKGYkK1djTGHhFWCrYlQTWttb0TVJiTlrvcIbvuuZ3U,2732
|
|
56
|
-
quasardb/timestamp.hpp,sha256=fjGl0B4Sv_xhU6UWrhZzOfin7atlPqawKN-Bu1oiR6M,3889
|
|
57
|
-
quasardb/traits.hpp,sha256=FNAR2rAMlk2S_jxmfXwRusGVmHuyDltqiTO1vxYMzfU,16881
|
|
58
|
-
quasardb/ts_iterator.hpp,sha256=faP1HVGYbWubKr98yhkS6gqvyMiKWkl3tgedJfj2u1E,4395
|
|
59
|
-
quasardb/utils.cpp,sha256=PkuVxrj1cQfeVujA-kefx9-P0B6IJNtYDQzedCAMjKY,634
|
|
60
|
-
quasardb/utils.hpp,sha256=C5qxTYYN3-rzO01T_K23VEvhFsv2sJPK96SB_BJ2vZQ,4724
|
|
61
|
-
quasardb/writer.hpp,sha256=a9utSovwg83VNxM4WLddE5G1N16snyRMxleqrWTtkvg,14898
|
|
62
|
-
quasardb/CMakeFiles/generate.stamp,sha256=MC9-mgyGPAS3QAZa3gHSQ8dYfXJy_Hn7AChwEoqVWOs,55
|
|
63
|
-
quasardb/CMakeFiles/generate.stamp.depend,sha256=uY8FV-ceJ2Kk-6JfOnsIesDV7jKoUNfkKHNY2Nf7_E8,117
|
|
64
|
-
quasardb/convert/array.hpp,sha256=NtqEyx8a_Phc8VEu4nBqNt4UQ1C0TNTXylPxMHxEXSo,9532
|
|
65
|
-
quasardb/convert/point.hpp,sha256=0WYxllERnzX9O5vIeflHG1y7KHo1SsyWjkZCi05GXO4,11800
|
|
66
|
-
quasardb/convert/range.hpp,sha256=Z0skhVzQ8JSRL2RPOwqVXE8AV3kxPHw3amGcNZXQatI,11176
|
|
67
|
-
quasardb/convert/unicode.hpp,sha256=eW3OwKMnFrOJ9ftUzA6MeVH5nZMuT3q9vuDzxn97pSQ,15600
|
|
68
|
-
quasardb/convert/util.hpp,sha256=Ldie5abmB4H_OFvykp0twzwAzOw_hyaUr85Ob3Qr-ko,582
|
|
69
|
-
quasardb/convert/value.hpp,sha256=Zf79FDUirneSiMZbjUX2H66sITsGaO0zRF71jWC06XE,25340
|
|
70
|
-
quasardb/date/ALL_BUILD.vcxproj,sha256=uv91Hp757kNYRUQgYhNgROx9MLVZlIyCpiVybVUmul4,13228
|
|
71
|
-
quasardb/date/ALL_BUILD.vcxproj.filters,sha256=lTQk5MABpmIlZcZqriqmw7SlGUJKSM2xH8HnaKmgC5E,304
|
|
72
|
-
quasardb/date/INSTALL.vcxproj,sha256=B_uphlgUQz0DrGNomrcO0Q_gX_qjEdgJGx_aF6suf_M,10858
|
|
73
|
-
quasardb/date/INSTALL.vcxproj.filters,sha256=yKSAXzpNMfiySNU6-yMIZnPFqqA2d9bVT2yDKATYREs,564
|
|
74
|
-
quasardb/date/cmake_install.cmake,sha256=qrx_9oyd4dWQEZGR1UcwIlIwkzPfO2SMvbZ58prDqn0,3015
|
|
75
|
-
quasardb/date/date.sln,sha256=VxVNaOvts8xHoPDp9y4H6Qdf5cLjr0kVlbpEKDNs87I,3660
|
|
76
|
-
quasardb/date/dateConfigVersion.cmake,sha256=54LqYG6K3Si4Oq1UDH_bHTMzdr6c3KWFXpO0LdeO0zM,2827
|
|
77
|
-
quasardb/date/dateTargets.cmake,sha256=1t0xJ0SwcorkUjXIxBqpcO17sqbxH9dBshPDq9FRnEo,2842
|
|
78
|
-
quasardb/date/CMakeFiles/generate.stamp,sha256=MC9-mgyGPAS3QAZa3gHSQ8dYfXJy_Hn7AChwEoqVWOs,55
|
|
79
|
-
quasardb/date/CMakeFiles/generate.stamp.depend,sha256=eBon_pyXjQBtlkyebk9vymCTensUa7VkeitkWKofgbA,450
|
|
80
|
-
quasardb/date/CMakeFiles/Export/df49adab93b9e0c10c64f72458b31971/dateTargets.cmake,sha256=f8QV6e3TyVcIbdxKC33m0T0Y4CT4r_aXALcM83hIbrU,4189
|
|
81
|
-
quasardb/detail/invoke.hpp,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
82
|
-
quasardb/detail/qdb_resource.hpp,sha256=QaVzlgBZR04meF7iKPvwXCv46I98QlvvPdJ3CoDFM34,3319
|
|
83
|
-
quasardb/detail/retry.cpp,sha256=94_MFVfsh3yVxXkOF0GRFUUl5X8qk-Ae7vezht5dPOQ,1648
|
|
84
|
-
quasardb/detail/retry.hpp,sha256=kn9Sqq_qnND3WBWTRT3EVc1iKH984c3nmebUT9upoyM,5020
|
|
85
|
-
quasardb/detail/sleep.hpp,sha256=84G-9PWKfigveq7TfOdLbYZ_OBTfgVWLHQSIYMkygSY,2179
|
|
86
|
-
quasardb/detail/ts_column.hpp,sha256=pjmNWx6GVdtWRGrYrG0DotL9NccoQN10rGIcxanxo10,7555
|
|
87
|
-
quasardb/detail/writer.cpp,sha256=_8g9NRS9lhrBz0x0yBVtLtFGxTbXjhWT1JT2FiCXspI,15629
|
|
88
|
-
quasardb/detail/writer.hpp,sha256=T5oRdPtFa9iaItZqBGfQaWdBLK_tYzsxQGiD1WTSglk,17416
|
|
89
|
-
quasardb/extensions/__init__.py,sha256=zvMxXV_zuRSbNrkjsu-qFSEiZahdHmC0lhMqMVRzY_8,120
|
|
90
|
-
quasardb/extensions/writer.py,sha256=LcGhgr_jrHEDukVukLN1eGKCU0egeZkcCOenFEhZi3A,5928
|
|
91
|
-
quasardb/numpy/__init__.py,sha256=SKBNEXyVQNmiZCtg0rlsnpEwvUYKGhvjshPnyByNCbs,30951
|
|
92
|
-
quasardb/pandas/__init__.py,sha256=vU41-kF5Uiw45swfrjTVqoceDjgFFXG406UVfRQhd6E,15392
|
|
93
|
-
quasardb/pybind11/ALL_BUILD.vcxproj,sha256=M4GXlNOJFLBX8mJIOMe-IdxAW0qAJNUGPigTQxsTpIE,17668
|
|
94
|
-
quasardb/pybind11/ALL_BUILD.vcxproj.filters,sha256=WjgQPMVZN7jEaUOdw8Ha03hPfNxybvx_F2wOck10Kqo,308
|
|
95
|
-
quasardb/pybind11/INSTALL.vcxproj,sha256=j7JcriKVhEziyysG8XUBkIc46shueAY2KZUdl5KcKHw,10878
|
|
96
|
-
quasardb/pybind11/INSTALL.vcxproj.filters,sha256=mfFvyQS9NO7zM-cc3hBwqncqVjbXwHYPwTlqg4eYFsY,564
|
|
97
|
-
quasardb/pybind11/cmake_install.cmake,sha256=k8w7rY8hohkJE0J7y-mDFWP0y-IxQmNtYMU3-OVf4_I,1060
|
|
98
|
-
quasardb/pybind11/pybind11.sln,sha256=flEUYLO_2fPc1nMm_R2g8uqOFp7lGooQe-3MMpV6Aj8,3660
|
|
99
|
-
quasardb/pybind11/CMakeFiles/generate.stamp,sha256=MC9-mgyGPAS3QAZa3gHSQ8dYfXJy_Hn7AChwEoqVWOs,55
|
|
100
|
-
quasardb/pybind11/CMakeFiles/generate.stamp.depend,sha256=Iu96pwAzkgGpm3sTemJm2e2SAkYYT4f0VuwAqYabrCE,1565
|
|
101
|
-
quasardb/range-v3/ALL_BUILD.vcxproj,sha256=sSpD6lu2mmlMXobhg6L2UB_ivPgJn5vgz3KLLX_GOyk,16808
|
|
102
|
-
quasardb/range-v3/ALL_BUILD.vcxproj.filters,sha256=c0k-3qrBreLvjffsj9pJo50YOMqfDYnxLpBqvV1nI00,308
|
|
103
|
-
quasardb/range-v3/INSTALL.vcxproj,sha256=AVLBE-CYjgW9Hji_jkYODuz6FHkHBeCVsIZdrlRz_fU,10878
|
|
104
|
-
quasardb/range-v3/INSTALL.vcxproj.filters,sha256=2g4qJaR2DslilbfotApvpA3o1pWHN5ioYD6NhTshT4s,564
|
|
105
|
-
quasardb/range-v3/Range-v3.sln,sha256=jPWqGPa8SYDl1bGICA9KKIElbt85mcUxNflIj8-89d4,4506
|
|
106
|
-
quasardb/range-v3/cmake_install.cmake,sha256=GNKXfbyBtYoQAuTx7G1rohxh5v-fWej2QPyCdeGnj_k,6645
|
|
107
|
-
quasardb/range-v3/range-v3-config-version.cmake,sha256=57XQ96x5Ec1VvRfoIPND_DSMJ9ZbHUqa8iZEiS0YMvw,3332
|
|
108
|
-
quasardb/range-v3/range-v3-config.cmake,sha256=wFolzAbcw4vJS2746FsN5yQq9O4j35vq66OoRseaY-Q,3458
|
|
109
|
-
quasardb/range-v3/range.v3.headers.vcxproj,sha256=KjCpd68N4LeyxWwAVwZD7mb9musUu47KX3BOFujIEH0,56490
|
|
110
|
-
quasardb/range-v3/range.v3.headers.vcxproj.filters,sha256=vYhhNBSHSlTGEC15Fen1-GkwDnxbZwAHhdcgF5v4gNo,51825
|
|
111
|
-
quasardb/range-v3/CMakeFiles/generate.stamp,sha256=MC9-mgyGPAS3QAZa3gHSQ8dYfXJy_Hn7AChwEoqVWOs,55
|
|
112
|
-
quasardb/range-v3/CMakeFiles/generate.stamp.depend,sha256=RgLxGCugXajlClUb7ZjxkzkNdI8sDsOrfB0tnkZDvoE,1348
|
|
113
|
-
quasardb/range-v3/CMakeFiles/Export/d94ef200eca10a819b5858b33e808f5b/range-v3-targets.cmake,sha256=1s2G11_vLG2bI_U9FOKC7L2ZnyLBk2Jkv8_-_NlGHSs,5393
|
|
114
|
-
quasardb/range-v3/include/range/v3/version.hpp,sha256=jy6iEzXjaavicAw1VSIfvpS7Wu9IoEY51Q5N9m4eaB8,610
|
|
115
|
-
quasardb/utils/blob_deque.hpp,sha256=YLp0eG1fSQXIFo46rZ8YIeTSNRJSdmmtdhC2z-qMa08,2540
|
|
116
|
-
quasardb/utils/ostream.hpp,sha256=KYFwqXuZoxuZblHUM-z5xrd74P2Y5zWJqVpaQ9oedAo,390
|
|
117
|
-
quasardb/utils/permutation.hpp,sha256=BwJzgZmpS4G-oS7249GvnUFj_cmqSAbF2Fzb8wuihLo,1552
|
|
118
|
-
quasardb/utils/stable_sort.hpp,sha256=luIK9T76mT0NyDxpLxXjTt1eSSKEOY29jRANJNysJCo,489
|
|
119
|
-
quasardb/utils/unzip_view.hpp,sha256=nn6BSAI_cGsKgBh8WXhAUJ6Zzn3N0AnhtE6ePmhPeQM,2476
|
|
120
|
-
quasardb-3.14.2.dev3.dist-info/LICENSE.md,sha256=0iT1ltzDof6cJr8mSX2PVOGhKjISfCrOYzJg7rG2pOs,1477
|
|
121
|
-
quasardb-3.14.2.dev3.dist-info/METADATA,sha256=PM1RJWVqK0ZXj-XXTlIZ7gYm01RLCuHpJCR7fmcN6uk,1453
|
|
122
|
-
quasardb-3.14.2.dev3.dist-info/WHEEL,sha256=YorN2HPccIdfJm1vtDZTOGjQ579sMRaAowQ3R-HpNAE,100
|
|
123
|
-
quasardb-3.14.2.dev3.dist-info/top_level.txt,sha256=wlprix4hCywuF1PkgKWYdZeJKq_kgJOqkAvukm_sZQ8,9
|
|
124
|
-
quasardb-3.14.2.dev3.dist-info/RECORD,,
|
|
File without changes
|
|
File without changes
|