[svn.haxx.se] · SVN Dev · SVN Users · SVN Org · TSVN Dev · TSVN Users · Subclipse Dev · Subclipse Users · this month's index

Re: svn commit: r1142191 - in /subversion/branches/svn_mutex/subversion: include/private/ libsvn_fs/ libsvn_fs_fs/ libsvn_subr/

From: Daniel Shahaf <d.s_at_daniel.shahaf.name>
Date: Sat, 2 Jul 2011 23:40:43 +0300

stefan2_at_apache.org wrote on Sat, Jul 02, 2011 at 10:20:57 -0000:
> Author: stefan2
> Date: Sat Jul 2 10:20:56 2011
> New Revision: 1142191
>
> URL: http://svn.apache.org/viewvc?rev=1142191&view=rev
> Log:
> Bring svn_mutex__* API more in line with its APR counterpart.
>
> * subversion/include/private/svn_mutex.h
> (svn_mutex__t): make it an actual typedef instead of a wrapper struct
> (svn_mutex__init, svn_mutex__lock, svn_mutex__unlock): switch to pointer style API
> * subversion/libsvn_subr/svn_mutex.c
> (uninit, svn_mutex__lock, svn_mutex__unlock): adapt implementation to API change
> (svn_mutex__init): dito; use SVN error code instead of APR_ENOIMPL
...
> +++ subversion/branches/svn_mutex/subversion/include/private/svn_mutex.h Sat Jul 2 10:20:56 2011
> @@ -28,6 +28,7 @@
> @@ -37,35 +38,34 @@ extern "C" {
> /**
> * This is a simple wrapper around @c apr_thread_mutex_t and will be a
> * valid identifier even if APR does not support threading.
> - *
> - * @note In contrast to other structures, this one shall be treated as
> - * a pointer type, i.e. be instantiated and be passed by value instead by
> - * reference. There is simply no point in introducing yet another level
> - * of indirection and pointers to check for validity.
> */
> -typedef struct svn_mutex__t
> -{
> #if APR_HAS_THREADS
>
> - /** A mutex for synchronization between threads. It may be NULL, in
> - * which case no synchronization will take place. The latter is useful,
> - * if implement some functionality where synchronization is optional.
> - */
> - apr_thread_mutex_t *mutex;
> -
> +/** A mutex for synchronization between threads. It may be NULL, in
> + * which case no synchronization will take place. The latter is useful,
> + * if implement some functionality where synchronization is optional.
> + */
> +typedef apr_thread_mutex_t svn_mutex__t;
> +
> +#else
> +
> +/** Dummy definition. The content will never be actually accessed.
> + */
> +typedef int svn_mutex__t;

s/int/void/ ?

(to cause a compile-time error if it's ever dereferenced)

> +
> #endif
> -} svn_mutex__t;
Received on 2011-07-02 22:41:47 CEST

This is an archived mail posted to the Subversion Dev mailing list.

This site is subject to the Apache Privacy Policy and the Apache Public Forum Archive Policy.