mirror of
https://github.com/arcan1s/ahriman.git
synced 2026-04-07 11:03:37 +00:00
ensure_exists now accepts only argument
This commit is contained in:
@@ -79,7 +79,7 @@ def move_packages(repository_paths: RepositoryPaths, pacman: Pacman) -> None:
|
|||||||
artifacts.append(signature)
|
artifacts.append(signature)
|
||||||
|
|
||||||
for source in artifacts:
|
for source in artifacts:
|
||||||
target = repository_paths.ensure_exists(repository_paths.archive_for, package.base) / source.name
|
target = repository_paths.ensure_exists(repository_paths.archive_for(package.base)) / source.name
|
||||||
# move package to the archive directory
|
# move package to the archive directory
|
||||||
atomic_move(source, target)
|
atomic_move(source, target)
|
||||||
# create symlink to the archive
|
# create symlink to the archive
|
||||||
|
|||||||
@@ -171,7 +171,7 @@ class Executor(PackageInfo, Cleaner):
|
|||||||
files = self.sign.process_sign_package(full_path, packager_key)
|
files = self.sign.process_sign_package(full_path, packager_key)
|
||||||
|
|
||||||
for src in files:
|
for src in files:
|
||||||
dst = self.paths.ensure_exists(self.paths.archive_for, package_base) / src.name
|
dst = self.paths.ensure_exists(self.paths.archive_for(package_base)) / src.name
|
||||||
atomic_move(src, dst) # move package to archive directory
|
atomic_move(src, dst) # move package to archive directory
|
||||||
if not (symlink := self.paths.repository / dst.name).exists():
|
if not (symlink := self.paths.repository / dst.name).exists():
|
||||||
symlink_relative(symlink, dst) # create link to archive
|
symlink_relative(symlink, dst) # create link to archive
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ import contextlib
|
|||||||
import os
|
import os
|
||||||
import shutil
|
import shutil
|
||||||
|
|
||||||
from collections.abc import Callable, Iterator
|
from collections.abc import Iterator
|
||||||
from dataclasses import dataclass, field
|
from dataclasses import dataclass, field
|
||||||
from functools import cached_property
|
from functools import cached_property
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
@@ -246,15 +246,12 @@ class RepositoryPaths(LazyLogging):
|
|||||||
"""
|
"""
|
||||||
return self.cache / package_base
|
return self.cache / package_base
|
||||||
|
|
||||||
def ensure_exists(self, directory: Callable[Params, Path] | Path, *args: Params.args,
|
def ensure_exists(self, directory: Path) -> Path:
|
||||||
**kwargs: Params.kwargs) -> Path:
|
|
||||||
"""
|
"""
|
||||||
get path based on ``directory`` callable provided and ensure it exists
|
get path based on ``directory`` callable provided and ensure it exists
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
directory(Callable[Params, Path] | Path): either directory extractor or path to directory to check
|
directory(Path): path to directory to check
|
||||||
args(Params.args): positional arguments for directory call
|
|
||||||
kwargs(Params.kwargs): keyword arguments for directory call
|
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
Path: original path based on extractor provided. Directory will always exist
|
Path: original path based on extractor provided. Directory will always exist
|
||||||
@@ -262,11 +259,8 @@ class RepositoryPaths(LazyLogging):
|
|||||||
Examples:
|
Examples:
|
||||||
This method calls directory accessor and then checks if there is a directory and - otherwise - creates it::
|
This method calls directory accessor and then checks if there is a directory and - otherwise - creates it::
|
||||||
|
|
||||||
>>> paths.ensure_exists(paths.archive_for, package_base)
|
>>> paths.ensure_exists(paths.archive_for(package_base))
|
||||||
"""
|
"""
|
||||||
if callable(directory):
|
|
||||||
directory = directory(*args, **kwargs)
|
|
||||||
|
|
||||||
if not directory.is_dir():
|
if not directory.is_dir():
|
||||||
with self.preserve_owner():
|
with self.preserve_owner():
|
||||||
directory.mkdir(mode=0o755, parents=True)
|
directory.mkdir(mode=0o755, parents=True)
|
||||||
|
|||||||
Reference in New Issue
Block a user