ByteDev.M3u
1.0.0
dotnet add package ByteDev.M3u --version 1.0.0
NuGet\Install-Package ByteDev.M3u -Version 1.0.0
<PackageReference Include="ByteDev.M3u" Version="1.0.0" />
paket add ByteDev.M3u --version 1.0.0
#r "nuget: ByteDev.M3u, 1.0.0"
// Install ByteDev.M3u as a Cake Addin #addin nuget:?package=ByteDev.M3u&version=1.0.0 // Install ByteDev.M3u as a Cake Tool #tool nuget:?package=ByteDev.M3u&version=1.0.0
ByteDev.M3u
.NET Standard library to help handle playlists in the M3U format.
Installation
ByteDev.M3u is hosted as a package on nuget.org. To install from the Package Manager Console in Visual Studio run:
Install-Package ByteDev.M3u
Further details can be found on the nuget page.
Release Notes
Releases follow semantic versioning.
Full details of the release notes can be viewed on GitHub.
M3U Format & Library Support
The library supports both M3U simple format and M3U extended format (mostly).
Example of playlist content in simple M3U format:
https://somewhere/some/resource
C:\Sample.mp3
Greatest Hits\My Song.mp3
# This is a comment
Example of playlist content in M3U extended format describing two resources:
#EXTM3U
#EXTINF:180, Sample artist - Sample title
Sample.mp3
#EXTINF:240,Example Artist - Example title
Greatest Hits\Example.ogg
Notes on library support:
- Empty lines are ignored.
- Both Windows (
\r\n
) and Unix (\n
) line endings are supported. - Comments:
- Are supported using the hash
#
character as the first character on a line. - Are ignored by the library.
- Are supported using the hash
- Extended M3U format content:
- Must have the extended header directive (
#EXTM3U
) on the first line. - Must have any encoding directive (
#EXTENC:
) on the second line. - Resources always have their location (path, URI etc.) on the last line of each resource entry.
- Must have the extended header directive (
- Extended M3U format directives supported:
#EXTM3U
- Playlist header.#EXTENC:
- Playlist encoding.#PLAYLIST:
- Playlist title.#EXTINF:
- Resource track info.#EXTGRP:
- Resource grouping.#EXTALB:
- Resource album info.#EXTART:
- Resource album artist.#EXTGENRE:
- Resource album genre.#EXTBYT:
- Resource file size in bytes.#EXTIMG:
- Resource cover image file.
Usage
Example of initialization via class constructor:
string content =
"#EXTM3U\n" +
"#EXTENC: UTF-8\n" +
"#PLAYLIST: My Sample Playlist\n" +
"#EXTINF:180, Sample artist - Sample title\n" +
"Sample.mp3"
var pl = new M3uPlaylist(content);
// pl.IsExtended == true
// pl.Encoding == "UTF-8"
// pl.PlaylistTitle == "My Sample Playlist"
// pl.Resources.Single().TrackInfo == "180, Sample artist - Sample title"
// pl.Resources.Single().Location == "Sample.mp3"
Example of initialization via Load
method:
var pl = M3uPlaylist.Load(@"C:\Playlists\MyPlaylist.m3u");
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- ByteDev.Strings (>= 9.2.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.0 | 420 | 5/27/2021 |