[libbluray-devel] Implement get_mount_point for OSX.

Konstantin Pavlov git at videolan.org
Mon Mar 19 09:35:57 CET 2012


libbluray | branch: master | Konstantin Pavlov <thresh at videolan.org> | Mon Mar 19 12:07:23 2012 +0400| [a9795a81b12ed07202fc99db3aa381df00954079] | committer: hpi1

Implement get_mount_point for OSX.

Rebased against current HEAD.

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

 src/libbluray/bluray.c |   40 ++++++++++++++++++++++++++++++++++++++--
 1 files changed, 38 insertions(+), 2 deletions(-)

diff --git a/src/libbluray/bluray.c b/src/libbluray/bluray.c
index bc32d46..90fedfd 100644
--- a/src/libbluray/bluray.c
+++ b/src/libbluray/bluray.c
@@ -52,6 +52,14 @@
 #include <mntent.h>
 #endif
 
+#ifdef __APPLE__
+#define _DARWIN_C_SOURCE
+#include <sys/stat.h>
+#include <sys/param.h>
+#include <sys/ucred.h>
+#include <sys/mount.h>
+#endif
+
 typedef int     (*fptr_int)();
 typedef int32_t (*fptr_int32)();
 typedef void*   (*fptr_p_void)();
@@ -915,7 +923,7 @@ static void _fill_disc_info(BLURAY *bd)
 #ifdef HAVE_MNTENT_H
 /*
  * Replace device node (/dev/sr0) by mount point
- * Implemented on Linux only at the moment, could be added for other OS
+ * Implemented on Linux and MacOSX
  */
 static void get_mount_point(BLURAY *bd)
 {
@@ -948,6 +956,34 @@ static void get_mount_point(BLURAY *bd)
     endmntent (f);
 }
 #endif
+#ifdef __APPLE__
+static void get_mount_point(BLURAY *bd)
+{
+    struct stat st;
+    if (stat (bd->device_path, &st) )
+        return;
+
+    /* If it's a directory, all is good */
+    if (S_ISDIR(st.st_mode))
+        return;
+
+    struct statfs mbuf[128];
+    int fs_count;
+
+    if ( (fs_count = getfsstat (NULL, 0, MNT_NOWAIT)) == -1 ) {
+        return;
+    }
+
+    getfsstat (mbuf, fs_count * sizeof(mbuf[0]), MNT_NOWAIT);
+
+    for ( int i = 0; i < fs_count; ++i) {
+        if (!strcmp (mbuf[i].f_mntfromname, bd->device_path)) {
+            free(bd->device_path);
+            bd->device_path = strdup (mbuf[i].f_mntonname);
+        }
+    }
+}
+#endif
 
 /*
  * open / close
@@ -971,7 +1007,7 @@ BLURAY *bd_open(const char* device_path, const char* keyfile_path)
 
     bd->device_path = strdup(device_path);
 
-#ifdef HAVE_MNTENT_H
+#if (defined HAVE_MNTENT_H || defined __APPLE__)
     get_mount_point(bd);
 #endif
 



More information about the libbluray-devel mailing list