internal void AddVOCompatibilityCommands(XSharpCommandLineBuilder commandline) { // VO Compatibility switches if (NS) // Add Default Namespace { commandline.AppendSwitch("/ns:" + this.RootNameSpace); } commandline.AppendPlusOrMinusSwitch("/az", base.Bag, nameof(AZ)); //commandline.AppendPlusOrMinusSwitch("/cs", base.Bag, nameof(CS)); commandline.AppendPlusOrMinusSwitch("/ins", base.Bag, nameof(INS)); commandline.AppendPlusOrMinusSwitch("/lb", base.Bag, nameof(LB)); commandline.AppendPlusOrMinusSwitch("/namedarguments", base.Bag, nameof(NamedArgs)); commandline.AppendPlusOrMinusSwitch("/memvar", base.Bag, nameof(MemVar)); commandline.AppendPlusOrMinusSwitch("/undeclared", base.Bag, nameof(Undeclared)); commandline.AppendPlusOrMinusSwitch("/ovf", base.Bag, nameof(OVF)); commandline.AppendPlusOrMinusSwitch("/ppo", base.Bag, nameof(PPO)); commandline.AppendPlusOrMinusSwitch("/vo1", base.Bag, nameof(VO1)); commandline.AppendPlusOrMinusSwitch("/vo2", base.Bag, nameof(VO2)); commandline.AppendPlusOrMinusSwitch("/vo3", base.Bag, nameof(VO3)); commandline.AppendPlusOrMinusSwitch("/vo4", base.Bag, nameof(VO4)); commandline.AppendPlusOrMinusSwitch("/vo5", base.Bag, nameof(VO5)); commandline.AppendPlusOrMinusSwitch("/vo6", base.Bag, nameof(VO6)); commandline.AppendPlusOrMinusSwitch("/vo7", base.Bag, nameof(VO7)); commandline.AppendPlusOrMinusSwitch("/vo8", base.Bag, nameof(VO8)); commandline.AppendPlusOrMinusSwitch("/vo9", base.Bag, nameof(VO9)); commandline.AppendPlusOrMinusSwitch("/vo10", base.Bag, nameof(VO10)); //commandline.AppendPlusOrMinusSwitch("/vo11", base.Bag, nameof(VO11)); commandline.AppendPlusOrMinusSwitch("/vo12", base.Bag, nameof(VO12)); commandline.AppendPlusOrMinusSwitch("/vo13", base.Bag, nameof(VO13)); commandline.AppendPlusOrMinusSwitch("/vo14", base.Bag, nameof(VO14)); commandline.AppendPlusOrMinusSwitch("/vo15", base.Bag, nameof(VO15)); commandline.AppendPlusOrMinusSwitch("/vo16", base.Bag, nameof(VO16)); commandline.AppendPlusOrMinusSwitch("/xpp1", base.Bag, nameof(XPP1)); commandline.AppendPlusOrMinusSwitch("/xpp2", base.Bag, nameof(XPP2)); // User-defined CommandLine Option (in order to support switches unknown at that time) // cannot use appendswitch because it will quote the string when there are embedded spaces if (!String.IsNullOrEmpty(this.CommandLineOption)) { commandline.AppendTextUnquoted(this.CommandLineOption); } if (this.IncludePaths?.Length > 0) { StringBuilder sb = new StringBuilder(); foreach (var s in this.IncludePaths) { if (sb.Length > 0) { sb.Append(';'); } sb.Append(s); } string path = sb.ToString(); path = path.Replace(@"\\", @"\"); commandline.AppendTextUnquoted("/i:\"" + path + "\""); } }
/// <summary> /// Mostly copied from the csc task in Roslyn /// </summary> /// <param name="commandLine"></param> internal void AddCscCompilerCommands(XSharpCommandLineBuilder commandLine) { commandLine.AppendSwitchIfNotNull("/lib:", AdditionalLibPaths, ","); commandLine.AppendPlusOrMinusSwitch("/unsafe", base.Bag, nameof(AllowUnsafeBlocks)); commandLine.AppendPlusOrMinusSwitch("/checked", base.Bag, nameof(CheckForOverflowUnderflow)); commandLine.AppendSwitchWithSplitting("/nowarn:", DisabledWarnings, ",", ';', ','); //commandLine.AppendWhenTrue("/fullpaths", base.Bag, nameof(GenerateFullPaths)); commandLine.AppendSwitch("/fullpaths"); commandLine.AppendSwitchIfNotNull("/langversion:", LangVersion); commandLine.AppendSwitchIfNotNull("/moduleassemblyname:", ModuleAssemblyName); commandLine.AppendSwitchIfNotNull("/pdb:", PdbFile); commandLine.AppendPlusOrMinusSwitch("/nostdlib", base.Bag, nameof(NoStandardLib)); commandLine.AppendPlusOrMinusSwitch("/nostddefs", base.Bag, nameof(NoStandardDefs)); if (!NoStandardDefs && !string.IsNullOrEmpty(StandardDefs)) { commandLine.AppendSwitchIfNotNull("/stddefs:", StandardDefs); } commandLine.AppendSwitchIfNotNull("/platform:", PlatformWith32BitPreference); commandLine.AppendSwitchIfNotNull("/errorreport:", ErrorReport); commandLine.AppendSwitchWithInteger("/warn:", base.Bag, nameof(WarningLevel)); commandLine.AppendSwitchIfNotNull("/doc:", DocumentationFile); commandLine.AppendSwitchIfNotNull("/baseaddress:", BaseAddress); commandLine.AppendSwitchUnquotedIfNotNull("/define:", Utilities.GetDefineConstantsSwitch(DefineConstants, Log)); commandLine.AppendSwitchIfNotNull("/win32res:", Win32Resource); commandLine.AppendSwitchIfNotNull("/main:", MainEntryPoint); commandLine.AppendSwitchIfNotNull("/appconfig:", ApplicationConfiguration); commandLine.AppendWhenTrue("/errorendlocation", base.Bag, nameof(ErrorEndLocation)); commandLine.AppendSwitchIfNotNull("/preferreduilang:", PreferredUILang); commandLine.AppendPlusOrMinusSwitch("/highentropyva", base.Bag, nameof(HighEntropyVA)); //// If not design time build and the globalSessionGuid property was set then add a -globalsessionguid:<guid> //bool designTime = false; //if (HostObject != null) //{ // var csHost = HostObject as ICscHostObject; // designTime = csHost.IsDesignTime(); //} //if (!designTime) //{ // if (!string.IsNullOrWhiteSpace(VsSessionGuid)) // { // commandLine.AppendSwitchIfNotNull("/sqmsessionguid:", VsSessionGuid); // } //} AddReferencesToCommandLine(commandLine, References); AddManagedCompilerCommands(commandLine); // This should come after the "TreatWarningsAsErrors" flag is processed (in managedcompiler.cs). // Because if TreatWarningsAsErrors=false, then we'll have a /warnaserror- on the command-line, // and then any specific warnings that should be treated as errors should be specified with // /warnaserror+:<list> after the /warnaserror- switch. The order of the switches on the command-line // does matter. // // Note that // /warnaserror+ // is just shorthand for: // /warnaserror+:<all possible warnings> // // Similarly, // /warnaserror- // is just shorthand for: // /warnaserror-:<all possible warnings> commandLine.AppendSwitchWithSplitting("/warnaserror+:", WarningsAsErrors, ",", ';', ','); commandLine.AppendSwitchWithSplitting("/warnaserror-:", WarningsNotAsErrors, ",", ';', ','); // It's a good idea for the response file to be the very last switch passed, just // from a predictability perspective. It also solves the problem that a dogfooder // ran into, which is described in an email thread attached to bug VSWhidbey 146883. // See also bugs 177762 and 118307 for additional bugs related to response file position. if (ResponseFiles != null) { foreach (ITaskItem response in ResponseFiles) { commandLine.AppendSwitchIfNotNull("@", response.ItemSpec); } } }
/// <summary> /// Mostly copied from the csc task in Roslyn /// </summary> /// <param name="commandLine"></param> internal void AddCscCompilerCommands(XSharpCommandLineBuilder commandLine) { commandLine.AppendSwitchIfNotNull("/lib:", AdditionalLibPaths, ","); commandLine.AppendPlusOrMinusSwitch("/unsafe", base.Bag, nameof(AllowUnsafeBlocks)); commandLine.AppendPlusOrMinusSwitch("/checked", base.Bag, nameof(CheckForOverflowUnderflow)); commandLine.AppendSwitchWithSplitting("/nowarn:", DisabledWarnings, ",", ';', ','); //commandLine.AppendWhenTrue("/fullpaths", base.Bag, nameof(GenerateFullPaths)); commandLine.AppendSwitch("/fullpaths"); commandLine.AppendSwitchIfNotNull("/langversion:", LangVersion); commandLine.AppendSwitchIfNotNull("/moduleassemblyname:", ModuleAssemblyName); commandLine.AppendSwitchIfNotNull("/pdb:", PdbFile); commandLine.AppendPlusOrMinusSwitch("/nostdlib", base.Bag, nameof(NoStandardLib)); commandLine.AppendSwitchIfNotNull("/platform:", Platform); commandLine.AppendSwitchIfNotNull("/errorreport:", ErrorReport); commandLine.AppendSwitchWithInteger("/warn:", base.Bag, nameof(WarningLevel)); //commandLine.AppendSwitchIfNotNull("/doc:", DocumentationFile); commandLine.AppendSwitchIfNotNull("/baseaddress:", BaseAddress); commandLine.AppendSwitchUnquotedIfNotNull("/define:", Utilities.GetDefineConstantsSwitch(DefineConstants, Log)); commandLine.AppendSwitchIfNotNull("/win32res:", Win32Resource); commandLine.AppendSwitchIfNotNull("/main:", MainEntryPoint); commandLine.AppendSwitchIfNotNull("/appconfig:", ApplicationConfiguration); commandLine.AppendWhenTrue("/errorendlocation", base.Bag, nameof(ErrorEndLocation)); commandLine.AppendSwitchIfNotNull("/preferreduilang:", PreferredUILang); commandLine.AppendPlusOrMinusSwitch("/highentropyva", base.Bag, nameof(HighEntropyVA)); //// If not design time build and the globalSessionGuid property was set then add a -globalsessionguid:<guid> //bool designTime = false; //if (HostObject != null) //{ // var csHost = HostObject as ICscHostObject; // designTime = csHost.IsDesignTime(); //} //if (!designTime) //{ // if (!string.IsNullOrWhiteSpace(VsSessionGuid)) // { // commandLine.AppendSwitchIfNotNull("/sqmsessionguid:", VsSessionGuid); // } //} AddReferencesToCommandLine(commandLine, References); AddManagedCompilerCommands(commandLine); // This should come after the "TreatWarningsAsErrors" flag is processed (in managedcompiler.cs). // Because if TreatWarningsAsErrors=false, then we'll have a /warnaserror- on the command-line, // and then any specific warnings that should be treated as errors should be specified with // /warnaserror+:<list> after the /warnaserror- switch. The order of the switches on the command-line // does matter. // // Note that // /warnaserror+ // is just shorthand for: // /warnaserror+:<all possible warnings> // // Similarly, // /warnaserror- // is just shorthand for: // /warnaserror-:<all possible warnings> commandLine.AppendSwitchWithSplitting("/warnaserror+:", WarningsAsErrors, ",", ';', ','); commandLine.AppendSwitchWithSplitting("/warnaserror-:", WarningsNotAsErrors, ",", ';', ','); // It's a good idea for the response file to be the very last switch passed, just // from a predictability perspective. It also solves the problem that a dogfooder // ran into, which is described in an email thread attached to bug VSWhidbey 146883. // See also bugs 177762 and 118307 for additional bugs related to response file position. if (ResponseFiles != null) { foreach (ITaskItem response in ResponseFiles) { commandLine.AppendSwitchIfNotNull("@", response.ItemSpec); } } }
internal void AddVOCompatibilityCommands(XSharpCommandLineBuilder commandline) { // VO Compatibility switches if (NS) // Add Default Namespace { commandline.AppendSwitch("\n/ns:" + this.RootNameSpace); } commandline.AppendPlusOrMinusSwitch("/az", base.Bag, nameof(AZ)); commandline.AppendPlusOrMinusSwitch("/cs", base.Bag, nameof(CS)); commandline.AppendPlusOrMinusSwitch("/ins", base.Bag, nameof(INS)); if (this.IncludePaths?.Length > 0) { StringBuilder sb = new StringBuilder(); foreach (var s in this.IncludePaths) { if (sb.Length > 0) sb.Append(';'); sb.Append(s); } commandline.AppendTextUnquoted(" /i:\"" + sb.ToString()+"\""); } commandline.AppendPlusOrMinusSwitch("/lb", base.Bag, nameof(LB)); commandline.AppendPlusOrMinusSwitch("/ovf", base.Bag, nameof(OVF)); commandline.AppendPlusOrMinusSwitch("/ppo", base.Bag, nameof(PPO)); commandline.AppendPlusOrMinusSwitch("/vo1", base.Bag, nameof(VO1)); commandline.AppendPlusOrMinusSwitch("/vo2", base.Bag, nameof(VO2)); commandline.AppendPlusOrMinusSwitch("/vo3", base.Bag, nameof(VO3)); commandline.AppendPlusOrMinusSwitch("/vo4", base.Bag, nameof(VO4)); commandline.AppendPlusOrMinusSwitch("/vo5", base.Bag, nameof(VO5)); commandline.AppendPlusOrMinusSwitch("/vo6", base.Bag, nameof(VO6)); commandline.AppendPlusOrMinusSwitch("/vo7", base.Bag, nameof(VO7)); commandline.AppendPlusOrMinusSwitch("/vo8", base.Bag, nameof(VO8)); commandline.AppendPlusOrMinusSwitch("/vo9", base.Bag, nameof(VO9)); commandline.AppendPlusOrMinusSwitch("/vo10", base.Bag, nameof(VO10)); commandline.AppendPlusOrMinusSwitch("/vo11", base.Bag, nameof(VO11)); commandline.AppendPlusOrMinusSwitch("/vo12", base.Bag, nameof(VO12)); commandline.AppendPlusOrMinusSwitch("/vo13", base.Bag, nameof(VO13)); commandline.AppendPlusOrMinusSwitch("/vo14", base.Bag, nameof(VO14)); commandline.AppendPlusOrMinusSwitch("/vo15", base.Bag, nameof(VO15)); // User-defined CommandLine Option (in order to support switches unknown at that time) // cannot use appendswitch because it will quote the string when there are embedded spaces if(!String.IsNullOrEmpty(this.CommandLineOption)) { commandline.AppendTextUnquoted("\n" + this.CommandLineOption); } }