Show/Hide Toolbars

XSharp

Specifies the minimum version of the subsystem on which the generated executable file can run, thereby determining the versions of Windows on which the executable file can run. Most commonly, this option ensures that the executable file can leverage particular security features that are not available with older versions of Windows.

 

Note

To specify the subsystem itself, use the -target compiler option.

Syntax

-subsystemversion:major.minor  

 

Parameters

major.minorThe minimum required version of the subsystem, as expressed in a dot notation for major and minor versions. For example, you can specify that an application cannot run on an operating system that is older than Windows 7 if you set the value of this option to 6.01, as the table later in this topic describes. You must specify the values for major and minor as integers.

 

Leading zeroes in the minor version do not change the version, but trailing zeroes do. For example, 6.1 and 6.01 refer to the same version, but 6.10 refers to a different version. We recommend expressing the minor version as two digits to avoid confusion.

Remarks

The following table lists common subsystem versions of Windows:

 

Windows version

Subsystem version

Windows 2000

5.00

Windows XP

5.01

Windows Server 2003

5.02

Windows Vista

6.00

Windows 7

6.01

Windows Server 2008

6.01

Windows 8

6.02

Default values

The default value of the -subsystemversion compiler option depends on the conditions in the following list:

 

The default value is 6.02 if any compiler option in the following list is set:

o-target:appcontainerexe

o-target:winmdobj

o-platform:arm

The default value is 6.00 if you are using MSBuild, are targeting .NET Framework 4.5, and have not set any of the compiler options that were specified earlier in this list.

The default value is 4.00 if none of the previous conditions is true.

Setting this option

To set the -subsystemversion compiler option in Visual Studio, you must open the .xsproj file and specify a value for the SubsystemVersion property in the MSBuild XML. You cannot set this option in the Visual Studio IDE.