maxframe 0.1.0b5__cp39-cp39-macosx_11_0_arm64.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 maxframe might be problematic. Click here for more details.
- maxframe/__init__.py +32 -0
- maxframe/_utils.cpython-39-darwin.so +0 -0
- maxframe/_utils.pxd +33 -0
- maxframe/_utils.pyx +547 -0
- maxframe/codegen.py +528 -0
- maxframe/config/__init__.py +15 -0
- maxframe/config/config.py +443 -0
- maxframe/config/tests/__init__.py +13 -0
- maxframe/config/tests/test_config.py +103 -0
- maxframe/config/tests/test_validators.py +34 -0
- maxframe/config/validators.py +57 -0
- maxframe/conftest.py +139 -0
- maxframe/core/__init__.py +65 -0
- maxframe/core/base.py +156 -0
- maxframe/core/entity/__init__.py +44 -0
- maxframe/core/entity/chunks.py +68 -0
- maxframe/core/entity/core.py +152 -0
- maxframe/core/entity/executable.py +337 -0
- maxframe/core/entity/fuse.py +73 -0
- maxframe/core/entity/objects.py +100 -0
- maxframe/core/entity/output_types.py +90 -0
- maxframe/core/entity/tileables.py +438 -0
- maxframe/core/entity/utils.py +24 -0
- maxframe/core/graph/__init__.py +17 -0
- maxframe/core/graph/builder/__init__.py +16 -0
- maxframe/core/graph/builder/base.py +86 -0
- maxframe/core/graph/builder/chunk.py +430 -0
- maxframe/core/graph/builder/tileable.py +34 -0
- maxframe/core/graph/builder/utils.py +41 -0
- maxframe/core/graph/core.cpython-39-darwin.so +0 -0
- maxframe/core/graph/core.pyx +467 -0
- maxframe/core/graph/entity.py +171 -0
- maxframe/core/graph/tests/__init__.py +13 -0
- maxframe/core/graph/tests/test_graph.py +205 -0
- maxframe/core/mode.py +96 -0
- maxframe/core/operator/__init__.py +34 -0
- maxframe/core/operator/base.py +450 -0
- maxframe/core/operator/core.py +276 -0
- maxframe/core/operator/fetch.py +53 -0
- maxframe/core/operator/fuse.py +29 -0
- maxframe/core/operator/objects.py +72 -0
- maxframe/core/operator/shuffle.py +111 -0
- maxframe/core/operator/tests/__init__.py +13 -0
- maxframe/core/operator/tests/test_core.py +64 -0
- maxframe/core/tests/__init__.py +13 -0
- maxframe/core/tests/test_mode.py +75 -0
- maxframe/dataframe/__init__.py +81 -0
- maxframe/dataframe/arithmetic/__init__.py +359 -0
- maxframe/dataframe/arithmetic/abs.py +33 -0
- maxframe/dataframe/arithmetic/add.py +60 -0
- maxframe/dataframe/arithmetic/arccos.py +28 -0
- maxframe/dataframe/arithmetic/arccosh.py +28 -0
- maxframe/dataframe/arithmetic/arcsin.py +28 -0
- maxframe/dataframe/arithmetic/arcsinh.py +28 -0
- maxframe/dataframe/arithmetic/arctan.py +28 -0
- maxframe/dataframe/arithmetic/arctanh.py +28 -0
- maxframe/dataframe/arithmetic/around.py +152 -0
- maxframe/dataframe/arithmetic/bitwise_and.py +46 -0
- maxframe/dataframe/arithmetic/bitwise_or.py +50 -0
- maxframe/dataframe/arithmetic/bitwise_xor.py +46 -0
- maxframe/dataframe/arithmetic/ceil.py +28 -0
- maxframe/dataframe/arithmetic/core.py +342 -0
- maxframe/dataframe/arithmetic/cos.py +28 -0
- maxframe/dataframe/arithmetic/cosh.py +28 -0
- maxframe/dataframe/arithmetic/degrees.py +28 -0
- maxframe/dataframe/arithmetic/docstring.py +442 -0
- maxframe/dataframe/arithmetic/equal.py +56 -0
- maxframe/dataframe/arithmetic/exp.py +28 -0
- maxframe/dataframe/arithmetic/exp2.py +28 -0
- maxframe/dataframe/arithmetic/expm1.py +28 -0
- maxframe/dataframe/arithmetic/floor.py +28 -0
- maxframe/dataframe/arithmetic/floordiv.py +64 -0
- maxframe/dataframe/arithmetic/greater.py +57 -0
- maxframe/dataframe/arithmetic/greater_equal.py +57 -0
- maxframe/dataframe/arithmetic/invert.py +33 -0
- maxframe/dataframe/arithmetic/is_ufuncs.py +62 -0
- maxframe/dataframe/arithmetic/less.py +57 -0
- maxframe/dataframe/arithmetic/less_equal.py +57 -0
- maxframe/dataframe/arithmetic/log.py +28 -0
- maxframe/dataframe/arithmetic/log10.py +28 -0
- maxframe/dataframe/arithmetic/log2.py +28 -0
- maxframe/dataframe/arithmetic/mod.py +60 -0
- maxframe/dataframe/arithmetic/multiply.py +60 -0
- maxframe/dataframe/arithmetic/negative.py +33 -0
- maxframe/dataframe/arithmetic/not_equal.py +56 -0
- maxframe/dataframe/arithmetic/power.py +68 -0
- maxframe/dataframe/arithmetic/radians.py +28 -0
- maxframe/dataframe/arithmetic/sin.py +28 -0
- maxframe/dataframe/arithmetic/sinh.py +28 -0
- maxframe/dataframe/arithmetic/sqrt.py +28 -0
- maxframe/dataframe/arithmetic/subtract.py +64 -0
- maxframe/dataframe/arithmetic/tan.py +28 -0
- maxframe/dataframe/arithmetic/tanh.py +28 -0
- maxframe/dataframe/arithmetic/tests/__init__.py +13 -0
- maxframe/dataframe/arithmetic/tests/test_arithmetic.py +695 -0
- maxframe/dataframe/arithmetic/truediv.py +64 -0
- maxframe/dataframe/arithmetic/trunc.py +28 -0
- maxframe/dataframe/arrays.py +864 -0
- maxframe/dataframe/core.py +2417 -0
- maxframe/dataframe/datasource/__init__.py +15 -0
- maxframe/dataframe/datasource/core.py +81 -0
- maxframe/dataframe/datasource/dataframe.py +59 -0
- maxframe/dataframe/datasource/date_range.py +504 -0
- maxframe/dataframe/datasource/from_index.py +54 -0
- maxframe/dataframe/datasource/from_records.py +107 -0
- maxframe/dataframe/datasource/from_tensor.py +419 -0
- maxframe/dataframe/datasource/index.py +117 -0
- maxframe/dataframe/datasource/read_csv.py +528 -0
- maxframe/dataframe/datasource/read_odps_query.py +299 -0
- maxframe/dataframe/datasource/read_odps_table.py +253 -0
- maxframe/dataframe/datasource/read_parquet.py +421 -0
- maxframe/dataframe/datasource/series.py +55 -0
- maxframe/dataframe/datasource/tests/__init__.py +13 -0
- maxframe/dataframe/datasource/tests/test_datasource.py +401 -0
- maxframe/dataframe/datastore/__init__.py +26 -0
- maxframe/dataframe/datastore/core.py +19 -0
- maxframe/dataframe/datastore/to_csv.py +227 -0
- maxframe/dataframe/datastore/to_odps.py +162 -0
- maxframe/dataframe/extensions/__init__.py +41 -0
- maxframe/dataframe/extensions/accessor.py +50 -0
- maxframe/dataframe/extensions/reshuffle.py +83 -0
- maxframe/dataframe/extensions/tests/__init__.py +13 -0
- maxframe/dataframe/extensions/tests/test_extensions.py +38 -0
- maxframe/dataframe/fetch/__init__.py +15 -0
- maxframe/dataframe/fetch/core.py +86 -0
- maxframe/dataframe/groupby/__init__.py +82 -0
- maxframe/dataframe/groupby/aggregation.py +350 -0
- maxframe/dataframe/groupby/apply.py +251 -0
- maxframe/dataframe/groupby/core.py +179 -0
- maxframe/dataframe/groupby/cum.py +124 -0
- maxframe/dataframe/groupby/fill.py +141 -0
- maxframe/dataframe/groupby/getitem.py +92 -0
- maxframe/dataframe/groupby/head.py +105 -0
- maxframe/dataframe/groupby/sample.py +214 -0
- maxframe/dataframe/groupby/tests/__init__.py +13 -0
- maxframe/dataframe/groupby/tests/test_groupby.py +374 -0
- maxframe/dataframe/groupby/transform.py +255 -0
- maxframe/dataframe/indexing/__init__.py +84 -0
- maxframe/dataframe/indexing/add_prefix_suffix.py +110 -0
- maxframe/dataframe/indexing/align.py +349 -0
- maxframe/dataframe/indexing/at.py +83 -0
- maxframe/dataframe/indexing/getitem.py +204 -0
- maxframe/dataframe/indexing/iat.py +37 -0
- maxframe/dataframe/indexing/iloc.py +566 -0
- maxframe/dataframe/indexing/insert.py +86 -0
- maxframe/dataframe/indexing/loc.py +411 -0
- maxframe/dataframe/indexing/reindex.py +526 -0
- maxframe/dataframe/indexing/rename.py +462 -0
- maxframe/dataframe/indexing/rename_axis.py +209 -0
- maxframe/dataframe/indexing/reset_index.py +402 -0
- maxframe/dataframe/indexing/sample.py +221 -0
- maxframe/dataframe/indexing/set_axis.py +194 -0
- maxframe/dataframe/indexing/set_index.py +61 -0
- maxframe/dataframe/indexing/setitem.py +130 -0
- maxframe/dataframe/indexing/tests/__init__.py +13 -0
- maxframe/dataframe/indexing/tests/test_indexing.py +488 -0
- maxframe/dataframe/indexing/where.py +308 -0
- maxframe/dataframe/initializer.py +288 -0
- maxframe/dataframe/merge/__init__.py +32 -0
- maxframe/dataframe/merge/append.py +121 -0
- maxframe/dataframe/merge/concat.py +325 -0
- maxframe/dataframe/merge/merge.py +593 -0
- maxframe/dataframe/merge/tests/__init__.py +13 -0
- maxframe/dataframe/merge/tests/test_merge.py +215 -0
- maxframe/dataframe/misc/__init__.py +134 -0
- maxframe/dataframe/misc/_duplicate.py +46 -0
- maxframe/dataframe/misc/accessor.py +276 -0
- maxframe/dataframe/misc/apply.py +692 -0
- maxframe/dataframe/misc/astype.py +236 -0
- maxframe/dataframe/misc/case_when.py +141 -0
- maxframe/dataframe/misc/check_monotonic.py +84 -0
- maxframe/dataframe/misc/cut.py +383 -0
- maxframe/dataframe/misc/datetimes.py +79 -0
- maxframe/dataframe/misc/describe.py +108 -0
- maxframe/dataframe/misc/diff.py +210 -0
- maxframe/dataframe/misc/drop.py +440 -0
- maxframe/dataframe/misc/drop_duplicates.py +248 -0
- maxframe/dataframe/misc/duplicated.py +292 -0
- maxframe/dataframe/misc/eval.py +728 -0
- maxframe/dataframe/misc/explode.py +171 -0
- maxframe/dataframe/misc/get_dummies.py +208 -0
- maxframe/dataframe/misc/isin.py +217 -0
- maxframe/dataframe/misc/map.py +236 -0
- maxframe/dataframe/misc/melt.py +162 -0
- maxframe/dataframe/misc/memory_usage.py +248 -0
- maxframe/dataframe/misc/pct_change.py +150 -0
- maxframe/dataframe/misc/pivot_table.py +262 -0
- maxframe/dataframe/misc/qcut.py +104 -0
- maxframe/dataframe/misc/select_dtypes.py +104 -0
- maxframe/dataframe/misc/shift.py +256 -0
- maxframe/dataframe/misc/stack.py +238 -0
- maxframe/dataframe/misc/string_.py +221 -0
- maxframe/dataframe/misc/tests/__init__.py +13 -0
- maxframe/dataframe/misc/tests/test_misc.py +468 -0
- maxframe/dataframe/misc/to_numeric.py +178 -0
- maxframe/dataframe/misc/transform.py +361 -0
- maxframe/dataframe/misc/transpose.py +136 -0
- maxframe/dataframe/misc/value_counts.py +182 -0
- maxframe/dataframe/missing/__init__.py +53 -0
- maxframe/dataframe/missing/checkna.py +223 -0
- maxframe/dataframe/missing/dropna.py +280 -0
- maxframe/dataframe/missing/fillna.py +275 -0
- maxframe/dataframe/missing/replace.py +439 -0
- maxframe/dataframe/missing/tests/__init__.py +13 -0
- maxframe/dataframe/missing/tests/test_missing.py +89 -0
- maxframe/dataframe/operators.py +273 -0
- maxframe/dataframe/plotting/__init__.py +40 -0
- maxframe/dataframe/plotting/core.py +78 -0
- maxframe/dataframe/plotting/tests/__init__.py +13 -0
- maxframe/dataframe/plotting/tests/test_plotting.py +136 -0
- maxframe/dataframe/reduction/__init__.py +107 -0
- maxframe/dataframe/reduction/aggregation.py +344 -0
- maxframe/dataframe/reduction/all.py +78 -0
- maxframe/dataframe/reduction/any.py +78 -0
- maxframe/dataframe/reduction/core.py +837 -0
- maxframe/dataframe/reduction/count.py +59 -0
- maxframe/dataframe/reduction/cummax.py +30 -0
- maxframe/dataframe/reduction/cummin.py +30 -0
- maxframe/dataframe/reduction/cumprod.py +30 -0
- maxframe/dataframe/reduction/cumsum.py +30 -0
- maxframe/dataframe/reduction/custom_reduction.py +42 -0
- maxframe/dataframe/reduction/kurtosis.py +104 -0
- maxframe/dataframe/reduction/max.py +65 -0
- maxframe/dataframe/reduction/mean.py +61 -0
- maxframe/dataframe/reduction/min.py +65 -0
- maxframe/dataframe/reduction/nunique.py +141 -0
- maxframe/dataframe/reduction/prod.py +76 -0
- maxframe/dataframe/reduction/reduction_size.py +36 -0
- maxframe/dataframe/reduction/sem.py +69 -0
- maxframe/dataframe/reduction/skew.py +89 -0
- maxframe/dataframe/reduction/std.py +53 -0
- maxframe/dataframe/reduction/str_concat.py +48 -0
- maxframe/dataframe/reduction/sum.py +77 -0
- maxframe/dataframe/reduction/tests/__init__.py +13 -0
- maxframe/dataframe/reduction/tests/test_reduction.py +486 -0
- maxframe/dataframe/reduction/unique.py +90 -0
- maxframe/dataframe/reduction/var.py +72 -0
- maxframe/dataframe/sort/__init__.py +34 -0
- maxframe/dataframe/sort/core.py +36 -0
- maxframe/dataframe/sort/sort_index.py +153 -0
- maxframe/dataframe/sort/sort_values.py +311 -0
- maxframe/dataframe/sort/tests/__init__.py +13 -0
- maxframe/dataframe/sort/tests/test_sort.py +81 -0
- maxframe/dataframe/statistics/__init__.py +33 -0
- maxframe/dataframe/statistics/corr.py +280 -0
- maxframe/dataframe/statistics/quantile.py +341 -0
- maxframe/dataframe/statistics/tests/__init__.py +13 -0
- maxframe/dataframe/statistics/tests/test_statistics.py +82 -0
- maxframe/dataframe/tests/__init__.py +13 -0
- maxframe/dataframe/tests/test_initializer.py +29 -0
- maxframe/dataframe/tseries/__init__.py +13 -0
- maxframe/dataframe/tseries/tests/__init__.py +13 -0
- maxframe/dataframe/tseries/tests/test_tseries.py +30 -0
- maxframe/dataframe/tseries/to_datetime.py +297 -0
- maxframe/dataframe/ufunc/__init__.py +27 -0
- maxframe/dataframe/ufunc/tensor.py +54 -0
- maxframe/dataframe/ufunc/ufunc.py +52 -0
- maxframe/dataframe/utils.py +1267 -0
- maxframe/dataframe/window/__init__.py +29 -0
- maxframe/dataframe/window/aggregation.py +96 -0
- maxframe/dataframe/window/core.py +69 -0
- maxframe/dataframe/window/ewm.py +249 -0
- maxframe/dataframe/window/expanding.py +147 -0
- maxframe/dataframe/window/rolling.py +376 -0
- maxframe/dataframe/window/tests/__init__.py +13 -0
- maxframe/dataframe/window/tests/test_ewm.py +70 -0
- maxframe/dataframe/window/tests/test_expanding.py +66 -0
- maxframe/dataframe/window/tests/test_rolling.py +57 -0
- maxframe/env.py +33 -0
- maxframe/errors.py +21 -0
- maxframe/extension.py +81 -0
- maxframe/learn/__init__.py +17 -0
- maxframe/learn/contrib/__init__.py +17 -0
- maxframe/learn/contrib/pytorch/__init__.py +16 -0
- maxframe/learn/contrib/pytorch/run_function.py +110 -0
- maxframe/learn/contrib/pytorch/run_script.py +102 -0
- maxframe/learn/contrib/pytorch/tests/__init__.py +13 -0
- maxframe/learn/contrib/pytorch/tests/test_pytorch.py +42 -0
- maxframe/learn/contrib/utils.py +52 -0
- maxframe/learn/contrib/xgboost/__init__.py +26 -0
- maxframe/learn/contrib/xgboost/classifier.py +86 -0
- maxframe/learn/contrib/xgboost/core.py +156 -0
- maxframe/learn/contrib/xgboost/dmatrix.py +150 -0
- maxframe/learn/contrib/xgboost/predict.py +138 -0
- maxframe/learn/contrib/xgboost/regressor.py +78 -0
- maxframe/learn/contrib/xgboost/tests/__init__.py +13 -0
- maxframe/learn/contrib/xgboost/tests/test_core.py +43 -0
- maxframe/learn/contrib/xgboost/train.py +121 -0
- maxframe/learn/utils/__init__.py +15 -0
- maxframe/learn/utils/core.py +29 -0
- maxframe/lib/__init__.py +15 -0
- maxframe/lib/aio/__init__.py +27 -0
- maxframe/lib/aio/_runners.py +162 -0
- maxframe/lib/aio/_threads.py +35 -0
- maxframe/lib/aio/base.py +82 -0
- maxframe/lib/aio/file.py +85 -0
- maxframe/lib/aio/isolation.py +100 -0
- maxframe/lib/aio/lru.py +242 -0
- maxframe/lib/aio/parallelism.py +37 -0
- maxframe/lib/aio/tests/__init__.py +13 -0
- maxframe/lib/aio/tests/test_aio_file.py +55 -0
- maxframe/lib/compression.py +55 -0
- maxframe/lib/cython/__init__.py +13 -0
- maxframe/lib/cython/libcpp.pxd +30 -0
- maxframe/lib/filesystem/__init__.py +21 -0
- maxframe/lib/filesystem/_glob.py +173 -0
- maxframe/lib/filesystem/_oss_lib/__init__.py +13 -0
- maxframe/lib/filesystem/_oss_lib/common.py +198 -0
- maxframe/lib/filesystem/_oss_lib/glob.py +147 -0
- maxframe/lib/filesystem/_oss_lib/handle.py +156 -0
- maxframe/lib/filesystem/arrow.py +236 -0
- maxframe/lib/filesystem/base.py +263 -0
- maxframe/lib/filesystem/core.py +95 -0
- maxframe/lib/filesystem/fsmap.py +164 -0
- maxframe/lib/filesystem/hdfs.py +31 -0
- maxframe/lib/filesystem/local.py +112 -0
- maxframe/lib/filesystem/oss.py +157 -0
- maxframe/lib/filesystem/tests/__init__.py +13 -0
- maxframe/lib/filesystem/tests/test_filesystem.py +223 -0
- maxframe/lib/filesystem/tests/test_oss.py +182 -0
- maxframe/lib/functools_compat.py +81 -0
- maxframe/lib/mmh3.cpython-39-darwin.so +0 -0
- maxframe/lib/mmh3_src/MurmurHash3.cpp +339 -0
- maxframe/lib/mmh3_src/MurmurHash3.h +43 -0
- maxframe/lib/mmh3_src/mmh3module.cpp +387 -0
- maxframe/lib/sparse/__init__.py +861 -0
- maxframe/lib/sparse/array.py +1604 -0
- maxframe/lib/sparse/core.py +92 -0
- maxframe/lib/sparse/matrix.py +241 -0
- maxframe/lib/sparse/tests/__init__.py +15 -0
- maxframe/lib/sparse/tests/test_sparse.py +476 -0
- maxframe/lib/sparse/vector.py +150 -0
- maxframe/lib/tblib/LICENSE +20 -0
- maxframe/lib/tblib/__init__.py +327 -0
- maxframe/lib/tblib/cpython.py +83 -0
- maxframe/lib/tblib/decorators.py +44 -0
- maxframe/lib/tblib/pickling_support.py +90 -0
- maxframe/lib/tests/__init__.py +13 -0
- maxframe/lib/tests/test_wrapped_pickle.py +51 -0
- maxframe/lib/version.py +620 -0
- maxframe/lib/wrapped_pickle.py +139 -0
- maxframe/mixin.py +100 -0
- maxframe/odpsio/__init__.py +21 -0
- maxframe/odpsio/arrow.py +91 -0
- maxframe/odpsio/schema.py +364 -0
- maxframe/odpsio/tableio.py +322 -0
- maxframe/odpsio/tests/__init__.py +13 -0
- maxframe/odpsio/tests/test_arrow.py +88 -0
- maxframe/odpsio/tests/test_schema.py +297 -0
- maxframe/odpsio/tests/test_tableio.py +136 -0
- maxframe/odpsio/tests/test_volumeio.py +90 -0
- maxframe/odpsio/volumeio.py +95 -0
- maxframe/opcodes.py +590 -0
- maxframe/protocol.py +415 -0
- maxframe/remote/__init__.py +18 -0
- maxframe/remote/core.py +210 -0
- maxframe/remote/run_script.py +121 -0
- maxframe/serialization/__init__.py +26 -0
- maxframe/serialization/arrow.py +95 -0
- maxframe/serialization/core.cpython-39-darwin.so +0 -0
- maxframe/serialization/core.pxd +44 -0
- maxframe/serialization/core.pyi +61 -0
- maxframe/serialization/core.pyx +1094 -0
- maxframe/serialization/exception.py +86 -0
- maxframe/serialization/maxframe_objects.py +39 -0
- maxframe/serialization/numpy.py +91 -0
- maxframe/serialization/pandas.py +202 -0
- maxframe/serialization/scipy.py +71 -0
- maxframe/serialization/serializables/__init__.py +55 -0
- maxframe/serialization/serializables/core.py +262 -0
- maxframe/serialization/serializables/field.py +624 -0
- maxframe/serialization/serializables/field_type.py +589 -0
- maxframe/serialization/serializables/tests/__init__.py +13 -0
- maxframe/serialization/serializables/tests/test_field_type.py +121 -0
- maxframe/serialization/serializables/tests/test_serializable.py +250 -0
- maxframe/serialization/tests/__init__.py +13 -0
- maxframe/serialization/tests/test_serial.py +412 -0
- maxframe/session.py +1310 -0
- maxframe/tensor/__init__.py +183 -0
- maxframe/tensor/arithmetic/__init__.py +315 -0
- maxframe/tensor/arithmetic/abs.py +68 -0
- maxframe/tensor/arithmetic/absolute.py +68 -0
- maxframe/tensor/arithmetic/add.py +82 -0
- maxframe/tensor/arithmetic/angle.py +72 -0
- maxframe/tensor/arithmetic/arccos.py +104 -0
- maxframe/tensor/arithmetic/arccosh.py +91 -0
- maxframe/tensor/arithmetic/arcsin.py +94 -0
- maxframe/tensor/arithmetic/arcsinh.py +86 -0
- maxframe/tensor/arithmetic/arctan.py +106 -0
- maxframe/tensor/arithmetic/arctan2.py +128 -0
- maxframe/tensor/arithmetic/arctanh.py +86 -0
- maxframe/tensor/arithmetic/around.py +114 -0
- maxframe/tensor/arithmetic/bitand.py +95 -0
- maxframe/tensor/arithmetic/bitor.py +102 -0
- maxframe/tensor/arithmetic/bitxor.py +95 -0
- maxframe/tensor/arithmetic/cbrt.py +66 -0
- maxframe/tensor/arithmetic/ceil.py +71 -0
- maxframe/tensor/arithmetic/clip.py +165 -0
- maxframe/tensor/arithmetic/conj.py +74 -0
- maxframe/tensor/arithmetic/copysign.py +78 -0
- maxframe/tensor/arithmetic/core.py +544 -0
- maxframe/tensor/arithmetic/cos.py +85 -0
- maxframe/tensor/arithmetic/cosh.py +72 -0
- maxframe/tensor/arithmetic/deg2rad.py +72 -0
- maxframe/tensor/arithmetic/degrees.py +77 -0
- maxframe/tensor/arithmetic/divide.py +114 -0
- maxframe/tensor/arithmetic/equal.py +76 -0
- maxframe/tensor/arithmetic/exp.py +106 -0
- maxframe/tensor/arithmetic/exp2.py +67 -0
- maxframe/tensor/arithmetic/expm1.py +79 -0
- maxframe/tensor/arithmetic/fabs.py +74 -0
- maxframe/tensor/arithmetic/fix.py +69 -0
- maxframe/tensor/arithmetic/float_power.py +103 -0
- maxframe/tensor/arithmetic/floor.py +77 -0
- maxframe/tensor/arithmetic/floordiv.py +94 -0
- maxframe/tensor/arithmetic/fmax.py +105 -0
- maxframe/tensor/arithmetic/fmin.py +106 -0
- maxframe/tensor/arithmetic/fmod.py +99 -0
- maxframe/tensor/arithmetic/frexp.py +92 -0
- maxframe/tensor/arithmetic/greater.py +77 -0
- maxframe/tensor/arithmetic/greater_equal.py +69 -0
- maxframe/tensor/arithmetic/hypot.py +77 -0
- maxframe/tensor/arithmetic/i0.py +89 -0
- maxframe/tensor/arithmetic/imag.py +67 -0
- maxframe/tensor/arithmetic/invert.py +110 -0
- maxframe/tensor/arithmetic/isclose.py +115 -0
- maxframe/tensor/arithmetic/iscomplex.py +64 -0
- maxframe/tensor/arithmetic/isfinite.py +106 -0
- maxframe/tensor/arithmetic/isinf.py +103 -0
- maxframe/tensor/arithmetic/isnan.py +82 -0
- maxframe/tensor/arithmetic/isreal.py +63 -0
- maxframe/tensor/arithmetic/ldexp.py +99 -0
- maxframe/tensor/arithmetic/less.py +69 -0
- maxframe/tensor/arithmetic/less_equal.py +69 -0
- maxframe/tensor/arithmetic/log.py +92 -0
- maxframe/tensor/arithmetic/log10.py +85 -0
- maxframe/tensor/arithmetic/log1p.py +95 -0
- maxframe/tensor/arithmetic/log2.py +85 -0
- maxframe/tensor/arithmetic/logaddexp.py +80 -0
- maxframe/tensor/arithmetic/logaddexp2.py +78 -0
- maxframe/tensor/arithmetic/logical_and.py +81 -0
- maxframe/tensor/arithmetic/logical_not.py +74 -0
- maxframe/tensor/arithmetic/logical_or.py +82 -0
- maxframe/tensor/arithmetic/logical_xor.py +88 -0
- maxframe/tensor/arithmetic/lshift.py +82 -0
- maxframe/tensor/arithmetic/maximum.py +108 -0
- maxframe/tensor/arithmetic/minimum.py +108 -0
- maxframe/tensor/arithmetic/mod.py +104 -0
- maxframe/tensor/arithmetic/modf.py +83 -0
- maxframe/tensor/arithmetic/multiply.py +81 -0
- maxframe/tensor/arithmetic/nan_to_num.py +99 -0
- maxframe/tensor/arithmetic/negative.py +65 -0
- maxframe/tensor/arithmetic/nextafter.py +68 -0
- maxframe/tensor/arithmetic/not_equal.py +72 -0
- maxframe/tensor/arithmetic/positive.py +47 -0
- maxframe/tensor/arithmetic/power.py +106 -0
- maxframe/tensor/arithmetic/rad2deg.py +71 -0
- maxframe/tensor/arithmetic/radians.py +77 -0
- maxframe/tensor/arithmetic/real.py +70 -0
- maxframe/tensor/arithmetic/reciprocal.py +76 -0
- maxframe/tensor/arithmetic/rint.py +68 -0
- maxframe/tensor/arithmetic/rshift.py +81 -0
- maxframe/tensor/arithmetic/setimag.py +29 -0
- maxframe/tensor/arithmetic/setreal.py +29 -0
- maxframe/tensor/arithmetic/sign.py +81 -0
- maxframe/tensor/arithmetic/signbit.py +65 -0
- maxframe/tensor/arithmetic/sin.py +98 -0
- maxframe/tensor/arithmetic/sinc.py +102 -0
- maxframe/tensor/arithmetic/sinh.py +93 -0
- maxframe/tensor/arithmetic/spacing.py +72 -0
- maxframe/tensor/arithmetic/sqrt.py +81 -0
- maxframe/tensor/arithmetic/square.py +69 -0
- maxframe/tensor/arithmetic/subtract.py +81 -0
- maxframe/tensor/arithmetic/tan.py +88 -0
- maxframe/tensor/arithmetic/tanh.py +92 -0
- maxframe/tensor/arithmetic/tests/__init__.py +15 -0
- maxframe/tensor/arithmetic/tests/test_arithmetic.py +414 -0
- maxframe/tensor/arithmetic/truediv.py +104 -0
- maxframe/tensor/arithmetic/trunc.py +72 -0
- maxframe/tensor/arithmetic/utils.py +65 -0
- maxframe/tensor/array_utils.py +186 -0
- maxframe/tensor/base/__init__.py +34 -0
- maxframe/tensor/base/astype.py +119 -0
- maxframe/tensor/base/atleast_1d.py +74 -0
- maxframe/tensor/base/broadcast_to.py +89 -0
- maxframe/tensor/base/ravel.py +92 -0
- maxframe/tensor/base/tests/__init__.py +13 -0
- maxframe/tensor/base/tests/test_base.py +114 -0
- maxframe/tensor/base/transpose.py +125 -0
- maxframe/tensor/base/unique.py +205 -0
- maxframe/tensor/base/where.py +127 -0
- maxframe/tensor/core.py +724 -0
- maxframe/tensor/datasource/__init__.py +32 -0
- maxframe/tensor/datasource/arange.py +156 -0
- maxframe/tensor/datasource/array.py +415 -0
- maxframe/tensor/datasource/core.py +109 -0
- maxframe/tensor/datasource/empty.py +169 -0
- maxframe/tensor/datasource/from_dataframe.py +70 -0
- maxframe/tensor/datasource/from_dense.py +54 -0
- maxframe/tensor/datasource/from_sparse.py +47 -0
- maxframe/tensor/datasource/full.py +186 -0
- maxframe/tensor/datasource/ones.py +173 -0
- maxframe/tensor/datasource/scalar.py +40 -0
- maxframe/tensor/datasource/tests/__init__.py +13 -0
- maxframe/tensor/datasource/tests/test_datasource.py +278 -0
- maxframe/tensor/datasource/zeros.py +188 -0
- maxframe/tensor/fetch/__init__.py +15 -0
- maxframe/tensor/fetch/core.py +54 -0
- maxframe/tensor/indexing/__init__.py +47 -0
- maxframe/tensor/indexing/choose.py +196 -0
- maxframe/tensor/indexing/compress.py +124 -0
- maxframe/tensor/indexing/core.py +190 -0
- maxframe/tensor/indexing/extract.py +71 -0
- maxframe/tensor/indexing/fill_diagonal.py +183 -0
- maxframe/tensor/indexing/flatnonzero.py +60 -0
- maxframe/tensor/indexing/getitem.py +175 -0
- maxframe/tensor/indexing/nonzero.py +120 -0
- maxframe/tensor/indexing/setitem.py +132 -0
- maxframe/tensor/indexing/slice.py +29 -0
- maxframe/tensor/indexing/take.py +130 -0
- maxframe/tensor/indexing/tests/__init__.py +15 -0
- maxframe/tensor/indexing/tests/test_indexing.py +234 -0
- maxframe/tensor/indexing/unravel_index.py +103 -0
- maxframe/tensor/merge/__init__.py +15 -0
- maxframe/tensor/merge/stack.py +132 -0
- maxframe/tensor/merge/tests/__init__.py +13 -0
- maxframe/tensor/merge/tests/test_merge.py +52 -0
- maxframe/tensor/operators.py +123 -0
- maxframe/tensor/random/__init__.py +168 -0
- maxframe/tensor/random/beta.py +87 -0
- maxframe/tensor/random/binomial.py +137 -0
- maxframe/tensor/random/bytes.py +39 -0
- maxframe/tensor/random/chisquare.py +110 -0
- maxframe/tensor/random/choice.py +186 -0
- maxframe/tensor/random/core.py +234 -0
- maxframe/tensor/random/dirichlet.py +123 -0
- maxframe/tensor/random/exponential.py +94 -0
- maxframe/tensor/random/f.py +135 -0
- maxframe/tensor/random/gamma.py +128 -0
- maxframe/tensor/random/geometric.py +93 -0
- maxframe/tensor/random/gumbel.py +167 -0
- maxframe/tensor/random/hypergeometric.py +148 -0
- maxframe/tensor/random/laplace.py +133 -0
- maxframe/tensor/random/logistic.py +129 -0
- maxframe/tensor/random/lognormal.py +159 -0
- maxframe/tensor/random/logseries.py +122 -0
- maxframe/tensor/random/multinomial.py +133 -0
- maxframe/tensor/random/multivariate_normal.py +192 -0
- maxframe/tensor/random/negative_binomial.py +125 -0
- maxframe/tensor/random/noncentral_chisquare.py +132 -0
- maxframe/tensor/random/noncentral_f.py +126 -0
- maxframe/tensor/random/normal.py +143 -0
- maxframe/tensor/random/pareto.py +140 -0
- maxframe/tensor/random/permutation.py +104 -0
- maxframe/tensor/random/poisson.py +111 -0
- maxframe/tensor/random/power.py +142 -0
- maxframe/tensor/random/rand.py +82 -0
- maxframe/tensor/random/randint.py +121 -0
- maxframe/tensor/random/randn.py +96 -0
- maxframe/tensor/random/random_integers.py +123 -0
- maxframe/tensor/random/random_sample.py +86 -0
- maxframe/tensor/random/rayleigh.py +110 -0
- maxframe/tensor/random/shuffle.py +61 -0
- maxframe/tensor/random/standard_cauchy.py +105 -0
- maxframe/tensor/random/standard_exponential.py +72 -0
- maxframe/tensor/random/standard_gamma.py +120 -0
- maxframe/tensor/random/standard_normal.py +74 -0
- maxframe/tensor/random/standard_t.py +135 -0
- maxframe/tensor/random/tests/__init__.py +15 -0
- maxframe/tensor/random/tests/test_random.py +167 -0
- maxframe/tensor/random/triangular.py +119 -0
- maxframe/tensor/random/uniform.py +131 -0
- maxframe/tensor/random/vonmises.py +131 -0
- maxframe/tensor/random/wald.py +114 -0
- maxframe/tensor/random/weibull.py +140 -0
- maxframe/tensor/random/zipf.py +122 -0
- maxframe/tensor/rechunk/__init__.py +26 -0
- maxframe/tensor/rechunk/rechunk.py +43 -0
- maxframe/tensor/reduction/__init__.py +66 -0
- maxframe/tensor/reduction/all.py +103 -0
- maxframe/tensor/reduction/allclose.py +88 -0
- maxframe/tensor/reduction/any.py +105 -0
- maxframe/tensor/reduction/argmax.py +103 -0
- maxframe/tensor/reduction/argmin.py +103 -0
- maxframe/tensor/reduction/array_equal.py +64 -0
- maxframe/tensor/reduction/core.py +168 -0
- maxframe/tensor/reduction/count_nonzero.py +81 -0
- maxframe/tensor/reduction/cumprod.py +97 -0
- maxframe/tensor/reduction/cumsum.py +101 -0
- maxframe/tensor/reduction/max.py +120 -0
- maxframe/tensor/reduction/mean.py +123 -0
- maxframe/tensor/reduction/min.py +120 -0
- maxframe/tensor/reduction/nanargmax.py +82 -0
- maxframe/tensor/reduction/nanargmin.py +76 -0
- maxframe/tensor/reduction/nancumprod.py +91 -0
- maxframe/tensor/reduction/nancumsum.py +94 -0
- maxframe/tensor/reduction/nanmax.py +111 -0
- maxframe/tensor/reduction/nanmean.py +106 -0
- maxframe/tensor/reduction/nanmin.py +111 -0
- maxframe/tensor/reduction/nanprod.py +94 -0
- maxframe/tensor/reduction/nanstd.py +126 -0
- maxframe/tensor/reduction/nansum.py +115 -0
- maxframe/tensor/reduction/nanvar.py +149 -0
- maxframe/tensor/reduction/prod.py +130 -0
- maxframe/tensor/reduction/std.py +134 -0
- maxframe/tensor/reduction/sum.py +125 -0
- maxframe/tensor/reduction/tests/__init__.py +13 -0
- maxframe/tensor/reduction/tests/test_reduction.py +181 -0
- maxframe/tensor/reduction/var.py +176 -0
- maxframe/tensor/reshape/__init__.py +17 -0
- maxframe/tensor/reshape/reshape.py +188 -0
- maxframe/tensor/reshape/tests/__init__.py +15 -0
- maxframe/tensor/reshape/tests/test_reshape.py +37 -0
- maxframe/tensor/statistics/__init__.py +13 -0
- maxframe/tensor/statistics/percentile.py +175 -0
- maxframe/tensor/statistics/quantile.py +288 -0
- maxframe/tensor/ufunc/__init__.py +26 -0
- maxframe/tensor/ufunc/ufunc.py +200 -0
- maxframe/tensor/utils.py +718 -0
- maxframe/tests/__init__.py +13 -0
- maxframe/tests/test_codegen.py +69 -0
- maxframe/tests/test_protocol.py +144 -0
- maxframe/tests/test_utils.py +376 -0
- maxframe/tests/utils.py +164 -0
- maxframe/typing_.py +37 -0
- maxframe/udf.py +134 -0
- maxframe/utils.py +1114 -0
- maxframe-0.1.0b5.dist-info/METADATA +104 -0
- maxframe-0.1.0b5.dist-info/RECORD +647 -0
- maxframe-0.1.0b5.dist-info/WHEEL +5 -0
- maxframe-0.1.0b5.dist-info/top_level.txt +3 -0
- maxframe_client/__init__.py +17 -0
- maxframe_client/clients/__init__.py +13 -0
- maxframe_client/clients/framedriver.py +118 -0
- maxframe_client/clients/spe.py +104 -0
- maxframe_client/conftest.py +15 -0
- maxframe_client/fetcher.py +264 -0
- maxframe_client/session/__init__.py +22 -0
- maxframe_client/session/consts.py +36 -0
- maxframe_client/session/graph.py +119 -0
- maxframe_client/session/odps.py +482 -0
- maxframe_client/session/task.py +280 -0
- maxframe_client/session/tests/__init__.py +13 -0
- maxframe_client/session/tests/test_task.py +85 -0
- maxframe_client/tests/__init__.py +13 -0
- maxframe_client/tests/test_fetcher.py +89 -0
- maxframe_client/tests/test_session.py +255 -0
maxframe/lib/version.py
ADDED
|
@@ -0,0 +1,620 @@
|
|
|
1
|
+
# Copyright 1999-2024 Alibaba Group Holding Ltd.
|
|
2
|
+
#
|
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
+
# you may not use this file except in compliance with the License.
|
|
5
|
+
# You may obtain a copy of the License at
|
|
6
|
+
#
|
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
#
|
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
+
# See the License for the specific language governing permissions and
|
|
13
|
+
# limitations under the License.
|
|
14
|
+
|
|
15
|
+
# File merged from these files:
|
|
16
|
+
# setuptools/pkg_resources/_vendor/packaging/_structures.py
|
|
17
|
+
# setuptools/pkg_resources/_vendor/packaging/_typing.py
|
|
18
|
+
# setuptools/pkg_resources/_vendor/packaging/version.py
|
|
19
|
+
# Originally released under Apache License, Version 2.0, and the BSD License.
|
|
20
|
+
|
|
21
|
+
# This file is dual licensed under the terms of the Apache License, Version
|
|
22
|
+
# 2.0, and the BSD License. See the LICENSE file in the root of this repository
|
|
23
|
+
# for complete details.
|
|
24
|
+
|
|
25
|
+
# Copyright Jason R. Coombs
|
|
26
|
+
#
|
|
27
|
+
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
28
|
+
# of this software and associated documentation files (the "Software"), to
|
|
29
|
+
# deal in the Software without restriction, including without limitation the
|
|
30
|
+
# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
31
|
+
# sell copies of the Software, and to permit persons to whom the Software is
|
|
32
|
+
# furnished to do so, subject to the following conditions:
|
|
33
|
+
#
|
|
34
|
+
# The above copyright notice and this permission notice shall be included in
|
|
35
|
+
# all copies or substantial portions of the Software.
|
|
36
|
+
#
|
|
37
|
+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
38
|
+
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
39
|
+
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
40
|
+
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
41
|
+
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
42
|
+
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
|
43
|
+
# IN THE SOFTWARE.
|
|
44
|
+
|
|
45
|
+
import collections
|
|
46
|
+
import itertools
|
|
47
|
+
import re
|
|
48
|
+
import warnings
|
|
49
|
+
from typing import Callable, Iterator, List, Optional, SupportsInt, Tuple, Union
|
|
50
|
+
|
|
51
|
+
__all__ = ["parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN"]
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
class InfinityType(object):
|
|
55
|
+
def __repr__(self):
|
|
56
|
+
# type: () -> str
|
|
57
|
+
return "Infinity"
|
|
58
|
+
|
|
59
|
+
def __hash__(self):
|
|
60
|
+
# type: () -> int
|
|
61
|
+
return hash(repr(self))
|
|
62
|
+
|
|
63
|
+
def __lt__(self, other):
|
|
64
|
+
# type: (object) -> bool
|
|
65
|
+
return False
|
|
66
|
+
|
|
67
|
+
def __le__(self, other):
|
|
68
|
+
# type: (object) -> bool
|
|
69
|
+
return False
|
|
70
|
+
|
|
71
|
+
def __eq__(self, other):
|
|
72
|
+
# type: (object) -> bool
|
|
73
|
+
return isinstance(other, self.__class__)
|
|
74
|
+
|
|
75
|
+
def __ne__(self, other):
|
|
76
|
+
# type: (object) -> bool
|
|
77
|
+
return not isinstance(other, self.__class__)
|
|
78
|
+
|
|
79
|
+
def __gt__(self, other):
|
|
80
|
+
# type: (object) -> bool
|
|
81
|
+
return True
|
|
82
|
+
|
|
83
|
+
def __ge__(self, other):
|
|
84
|
+
# type: (object) -> bool
|
|
85
|
+
return True
|
|
86
|
+
|
|
87
|
+
def __neg__(self):
|
|
88
|
+
# type: (object) -> NegativeInfinityType
|
|
89
|
+
return NegativeInfinity
|
|
90
|
+
|
|
91
|
+
|
|
92
|
+
Infinity = InfinityType()
|
|
93
|
+
|
|
94
|
+
|
|
95
|
+
class NegativeInfinityType(object):
|
|
96
|
+
def __repr__(self):
|
|
97
|
+
# type: () -> str
|
|
98
|
+
return "-Infinity"
|
|
99
|
+
|
|
100
|
+
def __hash__(self):
|
|
101
|
+
# type: () -> int
|
|
102
|
+
return hash(repr(self))
|
|
103
|
+
|
|
104
|
+
def __lt__(self, other):
|
|
105
|
+
# type: (object) -> bool
|
|
106
|
+
return True
|
|
107
|
+
|
|
108
|
+
def __le__(self, other):
|
|
109
|
+
# type: (object) -> bool
|
|
110
|
+
return True
|
|
111
|
+
|
|
112
|
+
def __eq__(self, other):
|
|
113
|
+
# type: (object) -> bool
|
|
114
|
+
return isinstance(other, self.__class__)
|
|
115
|
+
|
|
116
|
+
def __ne__(self, other):
|
|
117
|
+
# type: (object) -> bool
|
|
118
|
+
return not isinstance(other, self.__class__)
|
|
119
|
+
|
|
120
|
+
def __gt__(self, other):
|
|
121
|
+
# type: (object) -> bool
|
|
122
|
+
return False
|
|
123
|
+
|
|
124
|
+
def __ge__(self, other):
|
|
125
|
+
# type: (object) -> bool
|
|
126
|
+
return False
|
|
127
|
+
|
|
128
|
+
def __neg__(self):
|
|
129
|
+
# type: (object) -> InfinityType
|
|
130
|
+
return Infinity
|
|
131
|
+
|
|
132
|
+
|
|
133
|
+
NegativeInfinity = NegativeInfinityType()
|
|
134
|
+
|
|
135
|
+
|
|
136
|
+
InfiniteTypes = Union[InfinityType, NegativeInfinityType]
|
|
137
|
+
PrePostDevType = Union[InfiniteTypes, Tuple[str, int]]
|
|
138
|
+
SubLocalType = Union[InfiniteTypes, int, str]
|
|
139
|
+
LocalType = Union[
|
|
140
|
+
NegativeInfinityType,
|
|
141
|
+
Tuple[
|
|
142
|
+
Union[
|
|
143
|
+
SubLocalType,
|
|
144
|
+
Tuple[SubLocalType, str],
|
|
145
|
+
Tuple[NegativeInfinityType, SubLocalType],
|
|
146
|
+
],
|
|
147
|
+
...,
|
|
148
|
+
],
|
|
149
|
+
]
|
|
150
|
+
CmpKey = Tuple[
|
|
151
|
+
int, Tuple[int, ...], PrePostDevType, PrePostDevType, PrePostDevType, LocalType
|
|
152
|
+
]
|
|
153
|
+
LegacyCmpKey = Tuple[int, Tuple[str, ...]]
|
|
154
|
+
VersionComparisonMethod = Callable[
|
|
155
|
+
[Union[CmpKey, LegacyCmpKey], Union[CmpKey, LegacyCmpKey]], bool
|
|
156
|
+
]
|
|
157
|
+
|
|
158
|
+
_Version = collections.namedtuple(
|
|
159
|
+
"_Version", ["epoch", "release", "dev", "pre", "post", "local"]
|
|
160
|
+
)
|
|
161
|
+
|
|
162
|
+
|
|
163
|
+
def parse(version: str) -> Union["LegacyVersion", "Version"]:
|
|
164
|
+
"""
|
|
165
|
+
Parse the given version string and return either a :class:`Version` object
|
|
166
|
+
or a :class:`LegacyVersion` object depending on if the given version is
|
|
167
|
+
a valid PEP 440 version or a legacy version.
|
|
168
|
+
"""
|
|
169
|
+
try:
|
|
170
|
+
return Version(version)
|
|
171
|
+
except InvalidVersion:
|
|
172
|
+
return LegacyVersion(version)
|
|
173
|
+
|
|
174
|
+
|
|
175
|
+
class InvalidVersion(ValueError):
|
|
176
|
+
"""
|
|
177
|
+
An invalid version was found, users should refer to PEP 440.
|
|
178
|
+
"""
|
|
179
|
+
|
|
180
|
+
|
|
181
|
+
class _BaseVersion:
|
|
182
|
+
_key: Union[CmpKey, LegacyCmpKey]
|
|
183
|
+
|
|
184
|
+
def __hash__(self) -> int:
|
|
185
|
+
return hash(self._key)
|
|
186
|
+
|
|
187
|
+
# Please keep the duplicated `isinstance` check
|
|
188
|
+
# in the six comparisons hereunder
|
|
189
|
+
# unless you find a way to avoid adding overhead function calls.
|
|
190
|
+
def __lt__(self, other: "_BaseVersion") -> bool:
|
|
191
|
+
if not isinstance(other, _BaseVersion):
|
|
192
|
+
return NotImplemented
|
|
193
|
+
|
|
194
|
+
return self._key < other._key
|
|
195
|
+
|
|
196
|
+
def __le__(self, other: "_BaseVersion") -> bool:
|
|
197
|
+
if not isinstance(other, _BaseVersion):
|
|
198
|
+
return NotImplemented
|
|
199
|
+
|
|
200
|
+
return self._key <= other._key
|
|
201
|
+
|
|
202
|
+
def __eq__(self, other: object) -> bool:
|
|
203
|
+
if not isinstance(other, _BaseVersion):
|
|
204
|
+
return NotImplemented
|
|
205
|
+
|
|
206
|
+
return self._key == other._key
|
|
207
|
+
|
|
208
|
+
def __ge__(self, other: "_BaseVersion") -> bool:
|
|
209
|
+
if not isinstance(other, _BaseVersion):
|
|
210
|
+
return NotImplemented
|
|
211
|
+
|
|
212
|
+
return self._key >= other._key
|
|
213
|
+
|
|
214
|
+
def __gt__(self, other: "_BaseVersion") -> bool:
|
|
215
|
+
if not isinstance(other, _BaseVersion):
|
|
216
|
+
return NotImplemented
|
|
217
|
+
|
|
218
|
+
return self._key > other._key
|
|
219
|
+
|
|
220
|
+
def __ne__(self, other: object) -> bool:
|
|
221
|
+
if not isinstance(other, _BaseVersion):
|
|
222
|
+
return NotImplemented
|
|
223
|
+
|
|
224
|
+
return self._key != other._key
|
|
225
|
+
|
|
226
|
+
|
|
227
|
+
class LegacyVersion(_BaseVersion):
|
|
228
|
+
def __init__(self, version: str) -> None:
|
|
229
|
+
self._version = str(version)
|
|
230
|
+
self._key = _legacy_cmpkey(self._version)
|
|
231
|
+
|
|
232
|
+
warnings.warn(
|
|
233
|
+
"Creating a LegacyVersion has been deprecated and will be "
|
|
234
|
+
"removed in the next major release",
|
|
235
|
+
DeprecationWarning,
|
|
236
|
+
)
|
|
237
|
+
|
|
238
|
+
def __str__(self) -> str:
|
|
239
|
+
return self._version
|
|
240
|
+
|
|
241
|
+
def __repr__(self) -> str:
|
|
242
|
+
return f"<LegacyVersion('{self}')>"
|
|
243
|
+
|
|
244
|
+
@property
|
|
245
|
+
def public(self) -> str:
|
|
246
|
+
return self._version
|
|
247
|
+
|
|
248
|
+
@property
|
|
249
|
+
def base_version(self) -> str:
|
|
250
|
+
return self._version
|
|
251
|
+
|
|
252
|
+
@property
|
|
253
|
+
def epoch(self) -> int:
|
|
254
|
+
return -1
|
|
255
|
+
|
|
256
|
+
@property
|
|
257
|
+
def release(self) -> None:
|
|
258
|
+
return None
|
|
259
|
+
|
|
260
|
+
@property
|
|
261
|
+
def pre(self) -> None:
|
|
262
|
+
return None
|
|
263
|
+
|
|
264
|
+
@property
|
|
265
|
+
def post(self) -> None:
|
|
266
|
+
return None
|
|
267
|
+
|
|
268
|
+
@property
|
|
269
|
+
def dev(self) -> None:
|
|
270
|
+
return None
|
|
271
|
+
|
|
272
|
+
@property
|
|
273
|
+
def local(self) -> None:
|
|
274
|
+
return None
|
|
275
|
+
|
|
276
|
+
@property
|
|
277
|
+
def is_prerelease(self) -> bool:
|
|
278
|
+
return False
|
|
279
|
+
|
|
280
|
+
@property
|
|
281
|
+
def is_postrelease(self) -> bool:
|
|
282
|
+
return False
|
|
283
|
+
|
|
284
|
+
@property
|
|
285
|
+
def is_devrelease(self) -> bool:
|
|
286
|
+
return False
|
|
287
|
+
|
|
288
|
+
|
|
289
|
+
_legacy_version_component_re = re.compile(r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE)
|
|
290
|
+
|
|
291
|
+
_legacy_version_replacement_map = {
|
|
292
|
+
"pre": "c",
|
|
293
|
+
"preview": "c",
|
|
294
|
+
"-": "final-",
|
|
295
|
+
"rc": "c",
|
|
296
|
+
"dev": "@",
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
|
|
300
|
+
def _parse_version_parts(s: str) -> Iterator[str]:
|
|
301
|
+
for part in _legacy_version_component_re.split(s):
|
|
302
|
+
part = _legacy_version_replacement_map.get(part, part)
|
|
303
|
+
|
|
304
|
+
if not part or part == ".":
|
|
305
|
+
continue
|
|
306
|
+
|
|
307
|
+
if part[:1] in "0123456789":
|
|
308
|
+
# pad for numeric comparison
|
|
309
|
+
yield part.zfill(8)
|
|
310
|
+
else:
|
|
311
|
+
yield "*" + part
|
|
312
|
+
|
|
313
|
+
# ensure that alpha/beta/candidate are before final
|
|
314
|
+
yield "*final"
|
|
315
|
+
|
|
316
|
+
|
|
317
|
+
def _legacy_cmpkey(version: str) -> LegacyCmpKey:
|
|
318
|
+
# We hardcode an epoch of -1 here. A PEP 440 version can only have a epoch
|
|
319
|
+
# greater than or equal to 0. This will effectively put the LegacyVersion,
|
|
320
|
+
# which uses the defacto standard originally implemented by setuptools,
|
|
321
|
+
# as before all PEP 440 versions.
|
|
322
|
+
epoch = -1
|
|
323
|
+
|
|
324
|
+
# This scheme is taken from pkg_resources.parse_version setuptools prior to
|
|
325
|
+
# it's adoption of the packaging library.
|
|
326
|
+
parts: List[str] = []
|
|
327
|
+
for part in _parse_version_parts(version.lower()):
|
|
328
|
+
if part.startswith("*"):
|
|
329
|
+
# remove "-" before a prerelease tag
|
|
330
|
+
if part < "*final":
|
|
331
|
+
while parts and parts[-1] == "*final-":
|
|
332
|
+
parts.pop()
|
|
333
|
+
|
|
334
|
+
# remove trailing zeros from each series of numeric parts
|
|
335
|
+
while parts and parts[-1] == "00000000":
|
|
336
|
+
parts.pop()
|
|
337
|
+
|
|
338
|
+
parts.append(part)
|
|
339
|
+
|
|
340
|
+
return epoch, tuple(parts)
|
|
341
|
+
|
|
342
|
+
|
|
343
|
+
# Deliberately not anchored to the start and end of the string, to make it
|
|
344
|
+
# easier for 3rd party code to reuse
|
|
345
|
+
VERSION_PATTERN = r"""
|
|
346
|
+
v?
|
|
347
|
+
(?:
|
|
348
|
+
(?:(?P<epoch>[0-9]+)!)? # epoch
|
|
349
|
+
(?P<release>[0-9]+(?:\.[0-9]+)*) # release segment
|
|
350
|
+
(?P<pre> # pre-release
|
|
351
|
+
[-_\.]?
|
|
352
|
+
(?P<pre_l>(a|b|c|rc|alpha|beta|pre|preview))
|
|
353
|
+
[-_\.]?
|
|
354
|
+
(?P<pre_n>[0-9]+)?
|
|
355
|
+
)?
|
|
356
|
+
(?P<post> # post release
|
|
357
|
+
(?:-(?P<post_n1>[0-9]+))
|
|
358
|
+
|
|
|
359
|
+
(?:
|
|
360
|
+
[-_\.]?
|
|
361
|
+
(?P<post_l>post|rev|r)
|
|
362
|
+
[-_\.]?
|
|
363
|
+
(?P<post_n2>[0-9]+)?
|
|
364
|
+
)
|
|
365
|
+
)?
|
|
366
|
+
(?P<dev> # dev release
|
|
367
|
+
[-_\.]?
|
|
368
|
+
(?P<dev_l>dev)
|
|
369
|
+
[-_\.]?
|
|
370
|
+
(?P<dev_n>[0-9]+)?
|
|
371
|
+
)?
|
|
372
|
+
)
|
|
373
|
+
(?:\+(?P<local>[a-z0-9]+(?:[-_\.][a-z0-9]+)*))? # local version
|
|
374
|
+
"""
|
|
375
|
+
|
|
376
|
+
|
|
377
|
+
class Version(_BaseVersion):
|
|
378
|
+
_regex = re.compile(r"^\s*" + VERSION_PATTERN + r"\s*$", re.VERBOSE | re.IGNORECASE)
|
|
379
|
+
|
|
380
|
+
def __init__(self, version: str) -> None:
|
|
381
|
+
# Validate the version and parse it into pieces
|
|
382
|
+
match = self._regex.search(version)
|
|
383
|
+
if not match:
|
|
384
|
+
raise InvalidVersion(f"Invalid version: '{version}'")
|
|
385
|
+
|
|
386
|
+
# Store the parsed out pieces of the version
|
|
387
|
+
self._version = _Version(
|
|
388
|
+
epoch=int(match.group("epoch")) if match.group("epoch") else 0,
|
|
389
|
+
release=tuple(int(i) for i in match.group("release").split(".")),
|
|
390
|
+
pre=_parse_letter_version(match.group("pre_l"), match.group("pre_n")),
|
|
391
|
+
post=_parse_letter_version(
|
|
392
|
+
match.group("post_l"), match.group("post_n1") or match.group("post_n2")
|
|
393
|
+
),
|
|
394
|
+
dev=_parse_letter_version(match.group("dev_l"), match.group("dev_n")),
|
|
395
|
+
local=_parse_local_version(match.group("local")),
|
|
396
|
+
)
|
|
397
|
+
|
|
398
|
+
# Generate a key which will be used for sorting
|
|
399
|
+
self._key = _cmpkey(
|
|
400
|
+
self._version.epoch,
|
|
401
|
+
self._version.release,
|
|
402
|
+
self._version.pre,
|
|
403
|
+
self._version.post,
|
|
404
|
+
self._version.dev,
|
|
405
|
+
self._version.local,
|
|
406
|
+
)
|
|
407
|
+
|
|
408
|
+
def __repr__(self) -> str:
|
|
409
|
+
return f"<Version('{self}')>"
|
|
410
|
+
|
|
411
|
+
def __str__(self) -> str:
|
|
412
|
+
parts = []
|
|
413
|
+
|
|
414
|
+
# Epoch
|
|
415
|
+
if self.epoch != 0:
|
|
416
|
+
parts.append(f"{self.epoch}!")
|
|
417
|
+
|
|
418
|
+
# Release segment
|
|
419
|
+
parts.append(".".join(str(x) for x in self.release))
|
|
420
|
+
|
|
421
|
+
# Pre-release
|
|
422
|
+
if self.pre is not None:
|
|
423
|
+
parts.append("".join(str(x) for x in self.pre))
|
|
424
|
+
|
|
425
|
+
# Post-release
|
|
426
|
+
if self.post is not None:
|
|
427
|
+
parts.append(f".post{self.post}")
|
|
428
|
+
|
|
429
|
+
# Development release
|
|
430
|
+
if self.dev is not None:
|
|
431
|
+
parts.append(f".dev{self.dev}")
|
|
432
|
+
|
|
433
|
+
# Local version segment
|
|
434
|
+
if self.local is not None:
|
|
435
|
+
parts.append(f"+{self.local}")
|
|
436
|
+
|
|
437
|
+
return "".join(parts)
|
|
438
|
+
|
|
439
|
+
@property
|
|
440
|
+
def epoch(self) -> int:
|
|
441
|
+
_epoch: int = self._version.epoch
|
|
442
|
+
return _epoch
|
|
443
|
+
|
|
444
|
+
@property
|
|
445
|
+
def release(self) -> Tuple[int, ...]:
|
|
446
|
+
_release: Tuple[int, ...] = self._version.release
|
|
447
|
+
return _release
|
|
448
|
+
|
|
449
|
+
@property
|
|
450
|
+
def pre(self) -> Optional[Tuple[str, int]]:
|
|
451
|
+
_pre: Optional[Tuple[str, int]] = self._version.pre
|
|
452
|
+
return _pre
|
|
453
|
+
|
|
454
|
+
@property
|
|
455
|
+
def post(self) -> Optional[int]:
|
|
456
|
+
return self._version.post[1] if self._version.post else None
|
|
457
|
+
|
|
458
|
+
@property
|
|
459
|
+
def dev(self) -> Optional[int]:
|
|
460
|
+
return self._version.dev[1] if self._version.dev else None
|
|
461
|
+
|
|
462
|
+
@property
|
|
463
|
+
def local(self) -> Optional[str]:
|
|
464
|
+
if self._version.local:
|
|
465
|
+
return ".".join(str(x) for x in self._version.local)
|
|
466
|
+
else:
|
|
467
|
+
return None
|
|
468
|
+
|
|
469
|
+
@property
|
|
470
|
+
def public(self) -> str:
|
|
471
|
+
return str(self).split("+", 1)[0]
|
|
472
|
+
|
|
473
|
+
@property
|
|
474
|
+
def base_version(self) -> str:
|
|
475
|
+
parts = []
|
|
476
|
+
|
|
477
|
+
# Epoch
|
|
478
|
+
if self.epoch != 0:
|
|
479
|
+
parts.append(f"{self.epoch}!")
|
|
480
|
+
|
|
481
|
+
# Release segment
|
|
482
|
+
parts.append(".".join(str(x) for x in self.release))
|
|
483
|
+
|
|
484
|
+
return "".join(parts)
|
|
485
|
+
|
|
486
|
+
@property
|
|
487
|
+
def is_prerelease(self) -> bool:
|
|
488
|
+
return self.dev is not None or self.pre is not None
|
|
489
|
+
|
|
490
|
+
@property
|
|
491
|
+
def is_postrelease(self) -> bool:
|
|
492
|
+
return self.post is not None
|
|
493
|
+
|
|
494
|
+
@property
|
|
495
|
+
def is_devrelease(self) -> bool:
|
|
496
|
+
return self.dev is not None
|
|
497
|
+
|
|
498
|
+
@property
|
|
499
|
+
def major(self) -> int:
|
|
500
|
+
return self.release[0] if len(self.release) >= 1 else 0
|
|
501
|
+
|
|
502
|
+
@property
|
|
503
|
+
def minor(self) -> int:
|
|
504
|
+
return self.release[1] if len(self.release) >= 2 else 0
|
|
505
|
+
|
|
506
|
+
@property
|
|
507
|
+
def micro(self) -> int:
|
|
508
|
+
return self.release[2] if len(self.release) >= 3 else 0
|
|
509
|
+
|
|
510
|
+
|
|
511
|
+
def _parse_letter_version(
|
|
512
|
+
letter: str, number: Union[str, bytes, SupportsInt]
|
|
513
|
+
) -> Optional[Tuple[str, int]]:
|
|
514
|
+
if letter:
|
|
515
|
+
# We consider there to be an implicit 0 in a pre-release if there is
|
|
516
|
+
# not a numeral associated with it.
|
|
517
|
+
if number is None:
|
|
518
|
+
number = 0
|
|
519
|
+
|
|
520
|
+
# We normalize any letters to their lower case form
|
|
521
|
+
letter = letter.lower()
|
|
522
|
+
|
|
523
|
+
# We consider some words to be alternate spellings of other words and
|
|
524
|
+
# in those cases we want to normalize the spellings to our preferred
|
|
525
|
+
# spelling.
|
|
526
|
+
if letter == "alpha":
|
|
527
|
+
letter = "a"
|
|
528
|
+
elif letter == "beta":
|
|
529
|
+
letter = "b"
|
|
530
|
+
elif letter in ["c", "pre", "preview"]:
|
|
531
|
+
letter = "rc"
|
|
532
|
+
elif letter in ["rev", "r"]:
|
|
533
|
+
letter = "post"
|
|
534
|
+
|
|
535
|
+
return letter, int(number)
|
|
536
|
+
if not letter and number:
|
|
537
|
+
# We assume if we are given a number, but we are not given a letter
|
|
538
|
+
# then this is using the implicit post release syntax (e.g. 1.0-1)
|
|
539
|
+
letter = "post"
|
|
540
|
+
|
|
541
|
+
return letter, int(number)
|
|
542
|
+
|
|
543
|
+
return None
|
|
544
|
+
|
|
545
|
+
|
|
546
|
+
_local_version_separators = re.compile(r"[\._-]")
|
|
547
|
+
|
|
548
|
+
|
|
549
|
+
def _parse_local_version(local: str) -> Optional[LocalType]:
|
|
550
|
+
"""
|
|
551
|
+
Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve").
|
|
552
|
+
"""
|
|
553
|
+
if local is not None:
|
|
554
|
+
return tuple(
|
|
555
|
+
part.lower() if not part.isdigit() else int(part)
|
|
556
|
+
for part in _local_version_separators.split(local)
|
|
557
|
+
)
|
|
558
|
+
return None
|
|
559
|
+
|
|
560
|
+
|
|
561
|
+
def _cmpkey(
|
|
562
|
+
epoch: int,
|
|
563
|
+
release: Tuple[int, ...],
|
|
564
|
+
pre: Optional[Tuple[str, int]],
|
|
565
|
+
post: Optional[Tuple[str, int]],
|
|
566
|
+
dev: Optional[Tuple[str, int]],
|
|
567
|
+
local: Optional[Tuple[SubLocalType]],
|
|
568
|
+
) -> CmpKey:
|
|
569
|
+
# When we compare a release version, we want to compare it with all of the
|
|
570
|
+
# trailing zeros removed. So we'll use a reverse the list, drop all the now
|
|
571
|
+
# leading zeros until we come to something non zero, then take the rest
|
|
572
|
+
# re-reverse it back into the correct order and make it a tuple and use
|
|
573
|
+
# that for our sorting key.
|
|
574
|
+
_release = tuple(
|
|
575
|
+
reversed(list(itertools.dropwhile(lambda x: x == 0, reversed(release))))
|
|
576
|
+
)
|
|
577
|
+
|
|
578
|
+
# We need to "trick" the sorting algorithm to put 1.0.dev0 before 1.0a0.
|
|
579
|
+
# We'll do this by abusing the pre segment, but we _only_ want to do this
|
|
580
|
+
# if there is not a pre or a post segment. If we have one of those then
|
|
581
|
+
# the normal sorting rules will handle this case correctly.
|
|
582
|
+
if pre is None and post is None and dev is not None:
|
|
583
|
+
_pre: PrePostDevType = NegativeInfinity
|
|
584
|
+
# Versions without a pre-release (except as noted above) should sort after
|
|
585
|
+
# those with one.
|
|
586
|
+
elif pre is None:
|
|
587
|
+
_pre = Infinity
|
|
588
|
+
else:
|
|
589
|
+
_pre = pre
|
|
590
|
+
|
|
591
|
+
# Versions without a post segment should sort before those with one.
|
|
592
|
+
if post is None:
|
|
593
|
+
_post: PrePostDevType = NegativeInfinity
|
|
594
|
+
|
|
595
|
+
else:
|
|
596
|
+
_post = post
|
|
597
|
+
|
|
598
|
+
# Versions without a development segment should sort after those with one.
|
|
599
|
+
if dev is None:
|
|
600
|
+
_dev: PrePostDevType = Infinity
|
|
601
|
+
|
|
602
|
+
else:
|
|
603
|
+
_dev = dev
|
|
604
|
+
|
|
605
|
+
if local is None:
|
|
606
|
+
# Versions without a local segment should sort before those with one.
|
|
607
|
+
_local: LocalType = NegativeInfinity
|
|
608
|
+
else:
|
|
609
|
+
# Versions with a local segment need that segment parsed to implement
|
|
610
|
+
# the sorting rules in PEP440.
|
|
611
|
+
# - Alpha numeric segments sort before numeric segments
|
|
612
|
+
# - Alpha numeric segments sort lexicographically
|
|
613
|
+
# - Numeric segments sort numerically
|
|
614
|
+
# - Shorter versions sort before longer versions when the prefixes
|
|
615
|
+
# match exactly
|
|
616
|
+
_local = tuple(
|
|
617
|
+
(i, "") if isinstance(i, int) else (NegativeInfinity, i) for i in local
|
|
618
|
+
)
|
|
619
|
+
|
|
620
|
+
return epoch, _release, _pre, _post, _dev, _local
|