|
--- subversion-0.35.0/subversion/clients/cmdline/cl.h 2003-12-11 01:01:45.000000000 +0100
|
|
+++ subversion-0.35.0_my/subversion/clients/cmdline/cl.h 2004-01-09 02:26:55.000000000 +0100
|
|
@@ -51,6 +51,7 @@
|
|
svn_cl__config_dir_opt,
|
|
svn_cl__diff_cmd_opt,
|
|
svn_cl__dry_run_opt,
|
|
+ svn_cl__duplicate_opt,
|
|
svn_cl__editor_cmd_opt,
|
|
svn_cl__encoding_opt,
|
|
svn_cl__force_log_opt,
|
|
@@ -117,6 +118,7 @@
|
|
svn_boolean_t notice_ancestry; /* notice ancestry for diff-y operations */
|
|
svn_boolean_t stop_on_copy; /* don't cross copies during processing */
|
|
svn_boolean_t dry_run; /* try operation but make no changes */
|
|
+ svn_boolean_t duplicate; /* simply duplicate copied files and dirs */
|
|
svn_boolean_t revprop; /* operate on a revision property */
|
|
const char *diff_cmd; /* the external diff command to use */
|
|
const char *merge_cmd; /* the external merge command to use */
|
|
--- subversion-0.35.0/subversion/clients/cmdline/main.c 2003-12-02 23:52:31.000000000 +0100
|
|
+++ subversion-0.35.0_my/subversion/clients/cmdline/main.c 2004-01-09 02:29:58.000000000 +0100
|
|
@@ -103,6 +103,8 @@
|
|
"do no interactive prompting"},
|
|
{"dry-run", svn_cl__dry_run_opt, 0,
|
|
"try operation but make no changes"},
|
|
+ {"duplicate", svn_cl__duplicate_opt, 0,
|
|
+ "simply duplicate copied files and directories"},
|
|
{"no-diff-deleted", svn_cl__no_diff_deleted, 0,
|
|
"do not print differences for deleted files"},
|
|
{"notice-ancestry", svn_cl__notice_ancestry_opt, 0,
|
|
@@ -367,7 +369,7 @@
|
|
" the sources have identical basenames that match a file within '.':\n"
|
|
" in which case, the differences will be applied to that file.\n",
|
|
{'r', 'N', 'q', svn_cl__force_opt, svn_cl__dry_run_opt,
|
|
- svn_cl__merge_cmd_opt, svn_cl__notice_ancestry_opt,
|
|
+ svn_cl__duplicate_opt, svn_cl__merge_cmd_opt, svn_cl__notice_ancestry_opt,
|
|
SVN_CL__AUTH_OPTIONS, svn_cl__config_dir_opt} },
|
|
|
|
{ "mkdir", svn_cl__mkdir, {0},
|
|
@@ -826,6 +828,9 @@
|
|
case svn_cl__dry_run_opt:
|
|
opt_state.dry_run = TRUE;
|
|
break;
|
|
+ case svn_cl__duplicate_opt:
|
|
+ opt_state.duplicate = TRUE;
|
|
+ break;
|
|
case svn_cl__revprop_opt:
|
|
opt_state.revprop = TRUE;
|
|
break;
|
|
--- subversion-0.35.0/subversion/clients/cmdline/merge-cmd.c 2003-12-07 19:53:31.000000000 +0100
|
|
+++ subversion-0.35.0_my/subversion/clients/cmdline/merge-cmd.c 2004-01-09 02:25:24.000000000 +0100
|
|
@@ -165,6 +165,7 @@
|
|
opt_state->notice_ancestry ? FALSE : TRUE,
|
|
opt_state->force,
|
|
opt_state->dry_run,
|
|
+ opt_state->duplicate,
|
|
ctx,
|
|
pool);
|
|
if (err)
|
|
--- subversion-0.35.0/subversion/include/svn_client.h 2003-12-05 23:33:54.000000000 +0100
|
|
+++ subversion-0.35.0_my/subversion/include/svn_client.h 2004-01-09 02:24:40.000000000 +0100
|
|
@@ -871,6 +871,7 @@
|
|
svn_boolean_t ignore_ancestry,
|
|
svn_boolean_t force,
|
|
svn_boolean_t dry_run,
|
|
+ svn_boolean_t duplicate,
|
|
svn_client_ctx_t *ctx,
|
|
apr_pool_t *pool);
|
|
|
|
--- subversion-0.35.0/subversion/libsvn_client/diff.c 2003-12-12 13:29:54.000000000 +0100
|
|
+++ subversion-0.35.0_my/subversion/libsvn_client/diff.c 2004-01-10 12:34:25.000000000 +0100
|
|
@@ -601,6 +601,7 @@
|
|
struct merge_cmd_baton {
|
|
svn_boolean_t force;
|
|
svn_boolean_t dry_run;
|
|
+ svn_boolean_t duplicate;
|
|
const char *target; /* Working copy target of merge */
|
|
const char *url; /* The second URL in the merge */
|
|
const char *path; /* The wc path of the second target, this
|
|
@@ -751,7 +752,7 @@
|
|
struct merge_cmd_baton *merge_b = baton;
|
|
apr_pool_t *subpool = svn_pool_create (merge_b->pool);
|
|
svn_node_kind_t kind;
|
|
- const char *copyfrom_url;
|
|
+ const char *copyfrom_url = NULL;
|
|
const char *child;
|
|
|
|
/* Easy out: if we have no adm_access for the parent directory,
|
|
@@ -783,8 +784,10 @@
|
|
{
|
|
child = svn_path_is_child(merge_b->target, mine, merge_b->pool);
|
|
assert (child != NULL);
|
|
- copyfrom_url = svn_path_join (merge_b->url, child, merge_b->pool);
|
|
- SVN_ERR (check_schema_match (adm_access, copyfrom_url));
|
|
+ if ( merge_b->duplicate == FALSE ) {
|
|
+ copyfrom_url = svn_path_join (merge_b->url, child, merge_b->pool);
|
|
+ SVN_ERR (check_schema_match (adm_access, copyfrom_url));
|
|
+ }
|
|
|
|
/* Since 'mine' doesn't exist, and this is
|
|
'merge_file_added', I hope it's safe to assume that
|
|
@@ -930,7 +933,8 @@
|
|
apr_pool_t *subpool = svn_pool_create (merge_b->pool);
|
|
svn_node_kind_t kind;
|
|
const svn_wc_entry_t *entry;
|
|
- const char *copyfrom_url, *child;
|
|
+ const char *copyfrom_url = NULL;
|
|
+ const char *child;
|
|
|
|
/* Easy out: if we have no adm_access for the parent directory,
|
|
then this portion of the tree-delta "patch" must be inapplicable.
|
|
@@ -945,8 +949,10 @@
|
|
|
|
child = svn_path_is_child (merge_b->target, path, subpool);
|
|
assert (child != NULL);
|
|
- copyfrom_url = svn_path_join (merge_b->url, child, subpool);
|
|
- SVN_ERR (check_schema_match (adm_access, copyfrom_url));
|
|
+ if ( merge_b->duplicate == FALSE ) {
|
|
+ copyfrom_url = svn_path_join (merge_b->url, child, subpool);
|
|
+ SVN_ERR (check_schema_match (adm_access, copyfrom_url));
|
|
+ }
|
|
|
|
SVN_ERR (svn_io_check_path (path, &kind, subpool));
|
|
switch (kind)
|
|
@@ -1945,6 +1951,7 @@
|
|
svn_boolean_t ignore_ancestry,
|
|
svn_boolean_t force,
|
|
svn_boolean_t dry_run,
|
|
+ svn_boolean_t duplicate,
|
|
svn_client_ctx_t *ctx,
|
|
apr_pool_t *pool)
|
|
{
|
|
@@ -1992,6 +1999,7 @@
|
|
|
|
merge_cmd_baton.force = force;
|
|
merge_cmd_baton.dry_run = dry_run;
|
|
+ merge_cmd_baton.duplicate = duplicate;
|
|
merge_cmd_baton.target = target_wcpath;
|
|
merge_cmd_baton.url = URL2;
|
|
merge_cmd_baton.revision = revision2;
|