DSInternals/Src/Microsoft.Isam.Esent.Interop/jet_lgpos.cs
2016-01-24 09:59:40 +01:00

230 lines
7.8 KiB
C#
Vendored

//-----------------------------------------------------------------------
// <copyright file="jet_lgpos.cs" company="Microsoft Corporation">
// Copyright (c) Microsoft Corporation.
// </copyright>
//-----------------------------------------------------------------------
namespace Microsoft.Isam.Esent.Interop
{
using System;
using System.Diagnostics;
using System.Diagnostics.CodeAnalysis;
using System.Globalization;
using System.Runtime.InteropServices;
/// <summary>
/// Describes an offset in the log sequence.
/// </summary>
[SuppressMessage(
"Microsoft.StyleCop.CSharp.NamingRules",
"SA1300:ElementMustBeginWithUpperCaseLetter",
Justification = "This should match the name of the unmanaged structure.")]
[StructLayout(LayoutKind.Sequential)]
[Serializable]
public struct JET_LGPOS : IEquatable<JET_LGPOS>, IComparable<JET_LGPOS>, INullableJetStruct
{
/// <summary>
/// Byte offset inside the sector.
/// </summary>
private ushort offset;
/// <summary>
/// Sector number.
/// </summary>
private ushort sector;
/// <summary>
/// Generation number.
/// </summary>
private int generation;
/// <summary>
/// Gets or sets the byte offset represented by this log position. This
/// offset is inside of the sector.
/// </summary>
public int ib
{
[DebuggerStepThrough]
get { return this.offset; }
set { this.offset = checked((ushort)value); }
}
/// <summary>
/// Gets or sets the sector number represented by this log position.
/// </summary>
public int isec
{
[DebuggerStepThrough]
get { return this.sector; }
set { this.sector = checked((ushort)value); }
}
/// <summary>
/// Gets or sets the generation of this log position.
/// </summary>
public int lGeneration
{
[DebuggerStepThrough]
get { return this.generation; }
set { this.generation = value; }
}
/// <summary>
/// Gets a value indicating whether this log position is null.
/// </summary>
public bool HasValue
{
get
{
return 0 != this.lGeneration;
}
}
/// <summary>
/// Determines whether two specified instances of JET_LGPOS
/// are equal.
/// </summary>
/// <param name="lhs">The first instance to compare.</param>
/// <param name="rhs">The second instance to compare.</param>
/// <returns>True if the two instances are equal.</returns>
public static bool operator ==(JET_LGPOS lhs, JET_LGPOS rhs)
{
return lhs.Equals(rhs);
}
/// <summary>
/// Determines whether two specified instances of JET_LGPOS
/// are not equal.
/// </summary>
/// <param name="lhs">The first instance to compare.</param>
/// <param name="rhs">The second instance to compare.</param>
/// <returns>True if the two instances are not equal.</returns>
public static bool operator !=(JET_LGPOS lhs, JET_LGPOS rhs)
{
return !(lhs == rhs);
}
/// <summary>
/// Determine whether one log position is before another log position.
/// </summary>
/// <param name="lhs">The first log position to compare.</param>
/// <param name="rhs">The second log position to compare.</param>
/// <returns>True if lhs comes before rhs.</returns>
public static bool operator <(JET_LGPOS lhs, JET_LGPOS rhs)
{
return lhs.CompareTo(rhs) < 0;
}
/// <summary>
/// Determine whether one log position is after another log position.
/// </summary>
/// <param name="lhs">The first log position to compare.</param>
/// <param name="rhs">The second log position to compare.</param>
/// <returns>True if lhs comes after rhs.</returns>
public static bool operator >(JET_LGPOS lhs, JET_LGPOS rhs)
{
return lhs.CompareTo(rhs) > 0;
}
/// <summary>
/// Determine whether one log position is before or equal to
/// another log position.
/// </summary>
/// <param name="lhs">The first log position to compare.</param>
/// <param name="rhs">The second log position to compare.</param>
/// <returns>True if lhs comes before or is equal to rhs.</returns>
public static bool operator <=(JET_LGPOS lhs, JET_LGPOS rhs)
{
return lhs.CompareTo(rhs) <= 0;
}
/// <summary>
/// Determine whether one log position is after or equal to
/// another log position.
/// </summary>
/// <param name="lhs">The first log position to compare.</param>
/// <param name="rhs">The second log position to compare.</param>
/// <returns>True if lhs comes after or is equal to rhs.</returns>
public static bool operator >=(JET_LGPOS lhs, JET_LGPOS rhs)
{
return lhs.CompareTo(rhs) >= 0;
}
/// <summary>
/// Generate a string representation of the structure.
/// </summary>
/// <returns>The structure as a string.</returns>
public override string ToString()
{
return string.Format(
CultureInfo.InvariantCulture,
"JET_LGPOS(0x{0:X},{1:X},{2:X})",
this.lGeneration,
this.isec,
this.ib);
}
/// <summary>
/// Returns a value indicating whether this instance is equal
/// to another instance.
/// </summary>
/// <param name="obj">An object to compare with this instance.</param>
/// <returns>True if the two instances are equal.</returns>
public override bool Equals(object obj)
{
if (obj == null || this.GetType() != obj.GetType())
{
return false;
}
return this.Equals((JET_LGPOS)obj);
}
/// <summary>
/// Returns the hash code for this instance.
/// </summary>
/// <returns>The hash code for this instance.</returns>
public override int GetHashCode()
{
return this.generation ^ (this.sector << 16) ^ this.offset;
}
/// <summary>
/// Returns a value indicating whether this instance is equal
/// to another instance.
/// </summary>
/// <param name="other">An instance to compare with this instance.</param>
/// <returns>True if the two instances are equal.</returns>
public bool Equals(JET_LGPOS other)
{
return this.generation == other.generation
&& this.sector == other.sector
&& this.offset == other.offset;
}
/// <summary>
/// Compares this log position to another log position and determines
/// whether this instance is before, the same as or after the other
/// instance.
/// </summary>
/// <param name="other">The log position to compare to the current instance.</param>
/// <returns>
/// A signed number indicating the relative positions of this instance and the value parameter.
/// </returns>
public int CompareTo(JET_LGPOS other)
{
int compare = this.generation.CompareTo(other.generation);
if (0 == compare)
{
compare = this.sector.CompareTo(other.sector);
}
if (0 == compare)
{
compare = this.offset.CompareTo(other.offset);
}
return compare;
}
}
}