Howdy,

GS > With the manifest in place, it will *not* try to load the DLLs from the 
local directory (this is done to prohibit tampering of shared libraries).

Regis >But [1] says the searching sequence for the private assembly is:
Regis >
Regis >    1. Side-by-side searches the WinSxS folder.
Regis >    2. \\<appdir>\<assemblyname>.DLL
Regis >    3. \\<appdir>\<assemblyname>.manifest
Regis >    4. \\<appdir>\<assemblyname>\<assemblyname>.DLL
Regis >    5. \\<appdir>\<assemblyname>\<assemblyname>.manifest
Regis >

So, just to be clear, the <assemblyname> is not the same as the DLL name.
== This is where WinSxS gets *really* complicated. == 

With WinSxS, an "Assembly" is a collection of *one or more* files specified by 
a manifest. 
The <assemblyname>  is often == to a DLL name, but there is no requirement for 
this to be true.

the <assemblyname> in this case is "Microsoft.VC80.CRT".
    
When WinSxS looks for local (private) assemblies, it's looking for either:
    a DLL called "Microsoft.VC80.CRT.DLL" with a manifest resource or 
    an XML manifest file called "Microsoft.VC80.CRT.manifest"
that tells WinSxS about the files (dlls) in the manifest.

The assembly manifest (not to be confused with the application manifest) 
describes the contents of the assembly. 
In the case of the VC runtime, the manifest actually contains three DLL files:
    msvcr80.dll    
    msvcp80.dll
    msvcm80.dll

Regis >And I also found that manifest for redist CRT [2] has following lines:
Regis >
Regis >     <assemblyIdentity
Regis >         type="win32"
Regis >         name="Microsoft.VC80.CRT"
Regis >         version="8.0.50608.0"
Regis >         processorArchitecture="amd64"
Regis >         publicKeyToken="1fc8b3b9a1e18e3b"
Regis >     />
Regis >
Regis >but the version of msvcr80.dll in that folder is 8.0.50727.42
Regis >
Regis >[1] http://msdn.microsoft.com/en-us/library/aa374224%28VS.85%29.aspx
Regis >
Regis >[2] "C:\Program Files (x86)\Microsoft Visual Studio 
8\VC\redist\amd64\Microsoft.VC80.CRT\Microsoft.VC80.CRT.manifest"
Regis >

To be clear, just because you have version 8.0.50727.42 installed, does not 
mean that the 
binding policy redirecting 8.0.50608.0 to that newer version is installed.

** In My Opinion ** this should be the norm, but the VC++ team thought 
otherwise at the time.

To check if you have the Binding Policy installed, there will be a a file 
somewhere deep inside the c:\Windows\WinSxS folder with a name like

    
"amd64_policy.8.0.microsoft.vc80.crt_1fc8b3b9a1e18e3b_8.0.50727.42_none_1492cce54f6d20f0.manifest"

On Win2k3/XP the naming is different than on Vista and beyond, so I can't tell 
off the top of my head.
It should have "amd64" , "policy" , "8.0" , "microsoft.vc80.crt" in the 
filename.

If you have that file (which I suspect you don't) it would redirect requests 
for "8.0.50608.0" to "8.0.50727.42".

To get the Binding Policy, I believe the EXE installer of the 8.0.50727.42 
needs to be installed.

GS >
GS > Now, the publisher of the library can issue updates to the library and 
GS > redirect binding at runtime. This is done with what's called a "Binding 
Policy" in a "Publisher Configuration File". (Essentially, this policy tells 
the OS to redirect requests from a version range to a different version).  Now, 
the tricky part is, depending on how the newer version of the library got 
installed, the policy may or may not have been included. When the VC++ 
libraries are installed as part of a merge module (.msm) in an MSI installer, 
they don't redirect old versions of the library to the new one (the idea being 
that you don't neccesarily want old apps pointing to the new runtime[1]).  I 
believe if the VC++ redistributable (by installer [2]) is installed, it does 
install the new Binding Policy.
GS >
GS > By removing the Manifest, the OS just looks in the local directory for the 
libraries--this is not what you really really want--you'd need to include the 
VC++ runtimes in the application directory with the redistribution of Harmony 
itself.
GS >
Regis > Does it mean if we include the VC++ runtimes in Harmony local directory 
and expected it is used at runtime, we have to removing the manifest?

The *proper* way to include the runtimes in your local directory would be to 
place the manifest there (as <appdir>\Microsoft.VC80.CRT.manifest) and the 
files alongside it.

The *easy* way is to remove the assembly reference from your exe's manifest. 

Garrett

Reply via email to