coinex-api 0.0.12__py3-none-any.whl → 0.0.14__py3-none-any.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.
- coinex/__init__.py +7 -0
- coinex/ccxt/__init__.py +101 -0
- coinex/ccxt/abstract/coinex.py +237 -0
- coinex/ccxt/async_support/__init__.py +80 -0
- coinex/ccxt/async_support/base/__init__.py +1 -0
- coinex/ccxt/async_support/base/exchange.py +2100 -0
- coinex/ccxt/async_support/base/throttler.py +50 -0
- coinex/ccxt/async_support/base/ws/__init__.py +38 -0
- coinex/ccxt/async_support/base/ws/aiohttp_client.py +147 -0
- coinex/ccxt/async_support/base/ws/cache.py +213 -0
- coinex/ccxt/async_support/base/ws/client.py +214 -0
- coinex/ccxt/async_support/base/ws/fast_client.py +97 -0
- coinex/ccxt/async_support/base/ws/functions.py +59 -0
- coinex/ccxt/async_support/base/ws/future.py +69 -0
- coinex/ccxt/async_support/base/ws/order_book.py +78 -0
- coinex/ccxt/async_support/base/ws/order_book_side.py +174 -0
- coinex/ccxt/async_support/coinex.py +5833 -0
- coinex/ccxt/base/__init__.py +27 -0
- coinex/ccxt/base/decimal_to_precision.py +174 -0
- coinex/ccxt/base/errors.py +267 -0
- coinex/ccxt/base/exchange.py +6769 -0
- coinex/ccxt/base/precise.py +297 -0
- coinex/ccxt/base/types.py +577 -0
- coinex/ccxt/coinex.py +5832 -0
- coinex/ccxt/pro/__init__.py +21 -0
- coinex/ccxt/pro/coinex.py +1366 -0
- coinex/ccxt/static_dependencies/README.md +1 -0
- coinex/ccxt/static_dependencies/__init__.py +1 -0
- coinex/ccxt/static_dependencies/ecdsa/__init__.py +14 -0
- coinex/ccxt/static_dependencies/ecdsa/_version.py +520 -0
- coinex/ccxt/static_dependencies/ecdsa/curves.py +56 -0
- coinex/ccxt/static_dependencies/ecdsa/der.py +221 -0
- coinex/ccxt/static_dependencies/ecdsa/ecdsa.py +310 -0
- coinex/ccxt/static_dependencies/ecdsa/ellipticcurve.py +197 -0
- coinex/ccxt/static_dependencies/ecdsa/keys.py +332 -0
- coinex/ccxt/static_dependencies/ecdsa/numbertheory.py +531 -0
- coinex/ccxt/static_dependencies/ecdsa/rfc6979.py +100 -0
- coinex/ccxt/static_dependencies/ecdsa/util.py +266 -0
- coinex/ccxt/static_dependencies/ethereum/__init__.py +7 -0
- coinex/ccxt/static_dependencies/ethereum/abi/__init__.py +16 -0
- coinex/ccxt/static_dependencies/ethereum/abi/abi.py +19 -0
- coinex/ccxt/static_dependencies/ethereum/abi/base.py +152 -0
- coinex/ccxt/static_dependencies/ethereum/abi/codec.py +217 -0
- coinex/ccxt/static_dependencies/ethereum/abi/constants.py +3 -0
- coinex/ccxt/static_dependencies/ethereum/abi/decoding.py +565 -0
- coinex/ccxt/static_dependencies/ethereum/abi/encoding.py +720 -0
- coinex/ccxt/static_dependencies/ethereum/abi/exceptions.py +139 -0
- coinex/ccxt/static_dependencies/ethereum/abi/grammar.py +443 -0
- coinex/ccxt/static_dependencies/ethereum/abi/packed.py +13 -0
- coinex/ccxt/static_dependencies/ethereum/abi/py.typed +0 -0
- coinex/ccxt/static_dependencies/ethereum/abi/registry.py +643 -0
- coinex/ccxt/static_dependencies/ethereum/abi/tools/__init__.py +3 -0
- coinex/ccxt/static_dependencies/ethereum/abi/tools/_strategies.py +230 -0
- coinex/ccxt/static_dependencies/ethereum/abi/utils/__init__.py +0 -0
- coinex/ccxt/static_dependencies/ethereum/abi/utils/numeric.py +83 -0
- coinex/ccxt/static_dependencies/ethereum/abi/utils/padding.py +27 -0
- coinex/ccxt/static_dependencies/ethereum/abi/utils/string.py +19 -0
- coinex/ccxt/static_dependencies/ethereum/account/__init__.py +3 -0
- coinex/ccxt/static_dependencies/ethereum/account/encode_typed_data/__init__.py +4 -0
- coinex/ccxt/static_dependencies/ethereum/account/encode_typed_data/encoding_and_hashing.py +239 -0
- coinex/ccxt/static_dependencies/ethereum/account/encode_typed_data/helpers.py +40 -0
- coinex/ccxt/static_dependencies/ethereum/account/messages.py +263 -0
- coinex/ccxt/static_dependencies/ethereum/account/py.typed +0 -0
- coinex/ccxt/static_dependencies/ethereum/hexbytes/__init__.py +5 -0
- coinex/ccxt/static_dependencies/ethereum/hexbytes/_utils.py +54 -0
- coinex/ccxt/static_dependencies/ethereum/hexbytes/main.py +65 -0
- coinex/ccxt/static_dependencies/ethereum/hexbytes/py.typed +0 -0
- coinex/ccxt/static_dependencies/ethereum/typing/__init__.py +63 -0
- coinex/ccxt/static_dependencies/ethereum/typing/abi.py +6 -0
- coinex/ccxt/static_dependencies/ethereum/typing/bls.py +7 -0
- coinex/ccxt/static_dependencies/ethereum/typing/discovery.py +5 -0
- coinex/ccxt/static_dependencies/ethereum/typing/encoding.py +7 -0
- coinex/ccxt/static_dependencies/ethereum/typing/enums.py +17 -0
- coinex/ccxt/static_dependencies/ethereum/typing/ethpm.py +9 -0
- coinex/ccxt/static_dependencies/ethereum/typing/evm.py +20 -0
- coinex/ccxt/static_dependencies/ethereum/typing/networks.py +1122 -0
- coinex/ccxt/static_dependencies/ethereum/typing/py.typed +0 -0
- coinex/ccxt/static_dependencies/ethereum/utils/__init__.py +115 -0
- coinex/ccxt/static_dependencies/ethereum/utils/abi.py +72 -0
- coinex/ccxt/static_dependencies/ethereum/utils/address.py +171 -0
- coinex/ccxt/static_dependencies/ethereum/utils/applicators.py +151 -0
- coinex/ccxt/static_dependencies/ethereum/utils/conversions.py +190 -0
- coinex/ccxt/static_dependencies/ethereum/utils/currency.py +107 -0
- coinex/ccxt/static_dependencies/ethereum/utils/curried/__init__.py +269 -0
- coinex/ccxt/static_dependencies/ethereum/utils/debug.py +20 -0
- coinex/ccxt/static_dependencies/ethereum/utils/decorators.py +132 -0
- coinex/ccxt/static_dependencies/ethereum/utils/encoding.py +6 -0
- coinex/ccxt/static_dependencies/ethereum/utils/exceptions.py +4 -0
- coinex/ccxt/static_dependencies/ethereum/utils/functional.py +75 -0
- coinex/ccxt/static_dependencies/ethereum/utils/hexadecimal.py +74 -0
- coinex/ccxt/static_dependencies/ethereum/utils/humanize.py +188 -0
- coinex/ccxt/static_dependencies/ethereum/utils/logging.py +159 -0
- coinex/ccxt/static_dependencies/ethereum/utils/module_loading.py +31 -0
- coinex/ccxt/static_dependencies/ethereum/utils/numeric.py +43 -0
- coinex/ccxt/static_dependencies/ethereum/utils/py.typed +0 -0
- coinex/ccxt/static_dependencies/ethereum/utils/toolz.py +76 -0
- coinex/ccxt/static_dependencies/ethereum/utils/types.py +54 -0
- coinex/ccxt/static_dependencies/ethereum/utils/typing/__init__.py +18 -0
- coinex/ccxt/static_dependencies/ethereum/utils/typing/misc.py +14 -0
- coinex/ccxt/static_dependencies/ethereum/utils/units.py +31 -0
- coinex/ccxt/static_dependencies/keccak/__init__.py +3 -0
- coinex/ccxt/static_dependencies/keccak/keccak.py +197 -0
- coinex/ccxt/static_dependencies/lark/__init__.py +38 -0
- coinex/ccxt/static_dependencies/lark/__pyinstaller/__init__.py +6 -0
- coinex/ccxt/static_dependencies/lark/__pyinstaller/hook-lark.py +14 -0
- coinex/ccxt/static_dependencies/lark/ast_utils.py +59 -0
- coinex/ccxt/static_dependencies/lark/common.py +86 -0
- coinex/ccxt/static_dependencies/lark/exceptions.py +292 -0
- coinex/ccxt/static_dependencies/lark/grammar.py +130 -0
- coinex/ccxt/static_dependencies/lark/grammars/__init__.py +0 -0
- coinex/ccxt/static_dependencies/lark/grammars/common.lark +59 -0
- coinex/ccxt/static_dependencies/lark/grammars/lark.lark +62 -0
- coinex/ccxt/static_dependencies/lark/grammars/python.lark +302 -0
- coinex/ccxt/static_dependencies/lark/grammars/unicode.lark +7 -0
- coinex/ccxt/static_dependencies/lark/indenter.py +143 -0
- coinex/ccxt/static_dependencies/lark/lark.py +658 -0
- coinex/ccxt/static_dependencies/lark/lexer.py +678 -0
- coinex/ccxt/static_dependencies/lark/load_grammar.py +1428 -0
- coinex/ccxt/static_dependencies/lark/parse_tree_builder.py +391 -0
- coinex/ccxt/static_dependencies/lark/parser_frontends.py +257 -0
- coinex/ccxt/static_dependencies/lark/parsers/__init__.py +0 -0
- coinex/ccxt/static_dependencies/lark/parsers/cyk.py +340 -0
- coinex/ccxt/static_dependencies/lark/parsers/earley.py +314 -0
- coinex/ccxt/static_dependencies/lark/parsers/earley_common.py +42 -0
- coinex/ccxt/static_dependencies/lark/parsers/earley_forest.py +801 -0
- coinex/ccxt/static_dependencies/lark/parsers/grammar_analysis.py +203 -0
- coinex/ccxt/static_dependencies/lark/parsers/lalr_analysis.py +332 -0
- coinex/ccxt/static_dependencies/lark/parsers/lalr_interactive_parser.py +158 -0
- coinex/ccxt/static_dependencies/lark/parsers/lalr_parser.py +122 -0
- coinex/ccxt/static_dependencies/lark/parsers/lalr_parser_state.py +110 -0
- coinex/ccxt/static_dependencies/lark/parsers/xearley.py +165 -0
- coinex/ccxt/static_dependencies/lark/py.typed +0 -0
- coinex/ccxt/static_dependencies/lark/reconstruct.py +107 -0
- coinex/ccxt/static_dependencies/lark/tools/__init__.py +70 -0
- coinex/ccxt/static_dependencies/lark/tools/nearley.py +202 -0
- coinex/ccxt/static_dependencies/lark/tools/serialize.py +32 -0
- coinex/ccxt/static_dependencies/lark/tools/standalone.py +196 -0
- coinex/ccxt/static_dependencies/lark/tree.py +267 -0
- coinex/ccxt/static_dependencies/lark/tree_matcher.py +186 -0
- coinex/ccxt/static_dependencies/lark/tree_templates.py +180 -0
- coinex/ccxt/static_dependencies/lark/utils.py +343 -0
- coinex/ccxt/static_dependencies/lark/visitors.py +596 -0
- coinex/ccxt/static_dependencies/marshmallow/__init__.py +81 -0
- coinex/ccxt/static_dependencies/marshmallow/base.py +65 -0
- coinex/ccxt/static_dependencies/marshmallow/class_registry.py +94 -0
- coinex/ccxt/static_dependencies/marshmallow/decorators.py +231 -0
- coinex/ccxt/static_dependencies/marshmallow/error_store.py +60 -0
- coinex/ccxt/static_dependencies/marshmallow/exceptions.py +71 -0
- coinex/ccxt/static_dependencies/marshmallow/fields.py +2114 -0
- coinex/ccxt/static_dependencies/marshmallow/orderedset.py +89 -0
- coinex/ccxt/static_dependencies/marshmallow/py.typed +0 -0
- coinex/ccxt/static_dependencies/marshmallow/schema.py +1228 -0
- coinex/ccxt/static_dependencies/marshmallow/types.py +12 -0
- coinex/ccxt/static_dependencies/marshmallow/utils.py +378 -0
- coinex/ccxt/static_dependencies/marshmallow/validate.py +678 -0
- coinex/ccxt/static_dependencies/marshmallow/warnings.py +2 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/__init__.py +1047 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/collection_field.py +51 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/lazy_class_attribute.py +45 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/mypy.py +71 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/py.typed +0 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/typing.py +14 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/union_field.py +82 -0
- coinex/ccxt/static_dependencies/marshmallow_oneofschema/__init__.py +1 -0
- coinex/ccxt/static_dependencies/marshmallow_oneofschema/one_of_schema.py +193 -0
- coinex/ccxt/static_dependencies/marshmallow_oneofschema/py.typed +0 -0
- coinex/ccxt/static_dependencies/msgpack/__init__.py +55 -0
- coinex/ccxt/static_dependencies/msgpack/_cmsgpack.pyx +11 -0
- coinex/ccxt/static_dependencies/msgpack/_packer.pyx +374 -0
- coinex/ccxt/static_dependencies/msgpack/_unpacker.pyx +547 -0
- coinex/ccxt/static_dependencies/msgpack/buff_converter.h +8 -0
- coinex/ccxt/static_dependencies/msgpack/exceptions.py +48 -0
- coinex/ccxt/static_dependencies/msgpack/ext.py +168 -0
- coinex/ccxt/static_dependencies/msgpack/fallback.py +951 -0
- coinex/ccxt/static_dependencies/msgpack/pack.h +89 -0
- coinex/ccxt/static_dependencies/msgpack/pack_template.h +820 -0
- coinex/ccxt/static_dependencies/msgpack/sysdep.h +194 -0
- coinex/ccxt/static_dependencies/msgpack/unpack.h +391 -0
- coinex/ccxt/static_dependencies/msgpack/unpack_define.h +95 -0
- coinex/ccxt/static_dependencies/msgpack/unpack_template.h +464 -0
- coinex/ccxt/static_dependencies/parsimonious/__init__.py +10 -0
- coinex/ccxt/static_dependencies/parsimonious/exceptions.py +105 -0
- coinex/ccxt/static_dependencies/parsimonious/expressions.py +479 -0
- coinex/ccxt/static_dependencies/parsimonious/grammar.py +487 -0
- coinex/ccxt/static_dependencies/parsimonious/nodes.py +325 -0
- coinex/ccxt/static_dependencies/parsimonious/utils.py +40 -0
- coinex/ccxt/static_dependencies/starknet/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/abi/v0/__init__.py +2 -0
- coinex/ccxt/static_dependencies/starknet/abi/v0/model.py +44 -0
- coinex/ccxt/static_dependencies/starknet/abi/v0/parser.py +216 -0
- coinex/ccxt/static_dependencies/starknet/abi/v0/schemas.py +72 -0
- coinex/ccxt/static_dependencies/starknet/abi/v0/shape.py +63 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/__init__.py +2 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/core_structures.json +14 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/model.py +39 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/parser.py +220 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/parser_transformer.py +179 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/schemas.py +66 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/shape.py +47 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/__init__.py +2 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/model.py +89 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/parser.py +293 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/parser_transformer.py +192 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/schemas.py +132 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/shape.py +107 -0
- coinex/ccxt/static_dependencies/starknet/cairo/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/cairo/data_types.py +123 -0
- coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/cairo_types.py +77 -0
- coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser.py +46 -0
- coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser_transformer.py +138 -0
- coinex/ccxt/static_dependencies/starknet/cairo/felt.py +64 -0
- coinex/ccxt/static_dependencies/starknet/cairo/type_parser.py +121 -0
- coinex/ccxt/static_dependencies/starknet/cairo/v1/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/cairo/v1/type_parser.py +59 -0
- coinex/ccxt/static_dependencies/starknet/cairo/v2/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/cairo/v2/type_parser.py +77 -0
- coinex/ccxt/static_dependencies/starknet/ccxt_utils.py +7 -0
- coinex/ccxt/static_dependencies/starknet/common.py +15 -0
- coinex/ccxt/static_dependencies/starknet/constants.py +39 -0
- coinex/ccxt/static_dependencies/starknet/hash/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/hash/address.py +79 -0
- coinex/ccxt/static_dependencies/starknet/hash/compiled_class_hash_objects.py +111 -0
- coinex/ccxt/static_dependencies/starknet/hash/selector.py +16 -0
- coinex/ccxt/static_dependencies/starknet/hash/storage.py +12 -0
- coinex/ccxt/static_dependencies/starknet/hash/utils.py +78 -0
- coinex/ccxt/static_dependencies/starknet/models/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/models/typed_data.py +45 -0
- coinex/ccxt/static_dependencies/starknet/serialization/__init__.py +24 -0
- coinex/ccxt/static_dependencies/starknet/serialization/_calldata_reader.py +40 -0
- coinex/ccxt/static_dependencies/starknet/serialization/_context.py +142 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/__init__.py +10 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/_common.py +82 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/array_serializer.py +43 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/bool_serializer.py +37 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/byte_array_serializer.py +66 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/cairo_data_serializer.py +71 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/enum_serializer.py +71 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/felt_serializer.py +50 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/named_tuple_serializer.py +58 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/option_serializer.py +43 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/output_serializer.py +40 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/payload_serializer.py +72 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/struct_serializer.py +36 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/tuple_serializer.py +36 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/uint256_serializer.py +76 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/uint_serializer.py +100 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/unit_serializer.py +32 -0
- coinex/ccxt/static_dependencies/starknet/serialization/errors.py +10 -0
- coinex/ccxt/static_dependencies/starknet/serialization/factory.py +229 -0
- coinex/ccxt/static_dependencies/starknet/serialization/function_serialization_adapter.py +110 -0
- coinex/ccxt/static_dependencies/starknet/serialization/tuple_dataclass.py +59 -0
- coinex/ccxt/static_dependencies/starknet/utils/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/utils/constructor_args_translator.py +86 -0
- coinex/ccxt/static_dependencies/starknet/utils/iterable.py +13 -0
- coinex/ccxt/static_dependencies/starknet/utils/schema.py +13 -0
- coinex/ccxt/static_dependencies/starknet/utils/typed_data.py +182 -0
- coinex/ccxt/static_dependencies/starkware/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starkware/crypto/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starkware/crypto/fast_pedersen_hash.py +50 -0
- coinex/ccxt/static_dependencies/starkware/crypto/math_utils.py +78 -0
- coinex/ccxt/static_dependencies/starkware/crypto/signature.py +2344 -0
- coinex/ccxt/static_dependencies/starkware/crypto/utils.py +63 -0
- coinex/ccxt/static_dependencies/sympy/__init__.py +0 -0
- coinex/ccxt/static_dependencies/sympy/core/__init__.py +0 -0
- coinex/ccxt/static_dependencies/sympy/core/intfunc.py +35 -0
- coinex/ccxt/static_dependencies/sympy/external/__init__.py +0 -0
- coinex/ccxt/static_dependencies/sympy/external/gmpy.py +345 -0
- coinex/ccxt/static_dependencies/sympy/external/importtools.py +187 -0
- coinex/ccxt/static_dependencies/sympy/external/ntheory.py +637 -0
- coinex/ccxt/static_dependencies/sympy/external/pythonmpq.py +341 -0
- coinex/ccxt/static_dependencies/toolz/__init__.py +26 -0
- coinex/ccxt/static_dependencies/toolz/_signatures.py +784 -0
- coinex/ccxt/static_dependencies/toolz/_version.py +520 -0
- coinex/ccxt/static_dependencies/toolz/compatibility.py +30 -0
- coinex/ccxt/static_dependencies/toolz/curried/__init__.py +101 -0
- coinex/ccxt/static_dependencies/toolz/curried/exceptions.py +22 -0
- coinex/ccxt/static_dependencies/toolz/curried/operator.py +22 -0
- coinex/ccxt/static_dependencies/toolz/dicttoolz.py +339 -0
- coinex/ccxt/static_dependencies/toolz/functoolz.py +1049 -0
- coinex/ccxt/static_dependencies/toolz/itertoolz.py +1057 -0
- coinex/ccxt/static_dependencies/toolz/recipes.py +46 -0
- coinex/ccxt/static_dependencies/toolz/utils.py +9 -0
- coinex/ccxt/static_dependencies/typing_inspect/__init__.py +0 -0
- coinex/ccxt/static_dependencies/typing_inspect/typing_inspect.py +851 -0
- {coinex_api-0.0.12.dist-info → coinex_api-0.0.14.dist-info}/METADATA +1 -1
- coinex_api-0.0.14.dist-info/RECORD +288 -0
- coinex_api-0.0.12.dist-info/RECORD +0 -3
- {coinex_api-0.0.12.dist-info → coinex_api-0.0.14.dist-info}/WHEEL +0 -0
@@ -0,0 +1,339 @@
|
|
1
|
+
import operator
|
2
|
+
import collections
|
3
|
+
from functools import reduce
|
4
|
+
from collections.abc import Mapping
|
5
|
+
|
6
|
+
__all__ = ('merge', 'merge_with', 'valmap', 'keymap', 'itemmap',
|
7
|
+
'valfilter', 'keyfilter', 'itemfilter',
|
8
|
+
'assoc', 'dissoc', 'assoc_in', 'update_in', 'get_in')
|
9
|
+
|
10
|
+
|
11
|
+
def _get_factory(f, kwargs):
|
12
|
+
factory = kwargs.pop('factory', dict)
|
13
|
+
if kwargs:
|
14
|
+
raise TypeError("{}() got an unexpected keyword argument "
|
15
|
+
"'{}'".format(f.__name__, kwargs.popitem()[0]))
|
16
|
+
return factory
|
17
|
+
|
18
|
+
|
19
|
+
def merge(*dicts, **kwargs):
|
20
|
+
""" Merge a collection of dictionaries
|
21
|
+
|
22
|
+
>>> merge({1: 'one'}, {2: 'two'})
|
23
|
+
{1: 'one', 2: 'two'}
|
24
|
+
|
25
|
+
Later dictionaries have precedence
|
26
|
+
|
27
|
+
>>> merge({1: 2, 3: 4}, {3: 3, 4: 4})
|
28
|
+
{1: 2, 3: 3, 4: 4}
|
29
|
+
|
30
|
+
See Also:
|
31
|
+
merge_with
|
32
|
+
"""
|
33
|
+
if len(dicts) == 1 and not isinstance(dicts[0], Mapping):
|
34
|
+
dicts = dicts[0]
|
35
|
+
factory = _get_factory(merge, kwargs)
|
36
|
+
|
37
|
+
rv = factory()
|
38
|
+
for d in dicts:
|
39
|
+
rv.update(d)
|
40
|
+
return rv
|
41
|
+
|
42
|
+
|
43
|
+
def merge_with(func, *dicts, **kwargs):
|
44
|
+
""" Merge dictionaries and apply function to combined values
|
45
|
+
|
46
|
+
A key may occur in more than one dict, and all values mapped from the key
|
47
|
+
will be passed to the function as a list, such as func([val1, val2, ...]).
|
48
|
+
|
49
|
+
>>> merge_with(sum, {1: 1, 2: 2}, {1: 10, 2: 20})
|
50
|
+
{1: 11, 2: 22}
|
51
|
+
|
52
|
+
>>> merge_with(first, {1: 1, 2: 2}, {2: 20, 3: 30}) # doctest: +SKIP
|
53
|
+
{1: 1, 2: 2, 3: 30}
|
54
|
+
|
55
|
+
See Also:
|
56
|
+
merge
|
57
|
+
"""
|
58
|
+
if len(dicts) == 1 and not isinstance(dicts[0], Mapping):
|
59
|
+
dicts = dicts[0]
|
60
|
+
factory = _get_factory(merge_with, kwargs)
|
61
|
+
|
62
|
+
values = collections.defaultdict(lambda: [].append)
|
63
|
+
for d in dicts:
|
64
|
+
for k, v in d.items():
|
65
|
+
values[k](v)
|
66
|
+
|
67
|
+
result = factory()
|
68
|
+
for k, v in values.items():
|
69
|
+
result[k] = func(v.__self__)
|
70
|
+
return result
|
71
|
+
|
72
|
+
|
73
|
+
def valmap(func, d, factory=dict):
|
74
|
+
""" Apply function to values of dictionary
|
75
|
+
|
76
|
+
>>> bills = {"Alice": [20, 15, 30], "Bob": [10, 35]}
|
77
|
+
>>> valmap(sum, bills) # doctest: +SKIP
|
78
|
+
{'Alice': 65, 'Bob': 45}
|
79
|
+
|
80
|
+
See Also:
|
81
|
+
keymap
|
82
|
+
itemmap
|
83
|
+
"""
|
84
|
+
rv = factory()
|
85
|
+
rv.update(zip(d.keys(), map(func, d.values())))
|
86
|
+
return rv
|
87
|
+
|
88
|
+
|
89
|
+
def keymap(func, d, factory=dict):
|
90
|
+
""" Apply function to keys of dictionary
|
91
|
+
|
92
|
+
>>> bills = {"Alice": [20, 15, 30], "Bob": [10, 35]}
|
93
|
+
>>> keymap(str.lower, bills) # doctest: +SKIP
|
94
|
+
{'alice': [20, 15, 30], 'bob': [10, 35]}
|
95
|
+
|
96
|
+
See Also:
|
97
|
+
valmap
|
98
|
+
itemmap
|
99
|
+
"""
|
100
|
+
rv = factory()
|
101
|
+
rv.update(zip(map(func, d.keys()), d.values()))
|
102
|
+
return rv
|
103
|
+
|
104
|
+
|
105
|
+
def itemmap(func, d, factory=dict):
|
106
|
+
""" Apply function to items of dictionary
|
107
|
+
|
108
|
+
>>> accountids = {"Alice": 10, "Bob": 20}
|
109
|
+
>>> itemmap(reversed, accountids) # doctest: +SKIP
|
110
|
+
{10: "Alice", 20: "Bob"}
|
111
|
+
|
112
|
+
See Also:
|
113
|
+
keymap
|
114
|
+
valmap
|
115
|
+
"""
|
116
|
+
rv = factory()
|
117
|
+
rv.update(map(func, d.items()))
|
118
|
+
return rv
|
119
|
+
|
120
|
+
|
121
|
+
def valfilter(predicate, d, factory=dict):
|
122
|
+
""" Filter items in dictionary by value
|
123
|
+
|
124
|
+
>>> iseven = lambda x: x % 2 == 0
|
125
|
+
>>> d = {1: 2, 2: 3, 3: 4, 4: 5}
|
126
|
+
>>> valfilter(iseven, d)
|
127
|
+
{1: 2, 3: 4}
|
128
|
+
|
129
|
+
See Also:
|
130
|
+
keyfilter
|
131
|
+
itemfilter
|
132
|
+
valmap
|
133
|
+
"""
|
134
|
+
rv = factory()
|
135
|
+
for k, v in d.items():
|
136
|
+
if predicate(v):
|
137
|
+
rv[k] = v
|
138
|
+
return rv
|
139
|
+
|
140
|
+
|
141
|
+
def keyfilter(predicate, d, factory=dict):
|
142
|
+
""" Filter items in dictionary by key
|
143
|
+
|
144
|
+
>>> iseven = lambda x: x % 2 == 0
|
145
|
+
>>> d = {1: 2, 2: 3, 3: 4, 4: 5}
|
146
|
+
>>> keyfilter(iseven, d)
|
147
|
+
{2: 3, 4: 5}
|
148
|
+
|
149
|
+
See Also:
|
150
|
+
valfilter
|
151
|
+
itemfilter
|
152
|
+
keymap
|
153
|
+
"""
|
154
|
+
rv = factory()
|
155
|
+
for k, v in d.items():
|
156
|
+
if predicate(k):
|
157
|
+
rv[k] = v
|
158
|
+
return rv
|
159
|
+
|
160
|
+
|
161
|
+
def itemfilter(predicate, d, factory=dict):
|
162
|
+
""" Filter items in dictionary by item
|
163
|
+
|
164
|
+
>>> def isvalid(item):
|
165
|
+
... k, v = item
|
166
|
+
... return k % 2 == 0 and v < 4
|
167
|
+
|
168
|
+
>>> d = {1: 2, 2: 3, 3: 4, 4: 5}
|
169
|
+
>>> itemfilter(isvalid, d)
|
170
|
+
{2: 3}
|
171
|
+
|
172
|
+
See Also:
|
173
|
+
keyfilter
|
174
|
+
valfilter
|
175
|
+
itemmap
|
176
|
+
"""
|
177
|
+
rv = factory()
|
178
|
+
for item in d.items():
|
179
|
+
if predicate(item):
|
180
|
+
k, v = item
|
181
|
+
rv[k] = v
|
182
|
+
return rv
|
183
|
+
|
184
|
+
|
185
|
+
def assoc(d, key, value, factory=dict):
|
186
|
+
""" Return a new dict with new key value pair
|
187
|
+
|
188
|
+
New dict has d[key] set to value. Does not modify the initial dictionary.
|
189
|
+
|
190
|
+
>>> assoc({'x': 1}, 'x', 2)
|
191
|
+
{'x': 2}
|
192
|
+
>>> assoc({'x': 1}, 'y', 3) # doctest: +SKIP
|
193
|
+
{'x': 1, 'y': 3}
|
194
|
+
"""
|
195
|
+
d2 = factory()
|
196
|
+
d2.update(d)
|
197
|
+
d2[key] = value
|
198
|
+
return d2
|
199
|
+
|
200
|
+
|
201
|
+
def dissoc(d, *keys, **kwargs):
|
202
|
+
""" Return a new dict with the given key(s) removed.
|
203
|
+
|
204
|
+
New dict has d[key] deleted for each supplied key.
|
205
|
+
Does not modify the initial dictionary.
|
206
|
+
|
207
|
+
>>> dissoc({'x': 1, 'y': 2}, 'y')
|
208
|
+
{'x': 1}
|
209
|
+
>>> dissoc({'x': 1, 'y': 2}, 'y', 'x')
|
210
|
+
{}
|
211
|
+
>>> dissoc({'x': 1}, 'y') # Ignores missing keys
|
212
|
+
{'x': 1}
|
213
|
+
"""
|
214
|
+
factory = _get_factory(dissoc, kwargs)
|
215
|
+
d2 = factory()
|
216
|
+
|
217
|
+
if len(keys) < len(d) * .6:
|
218
|
+
d2.update(d)
|
219
|
+
for key in keys:
|
220
|
+
if key in d2:
|
221
|
+
del d2[key]
|
222
|
+
else:
|
223
|
+
remaining = set(d)
|
224
|
+
remaining.difference_update(keys)
|
225
|
+
for k in remaining:
|
226
|
+
d2[k] = d[k]
|
227
|
+
return d2
|
228
|
+
|
229
|
+
|
230
|
+
def assoc_in(d, keys, value, factory=dict):
|
231
|
+
""" Return a new dict with new, potentially nested, key value pair
|
232
|
+
|
233
|
+
>>> purchase = {'name': 'Alice',
|
234
|
+
... 'order': {'items': ['Apple', 'Orange'],
|
235
|
+
... 'costs': [0.50, 1.25]},
|
236
|
+
... 'credit card': '5555-1234-1234-1234'}
|
237
|
+
>>> assoc_in(purchase, ['order', 'costs'], [0.25, 1.00]) # doctest: +SKIP
|
238
|
+
{'credit card': '5555-1234-1234-1234',
|
239
|
+
'name': 'Alice',
|
240
|
+
'order': {'costs': [0.25, 1.00], 'items': ['Apple', 'Orange']}}
|
241
|
+
"""
|
242
|
+
return update_in(d, keys, lambda x: value, value, factory)
|
243
|
+
|
244
|
+
|
245
|
+
def update_in(d, keys, func, default=None, factory=dict):
|
246
|
+
""" Update value in a (potentially) nested dictionary
|
247
|
+
|
248
|
+
inputs:
|
249
|
+
d - dictionary on which to operate
|
250
|
+
keys - list or tuple giving the location of the value to be changed in d
|
251
|
+
func - function to operate on that value
|
252
|
+
|
253
|
+
If keys == [k0,..,kX] and d[k0]..[kX] == v, update_in returns a copy of the
|
254
|
+
original dictionary with v replaced by func(v), but does not mutate the
|
255
|
+
original dictionary.
|
256
|
+
|
257
|
+
If k0 is not a key in d, update_in creates nested dictionaries to the depth
|
258
|
+
specified by the keys, with the innermost value set to func(default).
|
259
|
+
|
260
|
+
>>> inc = lambda x: x + 1
|
261
|
+
>>> update_in({'a': 0}, ['a'], inc)
|
262
|
+
{'a': 1}
|
263
|
+
|
264
|
+
>>> transaction = {'name': 'Alice',
|
265
|
+
... 'purchase': {'items': ['Apple', 'Orange'],
|
266
|
+
... 'costs': [0.50, 1.25]},
|
267
|
+
... 'credit card': '5555-1234-1234-1234'}
|
268
|
+
>>> update_in(transaction, ['purchase', 'costs'], sum) # doctest: +SKIP
|
269
|
+
{'credit card': '5555-1234-1234-1234',
|
270
|
+
'name': 'Alice',
|
271
|
+
'purchase': {'costs': 1.75, 'items': ['Apple', 'Orange']}}
|
272
|
+
|
273
|
+
>>> # updating a value when k0 is not in d
|
274
|
+
>>> update_in({}, [1, 2, 3], str, default="bar")
|
275
|
+
{1: {2: {3: 'bar'}}}
|
276
|
+
>>> update_in({1: 'foo'}, [2, 3, 4], inc, 0)
|
277
|
+
{1: 'foo', 2: {3: {4: 1}}}
|
278
|
+
"""
|
279
|
+
ks = iter(keys)
|
280
|
+
k = next(ks)
|
281
|
+
|
282
|
+
rv = inner = factory()
|
283
|
+
rv.update(d)
|
284
|
+
|
285
|
+
for key in ks:
|
286
|
+
if k in d:
|
287
|
+
d = d[k]
|
288
|
+
dtemp = factory()
|
289
|
+
dtemp.update(d)
|
290
|
+
else:
|
291
|
+
d = dtemp = factory()
|
292
|
+
|
293
|
+
inner[k] = inner = dtemp
|
294
|
+
k = key
|
295
|
+
|
296
|
+
if k in d:
|
297
|
+
inner[k] = func(d[k])
|
298
|
+
else:
|
299
|
+
inner[k] = func(default)
|
300
|
+
return rv
|
301
|
+
|
302
|
+
|
303
|
+
def get_in(keys, coll, default=None, no_default=False):
|
304
|
+
""" Returns coll[i0][i1]...[iX] where [i0, i1, ..., iX]==keys.
|
305
|
+
|
306
|
+
If coll[i0][i1]...[iX] cannot be found, returns ``default``, unless
|
307
|
+
``no_default`` is specified, then it raises KeyError or IndexError.
|
308
|
+
|
309
|
+
``get_in`` is a generalization of ``operator.getitem`` for nested data
|
310
|
+
structures such as dictionaries and lists.
|
311
|
+
|
312
|
+
>>> transaction = {'name': 'Alice',
|
313
|
+
... 'purchase': {'items': ['Apple', 'Orange'],
|
314
|
+
... 'costs': [0.50, 1.25]},
|
315
|
+
... 'credit card': '5555-1234-1234-1234'}
|
316
|
+
>>> get_in(['purchase', 'items', 0], transaction)
|
317
|
+
'Apple'
|
318
|
+
>>> get_in(['name'], transaction)
|
319
|
+
'Alice'
|
320
|
+
>>> get_in(['purchase', 'total'], transaction)
|
321
|
+
>>> get_in(['purchase', 'items', 'apple'], transaction)
|
322
|
+
>>> get_in(['purchase', 'items', 10], transaction)
|
323
|
+
>>> get_in(['purchase', 'total'], transaction, 0)
|
324
|
+
0
|
325
|
+
>>> get_in(['y'], {}, no_default=True)
|
326
|
+
Traceback (most recent call last):
|
327
|
+
...
|
328
|
+
KeyError: 'y'
|
329
|
+
|
330
|
+
See Also:
|
331
|
+
itertoolz.get
|
332
|
+
operator.getitem
|
333
|
+
"""
|
334
|
+
try:
|
335
|
+
return reduce(operator.getitem, keys, coll)
|
336
|
+
except (KeyError, IndexError, TypeError):
|
337
|
+
if no_default:
|
338
|
+
raise
|
339
|
+
return default
|