aboutsummaryrefslogtreecommitdiff
path: root/Src/nsavi/file_avi_reader.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/nsavi/file_avi_reader.cpp
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/nsavi/file_avi_reader.cpp')
-rw-r--r--Src/nsavi/file_avi_reader.cpp43
1 files changed, 43 insertions, 0 deletions
diff --git a/Src/nsavi/file_avi_reader.cpp b/Src/nsavi/file_avi_reader.cpp
new file mode 100644
index 00000000..f6543a42
--- /dev/null
+++ b/Src/nsavi/file_avi_reader.cpp
@@ -0,0 +1,43 @@
+#include "file_avi_reader.h"
+
+AVIReaderFILE::AVIReaderFILE(const wchar_t *filename)
+{
+ f = _wfopen(filename, L"rb");
+}
+
+int AVIReaderFILE::Read(void *buffer, uint32_t read_length, uint32_t *bytes_read)
+{
+ *bytes_read = fread(buffer, 1, read_length, f);
+ return nsavi::READ_OK;
+}
+
+ int AVIReaderFILE::Peek(void *buffer, uint32_t read_length, uint32_t *bytes_read)
+ {
+ *bytes_read = fread(buffer, 1, read_length, f);
+ fseek(f, -read_length, SEEK_CUR);
+ return nsavi::READ_OK;
+ }
+
+ int AVIReaderFILE::Seek(uint64_t position)
+ {
+fsetpos(f, (const fpos_t *)&position);
+return nsavi::READ_OK;
+ }
+
+ uint64_t AVIReaderFILE::Tell()
+ {
+ uint64_t pos;
+ fgetpos(f, (fpos_t *)&pos);
+ return pos;
+ }
+
+ int AVIReaderFILE::Skip(uint32_t skip_bytes)
+ {
+ fseek(f, skip_bytes, SEEK_CUR);
+ return nsavi::READ_OK;
+ }
+
+ AVIReaderFILE::~AVIReaderFILE()
+ {
+ fclose(f);
+ } \ No newline at end of file