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

Re: svn commit: r953765 - in /subversion/trunk/subversion/libsvn_wc: update_editor.c wc-queries.sql wc_db.c wc_db.h workqueue.c

From: Hyrum K. Wright <hyrum_wright_at_mail.utexas.edu>
Date: Fri, 11 Jun 2010 23:06:43 +0200

On Fri, Jun 11, 2010 at 6:54 PM, <rhuijben_at_apache.org> wrote:

> Author: rhuijben
> Date: Fri Jun 11 16:54:04 2010
> New Revision: 953765
>
> URL: http://svn.apache.org/viewvc?rev=953765&view=rev
> Log:
> Replace two entry stub write operations that reset the stub to only
> an unmodified base node with a temporary wc_db operation.
>
> * subversion/libsvn_wc/update_editor.c
> (add_directory): Use svn_wc__db_temp_set_parent_stub_to_normal() instead
> of an entry update.
> * subversion/libsvn_wc/wc-queries.sql
> (STMT_UPDATE_BASE_PRESENCE_KIND): New statement.
>
> * subversion/libsvn_wc/wc_db.c
> (svn_wc__db_temp_set_parent_stub_to_normal): New function.
>
> * subversion/libsvn_wc/wc_db.h
> (svn_wc__db_temp_set_parent_stub_to_normal): New function.
>
> * subversion/libsvn_wc/workqueue.c
> (log_do_committed): Handle symlinks as files and use
> svn_wc__db_temp_set_parent_stub_to_normal to update the
> parent stub.
>
> Modified:
> subversion/trunk/subversion/libsvn_wc/update_editor.c
> subversion/trunk/subversion/libsvn_wc/wc-queries.sql
> subversion/trunk/subversion/libsvn_wc/wc_db.c
> subversion/trunk/subversion/libsvn_wc/wc_db.h
> subversion/trunk/subversion/libsvn_wc/workqueue.c
>
> ...
> Modified: subversion/trunk/subversion/libsvn_wc/wc_db.c
> URL:
> http://svn.apache.org/viewvc/subversion/trunk/subversion/libsvn_wc/wc_db.c?rev=953765&r1=953764&r2=953765&view=diff
>
> ==============================================================================
> --- subversion/trunk/subversion/libsvn_wc/wc_db.c (original)
> +++ subversion/trunk/subversion/libsvn_wc/wc_db.c Fri Jun 11 16:54:04 2010
> @@ -8300,4 +8300,73 @@ svn_wc__db_temp_op_set_property_conflict
> return svn_error_return(svn_sqlite__step_done(stmt));
> }
>
> +svn_error_t *
> +svn_wc__db_temp_set_parent_stub_to_normal(svn_wc__db_t *db,
> + const char *local_abspath,
> + svn_boolean_t delete_working,
> + apr_pool_t *scratch_pool)
> +{
> + svn_wc__db_pdh_t *pdh;
> + const char *local_relpath;
> + svn_sqlite__stmt_t *stmt;
> + const char *parent_abspath, *basename;
> + int affected_rows;
> +
> + SVN_ERR_ASSERT(svn_dirent_is_absolute(local_abspath)
> + && !svn_dirent_is_root(local_abspath,
> strlen(local_abspath)));
> +
> + svn_dirent_split(local_abspath, &parent_abspath, &basename,
> scratch_pool);
> +
> + SVN_ERR_ASSERT(*basename != '\0');
> +
> + SVN_ERR(svn_wc__db_pdh_parse_local_abspath(&pdh, &local_relpath, db,
> + parent_abspath,
> + svn_sqlite__mode_readwrite,
> + scratch_pool, scratch_pool));
> + VERIFY_USABLE_PDH(pdh);
> +
> +#ifndef SINGLE_DB
> + /* This should be handled in a transaction, but we can assume a db lock
> + and this code won't survive until 1.7 */
> +
> + if (delete_working)
> + {
> + SVN_DBG(("Deleting working\n"));
>

Vestigial debug statement.

> + SVN_ERR(svn_sqlite__get_statement(&stmt, pdh->wcroot->sdb,
> + STMT_DELETE_WORKING_NODE));
> + SVN_ERR(svn_sqlite__bindf(stmt, "is", pdh->wcroot->wc_id,
> basename));
> +
> + SVN_ERR(svn_sqlite__step_done(stmt));
> + }
> +
> + SVN_DBG(("Updating presence for %s\n",
> svn_dirent_local_style(local_abspath, scratch_pool)));
>

Same.

> + SVN_ERR(svn_sqlite__get_statement(&stmt, pdh->wcroot->sdb,
> + STMT_UPDATE_BASE_PRESENCE_KIND));
> +
> + SVN_ERR(svn_sqlite__bindf(stmt, "istt", pdh->wcroot->wc_id, basename,
> + presence_map, svn_wc__db_status_normal,
> + kind_map, svn_wc__db_kind_subdir));
> +
> + SVN_ERR(svn_sqlite__update(&affected_rows, stmt));
> +
> + if (affected_rows == 0)
> + {
> + /* Worst case: We have to create a new parent stub */
> + SVN_DBG(("Inserting instead\n"));
>

Same.

> + SVN_ERR(svn_sqlite__get_statement(&stmt, pdh->wcroot->sdb,
> + STMT_INSERT_BASE_NODE));
> +
> + SVN_ERR(svn_sqlite__bindf(stmt, "is", pdh->wcroot->wc_id,
> basename));
> + SVN_ERR(svn_sqlite__bind_text(stmt, 5, ""));
> + SVN_ERR(svn_sqlite__bind_token(stmt, 6, presence_map,
> + svn_wc__db_status_normal));
> + SVN_ERR(svn_sqlite__bind_token(stmt, 7, kind_map,
> + svn_wc__db_kind_subdir));
> +
> + SVN_ERR(svn_sqlite__step_done(stmt));
> + }
> +#endif
> + flush_entries(pdh);
> + return SVN_NO_ERROR;
> +}

...

-Hyrum
Received on 2010-06-11 23:07:30 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.