Welcome to WuJiGu Developer Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
679 views
in Technique[技术] by (71.8m points)

cmake - glog doesn't compile on Windows with MinGW

It seems that glog doesn't compile on Windows with MinGW. Cmake configuration and generation is OK, but when I start the mingw32-make.exe -j10 command, I get a lot of errors related with ambiguity declarations.

This is the complete cmake configure and generate command output:

D:INSTALLDevelopmentlibceres-mingwgloguild>"D:Program FilesCMakeincmake.exe" -G "MinGW Makefiles" -Dgflags_DIR="D:INSTALLDevelopmentlibceres-mingwgflagsuild" ..
-- The C compiler identification is GNU 9.2.0
-- The CXX compiler identification is GNU 9.2.0
-- Check for working C compiler: D:/MinGW/bin/gcc.exe
-- Check for working C compiler: D:/MinGW/bin/gcc.exe -- works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Detecting C compile features
-- Detecting C compile features - done
-- Check for working CXX compiler: D:/MinGW/bin/g++.exe
-- Check for working CXX compiler: D:/MinGW/bin/g++.exe -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Detecting CXX compile features
-- Detecting CXX compile features - done
-- Looking for gflags namespace
-- Looking for gflags namespace - gflags
-- Looking for pthread.h
-- Looking for pthread.h - found
-- Performing Test CMAKE_HAVE_LIBC_PTHREAD
-- Performing Test CMAKE_HAVE_LIBC_PTHREAD - Failed
-- Looking for pthread_create in pthreads
-- Looking for pthread_create in pthreads - not found
-- Looking for pthread_create in pthread
-- Looking for pthread_create in pthread - found
-- Found Threads: TRUE
-- Could NOT find Unwind (missing: Unwind_INCLUDE_DIR Unwind_LIBRARY Unwind_PLATFORM_LIBRARY)
-- Looking for dlfcn.h
-- Looking for dlfcn.h - found
-- Looking for execinfo.h
-- Looking for execinfo.h - not found
-- Looking for glob.h
-- Looking for glob.h - found
-- Looking for inttypes.h
-- Looking for inttypes.h - found
-- Looking for memory.h
-- Looking for memory.h - found
-- Looking for pwd.h
-- Looking for pwd.h - not found
-- Looking for stdint.h
-- Looking for stdint.h - found
-- Looking for stdlib.h
-- Looking for stdlib.h - found
-- Looking for string.h
-- Looking for string.h - found
-- Looking for strings.h
-- Looking for strings.h - found
-- Looking for sys/stat.h
-- Looking for sys/stat.h - found
-- Looking for sys/syscall.h
-- Looking for sys/syscall.h - not found
-- Looking for sys/time.h
-- Looking for sys/time.h - found
-- Looking for sys/types.h
-- Looking for sys/types.h - found
-- Looking for sys/utsname.h
-- Looking for sys/utsname.h - not found
-- Looking for sys/wait.h
-- Looking for sys/wait.h - not found
-- Looking for syscall.h
-- Looking for syscall.h - not found
-- Looking for syslog.h
-- Looking for syslog.h - not found
-- Looking for ucontext.h
-- Looking for ucontext.h - not found
-- Looking for unistd.h
-- Looking for unistd.h - found
-- Looking for C++ include ext/hash_map
-- Looking for C++ include ext/hash_map - found
-- Looking for C++ include ext/hash_set
-- Looking for C++ include ext/hash_set - found
-- Looking for C++ include ext/slist
-- Looking for C++ include ext/slist - found
-- Looking for C++ include tr1/unordered_map
-- Looking for C++ include tr1/unordered_map - found
-- Looking for C++ include tr1/unordered_set
-- Looking for C++ include tr1/unordered_set - found
-- Looking for C++ include unordered_map
-- Looking for C++ include unordered_map - found
-- Looking for C++ include unordered_set
-- Looking for C++ include unordered_set - found
-- Looking for stddef.h
-- Looking for stddef.h - found
-- Check size of unsigned __int16
-- Check size of unsigned __int16 - done
-- Check size of u_int16_t
-- Check size of u_int16_t - failed
-- Check size of uint16_t
-- Check size of uint16_t - done
-- Looking for dladdr
-- Looking for dladdr - not found
-- Looking for fcntl
-- Looking for fcntl - not found
-- Looking for pread
-- Looking for pread - not found
-- Looking for pwrite
-- Looking for pwrite - not found
-- Looking for sigaction
-- Looking for sigaction - not found
-- Looking for sigaltstack
-- Looking for sigaltstack - not found
-- Performing Test HAVE_NO_DEPRECATED
-- Performing Test HAVE_NO_DEPRECATED - Success
-- Performing Test HAVE_NO_UNNAMED_TYPE_TEMPLATE_ARGS
-- Performing Test HAVE_NO_UNNAMED_TYPE_TEMPLATE_ARGS - Failed
-- Looking for snprintf
-- Looking for snprintf - found
-- Looking for UnDecorateSymbolName in dbghelp
-- Looking for UnDecorateSymbolName in dbghelp - not found
-- Performing Test HAVE___ATTRIBUTE__
-- Performing Test HAVE___ATTRIBUTE__ - Success
-- Performing Test HAVE___ATTRIBUTE__VISIBILITY_DEFAULT
-- Performing Test HAVE___ATTRIBUTE__VISIBILITY_DEFAULT - Success
-- Performing Test HAVE___ATTRIBUTE__VISIBILITY_HIDDEN
-- Performing Test HAVE___ATTRIBUTE__VISIBILITY_HIDDEN - Success
-- Performing Test HAVE___BUILTIN_EXPECT
-- Performing Test HAVE___BUILTIN_EXPECT - Success
-- Performing Test HAVE___SYNC_VAL_COMPARE_AND_SWAP
-- Performing Test HAVE___SYNC_VAL_COMPARE_AND_SWAP - Success
-- Performing Test HAVE_RWLOCK
-- Performing Test HAVE_RWLOCK - Failed
-- Performing Test HAVE___DECLSPEC
-- Performing Test HAVE___DECLSPEC - Success
-- Performing Test STL_NO_NAMESPACE
-- Performing Test STL_NO_NAMESPACE - Failed
-- Performing Test STL_STD_NAMESPACE
-- Performing Test STL_STD_NAMESPACE - Success
-- Performing Test HAVE_USING_OPERATOR
-- Performing Test HAVE_USING_OPERATOR - Success
-- Performing Test HAVE_NAMESPACES
-- Performing Test HAVE_NAMESPACES - Success
-- Performing Test HAVE_GCC_TLS
-- Performing Test HAVE_GCC_TLS - Success
-- Performing Test HAVE_MSVC_TLS
-- Performing Test HAVE_MSVC_TLS - Success
-- Performing Test HAVE_CXX11_TLS
-- Performing Test HAVE_CXX11_TLS - Success
-- Performing Test HAVE_ALIGNED_STORAGE
-- Performing Test HAVE_ALIGNED_STORAGE - Success
-- Performing Test HAVE_SYMBOLIZE
-- Performing Test HAVE_SYMBOLIZE - Failed
-- Performing Test HAVE_LOCALTIME_R
-- Performing Test HAVE_LOCALTIME_R - Failed
-- Configuring done
-- Generating done
-- Build files have been written to: D:/INSTALL/Development/lib/ceres-mingw/glog/build

And this is the error output of the mingw32 compilation command:

D:INSTALLDevelopmentlibceres-mingwglogsrcdemangle.cc:42:10: fatal error: dbghelp.h: No such file or directory
   42 | #include <dbghelp.h>
      |          ^~~~~~~~~~~
compilation terminated.
CMakeFilesglog.diruild.make:62: recipe for target 'CMakeFiles/glog.dir/src/demangle.cc.obj' failed
mingw32-make[2]: *** [CMakeFiles/glog.dir/src/demangle.cc.obj] Error 1
mingw32-make[2]: *** Waiting for unfinished jobs....
In file included from D:INSTALLDevelopmentlibceres-mingwglogsrclogging.cc:63:
D:INSTALLDevelopmentlibceres-mingwglogsrcwindows/dirent.h:383:28: error: missing binary operator before token "("
  383 | #if WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
      |                            ^
D:INSTALLDevelopmentlibceres-mingwglogsrcwindows/dirent.h:405:28: error: missing binary operator before token "("
  405 | #if WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
      |                            ^
D:INSTALLDevelopmentlibceres-mingwglogsrcsymbolize.cc:877:10: fatal error: dbghelp.h: No such file or directory
  877 | #include <dbghelp.h>
      |          ^~~~~~~~~~~
compilation terminated.
In file included from D:INSTALLDevelopmentlibceres-mingwglogsrcwindowsport.cc:41:
D:INSTALLDevelopmentlibceres-mingwglogsrcwindowsport.h:166:14: error: ambiguating new declaration of 'char* strerror_r(int, char*, size_t)'
  166 | inline char* strerror_r(int errnum, char* buf, size_t buflen) {
      |              ^~~~~~~~~~
In file included from d:mingwincludewinnt.h:49,
                 from d:mingwincludewindef.h:269,
                 from d:mingwincludewindows.h:42,
                 from D:INSTALLDevelopmentlibceres-mingwglogsrcwindowsport.h:52,
                 from D:INSTALLDevelopmentlibceres-mingwglogsrcwindowsport.cc:41:
d:mingwincludestring.h:223:12: note: old declaration 'int strerror_r(int, char*, size_t)'
  223 | extern int strerror_r (int, char *, size_t);
      |            ^~~~~~~~~~C akeFilesglog.diruild.make:104: recipe for target 'CMakeFiles/glog.dir/src/symbolize.cc.obj' failed

mingw32-make[2]: *** [CMakeFiles/glog.dir/src/sy D:INSTALLDevelopmentlibceres-mingwglogsrcwindowsport.cc:bo In function 'litm* localtime_r(const time_t*, tm*)ze':
.cD:INSTALLDevelopmentlibceres-mingwglogsrcwindowsport.cc:53:3:c. oberror: j]' Elocaltime_srr' was not declared in this scope; did you mean 'orlocaltime_r 1'?
   53 |
localtime_s(result, timep);
      |   ^~~~~~~~~~~
      |   localtime_r
D:INSTALLDevelopmentlibceres-mingwglogsrcwindowsport.cc: In function 'tm* gmtime_r(const time_t*, tm*)':
D:INSTALLDevelopmentlibceres-mingwglogsrcwindowsport.cc:59:5: error: 'gmtime_s' was not declared in this scope; did you mean 'gmtime_r'?
   59 |     gmtime_s(result, timep);
      |     ^~~~~~~~
      |     gmtime_r
In file included from D:INSTALLDevelopmentlibceres-mingwglogsrcutilities.h:80,
                 from D:INSTALLDevelopmentlibceres-mingwglogsrc
aw_logging.cc:34:
D:/INSTALL/Development/lib/ceres-mingw/glog/src/windows/port.h:166:14: error: ambiguating new declaration of 'char* strerror_r(int, char*, size_t)'
  166 | inline char* strerror_r(int errnum, char* buf, size_t buflen) {
      |              ^~~~~~~~~~
In file included from d:mingwincludewinnt.h:49,
                 from d:mingwincludewindef.h:269,
                 from d:mingwincludewindows.h:42,
                 from D:INSTALLDevelopmentlibceres-mingwglogsrcase/mutex.h:129,
                 from D:INSTALLDevelopmentlibceres-mingwglogsrcutilities.h:75,
                 from D:INSTALLDevelopmentlibceres-mingwglogsrc
aw_logging.cc:34:
d:mingwincludestring.h:223:12: note: old declaration 'int strerror_r(int, char*, size_t)'
  223 | extern int  MakeFilesglog.diruild.make:160: recipe for target 'CMakeFiles/glog.dirstrerror_r/ rc/windows/port.cc.obj' failed
 (int, char *, size_t);
      |            mi^~~~~~~~~~ng
w32-make[2]: *** [CMakeFiles/glog.dir/src/windows/port.cc.obj] Error 1
In file included from D:INSTALLDevelopmentlibceres-mingwglogsrcutilities.h:80,
                 from D:INSTALLDevelopmentlibceres-mingwglogsrclogging.cc:32:
D:/INSTALL/Development/lib/ceres-mingw/glog/src/windows/port.h:166:14: error: ambiguating new declaration of 'char* strerror_r(int, char*, size_t)'
  166 | inline char* strerror_r(int errnum, char* buf, size_t buflen) {
      |              ^~~~~~~~~~
In file included from d:mingwincludewinnt.h:49,
                 from d:mingwincludewindef.h:269,
                 from d:mingwincludewindows.h:42,
                 from In file included from                                                                                                                                                                                                                   from ,
                 from                                                                                                                                                                                                                                         from :
                                                                                                                                                                                                                                                                                       ambiguating new declaration of '                                                           '
  166 | inline char*                                                                                                                                                                                          

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Answer

0 votes
by (71.8m points)

I managed to compile glog on Windows with MinGW using these steps:

in my ceres folder (in my case "D:INSTALLDevelopmentlibceres-mingw") I typed:

> git clone https://github.com/google/glog.git

After that I renamed the "glog/BUILD" file to "_BUILD" and created a folder named 'build'. After that I entered the newly created 'build' folder and issued this command:

> "D:Program FilesCMakeincmake.exe" -G "MinGW Makefiles" -DCMAKE_CXX_STANDARD=14 -DCMAKE_CXX_STANDARD_REQUIRED=ON -Dgflags_DIR="D:INSTALLDevelopmentlibceres-mingwgflagsuild" ..
> "D:MinGW64mingw64inmingw32-make.exe" -j10

Important remark: I copied 'log_severity.h' from the 'srcglog' folder (in my case 'D:INSTALLDevelopmentlibceres-mingwglogsrcglog') to the 'buildglog' folder (in my case 'D:INSTALLDevelopmentlibceres-mingwgloguildglog').

As a result, I have:

  • All include files located in
    'D:INSTALLDevelopmentlibceres-mingwgloguildglog'

  • libglog.a static library located in
    'D:INSTALLDevelopmentlibceres-mingwgloguild'

  • glog-config.cmake file located in my build folder (in my case
    'D:INSTALLDevelopmentlibceres-mingwgloguild')

Optionally one can make install (I didn't):

> "D:MinGW64mingw64inmingw32-make.exe" install

Hope this information will be useful for other users too!

P.S.: I should most probably have to recompile again glog (and maybe also gflags and ceres), adding '-fPIC' to CMAKE_CXX_FLAGS, otherwise I get an error linking libopencv_java4.so to libglog.a when compiling OpenCV for Android with MinGW on Windows. Or I have to use shared libraries when compiling OpenCV for Android. I am going to check this soon.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome to WuJiGu Developer Q&A Community for programmer and developer-Open, Learning and Share
...