--- Begin Message ---
- To: Debian Bug Tracking System <submit@bugs.debian.org>
- Subject: breaks-without-version does not make much sense in many cases
- From: Modestas Vainius <modestas@vainius.eu>
- Date: Fri, 03 Dec 2010 01:02:43 +0200
- Message-id: <20101202230243.23140.446.reportbug@mdxdesktop.lan.vainius.eu>
Package: lintian
Version: 2.4.3
Severity: normal
Hello,
I don't think that breaks-without-version makes much sense, especially after
policy 3.9.0 has clarified Replaces/Breaks/Conflicts usage. At least, it should
not be a "warning" as it says nothing about quality of the package and in many
cases it could be misleading.
Breaks is more package manager friendly relationship when it comes to upgrades
and there is absolutely nothing wrong with having Breaks without version in
almost all (if not all) cases when Replaces for the same package is also
present. One of the most common example from my experience is the following:
Suppose you want to split a package (app-common) into smaller parts (app-data
and app-doc). Then a very apt-friendly approach (in the spirit of policy 3.9.0)
would be:
Package: app-data
Replaces: app-common
Breaks: app-common
Package: app-doc
Replaces: app-common
Breaks: app-common
However, instead lintian suggests using Conflicts here which clearly
contradicts policy 7.4 recommendation:
------------------------------------------------------------------------------
Normally, Breaks should be used instead of Conflicts since Conflicts imposes a
stronger restriction on the ordering of package installation or upgrade and can
make it more difficult for the package manager to find a correct solution to an
upgrade or installation problem. Breaks should be used:
* when moving a file from one package to another (see Overwriting files and
  replacing packages - Replaces, Section 7.6),
*  when splitting a package (a special case of the previous one), or
....
------------------------------------------------------------------------------
I could also think of more examples with moving of files if needed.
So generally I have a couple of suggestions here. They are listed in the order
of my preference:
* Drop breaks-without-version completely (at least for 3.9.0 compliant packages).
* Do not emit breaks-without-version when the same package is found in
  Replaces field (provided it's not Breaks/Replaces against itself). Though I
  still prefer complete removal of breaks-without-version as I don't believe it
  makes much sense in general (as it's worded) and it's too prone to false
  positives.
* Downgrade breaks-without-version to info/pedantic level. This would be the
  worst case scenario but I could probably accept it as I generally do not care
  much about false positives at those levels.
-- System Information:
Debian Release: squeeze/sid
  APT prefers unstable
  APT policy: (500, 'unstable'), (100, 'experimental')
Architecture: amd64 (x86_64)
Kernel: Linux 2.6.36-trunk-amd64 (SMP w/4 CPU cores)
Locale: LANG=lt_LT.UTF-8, LC_CTYPE=lt_LT.UTF-8 (charmap=UTF-8)
Shell: /bin/sh linked to /bin/dash
Versions of packages lintian depends on:
ii  binutils               2.20.1-15         The GNU assembler, linker and bina
ii  diffstat               1.53-1            produces graph of changes introduc
ii  dpkg-dev               1.15.8.6          Debian package development tools
ii  file                   5.04-5            Determines file type using "magic"
ii  gettext                0.18.1.1-3        GNU Internationalization utilities
ii  intltool-debian        0.35.0+20060710.1 Help i18n of RFC822 compliant conf
ii  libapt-pkg-perl        0.1.24+b1         Perl interface to libapt-pkg
ii  libclass-accessor-perl 0.34-1            Perl module that automatically gen
ii  libipc-run-perl        0.89-1            Perl module for running processes
ii  libparse-debianchangel 1.1.1-2.1         parse Debian changelogs and output
ii  libtimedate-perl       1.2000-1          collection of modules to manipulat
ii  liburi-perl            1.56-1            module to manipulate and access UR
ii  locales                2.11.2-7          Embedded GNU C Library: National L
ii  man-db                 2.5.7-6           on-line manual pager
ii  perl [libdigest-sha-pe 5.10.1-16         Larry Wall's Practical Extraction 
lintian recommends no packages.
Versions of packages lintian suggests:
ii  binutils-multiarch            2.20.1-15  Binary utilities that support mult
pn  libtext-template-perl         <none>     (no description available)
ii  man-db                        2.5.7-6    on-line manual pager
-- no debconf information
--- End Message ---
--- Begin Message ---
Source: lintian
Source-Version: 2.5.0~rc1
We believe that the bug you reported is fixed in the latest version of
lintian, which is due to be installed in the Debian FTP archive:
lintian_2.5.0~rc1.dsc
  to main/l/lintian/lintian_2.5.0~rc1.dsc
lintian_2.5.0~rc1.tar.gz
  to main/l/lintian/lintian_2.5.0~rc1.tar.gz
lintian_2.5.0~rc1_all.deb
  to main/l/lintian/lintian_2.5.0~rc1_all.deb
A summary of the changes between this version and the previous one is
attached.
Thank you for reporting the bug, which will now be closed.  If you
have further comments please address them to 605744@bugs.debian.org,
and the maintainer will reopen the bug report if appropriate.
Debian distribution maintenance software
pp.
Raphael Geissert <geissert@debian.org> (supplier of updated lintian package)
(This message was generated automatically at their request; if you
believe that there is a problem with it please contact the archive
administrators by mailing ftpmaster@debian.org)
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
Format: 1.8
Date: Tue, 22 Feb 2011 20:28:48 -0600
Source: lintian
Binary: lintian
Architecture: source all
Version: 2.5.0~rc1
Distribution: experimental
Urgency: low
Maintainer: Debian Lintian Maintainers <lintian-maint@debian.org>
Changed-By: Raphael Geissert <geissert@debian.org>
Description: 
 lintian    - Debian package checker
Closes: 534940 576005 576012 576014 576283 582408 582767 582769 590723 591300 591316 591323 591331 592358 592491 592533 593397 593603 593832 593837 594254 595530 595941 596848 597990 598251 600866 600905 600906 602632 602655 603053 603800 604047 604167 605744 605844 606506 606933 607281 607502 607730 607731 608554 608810 608866 609153 610218 611349 611439 612137 612568
Changes: 
 lintian (2.5.0~rc1) experimental; urgency=low
 .
   The "welcome Niels Thykier!" release.
 .
   * Summary of tag changes:
     + Added:
       - build-depends-on-specific-java-doc-package
       - depends-on-specific-java-doc-package
       - unneeded-build-dep-on-quilt
       - description-synopsis-starts-with-article
       - needless-dependency-on-jre
       - temporary-debhelper-file
       - compressed-objects.inv
       - unused-build-dependency-on-cdbs
       - python-debug-in-wrong-location
       - debian-watch-contains-dh_make-template
       - missing-dependency-on-python-central
       - python-module-in-wrong-location
       - missing-dependency-on-python-support
       - package-installs-python-bytecode
       - debhelper-maintscript-needs-versioned-build-depends
     + Removed:
       - embedded-zlib (now in embedded-library)
       - embedded-libpng (now in embedded-library)
       - embedded-libjpeg (now in embedded-library)
       - embedded-libopenjpeg (now in embedded-library)
       - package-installs-python-pyc (replaced by
         package-installs-python-bytecode)
 .
   * checks/*:
     + [NT] Use the new pre-sorted file {index,info} when iterating over
       files.
     + [NT] All checks now report files without any "./" or "/" prefix.
       This may break existing overrides.  (Closes: #534940)
   * checks/binaries:
     + [RA] Exclude kfreebsd-kernel-di-{amd64,i386} from the
       embedded-zlib check since it's in the kernel.  (Closes: #593397)
     + [RG] Add swipl to the list of known interpreters.  (Closes: #591316)
     + [RG] Detect embedded copies of ftgl, t1lib, gl2ps, libgd2,
       ncurses, openssl (libcrypto), sqlite/3, libm, ltdl, curl, libmng,
       libmsn, libmikmod, libmysqlclient, and tinyxml.
     + [RG] Merge embedded-{zlib,lib{png,jpeg,openjpeg}} into
       embedded-library.
     + [RG] Find directories based on the file's type instead of file(1)'s
       unforgiving output.  Thanks, Gabriele Giacone.  (Closes: #597990)
   * checks/cruft{,.desc}:
     + [NT] Extended the diff-contains-substvars check to also catch files
       prefixed with a package name.
     + [NT] Corrected the description of diff-contains-$vcs-control-dir.
       It incorrectly assumed that -i worked for native packages.
       (Closes: #609153)
     + [NT] Moved the list of autotools packages into data/cruft/autotools.
     + [NT] Clarified that dpkg-source looks for <package>_<upstreamversion>
       and not <package>_<version> in the description of
       native-package-with-dash-version.  Thanks to Daniel Thomas for the
       report.  (Closes: #594254)
   * checks/debhelper{,.desc}:
     + [NT] Fix dependency check for dh_nativejava, default-jdk has never
       provided dh_nativejava.  (Closes: #606506)
     + [NT] Added check for temporary debhelper files that ought to have
       been removed by dh_clean.  (Closes: #598251)
     + [NT] Added check for unused build dependency on cdbs.  Thanks to
       Jari Aalto for suggesting this.  (Closes: #582769)
     + [NT] Added check for incorrect debhelper version when using the
       maintscript feature from debhelper 8.1.0.
   * checks/debian-source-dir:
     + [NT] Added missing import of "Util" perl module.  Thanks to David
       Bremner for the patch.
   * checks/description{,.desc}:
     + [NT] Add a check for synopsis starting with articles.  Thanks to
       Nelson A. de Oliveira for the patch.  (Closes: #603053)
     + [NT] Fixed false positive description-contains-duplicated-word
       caused by Lintian ignoring quoted words.  Thanks to Gregor
       Herrmann for report.  (Closes: #590723)
   * checks/fields{,.desc}:
     + [NT] Added check for packages (build) depending on openjdk-X-doc or
       classpath-doc instead of the default-jdk-doc metapackage.
       (Closes: #593837)
     + [NT] Fixed spelling of metapackage in tag descriptions.
     + [NT] Added needless-dependency-on-jre tag.
     + [NT] Corrected Policy references for the uploader tags.  Thanks to
       David Prévot for spotting this issue and providing a patch.
       (Closes: #602632)
     + [NT] Fixed false positives for breaks-without-version.  The tag
       will no longer be emitted if the package listed in Breaks is also
       listed in Replaces.  Thanks to Modestas Vainius for the report.
       (Closes: #605744)
     + [NT] Clarified that old-versioned-python-dependency can also be
       triggered if dh_python2 is used and the package is missing
       ${python:Breaks}. Thanks to Piotr Ożarowski for the report.
       (Closes: #604167)
     + [RG] Mention the package's original area in
       wrong-section-according-to-package-name.  (Closes: #608554)
   * checks/files{,.desc}:
     + [NT] Fixed false-positive extra-license-file for license.ui files.
       Thanks to Jeremy Sanders for the report.  (Closes: #595941)
     + [NT] Added hurd-udeb to the list of packages allowed to ship
       unusual top-level directories.  Thanks to Samual Thibault for
       the patch.  (Closes: #591331)
     + [NT] Fixed spelling of metapackage in empty-binary-package tag
       description.  (Closes: #591300)
     + [NT] Fixed false-positive extra-license-file for games.  Instead
       of skipping PATH directories Lintian now ignores all executable
       files.  (Closes: #608866)
     + [NT] Added compressed-objects.inv tag to catch compressed
       objects.inv files in python documentation.  Thanks to
       Fladischer Michael for the report and a partial patch.
       (Closes: #608810)
     + [NT] Added check for misplaced python debug files.  Thanks to
       Jakub Wilk for the report.  (Closes: #576014)
     + [NT] Added check for missing dependency on python-central.
       Thanks to Jakub Wilk for the report.  (Closes: #592533)
     + [NT] Added check for misplaced Python modules.  Thanks to
       Jakub Wilk for the report.  (Closes: #576012)
     + [NT] Removed the "!= 0755" part from the out of the tag
       executable-is-not-world-readable, since there are other valid
       world readable file permissions.
     + [NT] Added check for missing dependency on python-support.
       Thanks to Jakub Wilk for the report.  (Closes: #592491)
     + [NT] Added check for packages installing Python eggs and
       __pycache__ directories.  Also extended existing Python bytecode
       check to include ".pyo" files.  Thanks to Piotr Ożarowski,
       Jakub Wilk and the people in #debian-python for the report and
       help with implementing this.  (Closes: #576005)
   * checks/init.d.desc:
     + [RG] Raise severity of init.d-script-starts-in-stop-runlevel.
       (Closes: #603800)
   * checks/manpages:
     + [NT] Fixed typo in locale name.  Thanks to Christoph Biedl for
       spotting this.  (Closes: #606933)
   * checks/menu-format.desc:
     + [CW] Fix several typos.
   * checks/menus.desc:
     + [RA] Rephrase doc-base-uses-applications-section to be clearer that
       its advice is to remove the "Applications/" part of the section.
   * checks/nmu:
     + [RG] Completely abort if debian/changelog is a symlink.
       (Closes: #582408)
   * checks/patch-systems{,.desc}:
     + [NT] Added check for new unneeded-build-dep-on-quilt.
       (Closes: #582767)
   * checks/rules:
     + [RG] Drop some checks for versioned dependencies that can now be
       satisfied in stable (squeeze).  Thanks, Cyril Brulebois.
       (Closes: #612137)
     + [RG] Correctly handle include directives preceded by a tab.
       (Closes: #607281)
     + [RG] Allow 'ocaml' as an alternative to 'ocaml-nox'.  Thanks,
       Ralf Treinen.  (Closes: #612568)
   * checks/scripts:
     + [NT] Added mscgen as interpreter.
   * checks/standards-version:
     + [RG] Correctly handle cases where debian/changelog is a symlink.
   * checks/watch-file{,.desc}:
     + [NT] Added check for dh_make(1) templates in the watch file.
       Thanks to Nelson A. de Oliveira for the report.  (Closes: #600866)
     + [RG] Document that relying on SourceForge's webpages for finding
       new versions is not recommended either.  (Closes: #593603)
 .
   * collection/objdump-info:
     + [RG] Support stricter parameter handling of objdump-info from
       binutils 2.21.  Thanks, Andreas Beckmann.
       (Closes: #604047, LP: #683347)
 .
   * data/changelog-file/ubuntu-dists:
     + [CW] Add natty as a valid Ubuntu distribution, and remove the EOLed
       intrepid and jaunty.  (Closes: #611439)
   * data/cruft/autotools:
     + [NT] Added the file which is a list of all packages that will
       suppress the {ancient,outdated}-autotools-helper-file tags.
       Currently this is manually updated.  This new list includes
       dh-autoreconf, thanks to Felix Geyer.  (Closes: #592358)
   * data/debhelper/*:
     + [RG] Refresh against unstable.
   * data/debian-source-dir/known-files:
     + [NT] Added the file and included git-patches in it.  Thanks to
       Ron for the report and David Bremner for the initial patch.
       (Closes: #607502)
   * data/fields/essential:
     + [RG] Add hurd.  (Closes: #591323)
   * data/fields/obsolete-packages:
     + [NT] Added default-jdk-builddep.  See README.gcj-native-transition
       in java-common for the replacement.
   * data/fields/perl-provides:
     + [RG] Refresh against perl 5.10.1.
   * data/files/fonts:
     + [NT] Made tipa replace xfonts-tipa as font provider.
       (Closes: #595530)
     + [RG] Refresh against unstable.
   * data/files/locale-codes:
     + [RG] Refresh against isoquery 1.4.
   * data/shared-libs/ldconfig-dirs:
     + [NT] Removed the emul/ia32-linux directories as they are no longer
       used.  (Closes: #596848)
   * data/spelling/corrections:
     + [NT] Added more corrections.
   * data/spelling/corrections-case:
     + [NT] Added DocBook corrections.  Thanks to Jakub Wilk.
       (Closes: #611349)
   * data/spelling/corrections-multiword:
     + [NT] Added "allows to" and other similar misspellings.  Thanks
       to Matthew Paul Thomas for the report.  (LP: #608231)
 .
   * debian/control:
     + [RA] Add the build dependencies required to run the test suite
       during the build.  Many thanks to Niels Thykier for the investigative
       work to determine which packages are required.  (Closes: #593832)
     + [RA] Remove versions from dependencies when those versions are
       satisfied by oldstable (lenny).
     + [NT] Bump debhelper build dependency to 7.0.50~, since some tests
       depend on using dh7 with override targets.  (Closes: #607730)
     + [NT] Added Niels Thykier to uploaders.
     + [NT] Introduce (build) dependency on libemail-valid-perl.
     + [RG] Add a versioned build dependency on libtest-simple-perl or a
       recent Perl that has Test::More with subtests support.
   * debian/copyright:
     + [NT] Added Niels Thykier to maintainers.
   * debian/rules:
     + [RA] Run the test suite during the package build.
     + [NT] Replace dh_clean -k with dh_prep.
     + [NT] Add support for skipping the test suite per policy 4.9.1.
       Many thanks to David Bremner for the patch.
   * debian/compat:
     + [NT] Bump debhelper compat to 7.
   * debian/source/lintian-overrides:
     + [RG] Add overrides for quilt-related checks.
 .
   * frontend/lintian:
     + [NT] Ensure that Lintian always reaps processes it started before
       exiting.  In some cases these jobs would attempt to modify the
       lab while Lintian was trying to remove it.  Thanks to
       Andreas Beckmann for reporting this issue.  (Closes: #610218)
     + [NT] Sorted related options alphabetically.  Thanks to Jari Aalto
       for the initial patch.  (Closes: #600905)
 .
   * lib/Lintian/Check.pm:
     + [NT] Use Email::Valid to validate email addresses.
       (Closes: #602655)
     + [NT] Allow package names to be excluded from regular spelling
       checks.  They are still subject to multi word and case sensitive
       spelling checks.  Thanks to syq for the suggestion.
       (Closes: #576283)
   * lib/Lintian/Collect/Binary.pm:
     + [NT] Pre-sort file index and file info to avoid sorting it
       repeatedly in the checks.  (Closes: #605844)
 .
   * man/*:
     + [NT] Rewrote the man pages in pod.  (Closes: #600906)
 .
   * t/runtests:
     + [RG] Run blackbox tests in parallel too.
   * t/tests/{rules-not-makefile,scripts-missing-dep}:
     + [NT] Added new tests.  (Closes: #607731)
Checksums-Sha1: 
 393246bbb8e01b66f94788d04f512459bb657e16 1697 lintian_2.5.0~rc1.dsc
 d001ade3abcf4908e4f1841f06332a9d3b44930e 909647 lintian_2.5.0~rc1.tar.gz
 6feca23846f0e897c297ba53154ff33c0306cf64 563360 lintian_2.5.0~rc1_all.deb
Checksums-Sha256: 
 e65be540b6286ca66b827cccf5b32b1bc5650f91125d62ba9c29b464f06828ea 1697 lintian_2.5.0~rc1.dsc
 0d74d3a05e11cc519ec013f22bd657c00d376bb0929c91377823e823ccfe0352 909647 lintian_2.5.0~rc1.tar.gz
 c4ec6f31cfb6fe96106666a0a89ecf823bafe4e47d039cd5c9115acd4a7f76be 563360 lintian_2.5.0~rc1_all.deb
Files: 
 f1e2cea439183972a4f4a3ba07c66de5 1697 devel optional lintian_2.5.0~rc1.dsc
 18886d2dfa7aaa90fc8c48d7b513dae6 909647 devel optional lintian_2.5.0~rc1.tar.gz
 3c265dc8ffca6eab4816cca548352950 563360 devel optional lintian_2.5.0~rc1_all.deb
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.10 (GNU/Linux)
iEYEARECAAYFAk1kloYACgkQYy49rUbZzlqrCQCfeUGWWbEiuIPqjzFkVo0d5qFs
l3sAn1/I/lWXGP7HaZa0hB0B+XV+9LUB
=gQ2a
-----END PGP SIGNATURE-----
--- End Message ---