quasardb 3.14.2.dev3__cp39-cp39-win32.whl → 3.14.2.dev5__cp39-cp39-win32.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-win32.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/stats.py
CHANGED
|
@@ -3,12 +3,12 @@ import quasardb
|
|
|
3
3
|
import logging
|
|
4
4
|
from datetime import datetime
|
|
5
5
|
|
|
6
|
-
logger = logging.getLogger(
|
|
6
|
+
logger = logging.getLogger("quasardb.stats")
|
|
7
7
|
|
|
8
8
|
|
|
9
|
-
stats_prefix =
|
|
10
|
-
user_pattern = re.compile(r
|
|
11
|
-
total_pattern = re.compile(r
|
|
9
|
+
stats_prefix = "$qdb.statistics."
|
|
10
|
+
user_pattern = re.compile(r"\$qdb.statistics.(.*).uid_([0-9]+)$")
|
|
11
|
+
total_pattern = re.compile(r"\$qdb.statistics.(.*)$")
|
|
12
12
|
|
|
13
13
|
|
|
14
14
|
def is_user_stat(s):
|
|
@@ -50,92 +50,90 @@ def of_node(dconn):
|
|
|
50
50
|
"""
|
|
51
51
|
|
|
52
52
|
start = datetime.now()
|
|
53
|
-
raw = {
|
|
54
|
-
k: _get_stat(dconn,k) for k in dconn.prefix_get(stats_prefix, 1000)}
|
|
53
|
+
raw = {k: _get_stat(dconn, k) for k in dconn.prefix_get(stats_prefix, 1000)}
|
|
55
54
|
|
|
56
|
-
ret = {
|
|
57
|
-
'cumulative': _cumulative(raw)}
|
|
55
|
+
ret = {"by_uid": _by_uid(raw), "cumulative": _cumulative(raw)}
|
|
58
56
|
|
|
59
57
|
check_duration = datetime.now() - start
|
|
60
58
|
|
|
61
|
-
ret[
|
|
62
|
-
ret[
|
|
59
|
+
ret["cumulative"]["check.online"] = 1
|
|
60
|
+
ret["cumulative"]["check.duration_ms"] = int(check_duration.total_seconds() * 1000)
|
|
63
61
|
|
|
64
62
|
return ret
|
|
65
63
|
|
|
66
|
-
_stat_types = {'node_id': ('constant', None),
|
|
67
|
-
'operating_system': ('constant', None),
|
|
68
|
-
'partitions_count': ('constant', 'count'),
|
|
69
64
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
65
|
+
_stat_types = {
|
|
66
|
+
"node_id": ("constant", None),
|
|
67
|
+
"operating_system": ("constant", None),
|
|
68
|
+
"partitions_count": ("constant", "count"),
|
|
69
|
+
"cpu.system": ("counter", "ns"),
|
|
70
|
+
"cpu.user": ("counter", "ns"),
|
|
71
|
+
"cpu.idle": ("counter", "ns"),
|
|
72
|
+
"startup": ("constant", None),
|
|
73
|
+
"startup_time": ("constant", None),
|
|
74
|
+
"shutdown_time": ("constant", None),
|
|
75
|
+
"network.current_users_count": ("gauge", "count"),
|
|
76
|
+
"hardware_concurrency": ("gauge", "count"),
|
|
77
|
+
"check.online": ("gauge", "count"),
|
|
78
|
+
"check.duration_ms": ("constant", "ms"),
|
|
79
|
+
"requests.bytes_in": ("counter", "bytes"),
|
|
80
|
+
"requests.bytes_out": ("counter", "bytes"),
|
|
81
|
+
"requests.errors_count": ("counter", "count"),
|
|
82
|
+
"requests.successes_count": ("counter", "count"),
|
|
83
|
+
"requests.total_count": ("counter", "count"),
|
|
84
|
+
"async_pipelines.merge.bucket_count": ("counter", "count"),
|
|
85
|
+
"async_pipelines.merge.duration_us": ("counter", "us"),
|
|
86
|
+
"async_pipelines.write.successes_count": ("counter", "count"),
|
|
87
|
+
"async_pipelines.write.failures_count": ("counter", "count"),
|
|
88
|
+
"async_pipelines.write.time_us": ("counter", "us"),
|
|
89
|
+
"async_pipelines.merge.max_bucket_count": ("gauge", "count"),
|
|
90
|
+
"async_pipelines.merge.max_depth_count": ("gauge", "count"),
|
|
91
|
+
"async_pipelines.merge.requests_count": ("counter", "count"),
|
|
92
|
+
"evicted.count": ("counter", "count"),
|
|
93
|
+
"pageins.count": ("counter", "count"),
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
async_pipeline_bytes_pattern = re.compile(
|
|
97
|
+
r"async_pipelines.pipe_[0-9]+.merge_map.bytes"
|
|
98
|
+
)
|
|
99
|
+
async_pipeline_count_pattern = re.compile(
|
|
100
|
+
r"async_pipelines.pipe_[0-9]+.merge_map.count"
|
|
101
|
+
)
|
|
76
102
|
|
|
77
|
-
'network.current_users_count': ('gauge', 'count'),
|
|
78
|
-
'hardware_concurrency': ('gauge', 'count'),
|
|
79
|
-
|
|
80
|
-
'check.online': ('gauge', 'count'),
|
|
81
|
-
'check.duration_ms': ('constant', 'ms'),
|
|
82
|
-
|
|
83
|
-
'requests.bytes_in': ('counter', 'bytes'),
|
|
84
|
-
'requests.bytes_out': ('counter', 'bytes'),
|
|
85
|
-
'requests.errors_count': ('counter', 'count'),
|
|
86
|
-
'requests.successes_count': ('counter', 'count'),
|
|
87
|
-
'requests.total_count': ('counter', 'count'),
|
|
88
|
-
|
|
89
|
-
'async_pipelines.merge.bucket_count': ('counter', 'count'),
|
|
90
|
-
'async_pipelines.merge.duration_us': ('counter', 'us'),
|
|
91
|
-
'async_pipelines.write.successes_count': ('counter', 'count'),
|
|
92
|
-
'async_pipelines.write.failures_count': ('counter', 'count'),
|
|
93
|
-
'async_pipelines.write.time_us': ('counter', 'us'),
|
|
94
|
-
|
|
95
|
-
'async_pipelines.merge.max_bucket_count': ('gauge', 'count'),
|
|
96
|
-
'async_pipelines.merge.max_depth_count': ('gauge', 'count'),
|
|
97
|
-
'async_pipelines.merge.requests_count': ('counter', 'count'),
|
|
98
|
-
|
|
99
|
-
'evicted.count': ('counter', 'count'),
|
|
100
|
-
'pageins.count': ('counter', 'count'),
|
|
101
|
-
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
async_pipeline_bytes_pattern = re.compile(r'async_pipelines.pipe_[0-9]+.merge_map.bytes')
|
|
105
|
-
async_pipeline_count_pattern = re.compile(r'async_pipelines.pipe_[0-9]+.merge_map.count')
|
|
106
103
|
|
|
107
104
|
def _stat_type(stat_id):
|
|
108
105
|
if stat_id in _stat_types:
|
|
109
106
|
return _stat_types[stat_id]
|
|
110
|
-
elif stat_id.endswith(
|
|
111
|
-
return (
|
|
112
|
-
elif stat_id.endswith(
|
|
113
|
-
return (
|
|
114
|
-
elif stat_id.endswith(
|
|
115
|
-
return (
|
|
116
|
-
elif stat_id.endswith(
|
|
117
|
-
return (
|
|
118
|
-
elif stat_id.endswith(
|
|
119
|
-
return (
|
|
120
|
-
elif stat_id.startswith(
|
|
121
|
-
return (
|
|
122
|
-
elif stat_id.startswith(
|
|
107
|
+
elif stat_id.endswith("total_ns"):
|
|
108
|
+
return ("counter", "ns")
|
|
109
|
+
elif stat_id.endswith("total_bytes"):
|
|
110
|
+
return ("counter", "bytes")
|
|
111
|
+
elif stat_id.endswith("read_bytes"):
|
|
112
|
+
return ("counter", "bytes")
|
|
113
|
+
elif stat_id.endswith("written_bytes"):
|
|
114
|
+
return ("counter", "bytes")
|
|
115
|
+
elif stat_id.endswith("total_count"):
|
|
116
|
+
return ("counter", "count")
|
|
117
|
+
elif stat_id.startswith("network.sessions."):
|
|
118
|
+
return ("gauge", "count")
|
|
119
|
+
elif stat_id.startswith("memory."):
|
|
123
120
|
# memory statistics are all gauges i think, describes how much memory currently allocated where
|
|
124
|
-
return (
|
|
125
|
-
elif stat_id.startswith(
|
|
121
|
+
return ("gauge", "bytes")
|
|
122
|
+
elif stat_id.startswith("persistence.") or stat_id.startswith("disk"):
|
|
126
123
|
# persistence are also all gauges, describes mostly how much is currently available/used on storage
|
|
127
|
-
return (
|
|
128
|
-
elif stat_id.startswith(
|
|
129
|
-
return (
|
|
130
|
-
elif stat_id.startswith(
|
|
131
|
-
return (
|
|
124
|
+
return ("gauge", "bytes")
|
|
125
|
+
elif stat_id.startswith("license."):
|
|
126
|
+
return ("gauge", None)
|
|
127
|
+
elif stat_id.startswith("engine_"):
|
|
128
|
+
return ("constant", None)
|
|
132
129
|
elif async_pipeline_bytes_pattern.match(stat_id):
|
|
133
|
-
return (
|
|
130
|
+
return ("gauge", "bytes")
|
|
134
131
|
elif async_pipeline_count_pattern.match(stat_id):
|
|
135
|
-
return (
|
|
132
|
+
return ("gauge", "count")
|
|
136
133
|
else:
|
|
137
134
|
return None
|
|
138
135
|
|
|
136
|
+
|
|
139
137
|
def stat_type(stat_id):
|
|
140
138
|
"""
|
|
141
139
|
Returns the statistic type by a stat id. Returns one of:
|
|
@@ -150,22 +148,27 @@ def stat_type(stat_id):
|
|
|
150
148
|
|
|
151
149
|
|
|
152
150
|
def _calculate_delta_stat(stat_id, prev, cur):
|
|
153
|
-
logger.info(
|
|
151
|
+
logger.info(
|
|
152
|
+
"calculating delta for stat_id = {}, prev = {}. cur = {}".format(
|
|
153
|
+
stat_id, prev, cur
|
|
154
|
+
)
|
|
155
|
+
)
|
|
154
156
|
|
|
155
157
|
stat_type = _stat_type(stat_id)
|
|
156
|
-
if stat_type ==
|
|
158
|
+
if stat_type == "counter":
|
|
157
159
|
return cur - prev
|
|
158
|
-
elif stat_type ==
|
|
160
|
+
elif stat_type == "gauge":
|
|
159
161
|
return cur
|
|
160
162
|
else:
|
|
161
163
|
return None
|
|
162
164
|
|
|
165
|
+
|
|
163
166
|
def _calculate_delta_stats(prev_stats, cur_stats):
|
|
164
167
|
ret = {}
|
|
165
168
|
for stat_id in cur_stats.keys():
|
|
166
169
|
try:
|
|
167
170
|
prev_stat = cur_stats[stat_id]
|
|
168
|
-
cur_stat
|
|
171
|
+
cur_stat = cur_stats[stat_id]
|
|
169
172
|
|
|
170
173
|
value = _calculate_delta_stat(stat_id, prev_stat, cur_stat)
|
|
171
174
|
if value is not None:
|
|
@@ -184,16 +187,18 @@ def calculate_delta(prev, cur):
|
|
|
184
187
|
"""
|
|
185
188
|
ret = {}
|
|
186
189
|
for node_id in cur.keys():
|
|
187
|
-
ret[node_id] = _calculate_delta_stats(
|
|
188
|
-
|
|
190
|
+
ret[node_id] = _calculate_delta_stats(
|
|
191
|
+
prev[node_id]["cumulative"], cur[node_id]["cumulative"]
|
|
192
|
+
)
|
|
189
193
|
|
|
190
194
|
return ret
|
|
191
195
|
|
|
196
|
+
|
|
192
197
|
def _clean_blob(x):
|
|
193
|
-
x_ = x.decode(
|
|
198
|
+
x_ = x.decode("utf-8", "replace")
|
|
194
199
|
|
|
195
200
|
# remove trailing zero-terminator
|
|
196
|
-
return
|
|
201
|
+
return "".join(c for c in x_ if ord(c) != 0)
|
|
197
202
|
|
|
198
203
|
|
|
199
204
|
def _get_stat(dconn, k):
|
|
@@ -201,9 +206,16 @@ def _get_stat(dconn, k):
|
|
|
201
206
|
# blob
|
|
202
207
|
try:
|
|
203
208
|
return dconn.integer(k).get()
|
|
209
|
+
|
|
210
|
+
# Older versions of qdb api returned 'alias not found'
|
|
204
211
|
except quasardb.quasardb.AliasNotFoundError:
|
|
205
212
|
return _clean_blob(dconn.blob(k).get())
|
|
206
213
|
|
|
214
|
+
# Since ~ 3.14.2, it returns 'Incompatible Type'
|
|
215
|
+
except quasardb.quasardb.IncompatibleTypeError:
|
|
216
|
+
return _clean_blob(dconn.blob(k).get())
|
|
217
|
+
|
|
218
|
+
|
|
207
219
|
def _by_uid(stats):
|
|
208
220
|
xs = {}
|
|
209
221
|
for k, v in stats.items():
|
|
@@ -214,7 +226,7 @@ def _by_uid(stats):
|
|
|
214
226
|
if uid not in xs:
|
|
215
227
|
xs[uid] = {}
|
|
216
228
|
|
|
217
|
-
if not metric.startswith(
|
|
229
|
+
if not metric.startswith("serialized"):
|
|
218
230
|
xs[uid][metric] = v
|
|
219
231
|
|
|
220
232
|
return xs
|
|
@@ -227,7 +239,7 @@ def _cumulative(stats):
|
|
|
227
239
|
matches = total_pattern.match(k)
|
|
228
240
|
if is_cumulative_stat(k) and matches:
|
|
229
241
|
metric = matches.groups()[0]
|
|
230
|
-
if not metric.startswith(
|
|
242
|
+
if not metric.startswith("serialized"):
|
|
231
243
|
xs[metric] = v
|
|
232
244
|
|
|
233
245
|
return xs
|
quasardb/table_cache.py
CHANGED
|
@@ -1,19 +1,22 @@
|
|
|
1
1
|
import logging
|
|
2
2
|
|
|
3
|
-
logger = logging.getLogger(
|
|
3
|
+
logger = logging.getLogger("quasardb.table_cache")
|
|
4
4
|
|
|
5
5
|
_cache = {}
|
|
6
6
|
|
|
7
|
+
|
|
7
8
|
def clear():
|
|
8
9
|
logger.info("Clearing table cache")
|
|
9
10
|
_cache = {}
|
|
10
11
|
|
|
12
|
+
|
|
11
13
|
def exists(table_name: str) -> bool:
|
|
12
14
|
"""
|
|
13
15
|
Returns true if table already exists in table cache.
|
|
14
16
|
"""
|
|
15
17
|
return table_name in _cache
|
|
16
18
|
|
|
19
|
+
|
|
17
20
|
def store(table, table_name=None, force_retrieve_metadata=True):
|
|
18
21
|
"""
|
|
19
22
|
Stores a table into the cache. Ensures metadata is retrieved. This is useful if you want
|
|
@@ -35,6 +38,7 @@ def store(table, table_name=None, force_retrieve_metadata=True):
|
|
|
35
38
|
|
|
36
39
|
return table
|
|
37
40
|
|
|
41
|
+
|
|
38
42
|
def lookup(table_name: str, conn, force_retrieve_metadata=True):
|
|
39
43
|
"""
|
|
40
44
|
Retrieves table from _cache if already exists. If it does not exist,
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
Metadata-Version: 2.
|
|
1
|
+
Metadata-Version: 2.2
|
|
2
2
|
Name: quasardb
|
|
3
|
-
Version: 3.14.2.
|
|
3
|
+
Version: 3.14.2.dev5
|
|
4
4
|
Summary: Python API for quasardb
|
|
5
5
|
Home-page: https://www.quasardb.net/
|
|
6
6
|
Author: quasardb SAS
|
|
@@ -27,9 +27,14 @@ License-File: LICENSE.md
|
|
|
27
27
|
Requires-Dist: numpy
|
|
28
28
|
Provides-Extra: pandas
|
|
29
29
|
Requires-Dist: pandas; extra == "pandas"
|
|
30
|
-
Provides-Extra:
|
|
31
|
-
Requires-Dist: pytest; extra == "
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
30
|
+
Provides-Extra: test
|
|
31
|
+
Requires-Dist: pytest; extra == "test"
|
|
32
|
+
Dynamic: author
|
|
33
|
+
Dynamic: author-email
|
|
34
|
+
Dynamic: classifier
|
|
35
|
+
Dynamic: home-page
|
|
36
|
+
Dynamic: keywords
|
|
37
|
+
Dynamic: license
|
|
38
|
+
Dynamic: provides-extra
|
|
39
|
+
Dynamic: requires-dist
|
|
40
|
+
Dynamic: summary
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
quasardb/INSTALL.vcxproj,sha256=WslGjNKZTC5F7cDyVKJUcgbvlZQqInmzjILAu61qBHw,11116
|
|
2
|
+
quasardb/INSTALL.vcxproj.filters,sha256=dFOKPK0DPuAandM3hgQZFIEZm7ZCcuqPRHcMLVFKyEA,560
|
|
3
|
+
quasardb/__init__.py,sha256=v8N9gkakw2bRY1Ql3P1yBJRjj0HttNkXPPv1S08Nu3I,4751
|
|
4
|
+
quasardb/cmake_install.cmake,sha256=RYywzMyeSIFfm5CpPIrsoxnWUNXkN_Psgd_taYTjSUY,1788
|
|
5
|
+
quasardb/firehose.py,sha256=thpTQktgzyY9nTk7vnxckSIZcUATgfkPrBheOLvK1SI,3453
|
|
6
|
+
quasardb/pool.py,sha256=AQfvBwavnNIqPMprqbUua4NuhVxg4FuRVqpa3Aigk9A,8779
|
|
7
|
+
quasardb/qdb_api.dll,sha256=vOnPSxDVE1OJOgciwHxukEG40uezWFAKz5dwHQivHHU,16544768
|
|
8
|
+
quasardb/quasardb.cp39-win32.pyd,sha256=qfkW1ha81jHElAmO38rOxqKjSvwPNRk-yUMkfwZob-A,1158144
|
|
9
|
+
quasardb/stats.py,sha256=WW9wDowjqhokVjg-Yf4wKhMeuOvchZlxUb4PjRVKQTg,7539
|
|
10
|
+
quasardb/table_cache.py,sha256=9XdHrWb_zpC9gikyZJhFX1qy5rMUc7o7uEPKfyZHjVY,1567
|
|
11
|
+
quasardb/CMakeFiles/generate.stamp,sha256=MC9-mgyGPAS3QAZa3gHSQ8dYfXJy_Hn7AChwEoqVWOs,55
|
|
12
|
+
quasardb/CMakeFiles/generate.stamp.depend,sha256=uY8FV-ceJ2Kk-6JfOnsIesDV7jKoUNfkKHNY2Nf7_E8,117
|
|
13
|
+
quasardb/date/ALL_BUILD.vcxproj,sha256=rdpyxZnfg8-poTfDNZ7SHo-gfVfV_1PmDQ_z0tpPJ6I,14287
|
|
14
|
+
quasardb/date/ALL_BUILD.vcxproj.filters,sha256=lTQk5MABpmIlZcZqriqmw7SlGUJKSM2xH8HnaKmgC5E,304
|
|
15
|
+
quasardb/date/INSTALL.vcxproj,sha256=W-CEoegtDWUawtyK1FfUlDoIR2VzNIu-5OxRzHaBIZI,11141
|
|
16
|
+
quasardb/date/INSTALL.vcxproj.filters,sha256=1K2cU-i9VoMqFFiWC5zwr0drgJEJuN7wSRbuhm5deu4,560
|
|
17
|
+
quasardb/date/cmake_install.cmake,sha256=dOMT0E1W7O9MA6QGToMBWBVsvH-akju-Xj_EzaHJMo8,3308
|
|
18
|
+
quasardb/date/date.sln,sha256=CZVemNcZ2KTDtuL1HoO3YEWTcY2BnqSxJWhv_2ZowuY,3752
|
|
19
|
+
quasardb/date/dateConfigVersion.cmake,sha256=gMHG49AUzfjGGWxNIwxVKqMNUhKftzyhUHHWjn3AXCY,2827
|
|
20
|
+
quasardb/date/dateTargets.cmake,sha256=FuGNruC_9fdY0b7YwlC80Kpx9H3Y5CnGXOVNRs6ePRU,2842
|
|
21
|
+
quasardb/date/CMakeFiles/generate.stamp,sha256=MC9-mgyGPAS3QAZa3gHSQ8dYfXJy_Hn7AChwEoqVWOs,55
|
|
22
|
+
quasardb/date/CMakeFiles/generate.stamp.depend,sha256=11aPCHB7lpRH6b_bDVsiKyXSI7SYKef11vbXQXT70Os,654
|
|
23
|
+
quasardb/date/CMakeFiles/Export/df49adab93b9e0c10c64f72458b31971/dateTargets.cmake,sha256=kI-gSADoA7MuLXEBcyU3_kYGNyGw6NoQ9chjo7LpEHY,4189
|
|
24
|
+
quasardb/extensions/__init__.py,sha256=zvMxXV_zuRSbNrkjsu-qFSEiZahdHmC0lhMqMVRzY_8,120
|
|
25
|
+
quasardb/extensions/writer.py,sha256=DWpm4qqBGtunIPyNuRLtUWouL_Tmr3_Zs3K5c0JtH04,5758
|
|
26
|
+
quasardb/numpy/__init__.py,sha256=YuQ2Srw2Yg5g2ROYYXrBF6ZzBjLWlCmRsc5lzSp3zRo,31543
|
|
27
|
+
quasardb/pandas/__init__.py,sha256=5zeAE4uD4uVIWggLaM3NKw5a1NhGtSV2m3eG5EGPwgU,16487
|
|
28
|
+
quasardb/pybind11/ALL_BUILD.vcxproj,sha256=Jp7ZILhE_nZOVPHM2piEYUmMWRHRaBY856Z_4M_a0XI,20767
|
|
29
|
+
quasardb/pybind11/ALL_BUILD.vcxproj.filters,sha256=WjgQPMVZN7jEaUOdw8Ha03hPfNxybvx_F2wOck10Kqo,308
|
|
30
|
+
quasardb/pybind11/INSTALL.vcxproj,sha256=RRdW1yTPS-spiLxpmPoWNA3qKpn53lZLd9HH0Ozwk1I,11161
|
|
31
|
+
quasardb/pybind11/INSTALL.vcxproj.filters,sha256=aobIBN5IR4A3jt2UwUN8UN-LoQE2FcBov-BTQ-XIHW8,560
|
|
32
|
+
quasardb/pybind11/cmake_install.cmake,sha256=nb1JEMsllscKOZ5Cx_HJirFbdXvFdCjp7HmotaPH6Z8,1369
|
|
33
|
+
quasardb/pybind11/pybind11.sln,sha256=6s2YoKqLZez6ZghXArPMrOmlJ4u2JYlke4QbPWf6Kq4,3752
|
|
34
|
+
quasardb/pybind11/CMakeFiles/generate.stamp,sha256=MC9-mgyGPAS3QAZa3gHSQ8dYfXJy_Hn7AChwEoqVWOs,55
|
|
35
|
+
quasardb/pybind11/CMakeFiles/generate.stamp.depend,sha256=tDBrq7Qv8vNzhlksUyy4jWyKRbN5tl4d_ieTFvl8QEs,2279
|
|
36
|
+
quasardb/range-v3/ALL_BUILD.vcxproj,sha256=9yP78ydd3NwmMwlVBntNGnoJB_064mow1gyC7orZAMk,19295
|
|
37
|
+
quasardb/range-v3/ALL_BUILD.vcxproj.filters,sha256=c0k-3qrBreLvjffsj9pJo50YOMqfDYnxLpBqvV1nI00,308
|
|
38
|
+
quasardb/range-v3/INSTALL.vcxproj,sha256=niv-3vWHcFWeVXnEYgUzGhujH6qQaEBNVaY919JkC0U,11161
|
|
39
|
+
quasardb/range-v3/INSTALL.vcxproj.filters,sha256=RMj6izQ1u2tFds36qpsIS_O2Yt_tg4lzBcFyddE-XrM,560
|
|
40
|
+
quasardb/range-v3/Range-v3.sln,sha256=dkQ_lzgk1kyhAhcC586abaqgEqyZkgIQTKpZM_ecJn0,4614
|
|
41
|
+
quasardb/range-v3/cmake_install.cmake,sha256=0yyPX-4r_WHW-8BLXymoHkL05QUGIpUc-oXJYiZ1VqE,6894
|
|
42
|
+
quasardb/range-v3/range-v3-config-version.cmake,sha256=57XQ96x5Ec1VvRfoIPND_DSMJ9ZbHUqa8iZEiS0YMvw,3332
|
|
43
|
+
quasardb/range-v3/range-v3-config.cmake,sha256=E7j1hj2ihfV3jYirDWkQgWZ9vjQTPUI9w2BR-qfV6qM,3458
|
|
44
|
+
quasardb/range-v3/range.v3.headers.vcxproj,sha256=rBwPzeddoGUmXtQRW0E52eDAGMqV2J7ihRClVFWtBcg,58977
|
|
45
|
+
quasardb/range-v3/range.v3.headers.vcxproj.filters,sha256=jLqAw0c5GcoJdqThj3oDekWbCWC5cIDp_5VHxtR0_pA,51825
|
|
46
|
+
quasardb/range-v3/CMakeFiles/generate.stamp,sha256=MC9-mgyGPAS3QAZa3gHSQ8dYfXJy_Hn7AChwEoqVWOs,55
|
|
47
|
+
quasardb/range-v3/CMakeFiles/generate.stamp.depend,sha256=w0AbvuzWxtj4KlrLa80jch7FU1J7Nz44AHq_UlUHi8g,1909
|
|
48
|
+
quasardb/range-v3/CMakeFiles/Export/d94ef200eca10a819b5858b33e808f5b/range-v3-targets.cmake,sha256=2WN8TJ25ES8AniYWyiS3BFiUz4RAJww7dvvnC-kE7zM,5393
|
|
49
|
+
quasardb/range-v3/include/range/v3/version.hpp,sha256=jy6iEzXjaavicAw1VSIfvpS7Wu9IoEY51Q5N9m4eaB8,610
|
|
50
|
+
quasardb-3.14.2.dev5.dist-info/LICENSE.md,sha256=0iT1ltzDof6cJr8mSX2PVOGhKjISfCrOYzJg7rG2pOs,1477
|
|
51
|
+
quasardb-3.14.2.dev5.dist-info/METADATA,sha256=W9MjerFMjq2V9Rg3mK6-uqDXKRr6VqO3WSd3Hee341A,1483
|
|
52
|
+
quasardb-3.14.2.dev5.dist-info/WHEEL,sha256=nit2jk1XD9iB81u5goYHy9pLj6BDgJHNYHDLr0P5SFs,95
|
|
53
|
+
quasardb-3.14.2.dev5.dist-info/top_level.txt,sha256=wlprix4hCywuF1PkgKWYdZeJKq_kgJOqkAvukm_sZQ8,9
|
|
54
|
+
quasardb-3.14.2.dev5.dist-info/RECORD,,
|