From 382bb1de2bd61006feb4b511856c3052e2239c17 Mon Sep 17 00:00:00 2001
From: 42Geese <0E5EB1FB2C894978ADAD6308@gmail.com>
Date: Mon, 3 Apr 2023 21:32:14 -0400
Subject: [PATCH] Audio Id3v2 split CreateID3Tags into CreateID3V1Tags and
CreateID3V2Tags properties
---
.../FileFormats/Id3BothFormatTest.cs | 44 +++++++++++
src/TaglibSharp/Mpeg/AudioFile.cs | 73 +++++++++++++++++--
2 files changed, 112 insertions(+), 5 deletions(-)
diff --git a/src/TaglibSharp.Tests/FileFormats/Id3BothFormatTest.cs b/src/TaglibSharp.Tests/FileFormats/Id3BothFormatTest.cs
index adcccc2c..c60a0268 100644
--- a/src/TaglibSharp.Tests/FileFormats/Id3BothFormatTest.cs
+++ b/src/TaglibSharp.Tests/FileFormats/Id3BothFormatTest.cs
@@ -133,5 +133,49 @@ public void TestCreateId3Tags ()
file = File.Create (tempFile);
Assert.AreEqual (TagTypes.Id3v1 | TagTypes.Id3v2, file.TagTypes);
}
+
+ [Test]
+ public void TestCreateId3SeparateTags ()
+ {
+ string tempFile = TestPath.Samples + "tmpwrite_sample_createid3tags.mp3";
+
+ System.IO.File.Copy (sample_file, tempFile, true);
+
+ // Remove All Tags first
+ var file = File.Create (tempFile);
+ file.RemoveTags (TagTypes.AllTags);
+ file.Save ();
+
+ // No TagTypes should exist
+ TagLib.Mpeg.AudioFile.CreateID3V1Tags = false;
+ TagLib.Mpeg.AudioFile.CreateID3V2Tags = false;
+ file = File.Create (tempFile);
+ Assert.AreEqual (TagTypes.None, file.TagTypes);
+ file.RemoveTags (TagTypes.AllTags);
+ file.Save ();
+
+ // Only V1 TagTypes should exist
+ TagLib.Mpeg.AudioFile.CreateID3V1Tags = true;
+ TagLib.Mpeg.AudioFile.CreateID3V2Tags = false;
+ file = File.Create (tempFile);
+ Assert.AreEqual (TagTypes.Id3v1, file.TagTypes);
+ file.RemoveTags (TagTypes.AllTags);
+ file.Save ();
+
+ // Only V2 TagTypes should exist
+ TagLib.Mpeg.AudioFile.CreateID3V1Tags = false;
+ TagLib.Mpeg.AudioFile.CreateID3V2Tags = true;
+ file = File.Create (tempFile);
+ Assert.AreEqual (TagTypes.Id3v2, file.TagTypes);
+ file.RemoveTags (TagTypes.AllTags);
+ file.Save ();
+
+ // Both V1 and V2 TagTypes should exist
+ TagLib.Mpeg.AudioFile.CreateID3V1Tags = true;
+ TagLib.Mpeg.AudioFile.CreateID3V2Tags = true;
+ file = File.Create (tempFile);
+ Assert.AreEqual (TagTypes.Id3v1 | TagTypes.Id3v2, file.TagTypes);
+ file.Save ();
+ }
}
}
diff --git a/src/TaglibSharp/Mpeg/AudioFile.cs b/src/TaglibSharp/Mpeg/AudioFile.cs
index ccfbee41..8bbbd70e 100644
--- a/src/TaglibSharp/Mpeg/AudioFile.cs
+++ b/src/TaglibSharp/Mpeg/AudioFile.cs
@@ -71,10 +71,16 @@ public class AudioFile : TagLib.NonContainer.File
#region Private Static Fields
///
- /// Specifies whether or not to create ID3v1 and
- /// ID3v2 tags when they don't exist..
+ /// Specifies whether or not to create ID3v1
+ /// tag when it doesn't exist.
///
- private static bool create_id3_tags = true;
+ private static bool create_id3_v1_tags = true;
+
+ ///
+ /// Specifies whether or not to create ID3v2
+ /// tag when it doesn't exist.
+ ///
+ private static bool create_id3_v2_tags = true;
#endregion
@@ -187,6 +193,63 @@ public AudioFile (IFileAbstraction abstraction)
public static bool CreateID3Tags {
get { return create_id3_tags; }
set { create_id3_tags = value; }
+ get {
+ if (create_id3_v1_tags && create_id3_v2_tags) {
+ return true;
+ } else if (!create_id3_v1_tags && !create_id3_v2_tags) {
+ return false;
+ }
+
+ throw new InvalidOperationException("Inconsistent V1 and V2 state.");
+ }
+ set {
+ create_id3_v1_tags = value;
+ create_id3_v2_tags = value;
+ }
+ }
+
+ ///
+ /// Gets and sets whether or not to create an ID3v1 tag
+ /// automatically when it is not existing.
+ ///
+ ///
+ /// if the tag is to be created automatically.
+ /// Otherwise, .
+ ///
+ ///
+ /// Sometimes an MP3 file should not contain an ID3v1 Tag.
+ /// By setting this property to ,
+ /// no ID3v1 Tag will be created when creating the file,
+ /// if it doesn't exist.
+ /// It needs to be created explicitly if needed.
+ /// The default is which means that
+ /// an ID3v1 tag is created when it doesn't exist.
+ ///
+ public static bool CreateID3V1Tags {
+ get { return create_id3_v1_tags; }
+ set { create_id3_v1_tags = value; }
+ }
+
+ ///
+ /// Gets and sets whether or not to create an ID3v2 tag
+ /// automatically when it is not existing.
+ ///
+ ///
+ /// if the tag is to be created automatically.
+ /// Otherwise, .
+ ///
+ ///
+ /// Sometimes an MP3 file should not contain an ID3v2 Tag.
+ /// By setting this property to ,
+ /// no ID3v1 Tag will be created when creating the file,
+ /// if it doesn't exist.
+ /// It needs to be created explicitly if needed.
+ /// The default is which means that
+ /// an ID3v2 tag is created when it doesn't exist.
+ ///
+ public static bool CreateID3V2Tags {
+ get { return create_id3_v2_tags; }
+ set { create_id3_v2_tags = value; }
}
#endregion
@@ -290,8 +353,8 @@ protected override void ReadStart (long start, ReadStyle propertiesStyle)
protected override void ReadEnd (long end, ReadStyle propertiesStyle)
{
// Creation of ID3v1 and ID3v2 tags based on CreateID3Tags property
- GetTag (TagTypes.Id3v1, create_id3_tags);
- GetTag (TagTypes.Id3v2, create_id3_tags);
+ GetTag (TagTypes.Id3v1, create_id3_v1_tags);
+ GetTag (TagTypes.Id3v2, create_id3_v2_tags);
}
///