mirror of
https://gitlab.com/dslackw/slpkg.git
synced 2024-12-31 10:26:39 +01:00
Updated for download only
This commit is contained in:
parent
39bf5db2ff
commit
cbb7a16d7a
1 changed files with 41 additions and 35 deletions
|
@ -27,55 +27,61 @@ class Download(Configs):
|
||||||
self.repos = Repositories()
|
self.repos = Repositories()
|
||||||
self.utils = Utilities()
|
self.utils = Utilities()
|
||||||
self.session = Session
|
self.session = Session
|
||||||
|
self.urls: list = []
|
||||||
|
self.download_path: Path = Path()
|
||||||
|
|
||||||
|
self.sbo_repo: dict = {
|
||||||
|
self.repos.sbo_repo_name: self.repos.sbo_repo_path,
|
||||||
|
self.repos.ponce_repo_name: self.repos.ponce_repo_path
|
||||||
|
}
|
||||||
|
|
||||||
self.is_binary: bool = self.utils.is_binary_repo(repository)
|
self.is_binary: bool = self.utils.is_binary_repo(repository)
|
||||||
|
|
||||||
self.option_for_directory: bool = self.utils.is_option(
|
self.option_for_directory: bool = self.utils.is_option(
|
||||||
['-z', '--directory='], flags)
|
['-z', '--directory='], flags)
|
||||||
|
|
||||||
def packages(self, packages: list) -> None:
|
def packages(self, packages: list) -> None:
|
||||||
""" Download the package only. """
|
""" Download the package only. """
|
||||||
urls: list = []
|
|
||||||
|
|
||||||
sbo_repo: dict = {
|
|
||||||
self.repos.sbo_repo_name: self.repos.sbo_repo_path,
|
|
||||||
self.repos.ponce_repo_name: self.repos.ponce_repo_path
|
|
||||||
}
|
|
||||||
|
|
||||||
packages: list = self.utils.apply_package_pattern(self.data, packages)
|
packages: list = self.utils.apply_package_pattern(self.data, packages)
|
||||||
|
|
||||||
self.view.download_packages(packages, self.directory)
|
self.view.download_packages(packages, self.directory)
|
||||||
self.view.question()
|
self.view.question()
|
||||||
|
self.set_download_path()
|
||||||
download_path: Path = self.download_only_path
|
|
||||||
if self.option_for_directory:
|
|
||||||
download_path: Path = self.directory
|
|
||||||
|
|
||||||
start: float = time.time()
|
start: float = time.time()
|
||||||
for pkg in packages:
|
|
||||||
|
|
||||||
|
for pkg in packages:
|
||||||
if self.is_binary:
|
if self.is_binary:
|
||||||
|
self.save_binary_sources(pkg)
|
||||||
|
else:
|
||||||
|
self.save_slackbuild_sources(pkg)
|
||||||
|
self.copy_slackbuild_scripts(pkg)
|
||||||
|
|
||||||
|
self.download_the_sources()
|
||||||
|
elapsed_time: float = time.time() - start
|
||||||
|
self.utils.finished_time(elapsed_time)
|
||||||
|
|
||||||
|
def set_download_path(self) -> None:
|
||||||
|
self.download_path: Path = self.download_only_path
|
||||||
|
if self.option_for_directory:
|
||||||
|
self.download_path: Path = self.directory
|
||||||
|
|
||||||
|
def save_binary_sources(self, pkg: str) -> None:
|
||||||
package: str = self.data[pkg][1]
|
package: str = self.data[pkg][1]
|
||||||
mirror: str = self.data[pkg][2]
|
mirror: str = self.data[pkg][2]
|
||||||
location: str = self.data[pkg][3]
|
location: str = self.data[pkg][3]
|
||||||
urls.append(f'{mirror}{location}/{package}')
|
self.urls.append(f'{mirror}{location}/{package}')
|
||||||
else:
|
|
||||||
location: str = self.data[pkg][0]
|
def save_slackbuild_sources(self, pkg: str) -> None:
|
||||||
if self.os_arch == 'x86_64' and self.data[pkg][4]:
|
if self.os_arch == 'x86_64' and self.data[pkg][4]:
|
||||||
sources = self.data[pkg][4].split()
|
sources: list = self.data[pkg][4].split()
|
||||||
else:
|
else:
|
||||||
sources = self.data[pkg][3].split()
|
sources: list = self.data[pkg][3].split()
|
||||||
|
self.urls.extend(sources)
|
||||||
|
|
||||||
urls.extend(sources)
|
def copy_slackbuild_scripts(self, pkg: str) -> None:
|
||||||
|
repo_path_package: Path = Path(self.sbo_repo[self.repository], self.data[pkg][0], pkg)
|
||||||
|
if not Path(self.download_path, pkg).is_dir():
|
||||||
|
shutil.copytree(repo_path_package, Path(self.download_path, pkg))
|
||||||
|
print(f"{self.byellow}Copying{self.endc}: {repo_path_package} -> {Path(self.download_path, pkg)}")
|
||||||
|
|
||||||
repo_path_package: Path = Path(sbo_repo[self.repository], location, pkg)
|
def download_the_sources(self) -> None:
|
||||||
if not Path(download_path, pkg).is_dir():
|
down = Downloader(self.download_path, self.urls, self.flags)
|
||||||
shutil.copytree(repo_path_package, Path(download_path, pkg))
|
|
||||||
|
|
||||||
print(f"{self.byellow}Copying{self.endc}: {repo_path_package} -> {Path(download_path, pkg)}")
|
|
||||||
|
|
||||||
down = Downloader(download_path, urls, self.flags)
|
|
||||||
down.download()
|
down.download()
|
||||||
|
|
||||||
elapsed_time: float = time.time() - start
|
|
||||||
self.utils.finished_time(elapsed_time)
|
|
||||||
|
|
Loading…
Reference in a new issue