-
Notifications
You must be signed in to change notification settings - Fork 116
/
Copy path_compat.py
65 lines (50 loc) · 2.05 KB
/
_compat.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
# Copyright (c) 2024, NVIDIA CORPORATION. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import sys
import dask
from packaging.version import parse as parse_version
try:
_dask_version = parse_version(dask.__version__)
except TypeError:
# When mocking with autodoc the dask version is not there
_dask_version = parse_version("2024.06.0")
try:
import dask_cudf
_dask_cudf_version = parse_version(dask_cudf.__version__)
except (ImportError, TypeError):
# When mocking with autodoc the dask version is not there
_dask_cudf_version = parse_version("2024.06.0")
try:
import cudf
CURRENT_CUDF_VERSION = parse_version(cudf.__version__)
except (ImportError, TypeError):
CURRENT_CUDF_VERSION = parse_version("24.10.0")
# TODO: remove when dask min version gets bumped
DASK_SHUFFLE_METHOD_ARG = _dask_version > parse_version("2024.1.0")
DASK_P2P_ERROR = _dask_version < parse_version("2023.10.0")
DASK_SHUFFLE_CAST_DTYPE = _dask_version > parse_version("2023.12.0")
DASK_CUDF_PARQUET_READ_INCONSISTENT_SCHEMA = _dask_cudf_version > parse_version(
"25.2.0"
)
# Query-planning check (and cache)
_DASK_QUERY_PLANNING_ENABLED = None
def query_planning_enabled():
global _DASK_QUERY_PLANNING_ENABLED
if _DASK_QUERY_PLANNING_ENABLED is None:
if _dask_version > parse_version("2024.6.0"):
import dask.dataframe as dd
_DASK_QUERY_PLANNING_ENABLED = dd.DASK_EXPR_ENABLED
else:
_DASK_QUERY_PLANNING_ENABLED = "dask_expr" in sys.modules
return _DASK_QUERY_PLANNING_ENABLED