2 * import-cmd.c -- Import a file or tree into the repository.
4 * ====================================================================
5 * Licensed to the Apache Software Foundation (ASF) under one
6 * or more contributor license agreements. See the NOTICE file
7 * distributed with this work for additional information
8 * regarding copyright ownership. The ASF licenses this file
9 * to you under the Apache License, Version 2.0 (the
10 * "License"); you may not use this file except in compliance
11 * with the License. You may obtain a copy of the License at
13 * http://www.apache.org/licenses/LICENSE-2.0
15 * Unless required by applicable law or agreed to in writing,
16 * software distributed under the License is distributed on an
17 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
18 * KIND, either express or implied. See the License for the
19 * specific language governing permissions and limitations
21 * ====================================================================
24 /* ==================================================================== */
30 #include "svn_client.h"
32 #include "svn_error.h"
35 #include "svn_private_config.h"
40 /* This implements the `svn_opt_subcommand_t' interface. */
42 svn_cl__import(apr_getopt_t *os,
46 svn_cl__opt_state_t *opt_state = ((svn_cl__cmd_baton_t *) baton)->opt_state;
47 svn_client_ctx_t *ctx = ((svn_cl__cmd_baton_t *) baton)->ctx;
48 apr_array_header_t *targets;
52 /* Import takes two arguments, for example
54 * $ svn import projects/test file:///home/jrandom/repos/trunk
55 * ^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
56 * (source) (repository)
60 * $ svn import file:///home/jrandom/repos/some/subdir
62 * What is the nicest behavior for import, from the user's point of
63 * view? This is a subtle question. Seemingly intuitive answers
64 * can lead to weird situations, such never being able to create
65 * non-directories in the top-level of the repository.
67 * If 'source' is a file then the basename of 'url' is used as the
68 * filename in the repository. If 'source' is a directory then the
69 * import happens directly in the repository target dir, creating
70 * however many new entries are necessary. If some part of 'url'
71 * does not exist in the repository then parent directories are created
74 * In the case where no 'source' is given '.' (the current directory)
77 * ### kff todo: review above behaviors.
80 SVN_ERR(svn_cl__args_to_target_array_print_reserved(&targets, os,
84 if (targets->nelts < 1)
85 return svn_error_create
86 (SVN_ERR_CL_INSUFFICIENT_ARGS, NULL,
87 _("Repository URL required when importing"));
88 else if (targets->nelts > 2)
89 return svn_error_create
90 (SVN_ERR_CL_ARG_PARSING_ERROR, NULL,
91 _("Too many arguments to import command"));
92 else if (targets->nelts == 1)
94 url = APR_ARRAY_IDX(targets, 0, const char *);
99 path = APR_ARRAY_IDX(targets, 0, const char *);
100 url = APR_ARRAY_IDX(targets, 1, const char *);
103 SVN_ERR(svn_cl__check_target_is_local_path(path));
105 if (! svn_path_is_url(url))
106 return svn_error_createf(SVN_ERR_CL_ARG_PARSING_ERROR, NULL,
107 _("Invalid URL '%s'"), url);
109 if (opt_state->depth == svn_depth_unknown)
110 opt_state->depth = svn_depth_infinity;
112 SVN_ERR(svn_cl__make_log_msg_baton(&(ctx->log_msg_baton3), opt_state,
113 NULL, ctx->config, pool));
115 SVN_ERR(svn_cl__cleanup_log_msg
116 (ctx->log_msg_baton3,
117 svn_client_import5(path,
120 opt_state->no_ignore,
121 opt_state->no_autoprops,
123 opt_state->revprop_table,
124 NULL, NULL, /* filter callback / baton */
126 ? NULL : svn_cl__print_commit_info),