[vlc-devel] commit: vlc_mutex_locker: automatic mutex locking for C++ ( Rémi Denis-Courmont )
    git version control 
    git at videolan.org
       
    Mon Oct 20 22:16:07 CEST 2008
    
    
  
vlc | branch: master | Rémi Denis-Courmont <rdenis at simphalempin.com> | Mon Oct 20 22:45:16 2008 +0300| [14e89cbcefbdd8efd03c6d7484d13682ffe67b4e] | committer: Rémi Denis-Courmont 
vlc_mutex_locker: automatic mutex locking for C++
> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=14e89cbcefbdd8efd03c6d7484d13682ffe67b4e
---
 include/vlc_threads.h |   23 +++++++++++++++++++++++
 1 files changed, 23 insertions(+), 0 deletions(-)
diff --git a/include/vlc_threads.h b/include/vlc_threads.h
index 4ab92c2..7b66e5b 100644
--- a/include/vlc_threads.h
+++ b/include/vlc_threads.h
@@ -448,4 +448,27 @@ static inline void barrier (void)
 #define vlc_thread_join( P_THIS )                                           \
     __vlc_thread_join( VLC_OBJECT(P_THIS) )
 
+#ifdef __cplusplus
+/**
+ * Helper C++ class to lock a mutex.
+ * The mutex is locked when the object is created, and unlocked when the object
+ * is destroyed.
+ */
+class vlc_mutex_locker
+{
+    private:
+        vlc_mutex_t *lock;
+    public:
+        vlc_mutex_locker (vlc_mutex_t *m) : lock (m)
+        {
+            vlc_mutex_lock (lock);
+        }
+
+        ~vlc_mutex_locker (void)
+        {
+            vlc_mutex_unlock (lock);
+        }
+};
+#endif
+
 #endif /* !_VLC_THREADS_H */
    
    
More information about the vlc-devel
mailing list