coinex-api 0.0.7__py3-none-any.whl → 0.0.8__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_api-0.0.7.dist-info → coinex_api-0.0.8.dist-info}/METADATA +33 -14
- coinex_api-0.0.8.dist-info/RECORD +3 -0
- coinex_api/__init__.py +0 -7
- coinex_api/ccxt/__init__.py +0 -101
- coinex_api/ccxt/abstract/coinex.py +0 -237
- coinex_api/ccxt/async_support/__init__.py +0 -80
- coinex_api/ccxt/async_support/base/__init__.py +0 -1
- coinex_api/ccxt/async_support/base/exchange.py +0 -2100
- coinex_api/ccxt/async_support/base/throttler.py +0 -50
- coinex_api/ccxt/async_support/base/ws/__init__.py +0 -38
- coinex_api/ccxt/async_support/base/ws/aiohttp_client.py +0 -147
- coinex_api/ccxt/async_support/base/ws/cache.py +0 -213
- coinex_api/ccxt/async_support/base/ws/client.py +0 -214
- coinex_api/ccxt/async_support/base/ws/fast_client.py +0 -97
- coinex_api/ccxt/async_support/base/ws/functions.py +0 -59
- coinex_api/ccxt/async_support/base/ws/future.py +0 -69
- coinex_api/ccxt/async_support/base/ws/order_book.py +0 -78
- coinex_api/ccxt/async_support/base/ws/order_book_side.py +0 -174
- coinex_api/ccxt/async_support/coinex.py +0 -5833
- coinex_api/ccxt/base/__init__.py +0 -27
- coinex_api/ccxt/base/decimal_to_precision.py +0 -174
- coinex_api/ccxt/base/errors.py +0 -267
- coinex_api/ccxt/base/exchange.py +0 -6770
- coinex_api/ccxt/base/precise.py +0 -297
- coinex_api/ccxt/base/types.py +0 -577
- coinex_api/ccxt/coinex.py +0 -5832
- coinex_api/ccxt/pro/__init__.py +0 -21
- coinex_api/ccxt/pro/coinex.py +0 -1366
- coinex_api/ccxt/static_dependencies/README.md +0 -1
- coinex_api/ccxt/static_dependencies/__init__.py +0 -1
- coinex_api/ccxt/static_dependencies/ecdsa/__init__.py +0 -14
- coinex_api/ccxt/static_dependencies/ecdsa/_version.py +0 -520
- coinex_api/ccxt/static_dependencies/ecdsa/curves.py +0 -56
- coinex_api/ccxt/static_dependencies/ecdsa/der.py +0 -221
- coinex_api/ccxt/static_dependencies/ecdsa/ecdsa.py +0 -310
- coinex_api/ccxt/static_dependencies/ecdsa/ellipticcurve.py +0 -197
- coinex_api/ccxt/static_dependencies/ecdsa/keys.py +0 -332
- coinex_api/ccxt/static_dependencies/ecdsa/numbertheory.py +0 -531
- coinex_api/ccxt/static_dependencies/ecdsa/rfc6979.py +0 -100
- coinex_api/ccxt/static_dependencies/ecdsa/util.py +0 -266
- coinex_api/ccxt/static_dependencies/ethereum/__init__.py +0 -7
- coinex_api/ccxt/static_dependencies/ethereum/abi/__init__.py +0 -16
- coinex_api/ccxt/static_dependencies/ethereum/abi/abi.py +0 -19
- coinex_api/ccxt/static_dependencies/ethereum/abi/base.py +0 -152
- coinex_api/ccxt/static_dependencies/ethereum/abi/codec.py +0 -217
- coinex_api/ccxt/static_dependencies/ethereum/abi/constants.py +0 -3
- coinex_api/ccxt/static_dependencies/ethereum/abi/decoding.py +0 -565
- coinex_api/ccxt/static_dependencies/ethereum/abi/encoding.py +0 -720
- coinex_api/ccxt/static_dependencies/ethereum/abi/exceptions.py +0 -139
- coinex_api/ccxt/static_dependencies/ethereum/abi/grammar.py +0 -443
- coinex_api/ccxt/static_dependencies/ethereum/abi/packed.py +0 -13
- coinex_api/ccxt/static_dependencies/ethereum/abi/py.typed +0 -0
- coinex_api/ccxt/static_dependencies/ethereum/abi/registry.py +0 -643
- coinex_api/ccxt/static_dependencies/ethereum/abi/tools/__init__.py +0 -3
- coinex_api/ccxt/static_dependencies/ethereum/abi/tools/_strategies.py +0 -230
- coinex_api/ccxt/static_dependencies/ethereum/abi/utils/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/ethereum/abi/utils/numeric.py +0 -83
- coinex_api/ccxt/static_dependencies/ethereum/abi/utils/padding.py +0 -27
- coinex_api/ccxt/static_dependencies/ethereum/abi/utils/string.py +0 -19
- coinex_api/ccxt/static_dependencies/ethereum/account/__init__.py +0 -3
- coinex_api/ccxt/static_dependencies/ethereum/account/encode_typed_data/__init__.py +0 -4
- coinex_api/ccxt/static_dependencies/ethereum/account/encode_typed_data/encoding_and_hashing.py +0 -239
- coinex_api/ccxt/static_dependencies/ethereum/account/encode_typed_data/helpers.py +0 -40
- coinex_api/ccxt/static_dependencies/ethereum/account/messages.py +0 -263
- coinex_api/ccxt/static_dependencies/ethereum/account/py.typed +0 -0
- coinex_api/ccxt/static_dependencies/ethereum/hexbytes/__init__.py +0 -5
- coinex_api/ccxt/static_dependencies/ethereum/hexbytes/_utils.py +0 -54
- coinex_api/ccxt/static_dependencies/ethereum/hexbytes/main.py +0 -65
- coinex_api/ccxt/static_dependencies/ethereum/hexbytes/py.typed +0 -0
- coinex_api/ccxt/static_dependencies/ethereum/typing/__init__.py +0 -63
- coinex_api/ccxt/static_dependencies/ethereum/typing/abi.py +0 -6
- coinex_api/ccxt/static_dependencies/ethereum/typing/bls.py +0 -7
- coinex_api/ccxt/static_dependencies/ethereum/typing/discovery.py +0 -5
- coinex_api/ccxt/static_dependencies/ethereum/typing/encoding.py +0 -7
- coinex_api/ccxt/static_dependencies/ethereum/typing/enums.py +0 -17
- coinex_api/ccxt/static_dependencies/ethereum/typing/ethpm.py +0 -9
- coinex_api/ccxt/static_dependencies/ethereum/typing/evm.py +0 -20
- coinex_api/ccxt/static_dependencies/ethereum/typing/networks.py +0 -1122
- coinex_api/ccxt/static_dependencies/ethereum/typing/py.typed +0 -0
- coinex_api/ccxt/static_dependencies/ethereum/utils/__init__.py +0 -115
- coinex_api/ccxt/static_dependencies/ethereum/utils/abi.py +0 -72
- coinex_api/ccxt/static_dependencies/ethereum/utils/address.py +0 -171
- coinex_api/ccxt/static_dependencies/ethereum/utils/applicators.py +0 -151
- coinex_api/ccxt/static_dependencies/ethereum/utils/conversions.py +0 -190
- coinex_api/ccxt/static_dependencies/ethereum/utils/currency.py +0 -107
- coinex_api/ccxt/static_dependencies/ethereum/utils/curried/__init__.py +0 -269
- coinex_api/ccxt/static_dependencies/ethereum/utils/debug.py +0 -20
- coinex_api/ccxt/static_dependencies/ethereum/utils/decorators.py +0 -132
- coinex_api/ccxt/static_dependencies/ethereum/utils/encoding.py +0 -6
- coinex_api/ccxt/static_dependencies/ethereum/utils/exceptions.py +0 -4
- coinex_api/ccxt/static_dependencies/ethereum/utils/functional.py +0 -75
- coinex_api/ccxt/static_dependencies/ethereum/utils/hexadecimal.py +0 -74
- coinex_api/ccxt/static_dependencies/ethereum/utils/humanize.py +0 -188
- coinex_api/ccxt/static_dependencies/ethereum/utils/logging.py +0 -159
- coinex_api/ccxt/static_dependencies/ethereum/utils/module_loading.py +0 -31
- coinex_api/ccxt/static_dependencies/ethereum/utils/numeric.py +0 -43
- coinex_api/ccxt/static_dependencies/ethereum/utils/py.typed +0 -0
- coinex_api/ccxt/static_dependencies/ethereum/utils/toolz.py +0 -76
- coinex_api/ccxt/static_dependencies/ethereum/utils/types.py +0 -54
- coinex_api/ccxt/static_dependencies/ethereum/utils/typing/__init__.py +0 -18
- coinex_api/ccxt/static_dependencies/ethereum/utils/typing/misc.py +0 -14
- coinex_api/ccxt/static_dependencies/ethereum/utils/units.py +0 -31
- coinex_api/ccxt/static_dependencies/keccak/__init__.py +0 -3
- coinex_api/ccxt/static_dependencies/keccak/keccak.py +0 -197
- coinex_api/ccxt/static_dependencies/lark/__init__.py +0 -38
- coinex_api/ccxt/static_dependencies/lark/__pyinstaller/__init__.py +0 -6
- coinex_api/ccxt/static_dependencies/lark/__pyinstaller/hook-lark.py +0 -14
- coinex_api/ccxt/static_dependencies/lark/ast_utils.py +0 -59
- coinex_api/ccxt/static_dependencies/lark/common.py +0 -86
- coinex_api/ccxt/static_dependencies/lark/exceptions.py +0 -292
- coinex_api/ccxt/static_dependencies/lark/grammar.py +0 -130
- coinex_api/ccxt/static_dependencies/lark/grammars/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/lark/grammars/common.lark +0 -59
- coinex_api/ccxt/static_dependencies/lark/grammars/lark.lark +0 -62
- coinex_api/ccxt/static_dependencies/lark/grammars/python.lark +0 -302
- coinex_api/ccxt/static_dependencies/lark/grammars/unicode.lark +0 -7
- coinex_api/ccxt/static_dependencies/lark/indenter.py +0 -143
- coinex_api/ccxt/static_dependencies/lark/lark.py +0 -658
- coinex_api/ccxt/static_dependencies/lark/lexer.py +0 -678
- coinex_api/ccxt/static_dependencies/lark/load_grammar.py +0 -1428
- coinex_api/ccxt/static_dependencies/lark/parse_tree_builder.py +0 -391
- coinex_api/ccxt/static_dependencies/lark/parser_frontends.py +0 -257
- coinex_api/ccxt/static_dependencies/lark/parsers/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/lark/parsers/cyk.py +0 -340
- coinex_api/ccxt/static_dependencies/lark/parsers/earley.py +0 -314
- coinex_api/ccxt/static_dependencies/lark/parsers/earley_common.py +0 -42
- coinex_api/ccxt/static_dependencies/lark/parsers/earley_forest.py +0 -801
- coinex_api/ccxt/static_dependencies/lark/parsers/grammar_analysis.py +0 -203
- coinex_api/ccxt/static_dependencies/lark/parsers/lalr_analysis.py +0 -332
- coinex_api/ccxt/static_dependencies/lark/parsers/lalr_interactive_parser.py +0 -158
- coinex_api/ccxt/static_dependencies/lark/parsers/lalr_parser.py +0 -122
- coinex_api/ccxt/static_dependencies/lark/parsers/lalr_parser_state.py +0 -110
- coinex_api/ccxt/static_dependencies/lark/parsers/xearley.py +0 -165
- coinex_api/ccxt/static_dependencies/lark/py.typed +0 -0
- coinex_api/ccxt/static_dependencies/lark/reconstruct.py +0 -107
- coinex_api/ccxt/static_dependencies/lark/tools/__init__.py +0 -70
- coinex_api/ccxt/static_dependencies/lark/tools/nearley.py +0 -202
- coinex_api/ccxt/static_dependencies/lark/tools/serialize.py +0 -32
- coinex_api/ccxt/static_dependencies/lark/tools/standalone.py +0 -196
- coinex_api/ccxt/static_dependencies/lark/tree.py +0 -267
- coinex_api/ccxt/static_dependencies/lark/tree_matcher.py +0 -186
- coinex_api/ccxt/static_dependencies/lark/tree_templates.py +0 -180
- coinex_api/ccxt/static_dependencies/lark/utils.py +0 -343
- coinex_api/ccxt/static_dependencies/lark/visitors.py +0 -596
- coinex_api/ccxt/static_dependencies/marshmallow/__init__.py +0 -81
- coinex_api/ccxt/static_dependencies/marshmallow/base.py +0 -65
- coinex_api/ccxt/static_dependencies/marshmallow/class_registry.py +0 -94
- coinex_api/ccxt/static_dependencies/marshmallow/decorators.py +0 -231
- coinex_api/ccxt/static_dependencies/marshmallow/error_store.py +0 -60
- coinex_api/ccxt/static_dependencies/marshmallow/exceptions.py +0 -71
- coinex_api/ccxt/static_dependencies/marshmallow/fields.py +0 -2114
- coinex_api/ccxt/static_dependencies/marshmallow/orderedset.py +0 -89
- coinex_api/ccxt/static_dependencies/marshmallow/py.typed +0 -0
- coinex_api/ccxt/static_dependencies/marshmallow/schema.py +0 -1228
- coinex_api/ccxt/static_dependencies/marshmallow/types.py +0 -12
- coinex_api/ccxt/static_dependencies/marshmallow/utils.py +0 -378
- coinex_api/ccxt/static_dependencies/marshmallow/validate.py +0 -678
- coinex_api/ccxt/static_dependencies/marshmallow/warnings.py +0 -2
- coinex_api/ccxt/static_dependencies/marshmallow_dataclass/__init__.py +0 -1047
- coinex_api/ccxt/static_dependencies/marshmallow_dataclass/collection_field.py +0 -51
- coinex_api/ccxt/static_dependencies/marshmallow_dataclass/lazy_class_attribute.py +0 -45
- coinex_api/ccxt/static_dependencies/marshmallow_dataclass/mypy.py +0 -71
- coinex_api/ccxt/static_dependencies/marshmallow_dataclass/py.typed +0 -0
- coinex_api/ccxt/static_dependencies/marshmallow_dataclass/typing.py +0 -14
- coinex_api/ccxt/static_dependencies/marshmallow_dataclass/union_field.py +0 -82
- coinex_api/ccxt/static_dependencies/marshmallow_oneofschema/__init__.py +0 -1
- coinex_api/ccxt/static_dependencies/marshmallow_oneofschema/one_of_schema.py +0 -193
- coinex_api/ccxt/static_dependencies/marshmallow_oneofschema/py.typed +0 -0
- coinex_api/ccxt/static_dependencies/msgpack/__init__.py +0 -55
- coinex_api/ccxt/static_dependencies/msgpack/_cmsgpack.pyx +0 -11
- coinex_api/ccxt/static_dependencies/msgpack/_packer.pyx +0 -374
- coinex_api/ccxt/static_dependencies/msgpack/_unpacker.pyx +0 -547
- coinex_api/ccxt/static_dependencies/msgpack/buff_converter.h +0 -8
- coinex_api/ccxt/static_dependencies/msgpack/exceptions.py +0 -48
- coinex_api/ccxt/static_dependencies/msgpack/ext.py +0 -168
- coinex_api/ccxt/static_dependencies/msgpack/fallback.py +0 -951
- coinex_api/ccxt/static_dependencies/msgpack/pack.h +0 -89
- coinex_api/ccxt/static_dependencies/msgpack/pack_template.h +0 -820
- coinex_api/ccxt/static_dependencies/msgpack/sysdep.h +0 -194
- coinex_api/ccxt/static_dependencies/msgpack/unpack.h +0 -391
- coinex_api/ccxt/static_dependencies/msgpack/unpack_define.h +0 -95
- coinex_api/ccxt/static_dependencies/msgpack/unpack_template.h +0 -464
- coinex_api/ccxt/static_dependencies/parsimonious/__init__.py +0 -10
- coinex_api/ccxt/static_dependencies/parsimonious/exceptions.py +0 -105
- coinex_api/ccxt/static_dependencies/parsimonious/expressions.py +0 -479
- coinex_api/ccxt/static_dependencies/parsimonious/grammar.py +0 -487
- coinex_api/ccxt/static_dependencies/parsimonious/nodes.py +0 -325
- coinex_api/ccxt/static_dependencies/parsimonious/utils.py +0 -40
- coinex_api/ccxt/static_dependencies/starknet/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/starknet/abi/v0/__init__.py +0 -2
- coinex_api/ccxt/static_dependencies/starknet/abi/v0/model.py +0 -44
- coinex_api/ccxt/static_dependencies/starknet/abi/v0/parser.py +0 -216
- coinex_api/ccxt/static_dependencies/starknet/abi/v0/schemas.py +0 -72
- coinex_api/ccxt/static_dependencies/starknet/abi/v0/shape.py +0 -63
- coinex_api/ccxt/static_dependencies/starknet/abi/v1/__init__.py +0 -2
- coinex_api/ccxt/static_dependencies/starknet/abi/v1/core_structures.json +0 -14
- coinex_api/ccxt/static_dependencies/starknet/abi/v1/model.py +0 -39
- coinex_api/ccxt/static_dependencies/starknet/abi/v1/parser.py +0 -220
- coinex_api/ccxt/static_dependencies/starknet/abi/v1/parser_transformer.py +0 -179
- coinex_api/ccxt/static_dependencies/starknet/abi/v1/schemas.py +0 -66
- coinex_api/ccxt/static_dependencies/starknet/abi/v1/shape.py +0 -47
- coinex_api/ccxt/static_dependencies/starknet/abi/v2/__init__.py +0 -2
- coinex_api/ccxt/static_dependencies/starknet/abi/v2/model.py +0 -89
- coinex_api/ccxt/static_dependencies/starknet/abi/v2/parser.py +0 -293
- coinex_api/ccxt/static_dependencies/starknet/abi/v2/parser_transformer.py +0 -192
- coinex_api/ccxt/static_dependencies/starknet/abi/v2/schemas.py +0 -132
- coinex_api/ccxt/static_dependencies/starknet/abi/v2/shape.py +0 -107
- coinex_api/ccxt/static_dependencies/starknet/cairo/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/starknet/cairo/data_types.py +0 -123
- coinex_api/ccxt/static_dependencies/starknet/cairo/deprecated_parse/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/starknet/cairo/deprecated_parse/cairo_types.py +0 -77
- coinex_api/ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser.py +0 -46
- coinex_api/ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser_transformer.py +0 -138
- coinex_api/ccxt/static_dependencies/starknet/cairo/felt.py +0 -64
- coinex_api/ccxt/static_dependencies/starknet/cairo/type_parser.py +0 -121
- coinex_api/ccxt/static_dependencies/starknet/cairo/v1/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/starknet/cairo/v1/type_parser.py +0 -59
- coinex_api/ccxt/static_dependencies/starknet/cairo/v2/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/starknet/cairo/v2/type_parser.py +0 -77
- coinex_api/ccxt/static_dependencies/starknet/ccxt_utils.py +0 -7
- coinex_api/ccxt/static_dependencies/starknet/common.py +0 -15
- coinex_api/ccxt/static_dependencies/starknet/constants.py +0 -39
- coinex_api/ccxt/static_dependencies/starknet/hash/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/starknet/hash/address.py +0 -79
- coinex_api/ccxt/static_dependencies/starknet/hash/compiled_class_hash_objects.py +0 -111
- coinex_api/ccxt/static_dependencies/starknet/hash/selector.py +0 -16
- coinex_api/ccxt/static_dependencies/starknet/hash/storage.py +0 -12
- coinex_api/ccxt/static_dependencies/starknet/hash/utils.py +0 -78
- coinex_api/ccxt/static_dependencies/starknet/models/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/starknet/models/typed_data.py +0 -45
- coinex_api/ccxt/static_dependencies/starknet/serialization/__init__.py +0 -24
- coinex_api/ccxt/static_dependencies/starknet/serialization/_calldata_reader.py +0 -40
- coinex_api/ccxt/static_dependencies/starknet/serialization/_context.py +0 -142
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/__init__.py +0 -10
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/_common.py +0 -82
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/array_serializer.py +0 -43
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/bool_serializer.py +0 -37
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/byte_array_serializer.py +0 -66
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/cairo_data_serializer.py +0 -71
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/enum_serializer.py +0 -71
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/felt_serializer.py +0 -50
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/named_tuple_serializer.py +0 -58
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/option_serializer.py +0 -43
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/output_serializer.py +0 -40
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/payload_serializer.py +0 -72
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/struct_serializer.py +0 -36
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/tuple_serializer.py +0 -36
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/uint256_serializer.py +0 -76
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/uint_serializer.py +0 -100
- coinex_api/ccxt/static_dependencies/starknet/serialization/data_serializers/unit_serializer.py +0 -32
- coinex_api/ccxt/static_dependencies/starknet/serialization/errors.py +0 -10
- coinex_api/ccxt/static_dependencies/starknet/serialization/factory.py +0 -229
- coinex_api/ccxt/static_dependencies/starknet/serialization/function_serialization_adapter.py +0 -110
- coinex_api/ccxt/static_dependencies/starknet/serialization/tuple_dataclass.py +0 -59
- coinex_api/ccxt/static_dependencies/starknet/utils/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/starknet/utils/constructor_args_translator.py +0 -86
- coinex_api/ccxt/static_dependencies/starknet/utils/iterable.py +0 -13
- coinex_api/ccxt/static_dependencies/starknet/utils/schema.py +0 -13
- coinex_api/ccxt/static_dependencies/starknet/utils/typed_data.py +0 -182
- coinex_api/ccxt/static_dependencies/starkware/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/starkware/crypto/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/starkware/crypto/fast_pedersen_hash.py +0 -50
- coinex_api/ccxt/static_dependencies/starkware/crypto/math_utils.py +0 -78
- coinex_api/ccxt/static_dependencies/starkware/crypto/signature.py +0 -2344
- coinex_api/ccxt/static_dependencies/starkware/crypto/utils.py +0 -63
- coinex_api/ccxt/static_dependencies/sympy/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/sympy/core/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/sympy/core/intfunc.py +0 -35
- coinex_api/ccxt/static_dependencies/sympy/external/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/sympy/external/gmpy.py +0 -345
- coinex_api/ccxt/static_dependencies/sympy/external/importtools.py +0 -187
- coinex_api/ccxt/static_dependencies/sympy/external/ntheory.py +0 -637
- coinex_api/ccxt/static_dependencies/sympy/external/pythonmpq.py +0 -341
- coinex_api/ccxt/static_dependencies/toolz/__init__.py +0 -26
- coinex_api/ccxt/static_dependencies/toolz/_signatures.py +0 -784
- coinex_api/ccxt/static_dependencies/toolz/_version.py +0 -520
- coinex_api/ccxt/static_dependencies/toolz/compatibility.py +0 -30
- coinex_api/ccxt/static_dependencies/toolz/curried/__init__.py +0 -101
- coinex_api/ccxt/static_dependencies/toolz/curried/exceptions.py +0 -22
- coinex_api/ccxt/static_dependencies/toolz/curried/operator.py +0 -22
- coinex_api/ccxt/static_dependencies/toolz/dicttoolz.py +0 -339
- coinex_api/ccxt/static_dependencies/toolz/functoolz.py +0 -1049
- coinex_api/ccxt/static_dependencies/toolz/itertoolz.py +0 -1057
- coinex_api/ccxt/static_dependencies/toolz/recipes.py +0 -46
- coinex_api/ccxt/static_dependencies/toolz/utils.py +0 -9
- coinex_api/ccxt/static_dependencies/typing_inspect/__init__.py +0 -0
- coinex_api/ccxt/static_dependencies/typing_inspect/typing_inspect.py +0 -851
- coinex_api-0.0.7.dist-info/RECORD +0 -288
- {coinex_api-0.0.7.dist-info → coinex_api-0.0.8.dist-info}/WHEEL +0 -0
@@ -1,339 +0,0 @@
|
|
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
|