Summary: | graphics/tesseract: Fails to build with invalid version information | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Product: | Ports & Packages | Reporter: | Tomoaki AOKI <junchoon> | ||||||||||
Component: | Individual Port(s) | Assignee: | Piotr Kubaj <pkubaj> | ||||||||||
Status: | Closed FIXED | ||||||||||||
Severity: | Affects Some People | CC: | alt2600, freebsd, ohartmann, rkoberman, sm | ||||||||||
Priority: | --- | Keywords: | patch | ||||||||||
Version: | Latest | Flags: | bugzilla:
maintainer-feedback?
(pkubaj) |
||||||||||
Hardware: | Any | ||||||||||||
OS: | Any | ||||||||||||
See Also: | https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=265083 | ||||||||||||
Attachments: |
|
Description
Tomoaki AOKI
2022-07-08 13:17:22 UTC
Created attachment 235204 [details]
Full build log including stderr
Uploaded full build log (including stderr) with MAKE_JOBS_UNSAFE=yes.
The problematic version string seems to be set at configure phase.
checking Major version... 11-eol-29006-g32aec1e
checking Minor version... e
checking Point version...
Can you check config.log for 11-eol-28628-ga7d313? Created attachment 235205 [details] config.log Uploaded WRKSRC/config.log Portions containing problematic version string are: (snip) It was created by tesseract configure 11-eol-29006-g32aec1e, which was generated by GNU Autoconf 2.71. Invocation command line was $ ./configure --enable-training --prefix=/usr/local --localstatedir=/var --mandir=/usr/local/man --disable-silent-rules --infodir=/usr/local/share/info/ --bui ld=amd64-portbld-freebsd13.1 (snip) configure:4786: checking Major version configure:4788: result: 11-eol-29006-g32aec1e configure:4790: checking Minor version configure:4792: result: e configure:4794: checking Point version configure:4796: result: (snip) configure:5693: checking for c++ option to support OpenMP configure:5715: c++ -c -O2 -pipe -march=haswell -fstack-protector-strong -isystem /usr/local/include -fno-strict-aliasing -isystem /usr/local/include -isyste m /usr/local/include conftest.cpp >&5 conftest.cpp:19:2: error: "OpenMP not supported" #error "OpenMP not supported" ^ 1 error generated. configure:5715: $? = 1 configure: failed program was: | /* confdefs.h */ | #define PACKAGE_NAME "tesseract" | #define PACKAGE_TARNAME "tesseract" | #define PACKAGE_VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_STRING "tesseract 11-eol-29006-g32aec1e" | #define PACKAGE_BUGREPORT "https://github.com/tesseract-ocr/tesseract/issues" | #define PACKAGE_URL "https://github.com/tesseract-ocr/tesseract/" | #define PACKAGE "tesseract" | #define VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_NAME "tesseract" | #define PACKAGE_VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_YEAR "2022" | #define PACKAGE_DATE "07/06" | #define HAVE_FEENABLEEXCEPT 1 | #define FAST_FLOAT 1 | /* end confdefs.h. */ (snip) configure:5888: checking for tensorflow/core/framework/graph.pb.h configure:5888: c++ -c -O2 -pipe -march=haswell -fstack-protector-strong -isystem /usr/local/include -fno-strict-aliasing -isystem /usr/local/include -isystem /usr/local/include conftest.cpp >&5 conftest.cpp:56:10: fatal error: 'tensorflow/core/framework/graph.pb.h' file not found #include <tensorflow/core/framework/graph.pb.h> ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 1 error generated. configure:5888: $? = 1 configure: failed program was: | /* confdefs.h */ | #define PACKAGE_NAME "tesseract" | #define PACKAGE_TARNAME "tesseract" | #define PACKAGE_VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_STRING "tesseract 11-eol-29006-g32aec1e" | #define PACKAGE_BUGREPORT "https://github.com/tesseract-ocr/tesseract/issues" | #define PACKAGE_URL "https://github.com/tesseract-ocr/tesseract/" | #define PACKAGE "tesseract" | #define VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_NAME "tesseract" | #define PACKAGE_VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_YEAR "2022" | #define PACKAGE_DATE "07/06" (snip) configure:15215: c++ -E -isystem /usr/local/include conftest.cpp conftest.cpp:30:10: fatal error: 'ac_nonexistent.h' file not found #include <ac_nonexistent.h> ^~~~~~~~~~~~~~~~~~ 1 error generated. configure:15215: $? = 1 configure: failed program was: | /* confdefs.h */ | #define PACKAGE_NAME "tesseract" | #define PACKAGE_TARNAME "tesseract" | #define PACKAGE_VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_STRING "tesseract 11-eol-29006-g32aec1e" | #define PACKAGE_BUGREPORT "https://github.com/tesseract-ocr/tesseract/issues" | #define PACKAGE_URL "https://github.com/tesseract-ocr/tesseract/" | #define PACKAGE "tesseract" | #define VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_NAME "tesseract" | #define PACKAGE_VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_YEAR "2022" | #define PACKAGE_DATE "07/06" (snip) configure:15271: c++ -E -isystem /usr/local/include conftest.cpp conftest.cpp:30:10: fatal error: 'ac_nonexistent.h' file not found #include <ac_nonexistent.h> ^~~~~~~~~~~~~~~~~~ 1 error generated. configure:15271: $? = 1 configure: failed program was: | /* confdefs.h */ | #define PACKAGE_NAME "tesseract" | #define PACKAGE_TARNAME "tesseract" | #define PACKAGE_VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_STRING "tesseract 11-eol-29006-g32aec1e" | #define PACKAGE_BUGREPORT "https://github.com/tesseract-ocr/tesseract/issues" | #define PACKAGE_URL "https://github.com/tesseract-ocr/tesseract/" | #define PACKAGE "tesseract" | #define VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_NAME "tesseract" | #define PACKAGE_VERSION "11-eol-29006-g32aec1e" | #define PACKAGE_YEAR "2022" | #define PACKAGE_DATE "07/06" (snip) ## ---------------------- ## ## Running config.status. ## ## ---------------------- ## This file was extended by tesseract config.status 11-eol-29006-g32aec1e, which was generated by GNU Autoconf 2.71. Invocation command line was CONFIG_FILES = CONFIG_HEADERS = CONFIG_LINKS = CONFIG_COMMANDS = $ ./config.status (snip) GENERIC_API_VERSION='11-eol-29006-g32aec1e.e' GENERIC_LIBRARY_NAME='tesseract' GENERIC_LIBRARY_VERSION='11-eol-29006-g32aec1e:e' GENERIC_MAJOR_VERSION='11-eol-29006-g32aec1e' GENERIC_MICRO_VERSION='' GENERIC_MINOR_VERSION='e' GENERIC_RELEASE='11-eol-29006-g32aec1e.e' GENERIC_VERSION='11-eol-29006-g32aec1e.e.' (snip) PACKAGE='tesseract' PACKAGE_BUGREPORT='https://github.com/tesseract-ocr/tesseract/issues' PACKAGE_DATE='07/06' PACKAGE_NAME='tesseract' PACKAGE_STRING='tesseract 11-eol-29006-g32aec1e' PACKAGE_TARNAME='tesseract' PACKAGE_URL='https://github.com/tesseract-ocr/tesseract/' PACKAGE_VERSION='11-eol-29006-g32aec1e' PACKAGE_YEAR='2022' (snip) VERSION='11-eol-29006-g32aec1e' (snip) ## ----------- ## ## confdefs.h. ## ## ----------- ## /* confdefs.h */ #define PACKAGE_NAME "tesseract" #define PACKAGE_TARNAME "tesseract" #define PACKAGE_VERSION "11-eol-29006-g32aec1e" #define PACKAGE_STRING "tesseract 11-eol-29006-g32aec1e" #define PACKAGE_BUGREPORT "https://github.com/tesseract-ocr/tesseract/issues" #define PACKAGE_URL "https://github.com/tesseract-ocr/tesseract/" #define PACKAGE "tesseract" #define VERSION "11-eol-29006-g32aec1e" #define PACKAGE_NAME "tesseract" #define PACKAGE_VERSION "11-eol-29006-g32aec1e" #define PACKAGE_YEAR "2022" #define PACKAGE_DATE "07/06" (snip) Created attachment 235206 [details] config.status To be sure, uploaded WRKSRC/config.status. Portions containing problematic version string are: (snip) exec 6>&1 ## ----------------------------------- ## ## Main body of $CONFIG_STATUS script. ## ## ----------------------------------- ## # Save the log message, to keep $0 and so on meaningful, and to # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" This file was extended by tesseract $as_me 11-eol-29006-g32aec1e, which was generated by GNU Autoconf 2.71. Invocation command line was CONFIG_FILES = $CONFIG_FILES CONFIG_HEADERS = $CONFIG_HEADERS CONFIG_LINKS = $CONFIG_LINKS CONFIG_COMMANDS = $CONFIG_COMMANDS $ $0 $@ on `(hostname || uname -n) 2>/dev/null | sed 1q` " (snip) ac_cs_config='--enable-training --prefix=/usr/local --localstatedir=/var --mandir=/usr/local/man --disable-silent-rules --infodir=/usr/local/share/info/ --build =amd64-portbld-freebsd13.1 build_alias=amd64-portbld-freebsd13.1 CXX=c++ '\''CXXFLAGS=-O2 -pipe -march=haswell -fstack-protector-strong -isystem /usr/local/incl ude -fno-strict-aliasing -isystem /usr/local/include '\'' '\''LDFLAGS= -pthread -fstack-protector-strong '\'' LIBS=-L/usr/local/lib '\''CPPFLAGS=-isystem /usr/ local/include'\'' CC=cc '\''CFLAGS=-O2 -pipe -march=haswell -fstack-protector-strong -isystem /usr/local/include -fno-strict-aliasing '\'' PKG_CONFIG=pkgconf P KG_CONFIG_LIBDIR=/usr/ports/graphics/tesseract/work/.pkgconfig:/usr/local/libdata/pkgconfig:/usr/libdata/pkgconfig' ac_cs_version="\ tesseract config.status 11-eol-29006-g32aec1e configured by ./configure, generated by GNU Autoconf 2.71, with options \"$ac_cs_config\" (snip) PACKAGE='tesseract' VERSION='11-eol-29006-g32aec1e' RM='rm -f' ofile='libtool' (snip) S["GENERIC_VERSION"]="11-eol-29006-g32aec1e.e." S["GENERIC_RELEASE"]="11-eol-29006-g32aec1e.e" S["GENERIC_LIBRARY_NAME"]="tesseract" S["GENERIC_LIBRARY_VERSION"]="11-eol-29006-g32aec1e:e" S["GENERIC_MICRO_VERSION"]="" S["GENERIC_MINOR_VERSION"]="e" S["GENERIC_MAJOR_VERSION"]="11-eol-29006-g32aec1e" S["GENERIC_API_VERSION"]="11-eol-29006-g32aec1e.e" S["SED"]="/usr/bin/sed" S["PACKAGE_DATE"]="07/06" S["PACKAGE_YEAR"]="2022" (snip) S["MAKEINFO"]="${SHELL} '/usr/ports/graphics/tesseract/work/tesseract-5.2.0/config/missing' makeinfo" S["AUTOHEADER"]="${SHELL} '/usr/ports/graphics/tesseract/work/tesseract-5.2.0/config/missing' autoheader" S["AUTOMAKE"]="${SHELL} '/usr/ports/graphics/tesseract/work/tesseract-5.2.0/config/missing' automake-1.16" S["AUTOCONF"]="${SHELL} '/usr/ports/graphics/tesseract/work/tesseract-5.2.0/config/missing' autoconf" S["ACLOCAL"]="${SHELL} '/usr/ports/graphics/tesseract/work/tesseract-5.2.0/config/missing' aclocal-1.16" S["VERSION"]="11-eol-29006-g32aec1e" S["PACKAGE"]="tesseract" (snip) S["PACKAGE_STRING"]="tesseract 11-eol-29006-g32aec1e" S["PACKAGE_VERSION"]="11-eol-29006-g32aec1e" S["PACKAGE_TARNAME"]="tesseract" S["PACKAGE_NAME"]="tesseract" (snip) # Set up the scripts for CONFIG_HEADERS section. # No need to generate them if there are no CONFIG_HEADERS. # This happens for instance with `./config.status Makefile'. if test -n "$CONFIG_HEADERS"; then cat >"$ac_tmp/defines.awk" <<\_ACAWK || BEGIN { D["PACKAGE_NAME"]=" \"tesseract\"" D["PACKAGE_TARNAME"]=" \"tesseract\"" D["PACKAGE_VERSION"]=" \"11-eol-29006-g32aec1e\"" D["PACKAGE_STRING"]=" \"tesseract 11-eol-29006-g32aec1e\"" D["PACKAGE_BUGREPORT"]=" \"https://github.com/tesseract-ocr/tesseract/issues\"" D["PACKAGE_URL"]=" \"https://github.com/tesseract-ocr/tesseract/\"" D["PACKAGE"]=" \"tesseract\"" D["VERSION"]=" \"11-eol-29006-g32aec1e\"" D["PACKAGE_NAME"]=" \"tesseract\"" D["PACKAGE_VERSION"]=" \"11-eol-29006-g32aec1e\"" D["PACKAGE_YEAR"]=" \"2022\"" D["PACKAGE_DATE"]=" \"07/06\"" (snip) Doing `grep -r -n "11-eol-29006-g32aec1e" /usr/ports/graphics/tesseract/ | cut -d : -f 1 | sort | uniq` *After `make extract` : None detected. *After `make patch` : None detected. *After `make configure`: Detected below. /usr/ports/graphics/tesseract/work/tesseract-5.2.0/autom4te.cache/output.0 /usr/ports/graphics/tesseract/work/tesseract-5.2.0/autom4te.cache/output.1 /usr/ports/graphics/tesseract/work/tesseract-5.2.0/autom4te.cache/output.2 /usr/ports/graphics/tesseract/work/tesseract-5.2.0/autom4te.cache/output.3 /usr/ports/graphics/tesseract/work/tesseract-5.2.0/config.log /usr/ports/graphics/tesseract/work/tesseract-5.2.0/config.status /usr/ports/graphics/tesseract/work/tesseract-5.2.0/configure /usr/ports/graphics/tesseract/work/tesseract-5.2.0/configure.libtool.bak /usr/ports/graphics/tesseract/work/tesseract-5.2.0/include/config_auto.h /usr/ports/graphics/tesseract/work/tesseract-5.2.0/include/tesseract/version.h /usr/ports/graphics/tesseract/work/tesseract-5.2.0/java/com/google/Makefile /usr/ports/graphics/tesseract/work/tesseract-5.2.0/java/com/google/scrollview/events/Makefile /usr/ports/graphics/tesseract/work/tesseract-5.2.0/java/com/google/scrollview/Makefile /usr/ports/graphics/tesseract/work/tesseract-5.2.0/java/com/google/scrollview/ui/Makefile /usr/ports/graphics/tesseract/work/tesseract-5.2.0/java/com/Makefile /usr/ports/graphics/tesseract/work/tesseract-5.2.0/java/Makefile /usr/ports/graphics/tesseract/work/tesseract-5.2.0/libtool /usr/ports/graphics/tesseract/work/tesseract-5.2.0/Makefile /usr/ports/graphics/tesseract/work/tesseract-5.2.0/tessdata/configs/Makefile /usr/ports/graphics/tesseract/work/tesseract-5.2.0/tessdata/Makefile /usr/ports/graphics/tesseract/work/tesseract-5.2.0/tessdata/tessconfigs/Makefile /usr/ports/graphics/tesseract/work/tesseract-5.2.0/tesseract.pc Running `grep -r -n "11-eol-29006-g32aec1e" (dir) | cut -d : -f 1 | sort | uniq` where (dir) is */usr/local/share/ : None detected. */usr/local/bin/ : None detected. */usr/local/lib/ : None detected. */usr/local/libdata/ : None detected. */usr/local/libexec/ : Detected below. Binary file /usr/local/libexec/libinput/libinput-record matches So x11/libinput should have same issue, but without harm. Is there anything else I can try? I am affected by exactly the same bug, let me know if you need more data points at this time. I am also having this issue. Maybe set bug to at least "Affects some people". This looks a lot like a compiler issue. It seems to build fine on the package builders for 13, but the think default compilers are different between 13.0 and 13.1. They certainly are between 13.0 and 13-STABLE. The port wants c++11-lang and I think that means the default compiler. Most failures that work with poudriere are the result of an unclean build environment, but this error does not seem like that sort of error. Maybe forcing the build to whatever version of clang is on 13.0-RELEASE would fix this. (Just guessing, I admit.) (In reply to rkoberman from comment #8) I have my own package builder on 13.1-RELEASE and the package builds just fine: https://talos.anongoth.pl/data/powerpc64le-default/2022-07-27_00h31m56s/logs/tesseract-5.2.0_1.log So it's not about using 13.1. Anyway, changed importance to "Affects some people" now as at least 3 (includng me) persons are affected. The problem is this change in tesseract's source code: https://github.com/tesseract-ocr/tesseract/commit/d7373727d6abcc7a9c50c744d6e63ab6a8ba36d6 Undo this change in configure.ac and it will build fine. The issue is that tesseract is trying to figure out its own version number from the most recent git commit, but ends up picking up the most recent commit to the ports tree instead (because the ports tree is kept in git, while the tesseract sources are extracted from a tar file). (In reply to freebsd from comment #11) Just a confirmation that this fixes my build problem. Could you try this patch? diff --git a/graphics/tesseract/Makefile b/graphics/tesseract/Makefile index 9d447cb9c780..96d434dbc718 100644 --- a/graphics/tesseract/Makefile +++ b/graphics/tesseract/Makefile @@ -30,6 +30,7 @@ CPE_VENDOR= tesseract_project USE_GITHUB= yes GH_ACCOUNT= ${PORTNAME}-ocr +BINARY_ALIAS= git=true DATADIR= ${PREFIX}/share/tessdata LDFLAGS+= -pthread PORTDATA= * (In reply to Piotr Kubaj from comment #13) Unfortunately, patch for Makefile didn't work. :-( (In reply to freebsd from comment #11) Thanks! looking into the upstream commit you mentioned, created a patch to store into (now non-existent) files/ directory, tried and it worked! I'll upload the patch shortly. Created attachment 235836 [details]
Patch to store into files/ directory
patch to store into (now non-existent) files/ directory.
As patches creating new directory often failes to reverse even if -E, this is NOT a patch to port tree. Just create files directory and store this there.
Just for the record: it also affects me and some others uitilizing FBSD/tesseract around here. Committed, thanks! A commit in branch main references this bug: URL: https://cgit.FreeBSD.org/ports/commit/?id=6c266c9c9e7b0ac1a35b05fbdeddbc330e4c5f43 commit 6c266c9c9e7b0ac1a35b05fbdeddbc330e4c5f43 Author: Piotr Kubaj <pkubaj@FreeBSD.org> AuthorDate: 2022-09-07 21:04:06 +0000 Commit: Piotr Kubaj <pkubaj@FreeBSD.org> CommitDate: 2022-09-07 21:08:25 +0000 graphics/tesseract: fix build when building from ports PR: 265091 Submitted by: junchoon@dec.sakura.ne.jp graphics/tesseract/files/patch-configure.ac (new) | 11 +++++++++++ 1 file changed, 11 insertions(+) *** Bug 265083 has been marked as a duplicate of this bug. *** |