aboutsummaryrefslogtreecommitdiff
path: root/Src/playlist/M3UWriter.cpp
diff options
context:
space:
mode:
authorJean-Francois Mauguit <jfmauguit@mac.com>2024-09-24 09:03:25 -0400
committerGitHub <noreply@github.com>2024-09-24 09:03:25 -0400
commitbab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/playlist/M3UWriter.cpp
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/playlist/M3UWriter.cpp')
-rw-r--r--Src/playlist/M3UWriter.cpp42
1 files changed, 42 insertions, 0 deletions
diff --git a/Src/playlist/M3UWriter.cpp b/Src/playlist/M3UWriter.cpp
new file mode 100644
index 00000000..07110c81
--- /dev/null
+++ b/Src/playlist/M3UWriter.cpp
@@ -0,0 +1,42 @@
+#include "M3UWriter.h"
+#include "../nu/AutoChar.h"
+
+M3UWriter::~M3UWriter()
+{
+ Close();
+}
+
+int M3UWriter::Open( const wchar_t *filename )
+{
+ if ( fp != NULL )
+ return 0;
+
+ fp = _wfopen( filename, L"wt" );
+ if ( !fp )
+ return 0;
+
+ fprintf( fp, "#EXTM3U\n" );
+
+ return 1;
+}
+
+void M3UWriter::Write( const wchar_t *filename )
+{
+ if ( fp != NULL )
+ fprintf( fp, "%s\n", (char *)AutoChar( filename ) );
+}
+
+void M3UWriter::Write( const wchar_t *filename, const wchar_t *title, int length )
+{
+ if ( fp != NULL )
+ fprintf( fp, "#EXTINF:%d,%s\n%s\n", length, (char *)AutoChar( title ), (char *)AutoChar( filename ) );
+}
+
+void M3UWriter::Close()
+{
+ if ( fp != NULL )
+ {
+ fclose( fp );
+ fp = NULL;
+ }
+} \ No newline at end of file