Dnspy/dnSpy/Roslyn/dnSpy.Roslyn/Compiler/VisualBasic/VisualBasicCompilerSettings.cs

76 lines
2.6 KiB
C#
Raw Permalink Normal View History

2021-09-20 18:20:01 +02:00
/*
Copyright (C) 2014-2019 de4dot@gmail.com
This file is part of dnSpy
dnSpy is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
dnSpy is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with dnSpy. If not, see <http://www.gnu.org/licenses/>.
*/
using System.ComponentModel;
namespace dnSpy.Roslyn.Compiler.VisualBasic {
/// <summary>
/// Visual Basic compiler settings
/// </summary>
abstract class VisualBasicCompilerSettings : INotifyPropertyChanged {
/// <summary>
/// Raised when a property is changed
/// </summary>
public event PropertyChangedEventHandler? PropertyChanged;
/// <summary>
/// Raises <see cref="PropertyChanged"/>
/// </summary>
/// <param name="propName">Name of property that got changed</param>
protected void OnPropertyChanged(string propName) => PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propName));
/// <summary>
/// Conditional compilation symbols, separated by ';' or ','. Key=Value pairs are allowed, but only a limited set of values
/// are supported (<see cref="bool"/>, <see cref="int"/>, <see cref="double"/>, <see cref="string"/>). String values can have double quotes.
/// </summary>
public abstract string PreprocessorSymbols { get; set; }
/// <summary>
/// Optimize the code (release builds)
/// </summary>
public abstract bool Optimize { get; set; }
/// <summary>
/// Require explicit declaration of variables
/// </summary>
public abstract bool OptionExplicit { get; set; }
/// <summary>
/// Allow type inference of variables
/// </summary>
public abstract bool OptionInfer { get; set; }
/// <summary>
/// Enforce strict language semantics
/// </summary>
public abstract bool OptionStrict { get; set; }
/// <summary>
/// true to use binary-style string comparisons, false to use text-style string comparisons
/// </summary>
public abstract bool OptionCompareBinary { get; set; }
/// <summary>
/// true to always embed the VB runtime, false to use the default behavior (either use the runtime in the GAC or
/// embed it depending on the target framework)
/// </summary>
public abstract bool EmbedVBRuntime { get; set; }
}
}