summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--pkgtools/url2pkg/files/url2pkg.py41
-rw-r--r--pkgtools/url2pkg/files/url2pkg_test.py60
2 files changed, 64 insertions, 37 deletions
diff --git a/pkgtools/url2pkg/files/url2pkg.py b/pkgtools/url2pkg/files/url2pkg.py
index 8aa77407636..6c58417b168 100644
--- a/pkgtools/url2pkg/files/url2pkg.py
+++ b/pkgtools/url2pkg/files/url2pkg.py
@@ -1,5 +1,5 @@
#! @PYTHONBIN@
-# $NetBSD: url2pkg.py,v 1.16 2019/10/06 05:53:00 rillig Exp $
+# $NetBSD: url2pkg.py,v 1.17 2019/10/06 08:24:18 rillig Exp $
# Copyright (c) 2019 The NetBSD Foundation, Inc.
# All rights reserved.
@@ -785,23 +785,21 @@ class Adjuster:
Sets abs_wrksrc depending on abs_wrkdir and the files found there.
"""
- def ignore(f: str) -> bool:
- return f.startswith('.') \
- or f == 'pax_global_header' \
- or f == 'package.xml' \
- or f.endswith('.gemspec')
+ def relevant(f: Path) -> bool:
+ return f.is_dir() and not f.name.startswith('.')
- files = list(filter(lambda x: not ignore(x), os.listdir(self.abs_wrkdir)))
+ subdirs = [f.name for f in self.abs_wrkdir.glob('*') if relevant(f)]
- if len(files) == 1:
- if files[0] != self.makefile_lines.get('DISTNAME'):
- self.build_vars.append(Var('WRKSRC', '=', '${WRKDIR}/' + files[0]))
- self.abs_wrksrc = self.abs_wrkdir / files[0]
- elif len(files) == 0:
+ if len(subdirs) == 1:
+ if subdirs[0] != self.makefile_lines.get('DISTNAME'):
+ self.build_vars.append(Var('WRKSRC', '=', '${WRKDIR}/' + subdirs[0]))
+ self.abs_wrksrc = self.abs_wrkdir / subdirs[0]
+ elif len(subdirs) == 0:
self.build_vars.append(Var('WRKSRC', '=', '${WRKDIR}'))
self.abs_wrksrc = self.abs_wrkdir
else:
- wrksrc = '${WRKDIR} # More than one possibility -- please check manually.'
+ choices = ' '.join(subdirs)
+ wrksrc = f'${{WRKDIR}} # TODO: one of {choices}, or leave it as-is'
self.build_vars.append(Var('WRKSRC', '=', wrksrc))
self.abs_wrksrc = self.abs_wrkdir
@@ -893,17 +891,18 @@ class Adjuster:
def adjust(self):
- def scan(basedir: Path, pattern: str) -> List[str]:
- full_paths = basedir.rglob(pattern)
- return [str(f.relative_to(basedir)) for f in full_paths]
+ def scan(basedir: Path, only: Callable[[Path], bool]) -> List[str]:
+ relevant = (f for f in basedir.rglob('*') if only(f))
+ relative = (str(f.relative_to(basedir)) for f in relevant)
+ return list(sorted((f for f in relative if not f.startswith('.'))))
self.up.debug('Adjusting the Makefile')
self.makefile_lines = Lines.read_from(self.up.pkgdir / 'Makefile')
self.abs_wrkdir = Path(self.up.show_var('WRKDIR'))
self.determine_wrksrc()
- self.wrksrc_files = scan(self.abs_wrksrc, '**')
- self.wrksrc_dirs = scan(self.abs_wrksrc, '**/')
+ self.wrksrc_dirs = scan(self.abs_wrksrc, Path.is_dir)
+ self.wrksrc_files = scan(self.abs_wrksrc, Path.is_file)
self.adjust_configure()
self.adjust_cmake()
@@ -939,11 +938,7 @@ def main(argv: List[str], up: Url2Pkg):
if not re.fullmatch(r'\w+://[!-~]+?/[!-~]+', url):
sys.exit(f'url2pkg: invalid URL: {url}')
- if not up.pkgdir.glob('w*/.extract_done') or not (up.pkgdir / 'Makefile').is_file():
- initial_lines = Generator(url).generate_package(up)
- else:
- initial_lines = Generator(url).generate_lines()
-
+ initial_lines = Generator(url).generate_package(up)
Adjuster(up, url, initial_lines).adjust()
up.out.write('\n')
diff --git a/pkgtools/url2pkg/files/url2pkg_test.py b/pkgtools/url2pkg/files/url2pkg_test.py
index 586f620781f..1d577e59cbb 100644
--- a/pkgtools/url2pkg/files/url2pkg_test.py
+++ b/pkgtools/url2pkg/files/url2pkg_test.py
@@ -1,4 +1,4 @@
-# $NetBSD: url2pkg_test.py,v 1.15 2019/10/06 05:53:00 rillig Exp $
+# $NetBSD: url2pkg_test.py,v 1.16 2019/10/06 08:24:18 rillig Exp $
import pytest
from url2pkg import *
@@ -1237,6 +1237,18 @@ def test_Adjuster_determine_wrksrc__single_dir(tmp_path: Path):
assert adjuster.abs_wrksrc == adjuster.abs_wrkdir / 'subdir'
+def test_Adjuster_determine_wrksrc__distname_dir(tmp_path: Path):
+ adjuster = Adjuster(up, '', Lines())
+ adjuster.abs_wrkdir = tmp_path
+ adjuster.makefile_lines.add_vars(Var('DISTNAME', '=', 'distname-1.0'))
+ (tmp_path / 'distname-1.0').mkdir()
+
+ adjuster.determine_wrksrc()
+
+ assert adjuster.abs_wrksrc == adjuster.abs_wrkdir / 'distname-1.0'
+ assert str_vars(adjuster.build_vars) == []
+
+
def test_Adjuster_determine_wrksrc__several_dirs(tmp_path: Path):
adjuster = Adjuster(up, '', Lines())
adjuster.abs_wrkdir = tmp_path
@@ -1247,26 +1259,15 @@ def test_Adjuster_determine_wrksrc__several_dirs(tmp_path: Path):
assert adjuster.abs_wrksrc == adjuster.abs_wrkdir
assert str_vars(adjuster.build_vars) == [
- 'WRKSRC=${WRKDIR} # More than one possibility -- please check manually.',
+ 'WRKSRC=${WRKDIR} # TODO: one of subdir1 subdir2, or leave it as-is',
]
def test_Adjuster_adjust__empty_wrkdir(tmp_path: Path):
- wrkdir = tmp_path / 'wrkdir'
up.pkgdir = tmp_path
- wrkdir.mkdir()
+ up.show_var = lambda varname: {'WRKDIR': str(tmp_path)}[varname]
adjuster = Adjuster(up, 'https://example.org/distfile-1.0.zip', Lines())
- adjuster.abs_wrkdir = wrkdir
(tmp_path / 'Makefile').write_text('# url2pkg-marker\n')
- fake_path = tmp_path / 'fake'
- fake_path.write_text(
- '#! /bin/sh\n'
- 'case $* in\n'
- f'("show-var VARNAME=WRKDIR") echo "{wrkdir}" ;;\n'
- '(*) "unknown: $*" ;;\n'
- 'esac\n')
- fake_path.chmod(0o755)
- up.make = fake_path
adjuster.adjust()
@@ -1277,6 +1278,37 @@ def test_Adjuster_adjust__empty_wrkdir(tmp_path: Path):
]
+def test_Adjuster_adjust__files_in_wrksrc(tmp_path: Path):
+ wrkdir = tmp_path / 'work'
+ wrkdir.mkdir()
+ (wrkdir / '.hidden').touch()
+ (wrkdir / 'file').touch()
+ (wrkdir / 'dir').mkdir()
+ (wrkdir / 'dir' / '.hidden-dir').mkdir()
+ (wrkdir / 'dir' / 'subdir').mkdir()
+ (wrkdir / 'dir' / 'subdir' / '.hidden').touch()
+ (wrkdir / 'dir' / 'subdir' / 'file').touch()
+ (wrkdir / 'dir2').mkdir() # to make WRKSRC = WRKDIR
+ up.show_var = lambda varname: {'WRKDIR': str(wrkdir)}[varname]
+ up.pkgdir = tmp_path
+ (tmp_path / 'Makefile').write_text('# url2pkg-marker\n')
+ adjuster = Adjuster(up, 'https://example.org/distfile-1.0.zip', Lines())
+
+ adjuster.adjust()
+
+ assert adjuster.wrksrc_dirs == [
+ 'dir',
+ 'dir/.hidden-dir',
+ 'dir/subdir',
+ 'dir2',
+ ]
+ assert adjuster.wrksrc_files == [
+ 'dir/subdir/.hidden',
+ 'dir/subdir/file',
+ 'file',
+ ]
+
+
def test_Adjuster_adjust_lines_python_module(tmp_path: Path):
url = 'https://github.com/espressif/esptool/archive/v2.7.tar.gz'
up.pkgdir = tmp_path