libaacs | branch: master | npzacs <npz...@gmail.com> | Mon Feb 22 20:47:13 2016 
+0200| [e190c88fc9b803f2e80cf7bde8b162717e8f1e95] | committer: npzacs

Merge file_write() from libbluray

> http://git.videolan.org/gitweb.cgi/libaacs.git/?a=commit;h=e190c88fc9b803f2e80cf7bde8b162717e8f1e95
---

 src/file/file.h       |    1 +
 src/file/file_posix.c |   23 +++++++++++++++++++++++
 src/file/file_win32.c |   11 +++++++++++
 3 files changed, 35 insertions(+)

diff --git a/src/file/file.h b/src/file/file.h
index 7bf8f2c..498da3e 100644
--- a/src/file/file.h
+++ b/src/file/file.h
@@ -42,6 +42,7 @@
 #define file_seek(X,Y,Z) X->seek(X,Y,Z)
 #define file_tell(X)     X->tell(X)
 #define file_read(X,Y,Z) X->read(X,Y,Z)
+#define file_write(X,Y,Z) X->write(X,Y,Z)
 BD_PRIVATE int64_t file_size(AACS_FILE_H *fp);
 
 BD_PRIVATE extern AACS_FILE_H *(*file_open)(const char* filename, const char 
*mode);
diff --git a/src/file/file_posix.c b/src/file/file_posix.c
index 07dd8a5..c19637d 100644
--- a/src/file/file_posix.c
+++ b/src/file/file_posix.c
@@ -87,6 +87,28 @@ static int64_t _file_read(AACS_FILE_H *file, uint8_t *buf, 
int64_t size)
     return (int64_t)got;
 }
 
+static int64_t _file_write(AACS_FILE_H *file, const uint8_t *buf, int64_t size)
+{
+    ssize_t written, result;
+
+    if (size <= 0 || size >= BD_MAX_SSIZE) {
+        BD_DEBUG(DBG_FILE | DBG_CRIT, "Ignoring invalid write of size 
%"PRId64" (%p)\n", size, (void*)file);
+        return 0;
+    }
+
+    for (written = 0; written < (ssize_t)size; written += result) {
+        result = write((int)(intptr_t)file->internal, buf + written, size - 
written);
+        if (result < 0) {
+            if (errno != EINTR) {
+                BD_DEBUG(DBG_FILE, "write() failed (%p)\n", (void*)file);
+                break;
+            }
+            result = 0;
+        }
+    }
+    return (int64_t)written;
+}
+
 static AACS_FILE_H *_file_open(const char* filename, const char *cmode)
 {
     AACS_FILE_H *file;
@@ -123,6 +145,7 @@ static AACS_FILE_H *_file_open(const char* filename, const 
char *cmode)
     file->close = _file_close;
     file->seek  = _file_seek;
     file->read  = _file_read;
+    file->write = _file_write;
     file->tell  = _file_tell;
 
     file->internal = (void*)(intptr_t)fd;
diff --git a/src/file/file_win32.c b/src/file/file_win32.c
index f8072a6..7d3e2d4 100644
--- a/src/file/file_win32.c
+++ b/src/file/file_win32.c
@@ -75,6 +75,16 @@ static int64_t _file_read(AACS_FILE_H *file, uint8_t *buf, 
int64_t size)
     return 0;
 }
 
+static int64_t _file_write(AACS_FILE_H *file, const uint8_t *buf, int64_t size)
+{
+    if (size > 0 && size < BD_MAX_SSIZE) {
+        return (int64_t)fwrite(buf, 1, (size_t)size, (FILE *)file->internal);
+    }
+
+    BD_DEBUG(DBG_FILE | DBG_CRIT, "Ignoring invalid write of size %"PRId64" 
(%p)\n", size, (void*)file);
+    return 0;
+}
+
 static AACS_FILE_H *_file_open(const char* filename, const char *mode)
 {
     AACS_FILE_H *file;
@@ -105,6 +115,7 @@ static AACS_FILE_H *_file_open(const char* filename, const 
char *mode)
     file->close    = _file_close;
     file->seek     = _file_seek;
     file->read     = _file_read;
+    file->write    = _file_write;
     file->tell     = _file_tell;
 
     BD_DEBUG(DBG_FILE, "Opened WIN32 file %s (%p)\n", filename, (void*)file);

_______________________________________________
libaacs-devel mailing list
libaacs-devel@videolan.org
https://mailman.videolan.org/listinfo/libaacs-devel

Reply via email to