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
|
from __future__ import annotations
import sys
from typing import TYPE_CHECKING
from upath.core import UPath
from upath.types import JoinablePathLike
if TYPE_CHECKING:
from typing import Literal
if sys.version_info >= (3, 11):
from typing import Unpack
else:
from typing_extensions import Unpack
from upath._chain import FSSpecChainParser
from upath.types.storage_options import HDFSStorageOptions
__all__ = ["HDFSPath"]
class HDFSPath(UPath):
__slots__ = ()
if TYPE_CHECKING:
def __init__(
self,
*args: JoinablePathLike,
protocol: Literal["hdfs"] | None = ...,
chain_parser: FSSpecChainParser = ...,
**storage_options: Unpack[HDFSStorageOptions],
) -> None: ...
def mkdir(
self, mode: int = 0o777, parents: bool = False, exist_ok: bool = False
) -> None:
if not exist_ok and self.exists():
raise FileExistsError(str(self))
super().mkdir(mode=mode, parents=parents, exist_ok=exist_ok)
|