On May 6, 2011 2:44 PM, <[email protected]> wrote:
>
> Author: pburba
> Date: Fri May  6 18:43:55 2011
> New Revision: 1100321
>
> URL: http://svn.apache.org/viewvc?rev=1100321&view=rev
> Log:
> Fix issue #3835
>
> * subversion/libsvn_wc/cleanup.c
>
>  (cleanup_internal): If the cleanup target is locked locked indirectly via
a
>   recursive lock on an ancestor, then recommend cleaning up the entire WC.
>
> Modified:
>    subversion/trunk/subversion/libsvn_wc/cleanup.c
>
> Modified: subversion/trunk/subversion/libsvn_wc/cleanup.c
> URL:
http://svn.apache.org/viewvc/subversion/trunk/subversion/libsvn_wc/cleanup.c?rev=1100321&r1=1100320&r2=1100321&view=diff
>
==============================================================================
> --- subversion/trunk/subversion/libsvn_wc/cleanup.c (original)
> +++ subversion/trunk/subversion/libsvn_wc/cleanup.c Fri May  6 18:43:55
2011
> @@ -142,13 +142,32 @@ cleanup_internal(svn_wc__db_t *db,
>  {
>   int wc_format;
>   const char *cleanup_abspath;
> +  svn_error_t *err;
>
>   /* Can we even work with this directory?  */
>   SVN_ERR(can_be_cleaned(&wc_format, db, dir_abspath, scratch_pool));
>
> -  /* ### This fails if ADM_ABSPATH is locked indirectly via a
> -     ### recursive lock on an ancestor. */
> -  SVN_ERR(svn_wc__db_wclock_obtain(db, dir_abspath, -1, TRUE,
scratch_pool));
> +  /* Issue #3835: If DIR_ABSPATH is locked indirectly via a recursive
lock
> +     on an ancestor, then recommend cleaning up the entire WC. */
> +  err = svn_wc__db_wclock_obtain(db, dir_abspath, -1, TRUE,
scratch_pool);
> +  if (err)
> +    {
> +      if (err->apr_err == SVN_ERR_WC_LOCKED)
> +        {
> +          const char *wcroot_abspath;
> +          svn_error_t *err2 = svn_wc__db_get_wcroot(&wcroot_abspath, db,
> +                                                    dir_abspath,
> +                                                    scratch_pool,
> +                                                    scratch_pool);
> +          if (err2)
> +            return svn_error_compose_create(err, err2);
> +
> +          return svn_error_createf(SVN_ERR_WC_LOCKED, err,
> +                                   _("Try cleanup from root of working
copy "
> +                                     "'%s'"), wcroot_abspath,
scratch_pool);

Need local style on that path

> +        }
> +      return svn_error_return(err);
> +    }
>
>   /* Run our changes before the subdirectories. We may not have to recurse
>      if we blow away a subdir.  */
>
>

Reply via email to