** Description changed: + [Impact] + + An old bug in intltool breaks out-of-tree builds, including "make + distcheck", in a lot of intltool-using projects when automake version is + 1.15 or newer. + + The fix for this issue (by Aleksander Morgado) is provided in the + debdiffs attached to the report. + + It's a long-standing bug which is present in all current Ubuntu releases, + starting from Xenial. Would be really nice to get it finally fixed. The developers have to patch their intltool locally just to have a working distcheck target (which is used when making release tarballs). + + [Test Case] + + Try making release tarball for some upstream package. For example, it + can be mate-desktop, a base project for various MATE components. + + $ sudo apt-get build-dep mate-desktop + $ git clone https://github.com/mate-desktop/mate-desktop + $ cd mate-desktop + $ ./autogen.sh --enable-gtk-doc --enable-deprecated --disable-strict + $ make -j5 && make dist -j5 && make distcheck -j5 + + This will build the project, make release tarball and check it by + unpacking it into a new directory and building (again) in it. The last + step will fail: + + ----------------------------------- + + srcdir=../../../po /usr/bin/intltool-update -m + The following files contain translations and are currently not in use. Please + consider adding these to the POTFILES.in file, located in the po/ directory. + + sub/mate-about/mate-about.desktop.in + sub/tools/mate-color-select.desktop.in + + If some of these files are left out on purpose then please add them to + POTFILES.skip instead of POTFILES.in. A file 'missing' containing this list + of left out files has been written in the current directory. + Please report to https://github.com/mate-desktop/mate-desktop/ + if [ -r missing -o -r notexist ]; then \ + exit 1; \ + fi + Makefile:179: recipe for target 'check' failed + + ----------------------------------- + + The out-of-tree build breaks here. + + [Regression Potential] + + None. This is a fix for a broken feature, it doesn't affects other ones. + Also the fix had been tested by MATE developers in various distros, including Debian, Ubuntu and Fedora. + + [Original Description] + systemd uses 'intltool-update -m' from intltoolize in its 'make check'. $(top_srcdir)/po/POTFILES.skip contains the name of a generated file (src/core/org.freedesktop.systemd1.policy.in), which will be generated as $(top_builddir)/src/core/org.freedesktop.systemd1.policy.in. If $(builddir)==$(srcdir) than everything works fine. When they are different, there's no way to instruct intltool-update to skip the file. Since the name of the build directory is not known and can be arbitrary, there should be a way to instruct intltool-update to ignore files relative to the $(top_builddir), or something like that. One option would be to turn the file list into a list of globs (**/src/core/org.freedesktop.systemd1.policy.in would work perfectly in our case).
-- You received this bug notification because you are a member of Desktop Packages, which is subscribed to intltool in Ubuntu. https://bugs.launchpad.net/bugs/1117944 Title: intltool confused by separate build-dir Status in intltool: Confirmed Status in intltool package in Ubuntu: Confirmed Bug description: [Impact] An old bug in intltool breaks out-of-tree builds, including "make distcheck", in a lot of intltool-using projects when automake version is 1.15 or newer. The fix for this issue (by Aleksander Morgado) is provided in the debdiffs attached to the report. It's a long-standing bug which is present in all current Ubuntu releases, starting from Xenial. Would be really nice to get it finally fixed. The developers have to patch their intltool locally just to have a working distcheck target (which is used when making release tarballs). [Test Case] Try making release tarball for some upstream package. For example, it can be mate-desktop, a base project for various MATE components. $ sudo apt-get build-dep mate-desktop $ git clone https://github.com/mate-desktop/mate-desktop $ cd mate-desktop $ ./autogen.sh --enable-gtk-doc --enable-deprecated --disable-strict $ make -j5 && make dist -j5 && make distcheck -j5 This will build the project, make release tarball and check it by unpacking it into a new directory and building (again) in it. The last step will fail: ----------------------------------- srcdir=../../../po /usr/bin/intltool-update -m The following files contain translations and are currently not in use. Please consider adding these to the POTFILES.in file, located in the po/ directory. sub/mate-about/mate-about.desktop.in sub/tools/mate-color-select.desktop.in If some of these files are left out on purpose then please add them to POTFILES.skip instead of POTFILES.in. A file 'missing' containing this list of left out files has been written in the current directory. Please report to https://github.com/mate-desktop/mate-desktop/ if [ -r missing -o -r notexist ]; then \ exit 1; \ fi Makefile:179: recipe for target 'check' failed ----------------------------------- The out-of-tree build breaks here. [Regression Potential] None. This is a fix for a broken feature, it doesn't affects other ones. Also the fix had been tested by MATE developers in various distros, including Debian, Ubuntu and Fedora. [Original Description] systemd uses 'intltool-update -m' from intltoolize in its 'make check'. $(top_srcdir)/po/POTFILES.skip contains the name of a generated file (src/core/org.freedesktop.systemd1.policy.in), which will be generated as $(top_builddir)/src/core/org.freedesktop.systemd1.policy.in. If $(builddir)==$(srcdir) than everything works fine. When they are different, there's no way to instruct intltool-update to skip the file. Since the name of the build directory is not known and can be arbitrary, there should be a way to instruct intltool-update to ignore files relative to the $(top_builddir), or something like that. One option would be to turn the file list into a list of globs (**/src/core/org.freedesktop.systemd1.policy.in would work perfectly in our case). To manage notifications about this bug go to: https://bugs.launchpad.net/intltool/+bug/1117944/+subscriptions -- Mailing list: https://launchpad.net/~desktop-packages Post to : desktop-packages@lists.launchpad.net Unsubscribe : https://launchpad.net/~desktop-packages More help : https://help.launchpad.net/ListHelp