Type a page name and press Enter. You'll jump to the page if it exists, or you can create it if it doesn't.
To create a page in a module other than msi, prefix the name with the module name and a period.
MsiProvideAssembly (msi)
.
C# Signature:
[DllImport("msi.dll", CharSet=CharSet.Auto, SetLastError=true)]
static extern uint MsiProvideAssembly(string assembly, string context, uint mode, int info, System.Text.StringBuilder path, ref int pathSize);
VB Signature:
Declare Function MsiProvideAssembly Lib "msi.dll" (TODO) As TODO
User-Defined Types:
None.
Notes:
This function is available starting with Windows Installer version 2.0.
Tips & Tricks:
Please add some!
Sample Code:
The following method will only work if your assembly was installed via Windows Installer:
public static string EnsureAssemblyIsInstalled(string assemblyName, string installPath)
{
int buffer = 1024;
if (error == 0)
return path.ToString(); // Already installed or successfully installed
// Failed to install
return null;
}
Alternative Managed API:
Do you know one? Please contribute it!
Please edit this page!
Do you have...
helpful tips or sample code to share for using this API in managed code?
corrections to the existing content?
variations of the signature you want to share?
additional languages you want to include?
Select "Edit This Page" on the right hand toolbar and edit it! Or add new pages containing supporting types needed for this API (structures, delegates, and more).