Import 2017-06-07 23:51:09: master cfd8f4b3

Author Committer Branch Timestamp Parent
jcfr jcfr master 2015-06-26 14:47:09 master fceeab83
Changeset

BUG: Update VTKv6 to include fix for vtkhdf5 libraries DLL manifest

At the time of this commit the associated change hadn't been integrated
in VTK master and were under review here:

https://gitlab.kitware.com/jcfr/vtk/tree/fix-hdf5-manifest

Author: Jean-Christophe Fillion-Robin <jchris.fillionr@kitware.com>
Date: Fri Jun 26 14:15:47 2015 -0400

Do not force manifest selection for vtkhdf5 libraries

Following e16fac1, hdf5 libraries are build with -D_BIND_TO_CURRENT_VCLIBS_VERSION=1.

When building VTK using VS2008, the result of this is that
(1) VTK libraries all reference &quot;9.0.21022.8&quot; manifest expect the hdf5
ones that reference &quot;9.0.30729.1&quot; and (2) in some case prevent application
built against VTK from starting.

The problem can also be detected when running CMakeVerifyManifest.cmake
against the application install tree. It basically returns a message
similar to the following one:

8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----
ERROR: C:/Program Files/AwesomeApp 1.0.0/bin/vtkhdf5_hl-6.2.dll uses 9.0.30729.6161 not found in shipped manifests:[9.0.21022.8].
CMake Error at C:/D/Support/cmake-3.2.2-win32-x86/share/cmake-3.2/Modules/CMakeVerifyManifest.cmake:118 (message):
  This distribution embeds dll versions that it does not ship, and may not
  work on other machines.
8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----

Here are some more information copied from the convenience script allowing
to patch the manifest from VS2008.

Source:  https://gist.github.com/jcfr/3c7bef3f8b32f9f6ad4b

8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----

.SYNOPSIS
    Patch manifests in the redist folder of Visual Studio 9 (2008)
.DESCRIPTION
    To avoid the dll hell associated with runtime libraries distribution. There are
    two approaches:
     (1) edit the manifest file to have &quot;9.0.21022.8&quot; from the &quot;9.0.30729.XXX&quot; that is there, you &quot;trick&quot;
         your executable into using the newer dlls.  There appears to be no ill effects from this.
         The executables work, and you are using a newer version of the run time library.
     (2) add -D_BIND_TO_CURRENT_VCLIBS=1 to ALL files being compiled, then all of your executable files
         and dll files will refer to &quot;9.0.30729.XXX&quot; and you can use the redist files without any edits.
         However, you have to be careful here to recompile everything with this.  By default the compiler
         will build for &quot;9.0.21022.8&quot;.

    This script will consider approach (1). If not already done, this script will first backup the
    manifest files and then patch them.

    See:
      * http://www.kitware.com/blog/home/post/4
      * http://stackoverflow.com/questions/8097733/how-to-distribute-c-run-time-crt-libraries

8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----8&lt;----

git-svn-id: http://svn.slicer.org/Slicer4/trunk@24363 3bd1e089-480b-0410-8dfb-8563597acbee

mod - SuperBuild/External_VTKv6.cmake Diff File