When sysutils/file is installed, Mk/Scripts/find-lib.sh ends up using it if $PATH puts /usr/local/bin first - the result is that it gives this: > file -b -L --mime-type /usr/local/lib/liblzo2.so application/x-pie-executable rather than what /usr/bin/file gives: > /usr/bin/file -b -L --mime-type /usr/local/lib/liblzo2.so application/x-sharedlib When /usr/local/bin/file is used, this test in Mk/Scripts/find-lib.sh fails: [ "$(file -b -L --mime-type ${libfile})" = "application/x-sharedlib" ] So, when any port Makefile uses the "LIB_DEPENDS= " construct, the port incorrectly rebuilds the dependency because it is marked as non-existent Suggested fixes: 1. use absolute path in Mk/Scripts/find-lib.sh: [ "$(/usr/bin/file -b -L --mime-type ${libfile})" = "application/x-sharedlib" ] 2. change test to also recognise "application/x-pie-executable" as a valid shared library object 3. change sysutils/file to return "application/x-sharedlib" when a FreeBSD lib*.so shared library object is encountered 4. all of the above
update to comment #1 "the port incorrectly rebuilds the dependency because it is marked as non-existent" should read: "the port incorrectly rebuilds an existing dependency because it is always marked as non-existent" Also the issue showed up via this forum: https://forum.iredmail.org/topic14696-install-iredmail098-on-fresh-freebsd-112.html
Don't install file from ports or submit a patch to fix the file port.
the iRedMail distro invokes the sysutils/file option for the security/amavisd-new port since it's more accurate/up-to-date with respect to email body attachments - it's not likely that they would back away from that in my first comment i made a suggestion which could easily become a patch - it needs to be discussed first to determine which of any or all of the suggestions made would be most apropos
reopening this since it needs discussion first
Created attachment 197320 [details] patches /usr/ports/Mk/Scripts/find-lib.sh to use absolute path for "file" this patches /usr/ports/Mk/Scripts/find-lib.sh to use absolute path for "file"
here is an implementation of suggestion 2. above: https://www.mail-archive.com/svn-src-all@freebsd.org/msg163025.html suggestion 3. would need the sysutils/file port maintainer to suggest a fix
With the new version of pkg and the large number of new port updates that seems to have been released today for FreeBSD 11.2, I can reproduce this bug on my machine. I would love to see hostmaster@GTS.NET's solution #1 integrated into FreeBSD. It seems like it would avoid a lot of confusion for countless users in the future.
A commit references this bug: Author: antoine Date: Sat Oct 6 08:19:19 UTC 2018 New revision: 481327 URL: https://svnweb.freebsd.org/changeset/ports/481327 Log: Use full path to file(1) from base as sysutils/file is buggy PR: 231554 Changes: head/Mk/Scripts/find-lib.sh