]> git.decadent.org.uk Git - dak.git/commitdiff
ensure the Source: field in changes files is a package name. Support new dpkg option...
authorArchive Administrator <ftpmaster@debian.org>
Tue, 27 Jun 2006 01:39:39 +0000 (18:39 -0700)
committerArchive Administrator <ftpmaster@debian.org>
Tue, 27 Jun 2006 01:39:39 +0000 (18:39 -0700)
ChangeLog
dak/process_unchecked.py

index fd2f9c3a4abdc3ad4c56bec24f88f9a06a3c7ad1..5f347bbb08e281ca5213ef89b2890c30ae126bb9 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2006-06-26  Ryan Murray  <rmurray@debian.org>
+
+       * dak/process_unchecked.py (check_files): strip optional source version
+       from Source: field in changes file, and ensure what is left is a valid
+       package name.
+
 2006-06-23  Ryan Murray  <rmurray@debian.org>
 
        * dak/process_unchecked.py (check_files): also check ProposedUpdates
index 9b1b48671177773ddab7bb8606fba61fc9804883..8a92e878f95a742f32936fc6865d278c3bd3114b 100755 (executable)
@@ -43,6 +43,7 @@ re_valid_version = re.compile(r"^([0-9]+:)?[0-9A-Za-z\.\-\+:]+$")
 re_valid_pkg_name = re.compile(r"^[\dA-Za-z][\dA-Za-z\+\-\.]+$")
 re_changelog_versions = re.compile(r"^\w[-+0-9a-z.]+ \([^\(\) \t]+\)")
 re_strip_revision = re.compile(r"-([^-]+)$")
+re_strip_srcver = re.compile(r"\s+\(\S+\)$")
 
 ################################################################################
 
@@ -202,6 +203,14 @@ def check_changes():
             reject("%s: Missing mandatory field `%s'." % (filename, i))
             return 0    # Avoid <undef> errors during later tests
 
+    # Strip a source version in brackets from the source field
+    if re_strip_srcver.search(changes["source"]):
+       changes["source"] = re_strip_srcver.sub('', changes["source"])
+
+    # Ensure the source field is a valid package name.
+    if not re_valid_pkg_name.match(changes["source"]):
+        reject("%s: invalid source name '%s'." % (filename, changes["source"]))
+
     # Split multi-value fields into a lower-level dictionary
     for i in ("architecture", "distribution", "binary", "closes"):
         o = changes.get(i, "")