Logo Search packages:      
Sourcecode: f-spot version File versions  Download package

Header.cs

//
// Header.cs:
//
// Author:
//   Brian Nickel (brian.nickel@gmail.com)
//
// Original Source:
//   id3v2header.cpp from TagLib
//
// Copyright (C) 2005-2007 Brian Nickel
// Copyright (C) 2002,2003 Scott Wheeler (Original Implementation)
//
// This library is free software; you can redistribute it and/or modify
// it  under the terms of the GNU Lesser General Public License version
// 2.1 as published by the Free Software Foundation.
//
// This library is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307
// USA
//

using System;

namespace TagLib.Id3v2 {
      /// <summary>
      ///    Indicates the flags applied to a <see cref="Header" /> object.
      /// </summary>
      [Flags]
      public enum HeaderFlags : byte {
            /// <summary>
            ///    The header contains no flags.
            /// </summary>
            None = 0,
            
            /// <summary>
            ///    The tag described by the header has been unsynchronized.
            /// </summary>
            Unsynchronisation = 0x80,
            
            /// <summary>
            ///    The tag described by the header has contains an extended
            ///    header.
            /// </summary>
            ExtendedHeader = 0x40,
            
            /// <summary>
            ///    The tag described by the header is experimental.
            /// </summary>
            ExperimentalIndicator = 0x20,
            
            /// <summary>
            ///    The tag described by the header contains a footer.
            /// </summary>
            FooterPresent = 0x10
      }
      
      /// <summary>
      ///    This structure provides a representation of an ID3v2 tag header
      ///    which can be read from and written to disk.
      /// </summary>
00067       public struct Header
      {
#region Private Fields
            
            /// <summary>
            ///    Contains the tag's major version.
            /// </summary>
00074             private byte major_version;
            
            /// <summary>
            ///    Contains the tag's version revision.
            /// </summary>
00079             private byte revision_number;
            
            /// <summary>
            ///    Contains tag's flags.
            /// </summary>
00084             private HeaderFlags flags;
            
            /// <summary>
            ///    Contains the tag size.
            /// </summary>
00089             private uint tag_size;
            
#endregion
            
            
            
#region Public Fields
            
            /// <summary>
            ///    The size of a ID3v2 header.
            /// </summary>
00100             public const uint Size = 10;
            
            /// <summary>
            ///    The identifier used to recognize a ID3v2 headers.
            /// </summary>
            /// <value>
            ///    "ID3"
            /// </value>
00108             public static readonly ReadOnlyByteVector FileIdentifier = "ID3";
            
#endregion
            
            
            
#region Constructors
            
            /// <summary>
            ///    Constructs and initializes a new instance of <see
            ///    cref="Header" /> by reading it from raw header data.
            /// </summary>
            /// <param name="data">
            ///    A <see cref="ByteVector" /> object containing the raw
            ///    data to build the new instance from.
            /// </param>
            /// <exception cref="ArgumentNullException">
            ///    <paramref name="data" /> is <see langword="null" />.
            /// </exception>
            /// <exception cref="CorruptFileException">
            ///    <paramref name="data" /> is smaller than <see
            ///    cref="Size" />, does not begin with <see
            ///    cref="FileIdentifier" />, contains invalid flag data,
            ///    or contains invalid size data.
            /// </exception>
00133             public Header (ByteVector data)
            {
                  if (data == null)
                        throw new ArgumentNullException ("data");
                  
                  if (data.Count < Size)
                        throw new CorruptFileException (
                              "Provided data is smaller than object size.");
                  
                  if (!data.StartsWith (FileIdentifier))
                        throw new CorruptFileException (
                              "Provided data does not start with the file identifier");
                  
                  major_version = data [3];
                  revision_number = data [4];
                  flags = (HeaderFlags) data [5];
                  
                  if (major_version == 2 && ((int) flags & 127) != 0)
                        throw new CorruptFileException (
                              "Invalid flags set on version 2 tag.");
                  
                  if (major_version == 3 && ((int) flags & 15) != 0)
                        throw new CorruptFileException (
                              "Invalid flags set on version 3 tag.");
                  
                  if (major_version == 4 && ((int) flags & 7) != 0)
                        throw new CorruptFileException (
                              "Invalid flags set on version 4 tag.");
                  
                  for (int i = 6; i < 10; i ++)
                        if (data [i] >= 128)
                              throw new CorruptFileException (
                                    "One of the bytes in the header was greater than the allowed 128.");
                  
                  tag_size = SynchData.ToUInt (data.Mid (6, 4));
            }
            
#endregion
            
            
            
#region Public Properties
            
            /// <summary>
            ///    Gets and sets the major version of the tag described by
            ///    the current instance.
            /// </summary>
            /// <value>
            ///    A <see cref="byte" /> value specifying the ID3v2 version
            ///    of tag described by the current instance.
            /// </value>
            /// <remarks>
            ///    When the version is set, unsupported header flags will
            ///    automatically be removed from the tag.
            /// </remarks>
            /// <exception cref="ArgumentOutOfRangeException">
            ///    <paramref name="value" /> is less than 2 or more than 4.
            /// </exception>
00191             public byte MajorVersion {
                  get {
                        return major_version == 0 ? Tag.DefaultVersion :
                              major_version;
                  }
                  set {
                        if (value < 2 || value > 4)
                              throw new ArgumentException (
                                    "Version unsupported");
                        
                        if (value < 3)
                              flags &= ~(HeaderFlags.ExtendedHeader |
                                    HeaderFlags.ExperimentalIndicator);
                        
                        if (value < 4)
                              flags &= ~HeaderFlags.FooterPresent;
                        
                        major_version = value;
                  }
            }
            
            /// <summary>
            ///    Gets and sets the version revision number of the tag
            ///    represented by the current instance.
            /// </summary>
            /// <value>
            ///    A <see cref="byte" /> value containing the version
            ///    revision number of the tag represented by the current
            ///    instance.
            /// </value>
            /// <remarks>
            ///    This value should always be zeroed. A non-zero value
            ///    indicates an experimental or new version of the format
            ///    which may not be completely understood by the current
            ///    implementation. Some software may refuse to read tags
            ///    with a non-zero value.
            /// </remarks>
00228             public byte RevisionNumber {
                  get {return revision_number;}
                  set {revision_number = value;}
            }
            
            /// <summary>
            ///    Gets and sets the flags applied to the current instance.
            /// </summary>
            /// <value>
            ///    A bitwise combined <see cref="HeaderFlags" /> value
            ///    containing the flags applied to the current instance.
            /// </value>
            /// <exception cref="ArgumentException">
            ///    <paramref name="value" /> contains a flag not supported
            ///    by the the ID3v2 version of the current instance.
            /// </exception>
00244             public HeaderFlags Flags {
                  get {return flags;}
                  set {
                        if (0 != (value & (HeaderFlags.ExtendedHeader |
                              HeaderFlags.ExperimentalIndicator)) &&
                              MajorVersion < 3)
                              throw new ArgumentException (
                                    "Feature only supported in version 2.3+",
                                    "value");
                        
                        if (0 != (value & HeaderFlags.FooterPresent) &&
                              MajorVersion < 3)
                              throw new ArgumentException (
                                    "Feature only supported in version 2.4+",
                                    "value");
                        
                        flags = value;
                  }
            }
            
            /// <summary>
            ///    Gets and sets the size of the tag described by the
            ///    current instance, minus the header and footer.
            /// </summary>
            /// <value>
            ///    A <see cref="uint" /> value containing the size of the
            ///    tag described by the current instance.
            /// </value>
00272             public uint TagSize {
                  get {return tag_size;}
                  set {tag_size = value;}
            }
            
            /// <summary>
            ///    Gets the complete size of the tag described by the
            ///    current instance, including the header and footer.
            /// </summary>
            /// <value>
            ///    A <see cref="uint" /> value containing the complete size
            ///    of the tag described by the current instance.
            /// </value>
00285             public uint CompleteTagSize {
                  get {
                        if ((flags & HeaderFlags.FooterPresent) != 0)
                              return TagSize + Size + Footer.Size;
                        else
                              return TagSize + Size;
                  }
            }
            
#endregion
            
            
            
#region Public Methods
            
            /// <summary>
            ///    Renders the current instance as a raw ID3v2 header.
            /// </summary>
            /// <returns>
            ///    A <see cref="ByteVector" /> object containing the
            ///    rendered header.
            /// </returns>
00307             public ByteVector Render ()
            {
                  ByteVector v = new ByteVector ();
                  v.Add (FileIdentifier);
                  v.Add (MajorVersion);
                  v.Add (RevisionNumber);
                  v.Add ((byte)flags);
                  v.Add (SynchData.FromUInt (TagSize));
                  return v;
            }
            
#endregion
      }
}

Generated by  Doxygen 1.6.0   Back to index