[vtkusers] Failing VTK 6.1.1 build with Tk/Python on OSX 10.9.4
Jens
linucks42 at gmail.com
Wed Sep 17 06:06:06 EDT 2014
Hi David,
I'm still struggling to get this build to work. I pointed the
CMakeCache.txt at the correct header and library directories (for tk 8.5),
but it persisted in setting:
TK_INTERNAL_PATH:PATH=/opt/VTK-6.1.0/ThirdParty/TclTk/internals/tk8.6
i.e. for version 8.6. In the end I manually set TK_INTERNAL_PATH so that it
pointed at tk 8.5.
The settings in my CMakeCache.txt are therefore:
//Path to a file.
TCL_INCLUDE_PATH:PATH=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk/System/Library/Frameworks/tcl.framework/Headers
//Path to a library.
TCL_LIBRARY:FILEPATH=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk/System/Library/Frameworks/tcl.framework
//Path to a program.
TCL_TCLSH:FILEPATH=/usr/bin/tclsh
//Path to a file.
TK_INCLUDE_PATH:PATH=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk/System/Library/Frameworks/tk.framework/Headers
//The path to the Tk internal headers (tkMacOSXDefault.h).
TK_INTERNAL_PATH:PATH=/opt/VTK-6.1.0/ThirdParty/TclTk/internals/tk8.5
//Path to a library.
TK_LIBRARY:FILEPATH=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk/System/Library/Frameworks/tk.framework
and just for reference, a long-listing of the tk.framework/Versions
directory shows:
Current -> 8.5
i.e. I'm pretty certain I should be using 8.5.
If I now run the make, it dies as follows:
[ 59%] Building CXX object
Rendering/Tk/CMakeFiles/vtkRenderingPythonTkWidgets.dir/vtkCocoaTkUtilities.mm.o
cd /opt/VTK-6.1.0/build/Rendering/Tk && /usr/bin/c++ -DVTK_IN_VTK
-DvtkRenderingPythonTkWidgets_EXPORTS -g -isysroot
/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk
-fPIC -I/opt/VTK-6.1.0/build/Interaction/Image
-I/opt/VTK-6.1.0/Interaction/Image -I/opt/VTK-6.1.0/build/Imaging/Color
-I/opt/VTK-6.1.0/Imaging/Color -I/opt/VTK-6.1.0/build/Imaging/Core
-I/opt/VTK-6.1.0/Imaging/Core -I/opt/VTK-6.1.0/build/Common/ExecutionModel
-I/opt/VTK-6.1.0/Common/ExecutionModel
-I/opt/VTK-6.1.0/build/Common/DataModel -I/opt/VTK-6.1.0/Common/DataModel
-I/opt/VTK-6.1.0/build/Common/Math -I/opt/VTK-6.1.0/Common/Math
-I/opt/VTK-6.1.0/build/Common/Core -I/opt/VTK-6.1.0/Common/Core
-I/opt/VTK-6.1.0/build/Utilities/KWSys -I/opt/VTK-6.1.0/Utilities/KWSys
-I/opt/VTK-6.1.0/build/Common/Misc -I/opt/VTK-6.1.0/Common/Misc
-I/opt/VTK-6.1.0/build/Common/System -I/opt/VTK-6.1.0/Common/System
-I/opt/VTK-6.1.0/build/Common/Transforms -I/opt/VTK-6.1.0/Common/Transforms
-I/opt/VTK-6.1.0/build/Interaction/Style -I/opt/VTK-6.1.0/Interaction/Style
-I/opt/VTK-6.1.0/build/Filters/Extraction
-I/opt/VTK-6.1.0/Filters/Extraction -I/opt/VTK-6.1.0/build/Filters/Core
-I/opt/VTK-6.1.0/Filters/Core -I/opt/VTK-6.1.0/build/Filters/General
-I/opt/VTK-6.1.0/Filters/General
-I/opt/VTK-6.1.0/build/Common/ComputationalGeometry
-I/opt/VTK-6.1.0/Common/ComputationalGeometry
-I/opt/VTK-6.1.0/build/Filters/Statistics
-I/opt/VTK-6.1.0/Filters/Statistics -I/opt/VTK-6.1.0/build/Imaging/Fourier
-I/opt/VTK-6.1.0/Imaging/Fourier -I/opt/VTK-6.1.0/build/ThirdParty/alglib
-I/opt/VTK-6.1.0/ThirdParty/alglib -I/opt/VTK-6.1.0/build/Filters/Sources
-I/opt/VTK-6.1.0/Filters/Sources -I/opt/VTK-6.1.0/build/Rendering/Core
-I/opt/VTK-6.1.0/Rendering/Core -I/opt/VTK-6.1.0/build/Filters/Geometry
-I/opt/VTK-6.1.0/Filters/Geometry
-I/opt/VTK-6.1.0/build/Interaction/Widgets
-I/opt/VTK-6.1.0/Interaction/Widgets -I/opt/VTK-6.1.0/build/Filters/Hybrid
-I/opt/VTK-6.1.0/Filters/Hybrid -I/opt/VTK-6.1.0/build/Imaging/Sources
-I/opt/VTK-6.1.0/Imaging/Sources -I/opt/VTK-6.1.0/build/Filters/Modeling
-I/opt/VTK-6.1.0/Filters/Modeling -I/opt/VTK-6.1.0/build/Imaging/General
-I/opt/VTK-6.1.0/Imaging/General -I/opt/VTK-6.1.0/build/Imaging/Hybrid
-I/opt/VTK-6.1.0/Imaging/Hybrid -I/opt/VTK-6.1.0/build/IO/Image
-I/opt/VTK-6.1.0/IO/Image -I/opt/VTK-6.1.0/build/Utilities/DICOMParser
-I/opt/VTK-6.1.0/Utilities/DICOMParser -I/opt/VTK-6.1.0/build/IO/Core
-I/opt/VTK-6.1.0/IO/Core -I/opt/VTK-6.1.0/build/ThirdParty/zlib
-I/opt/VTK-6.1.0/ThirdParty/zlib
-I/opt/VTK-6.1.0/build/Utilities/MetaIO/vtkmetaio
-I/opt/VTK-6.1.0/build/Utilities/MetaIO -I/opt/VTK-6.1.0/Utilities/MetaIO
-I/opt/VTK-6.1.0/build/ThirdParty/jpeg -I/opt/VTK-6.1.0/ThirdParty/jpeg
-I/opt/VTK-6.1.0/build/ThirdParty/png -I/opt/VTK-6.1.0/ThirdParty/png
-I/opt/VTK-6.1.0/build/ThirdParty/tiff -I/opt/VTK-6.1.0/ThirdParty/tiff
-I/opt/VTK-6.1.0/build/Rendering/Annotation
-I/opt/VTK-6.1.0/Rendering/Annotation
-I/opt/VTK-6.1.0/build/Rendering/FreeType
-I/opt/VTK-6.1.0/Rendering/FreeType
-I/opt/VTK-6.1.0/build/ThirdParty/freetype
-I/opt/VTK-6.1.0/ThirdParty/freetype -I/opt/VTK-6.1.0/ThirdParty/ftgl/src
-I/opt/VTK-6.1.0/build/ThirdParty/ftgl -I/opt/VTK-6.1.0/ThirdParty/ftgl
-I/opt/VTK-6.1.0/build/Rendering/Volume -I/opt/VTK-6.1.0/Rendering/Volume
-F/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk/System/Library/Frameworks
-I/opt/VTK-6.1.0/build/Rendering/OpenGL -I/opt/VTK-6.1.0/Rendering/OpenGL
-I/opt/VTK-6.1.0/build/Utilities/ParseOGLExt
-I/opt/VTK-6.1.0/Utilities/ParseOGLExt
-I/opt/VTK-6.1.0/build/Utilities/EncodeString
-I/opt/VTK-6.1.0/Utilities/EncodeString
-I/opt/VTK-6.1.0/build/ThirdParty/TclTk -I/opt/VTK-6.1.0/ThirdParty/TclTk
-I/opt/VTK-6.1.0/build/Rendering/Tk -I/opt/VTK-6.1.0/Rendering/Tk
-I/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk/System/Library/Frameworks/tk.framework/Headers
-I/opt/VTK-6.1.0/ThirdParty/TclTk/internals/tk8.5
-I/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk/System/Library/Frameworks/tcl.framework/Headers
-I/opt/VTK-6.1.0/Wrapping/Tcl -I/opt/VTK-6.1.0/build/Wrapping/Tcl -o
CMakeFiles/vtkRenderingPythonTkWidgets.dir/vtkCocoaTkUtilities.mm.o -c
/opt/VTK-6.1.0/Rendering/Tk/vtkCocoaTkUtilities.mm
/opt/VTK-6.1.0/Rendering/Tk/vtkCocoaTkUtilities.mm:57:28: error: no member
named 'view' in 'TkWindowPrivate'
NSView *result = macWin->view;
~~~~~~ ^
1 error generated.
make[2]: ***
[Rendering/Tk/CMakeFiles/vtkRenderingPythonTkWidgets.dir/vtkCocoaTkUtilities.mm.o]
Error 1
make[1]: *** [Rendering/Tk/CMakeFiles/vtkRenderingPythonTkWidgets.dir/all]
Error 2
make: *** [all] Error 2
If I get clang to print out the tk.h and tcl.h header files, it shows the
following:
/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk/System/Library/Frameworks/tcl.framework/Headers/tcl.h
/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk/System/Library/Frameworks/tk.framework/Headers/tk.h
Do you have any suggestions as to what might be going wrong here?
Best wishes,
Jens
On 15 September 2014 13:27, David Gobbi <david.gobbi at gmail.com> wrote:
> Hi Jens,
>
> I looked through FindTCL.cmake, and it looks like it tries to match
> the header to the library. Since it tries but fails, this could be
> considered a bug.
>
> - David
>
>
> On Mon, Sep 15, 2014 at 3:21 AM, Jens <linucks42 at gmail.com> wrote:
> > Hi David,
> >
> > Many thanks for the quick and very helpful reply. As you suspected there
> was
> > a mismatch between the tcl/tk headers. The headers were coming from:
> >
> > /usr/local/include
> >
> > and the libraries from:
> >
> >
> /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk/System/Library/Frameworks/tcl.framework
> >
> > I've pointed both at the /Applications/... directories and the build has
> now
> > got beyond that point, so thanks again for your help.
> >
> > Would that be considered a bug in cmake, or just bad luck on my part?
> >
> > I hadn't knowingly installed anything tk/tcl related on my machine (it's
> a
> > new macbook air and I've not loaded much software at all onto it), so
> I've
> > no idea where the stuff in /usr/local came from.
> >
> > However, if cmake had found the include files in /usr/local, shouldn't it
> > also have used the related libraries in /usr/local?
> >
> > Best wishes,
> >
> > Jens
> >
> >
> >
> > On 14 September 2014 22:34, David Gobbi <david.gobbi at gmail.com> wrote:
> >>
> >> Hi Jens,
> >>
> >> If the VTK build is looking for a function called Tcl_GetErrorLine(),
> >> that means that it is using a "tcl.h" for Tcl 8.6. This function
> doesn't
> >> exist in Tcl 8.5 or earlier versions of Tcl.
> >>
> >> My guess is that you have installed Tcl 8.6 on your system, and
> >> CMake has found the Tcl 8.6 headers, but is linking to the Tcl 8.5
> >> libraries in the System folder.
> >>
> >> Make sure that your CMakeCache.txt use the same framework for
> >> all the Tcl variables:
> >>
> >> TCL_INCLUDE_PATH:PATH=/System/Library/Frameworks/Tcl.framework/Headers
> >> TCL_LIBRARY:FILEPATH=/System/Library/Frameworks/Tcl.framework
> >> TCL_TCLSH:FILEPATH=/usr/bin/tclsh
> >> TK_INCLUDE_PATH:PATH=/System/Library/Frameworks/Tk.framework/Headers
> >>
> >>
> TK_INTERNAL_PATH:PATH=/System/Library/Frameworks/Tk.framework/PrivateHeaders
> >> TK_LIBRARY:FILEPATH=/System/Library/Frameworks/Tk.framework
> >>
> >> If you still have problems after setting your cache as shown above, then
> >> you might have to find and remove the tcl.h file that is causing the
> >> error.
> >>
> >> - David
> >>
> >>
> >> On Sun, Sep 14, 2014 at 2:57 PM, Jens <linucks42 at gmail.com> wrote:
> >> > Hi,
> >> >
> >> > I'm trying to build VTK 6.1.1 with the Tk and Python bindings on OSX
> >> > 10.9.4,
> >> > with cmake 3.0.2 and At 5.3.1.
> >> >
> >> > The build is failing with:
> >> >
> >> > /usr/bin/c++ -g -isysroot
> >> >
> >> >
> /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk
> >> > -dynamiclib -Wl,-headerpad_max_install_names -compatibility_version
> >> > 1.0.0
> >> > -current_version 1.0.0 -o ../../lib/libvtkCommonCoreTCL-6.1.1.dylib
> >> > -install_name /opt/VTK-6.1.0/build/lib/libvtkCommonCoreTCL-6.1.1.dylib
> >> >
> >> > ...snip...
> >> >
> >> > CMakeFiles/vtkCommonCoreTCL.dir/vtkTypeFloat64ArrayTcl.cxx.o
> >> > CMakeFiles/vtkCommonCoreTCL.dir/vtkCommonCoreTCLInit.cxx.o
> >> > CMakeFiles/vtkCommonCoreTCL.dir/__/__/Wrapping/Tcl/vtkTclUtil.cxx.o
> >> > ../../lib/libvtkCommonCore-6.1.1.dylib ../../lib/libvtksys-6.1.1.dylib
> >> > -framework tcl -lm
> >> >
> >> > Undefined symbols for architecture x86_64:
> >> >
> >> > "_Tcl_GetErrorLine", referenced from:
> >> >
> >> > vtkTclVoidFunc(void*) in vtkTclUtil.cxx.o
> >> >
> >> > vtkTclCommand::Execute(vtkObject*, unsigned long, void*) in
> >> > vtkTclUtil.cxx.o
> >> >
> >> > ld: symbol(s) not found for architecture x86_64
> >> >
> >> > clang: error: linker command failed with exit code 1 (use -v to see
> >> > invocation)
> >> >
> >> > make[2]: *** [lib/libvtkCommonCoreTCL-6.1.1.dylib] Error 1
> >> >
> >> > make[1]: *** [Common/Core/CMakeFiles/vtkCommonCoreTCL.dir/all] Error 2
> >> >
> >> >
> >> > Can anyone suggest a workaround?
> >> >
> >> >
> >> > Best wishes,
> >> >
> >> >
> >> > Jens
> >
> >
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://public.kitware.com/pipermail/vtkusers/attachments/20140917/c295fd42/attachment.html>
More information about the vtkusers
mailing list