File: Latency\Measure.cs
Web Access
Project: src\src\Libraries\Microsoft.Extensions.Telemetry.Abstractions\Microsoft.Extensions.Telemetry.Abstractions.csproj (Microsoft.Extensions.Telemetry.Abstractions)
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
 
using System;
 
namespace Microsoft.Extensions.Diagnostics.Latency;
 
/// <summary>
/// Represents a measure.
/// </summary>
/// <remarks>
/// Measures are used to aggregate or record values. They are used to track
/// statistics about recurring operations. Example: number of calls to
/// a database, or total latency of database calls.
/// </remarks>
public readonly struct Measure : IEquatable<Measure>
{
    /// <summary>
    /// Initializes a new instance of the <see cref="Measure"/> struct.
    /// </summary>
    /// <param name="name">Name of the counter.</param>
    /// <param name="value">Value of the counter.</param>
    public Measure(string name, long value)
    {
        Name = name;
        Value = value;
    }
 
    /// <summary>
    /// Gets the name of the measure.
    /// </summary>
    public string Name { get; }
 
    /// <summary>
    /// Gets the value of the measure.
    /// </summary>
    public long Value { get; }
 
    /// <summary>
    /// Determines whether this and a specified object are identical.
    /// </summary>
    /// /// <param name="obj">The object to compare.</param>
    /// <returns><see langword="true"/> if identical; <see langword="false"/> otherwise.</returns>
    public override bool Equals(object? obj) => obj is Measure m && Equals(m);
 
    /// <summary>
    /// Determines whether this and a specified measure are identical.
    /// </summary>
    /// <param name="other">The other measure.</param>
    /// <returns><see langword="true"/> if identical; <see langword="false"/> otherwise.</returns>
    public bool Equals(Measure other) => Value == other.Value && Name.Equals(other.Name, StringComparison.Ordinal);
 
    /// <summary>
    /// Gets a hash code for this object.
    /// </summary>
    /// <returns>A hash code for the current object.</returns>
    public override int GetHashCode() => HashCode.Combine(Name, Value);
 
    /// <summary>
    /// Equality operator.
    /// </summary>
    /// <param name="left">First value.</param>
    /// <param name="right">Second value.</param>
    /// <returns><see langword="true" /> if the operands are equal, <see langword="false" /> otherwise.</returns>
    public static bool operator ==(Measure left, Measure right)
    {
        return left.Equals(right);
    }
 
    /// <summary>
    /// Inequality operator.
    /// </summary>
    /// <param name="left">First value.</param>
    /// <param name="right">Second value.</param>
    /// <returns><see langword="true" /> if the operands are unequal, <see langword="false" /> otherwise.</returns>
    public static bool operator !=(Measure left, Measure right)
    {
        return !(left == right);
    }
}