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

Re: svn commit: r948250 - in /subversion/trunk/subversion: libsvn_client/merge.c libsvn_client/mergeinfo.h tests/cmdline/merge_tests.py

From: Philip Martin <philip.martin_at_wandisco.com>
Date: Wed, 26 May 2010 17:29:52 +0100

pburba_at_apache.org writes:

> Author: pburba
> Date: Tue May 25 23:28:46 2010
> New Revision: 948250

> +/* A svn_log_entry_receiver_t callback for
> + get_inoperative_immediate_children(). */
> +static svn_error_t *
> +log_find_operative_subtree_revs(void *baton,
> + svn_log_entry_t *log_entry,
> + apr_pool_t *pool)

Any reason why this is pool rather than scratch_pool?

> +{
> + apr_hash_t *immediate_children = baton;
> + apr_hash_index_t *hi, *hi2;
> + svn_revnum_t revision;
> +
> + revision = log_entry->revision;

revision is not used.

> +
> + for (hi = apr_hash_first(pool, log_entry->changed_paths2);
> + hi;
> + hi = apr_hash_next(hi))
> + {
> + const char *path = svn__apr_hash_index_key(hi);
> + for (hi2 = apr_hash_first(pool, immediate_children);

It's only a small allocation so I suppose we can get away without an
iteration pool.

> + hi2;
> + hi2 = apr_hash_next(hi2))
> + {
> + const char *immediate_path = svn__apr_hash_index_val(hi2);
> + if (svn_dirent_is_ancestor(immediate_path, path))
> + {
> + apr_hash_set(immediate_children, svn__apr_hash_index_key(hi2),
> + APR_HASH_KEY_STRING, NULL);
> + /* A path can't be the child of more than
> + one immediate child of the merge target. */
> + break;
> + }
> + }
> + }
> + return SVN_NO_ERROR;
> +}

> +static svn_error_t *
> +get_inoperative_immediate_children(apr_hash_t **immediate_children,
> + apr_array_header_t *children_with_mergeinfo,
> + const char *merge_source_repos_abspath,
> + svn_revnum_t oldest_rev,
> + svn_revnum_t youngest_rev,
> + const char *merge_target_abspath,
> + svn_ra_session_t *ra_session,
> + apr_pool_t *result_pool,
> + apr_pool_t *scratch_pool)
> +{
> + int i;
> + *immediate_children = apr_hash_make(result_pool);
> +
> + SVN_ERR_ASSERT(SVN_IS_VALID_REVNUM(oldest_rev));
> + SVN_ERR_ASSERT(SVN_IS_VALID_REVNUM(youngest_rev));
> + SVN_ERR_ASSERT(oldest_rev <= youngest_rev);
> +
> + /* Find all the children in CHILDREN_WITH_MERGEINFO with the
> + immediate_child_dir flag set and store them in *IMMEDIATE_CHILDREN. */
> + for (i = 0; i < children_with_mergeinfo->nelts; i++)
> + {
> + svn_client__merge_path_t *child =
> + APR_ARRAY_IDX(children_with_mergeinfo, i, svn_client__merge_path_t *);
> +
> + if (child->immediate_child_dir)
> + apr_hash_set(*immediate_children,
> + apr_pstrdup(result_pool, child->abspath),
> + APR_HASH_KEY_STRING,
> + svn_uri_join(merge_source_repos_abspath,
> + svn_dirent_is_child(merge_target_abspath,
> + child->abspath,
> + result_pool),

Arguments to svn_uri_join don't need to be in result pool. Use
scratch_pool or an iteration pool.

> + result_pool));
> + }
> +
> + /* Now remove any paths from *IMMEDIATE_CHILDREN that are inoperative when
> + merging MERGE_SOURCE_REPOS_PATH -r(OLDEST_REV - 1):YOUNGEST_REV to
> + MERGE_TARGET_ABSPATH at --depth infinity. */
> + if (apr_hash_count(*immediate_children))
> + {
> + apr_array_header_t *log_targets = apr_array_make(scratch_pool, 1,
> + sizeof(const char *));
> + APR_ARRAY_PUSH(log_targets, const char *) = "";
> + SVN_ERR(svn_ra_get_log2(ra_session, log_targets, youngest_rev,
> + oldest_rev, 0, TRUE, FALSE, FALSE,
> + NULL, log_find_operative_subtree_revs,
> + *immediate_children, scratch_pool));
> + }
> + return SVN_NO_ERROR;
> +}

-- 
Philip
Received on 2010-05-26 18:30:42 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.