File: BuildCheck\OM\PropertyWriteData.cs
Web Access
Project: ..\..\..\src\Build\Microsoft.Build.csproj (Microsoft.Build)
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
 
using Microsoft.Build.Experimental.BuildCheck;
using Microsoft.Build.Experimental.BuildCheck.Infrastructure;
using Microsoft.Build.Shared;
 
namespace Microsoft.Build.Experimental.BuildCheck;
 
/// <summary>
/// Information about property being written to - either during evaluation phase
///  or as part of property definition within the target.
/// </summary>
internal class PropertyWriteData(
    string projectFilePath,
    int? projectConfigurationId,
    string propertyName,
    IMSBuildElementLocation? elementLocation,
    bool isEmpty)
    : CheckData(projectFilePath, projectConfigurationId)
{
    public PropertyWriteData(string projectFilePath, int? projectConfigurationId, PropertyWriteInfo propertyWriteInfo)
        : this(projectFilePath,
            projectConfigurationId,
            propertyWriteInfo.PropertyName,
            propertyWriteInfo.ElementLocation,
            propertyWriteInfo.IsEmpty)
    { }
 
    /// <summary>
    /// Name of the property that was written to.
    /// </summary>
    public string PropertyName { get; } = propertyName;
 
    /// <summary>
    /// Location of the property write.
    /// If the location is null, it means that the property doesn't come from xml, but rather other sources
    ///  (environment variable, global property, toolset properties etc.).
    /// </summary>
    public IMSBuildElementLocation? ElementLocation { get; } = elementLocation;
 
    /// <summary>
    /// Was any value written? (E.g. if we set propA with value propB, while propB is undefined - the isEmpty will be true).
    /// </summary>
    public bool IsEmpty { get; } = isEmpty;
}