Skip to main content

Advanced Table Settings for Conversion to Microsoft App-V

You can customize your virtual conversion process in the following ways:

  • Per package—You can use InstallShield to directly edit the ISVirtualPackage table to modify the settings referenced below. You can also use the App-V Assistant user interface to modify the settings.

  • Globally for any conversion—You can edit the Settings.xml file to specify default values for many of the settings that can be specified in the ISVirtualPackage table.

In addition to editing the ISVirtualPackage table, you can also edit other tables (directory, file, registry, shortcut) that store App-V conversion settings related to a particular item in the package, such as a particular shortcut, file, registry entry, or directory.

Information about customizing table settings for your App-V conversion process are organized into the following sections:

ISVirtualPackage Table

The ISVirtualPackage table is the main table that stores package-wide conversion settings. To edit this table, open the package in InstallShield and open the Direct Editor view. Also, if you make selections in the InstallShield Assistants, it will modify the settings in this table.

The following are App-V settings in the ISVirtualPackage table.

NameValueDefaultMeaning
AppVCommentsSFT file comments
AppVDiagFileSystem10Include File System Diagnostic tool - a shortcut is included to run cmd.exe from the physical System32 folder. This cmd.exe and any programs launched from it will have access to the virtual environment of the package
AppVDiagRegistry10Include Registry System Diagnostic tool - a shortcut is included to run regedit.exe from the physical Windows folder. It will have access to the virtual environment.
AppVDSC0, AppVDSC1, etc.Absolute path to OSD or SFT file [ : MANDATORY]Dynamic Suite Composition settings
AppVFullVFSWriteMode10Set to enable full VFS Write mode.
Note: This setting only applies for App-V 5.x packages.
APPVLOADING10Set this option to not include the SFT file in the wrapper MSI. The SFT file will be streamed from the server location specified in the OSD and manifest files.
AppVMsiWrapperCompress10Compression setting for wrapper MSI
AppVNameSame as name of MSISpecify package name
AppVNoCompression10Compression setting - default is compressed
AppVNoSpacesInFileNames1Will replace spaces in the SFT, OSD, and Icon file names with '_'.
AppVOSBitwise or of flags representing OS00 indicates OS independent. Otherwise, here is the OS list starting with bit 1: WinXP, WinXP64, Win2003Svr, Win2003TS, Win2003TS64, Win2008Svr, Win2008TS, Win2008TS64, WinVista, WinVista64, Win7, Win764, Win2008R2TS64
AppVPackageOptimizationOffline or StreamStreamOnly the shortcut targets are put in feature block 1 (FB1) if Stream is selected. Otherwise the entire package is put in FB1.
AppVPrereq10Set this option to include App-V client setup as a setup prerequisite for the wrapper MSI. It will be necessary to obtain a redistributable copy of the App-V client setup to use this feature.
AppVRootFolderName8.3 name based on product name and versionSpecify root folder name
AppVRuntimeDriveDrive letter such as M:Q:App-V client drive to use
AppVServerURLHostServer location of SFT file
AppVServerURLPortServer location of SFT file
AppVServerURLProtocolRTSP, RTSPS, FILE, HTTP, or HTTPSProtocol to use to access SFT file location
AppVSpaceReplacementStringSome stringUse together with setting AppVNoSpacesInFileNames property to 1. Any spaces in SFT, OSD, and Icon file names will be replaced by the string specified in the value of this property. If the string 'EMPTYSTRING' is used, then spaces will just be removed.
AppVTestLauncher11AppVLauncher.exe is copied next to the newly built App-V package. This tool can be used to easily test deploy App-V packages.
AppVUpgrade10Enables creation of an upgrade package
AppVUpgradeAppendPackageVersion11Package version will be appended to the end of the SFT file name
AppVUpgradeLatest10Will locate the most recently built App-V package based on modified timestamp on SFT files found in appropriately named sub-folders next to the MSI file.
AppVUpgradePreviousPackageAbsolute path to SFT from previous package that will be upgraded.
AppVv5ComInprocess10Set to 1 to enable in-process COM interaction. Com Interaction has to also be enabled for this option to have effect.
Note: This setting only applies for App-V 5.x packages.
AppVv5ComInteraction10Set to 1 to enable COM interaction.
Note: This setting only applies for App-V 5.x packages.
AppVv5ComOutofprocess11Set to 1 to enable out-of-process COM interaction. Com Interaction has to also be enabled for this option to have effect.
Note: This setting only applies for App-V 5.x packages.
AppVv5EnableBrowserHelperObjects01Set to 0 to disable browser helper objects.
Note: This setting only applies for App-V 5.x packages.
AppVv5NamedObjectsInteraction10Set to 1 to enable named objects interaction.
Note: This setting only applies for App-V 5.x packages.
BuildMSI10Create a wrapper MSI file that can be used to deploy the App-V package
MSIFile0, MSIFile1, etcAbsolute path to MSIIndicates other MSI packages to suite together with the current one into one package.
VirtualPackageBuildOutputFolderAbsolute path to a directoryInstead of creating the converted virtual applications in a folder next to the source MSI, put them in a new folder under this specified location - this overrides the global redirect option in settings.xml.
note

If you want to modify these settings globally, you need to edit the Settings.xml file, as described in Editing the Settings.xml File.

ISVirtualRelease Table

The ISVirtualRelease table stores the relationship between InstallShield project releases and the virtual package type you want to build. This table is only relevant when you are editing an InstallShield Basic MSI project (not when you are editing an MSI package in the DirectEdit mode). If you make the relevant selections in the Assistants, it will modify the settings in this table.

note

The settings in this table cannot be specified in the Settings.xml file.

ISRelease_ISProductConfiguration_NameValueMeaning
Key to ISReleaseKey to ISProductConfigurationBuildVirtualPackage1Build virtual package when associated release is built
Key to ISReleaseKey to ISProductConfigurationProviderSemicolon separated list of Thinstall, AppV, and CitrixIndicates virtual technologies to which to convert MSI packages

ISVirtualDirectory Table

The following are App-V settings in the ISVirtualDirectory table.

Directory_NameValueMeaning
Key into Directory tableAppVUserData1If set, then treat this directory as user data. If unspecified, then default algorithm is used to determine whether to mark directory as user data or application data.
Key into Directory tableAppVOverride1Override directory contents during upgrade

ISVirtualFile Table

The following are App-V settings in the ISVirtualFile table.

File_NameValueMeaning
Key into File tableAppVUserData1If set, then treat this file as user data. If unspecified, then default algorithm is used to determine whether to mark file as user data or application data.
Key into File tableAppVOverride1Override file during upgrade

ISVirtualRegistry Table

The following are App-V settings in the ISVirtualRegistry table.

Registry_NameValueMeaning
Key into Registry tableAppVOverride1If set, virtual application will only see the registry key contents in the virtual package and no child keys that may be present on the physical machine. Otherwise, virtual application will see only values in the virtual package, but will see child keys present on the physical machine, if they are not also present in the virtual package.

ISVirtualShortcut Table

The following are App-V settings in the ISVirtualShortcut table.

Shortcut_NameValueMeaning
Key into Shortcut tableAppVApplication0A value of zero indicates that this shortcut will not be included in the converted App-V package.

Manually Adding an Entry to the ISVirtualShortcut Table

Typically the target version in an OSD file is automatically determined during conversion to App-V 4.x package format. The version of the shortcut target file is used, or if the target file does not have a version, then a default value of ‘1.0’ is used. To set a custom version, you can manually add an entry to the ISVirtualShortcut table.

To manually populate the ISVirtualShortcut table using the InstallShield Editor:

  1. Open the Direct Editor view.
  2. Select the ISVirtualShortcut table and click New to add a new record.
  3. Enter the following values:
    • For Shortcut, enter the key of the shortcut.

    • For Name, enter the property name which is AppVTargetVersion.

    • For Value, enter the desired version number.

  4. Click OK.
    note

    This setting only has effect for App-V 4.x conversion.

Miscellaneous Virtual Conversion Settings

You can edit the following XML file to modify global settings that also govern the creation of virtual packages.

LocationNameValueMeaning
System\Msi.xmlIgnoreTablesMSI table namesControl whether an error or warning is flagged for certain tables during conversion
System\Msi.xmlIgnoreCustomActionsMSI custom action namesList of custom actions that can safely be ignored during virtual conversion
System\Msi.xmlPropertyDefaultsMSI property names with given valuesDefault values to use for certain MSI properties rather than flagging them as warnings
Support\0409\settings.xmlGlobalBuildRedirectFolderAbsolute directory pathInstead of creating the converted virtual applications in a folder next to the source MSI, put them in a new folder under this specified location

Editing the Settings.xml File

To edit the Settings.xml file, add a property element for each setting in the Virtualization/Properties section of the file. You can find the Settings.xml file in the following directory:

[InstallShield Installation Directory]\Support\0409

Edit the following section of the file:

<Virtualization>
...
<Properties>
<!--Use this section to provide a global default for any setting that is found in the ISVirtualPackage table-->
<!--<Property Name="AppVRuntimeDrive" Value="G:"/>-->
<!--<Property Name="AppVServerURLPath" Value="%PackageName%_v%PackageVersion%" />-->
</Properties>
</Virtualization>