/* Copyright (C) 2008-2016 Peter Palotas, Jeffrey Jangli, Alexandr Normuradov * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ namespace Alphaleonis.Win32.Filesystem { /// The structure contains stream header data. /// public sealed class BackupStreamInfo { #region Private Fields private readonly long m_size; private readonly string m_name; private readonly BackupStreamType m_streamType; private readonly StreamAttributes m_attributes; #endregion #region Constructor /// Initializes a new instance of the class. /// The stream ID. /// The name. internal BackupStreamInfo(NativeMethods.WIN32_STREAM_ID streamID, string name) { m_name = name; m_size = (long) streamID.Size; m_attributes = streamID.dwStreamAttributes; m_streamType = streamID.dwStreamId; } #endregion #region Public Properties /// Gets the size of the data in the substream, in bytes. /// The size of the data in the substream, in bytes. public long Size { get { return m_size; } } /// Gets a string that specifies the name of the alternative data stream. /// A string that specifies the name of the alternative data stream. public string Name { get { return m_name; } } /// Gets the type of the data in the stream. /// The type of the data in the stream. public BackupStreamType StreamType { get { return m_streamType; } } /// Gets the attributes of the data to facilitate cross-operating system transfer. /// Attributes of the data to facilitate cross-operating system transfer. public StreamAttributes Attributes { get { return m_attributes; } } #endregion // Public Properties } }