mirror of
				https://github.com/gnh1201/welsonjs.git
				synced 2025-10-26 10:31:17 +00:00 
			
		
		
		
	Add the package ManagedEsent (microsoft/ManagedEsent@d358c07), and WelsonJS.Esent
		
			
				
	
	
		
			237 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			237 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //-----------------------------------------------------------------------
 | |
| // <copyright file="jet_setcolumn.cs" company="Microsoft Corporation">
 | |
| //     Copyright (c) Microsoft Corporation.
 | |
| // </copyright>
 | |
| //-----------------------------------------------------------------------
 | |
| 
 | |
| namespace Microsoft.Isam.Esent.Interop
 | |
| {
 | |
|     using System;
 | |
|     using System.Diagnostics.CodeAnalysis;
 | |
|     using System.Globalization;
 | |
|     using System.Runtime.InteropServices;
 | |
| 
 | |
|     /// <summary>
 | |
|     /// The native version of the <see cref="JET_SETCOLUMN"/> structure.
 | |
|     /// </summary>
 | |
|     [StructLayout(LayoutKind.Sequential)]
 | |
|     [SuppressMessage("Microsoft.StyleCop.CSharp.NamingRules",
 | |
|         "SA1305:FieldNamesMustNotUseHungarianNotation",
 | |
|         Justification = "This should match the unmanaged API, which isn't capitalized.")]
 | |
|     [SuppressMessage(
 | |
|         "Microsoft.StyleCop.CSharp.NamingRules",
 | |
|         "SA1307:AccessibleFieldsMustBeginWithUpperCaseLetter",
 | |
|         Justification = "This should match the unmanaged API, which isn't capitalized.")]
 | |
|     internal struct NATIVE_SETCOLUMN
 | |
|     {
 | |
|         /// <summary>
 | |
|         /// Columnid to set.
 | |
|         /// </summary>
 | |
|         public uint columnid;
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Data to set.
 | |
|         /// </summary>
 | |
|         public IntPtr pvData;
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Size of data to set.
 | |
|         /// </summary>
 | |
|         public uint cbData;
 | |
| 
 | |
|         /// <summary>
 | |
|         /// SetColumns options.
 | |
|         /// </summary>
 | |
|         public uint grbit;
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Long-value offset to set.
 | |
|         /// </summary>
 | |
|         public uint ibLongValue;
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Itag sequence to set.
 | |
|         /// </summary>
 | |
|         public uint itagSequence;
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Returns the error from setting the column.
 | |
|         /// </summary>
 | |
|         public uint err;
 | |
|     }
 | |
| 
 | |
|     /// <summary>
 | |
|     /// Contains input and output parameters for <see cref="Api.JetSetColumns"/>.
 | |
|     /// Fields in the structure describe what column value to set, how to set it,
 | |
|     /// and where to get the column set data.
 | |
|     /// </summary>
 | |
|     [SuppressMessage(
 | |
|         "Microsoft.StyleCop.CSharp.NamingRules",
 | |
|         "SA1300:ElementMustBeginWithUpperCaseLetter",
 | |
|         Justification = "This should match the unmanaged API, which isn't capitalized.")]
 | |
|     public class JET_SETCOLUMN : IContentEquatable<JET_SETCOLUMN>, IDeepCloneable<JET_SETCOLUMN>
 | |
|     {
 | |
|         /// <summary>
 | |
|         /// Gets or sets the column identifier for a column to set.
 | |
|         /// </summary>
 | |
|         public JET_COLUMNID columnid { get; set; }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Gets or sets a pointer to the data to set.
 | |
|         /// </summary>
 | |
|         public byte[] pvData { get; set; }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Gets or sets the offset of the data to set.
 | |
|         /// </summary>
 | |
|         public int ibData { get; set; }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Gets or sets the size of the data to set.
 | |
|         /// </summary>
 | |
|         public int cbData { get; set; }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Gets or sets options for the set column operation.
 | |
|         /// </summary>
 | |
|         public SetColumnGrbit grbit { get; set; }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Gets or sets offset to the first byte to be set in a column of type
 | |
|         /// <see cref="JET_coltyp.LongBinary"/> or <see cref="JET_coltyp.LongText"/>.
 | |
|         /// </summary>
 | |
|         public int ibLongValue { get; set; }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Gets or sets the sequence number of value in a multi-valued column to be set. The array of values is one-based.
 | |
|         /// The first value is sequence 1, not 0 (zero). If the record column has only one value then 1 should be passed
 | |
|         /// as the itagSequence if that value is being replaced. A value of 0 (zero) means to add a new column value instance
 | |
|         /// to the end of the sequence of column values.
 | |
|         /// </summary>
 | |
|         public int itagSequence { get; set; }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Gets the error code or warning returned from the set column operation.
 | |
|         /// </summary>
 | |
|         public JET_wrn err { get; internal set; }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Returns a <see cref="T:System.String"/> that represents the current <see cref="JET_SETCOLUMN"/>.
 | |
|         /// </summary>
 | |
|         /// <returns>
 | |
|         /// A <see cref="T:System.String"/> that represents the current <see cref="JET_SETCOLUMN"/>.
 | |
|         /// </returns>
 | |
|         public override string ToString()
 | |
|         {
 | |
|             return string.Format(
 | |
|                 CultureInfo.InvariantCulture,
 | |
|                 "JET_SETCOLUMN(0x{0:x},{1},ibLongValue={2},itagSequence={3})",
 | |
|                 this.columnid.Value,
 | |
|                 Util.DumpBytes(this.pvData, this.ibData, this.cbData),
 | |
|                 this.ibLongValue,
 | |
|                 this.itagSequence);
 | |
|         }
 | |
| 
 | |
|         /// <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 ContentEquals(JET_SETCOLUMN other)
 | |
|         {
 | |
|             if (null == other)
 | |
|             {
 | |
|                 return false;
 | |
|             }
 | |
| 
 | |
|             this.CheckDataSize();
 | |
|             other.CheckDataSize();
 | |
|             return this.columnid == other.columnid
 | |
|                    && this.ibData == other.ibData
 | |
|                    && this.cbData == other.cbData
 | |
|                    && this.grbit == other.grbit
 | |
|                    && this.ibLongValue == other.ibLongValue
 | |
|                    && this.itagSequence == other.itagSequence
 | |
|                    && this.err == other.err
 | |
|                    && Util.ArrayEqual(this.pvData, other.pvData, this.ibData, this.cbData);
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Returns a deep copy of the object.
 | |
|         /// </summary>
 | |
|         /// <returns>A deep copy of the object.</returns>
 | |
|         public JET_SETCOLUMN DeepClone()
 | |
|         {
 | |
|             JET_SETCOLUMN result = (JET_SETCOLUMN)this.MemberwiseClone();
 | |
|             if (null != this.pvData)
 | |
|             {
 | |
|                 result.pvData = new byte[this.pvData.Length];
 | |
|                 Array.Copy(this.pvData, result.pvData, this.cbData);
 | |
|             }
 | |
| 
 | |
|             return result;
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Check to see if cbData is negative or greater than the length of pvData.
 | |
|         /// Check to see if ibData is negative or greater than the length of pvData.
 | |
|         /// </summary>
 | |
|         internal void CheckDataSize()
 | |
|         {
 | |
|             if (this.cbData < 0)
 | |
|             {
 | |
|                 throw new ArgumentOutOfRangeException("cbData", "data length cannot be negative");    
 | |
|             }
 | |
| 
 | |
|             if (this.ibData < 0)
 | |
|             {
 | |
|                 throw new ArgumentOutOfRangeException("ibData", "data offset cannot be negative");
 | |
|             }
 | |
| 
 | |
|             if (0 != this.ibData && (null == this.pvData || this.ibData >= this.pvData.Length))
 | |
|             {
 | |
|                 throw new ArgumentOutOfRangeException(
 | |
|                     "ibData",
 | |
|                     this.ibData,
 | |
|                     "cannot be greater than the length of the pvData");
 | |
|             }
 | |
| 
 | |
|             if ((null == this.pvData && 0 != this.cbData && SetColumnGrbit.SizeLV != (this.grbit & SetColumnGrbit.SizeLV))
 | |
|                 || (null != this.pvData && this.cbData > (this.pvData.Length - this.ibData)))
 | |
|             {
 | |
|                 throw new ArgumentOutOfRangeException(
 | |
|                     "cbData",
 | |
|                     this.cbData,
 | |
|                     "cannot be greater than the length of the pvData (unless the SizeLV option is used)");
 | |
|             }
 | |
|             
 | |
|             if (this.itagSequence < 0)
 | |
|             {
 | |
|                 throw new ArgumentOutOfRangeException("itagSequence", this.itagSequence, "cannot be negative");
 | |
|             }
 | |
| 
 | |
|             if (this.ibLongValue < 0)
 | |
|             {
 | |
|                 throw new ArgumentOutOfRangeException("ibLongValue", this.ibLongValue, "cannot be negative");
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Gets the NATIVE_SETCOLUMN structure that represents the object.
 | |
|         /// </summary>
 | |
|         /// <returns>A NATIVE_SETCOLUMN structure whose fields match the class.</returns>
 | |
|         internal NATIVE_SETCOLUMN GetNativeSetcolumn()
 | |
|         {
 | |
|             var setinfo = new NATIVE_SETCOLUMN
 | |
|             {
 | |
|                 columnid = this.columnid.Value,
 | |
|                 cbData = checked((uint)this.cbData),
 | |
|                 grbit = (uint)this.grbit,
 | |
|                 ibLongValue = checked((uint)this.ibLongValue),
 | |
|                 itagSequence = checked((uint)this.itagSequence),
 | |
|             };
 | |
|             return setinfo;
 | |
|         }
 | |
|     }
 | |
| } |