blob: 6fe5af6639ad2a26dd7ab54b9c84e38103dc2655 [file] [log] [blame]
/*
* import-cmd.c -- Import a file or tree into the repository.
*
* ====================================================================
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
* ====================================================================
*/
/* ==================================================================== */
/*** Includes. ***/
#include "svn_client.h"
#include "svn_path.h"
#include "svn_error.h"
#include "cl.h"
#include "svn_private_config.h"
/*** Code. ***/
/* This implements the `svn_opt_subcommand_t' interface. */
svn_error_t *
svn_cl__import(apr_getopt_t *os,
void *baton,
apr_pool_t *pool)
{
svn_cl__opt_state_t *opt_state = ((svn_cl__cmd_baton_t *) baton)->opt_state;
svn_client_ctx_t *ctx = ((svn_cl__cmd_baton_t *) baton)->ctx;
apr_array_header_t *targets;
const char *path;
const char *url;
/* Import takes two arguments, for example
*
* $ svn import projects/test file:///home/jrandom/repos/trunk
* ^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
* (source) (repository)
*
* or
*
* $ svn import file:///home/jrandom/repos/some/subdir
*
* What is the nicest behavior for import, from the user's point of
* view? This is a subtle question. Seemingly intuitive answers
* can lead to weird situations, such never being able to create
* non-directories in the top-level of the repository.
*
* If 'source' is a file then the basename of 'url' is used as the
* filename in the repository. If 'source' is a directory then the
* import happens directly in the repository target dir, creating
* however many new entries are necessary. If some part of 'url'
* does not exist in the repository then parent directories are created
* as necessary.
*
* In the case where no 'source' is given '.' (the current directory)
* is implied.
*
* ### kff todo: review above behaviors.
*/
SVN_ERR(svn_cl__args_to_target_array_print_reserved(&targets, os,
opt_state->targets,
ctx, FALSE, pool));
if (targets->nelts < 1)
return svn_error_create
(SVN_ERR_CL_INSUFFICIENT_ARGS, NULL,
_("Repository URL required when importing"));
else if (targets->nelts > 2)
return svn_error_create
(SVN_ERR_CL_ARG_PARSING_ERROR, NULL,
_("Too many arguments to import command"));
else if (targets->nelts == 1)
{
url = APR_ARRAY_IDX(targets, 0, const char *);
path = "";
}
else
{
path = APR_ARRAY_IDX(targets, 0, const char *);
url = APR_ARRAY_IDX(targets, 1, const char *);
}
SVN_ERR(svn_cl__check_target_is_local_path(path));
if (! svn_path_is_url(url))
return svn_error_createf(SVN_ERR_CL_ARG_PARSING_ERROR, NULL,
_("Invalid URL '%s'"), url);
if (opt_state->depth == svn_depth_unknown)
opt_state->depth = svn_depth_infinity;
SVN_ERR(svn_cl__make_log_msg_baton(&(ctx->log_msg_baton3), opt_state,
NULL, ctx->config, pool));
SVN_ERR(svn_cl__cleanup_log_msg
(ctx->log_msg_baton3,
svn_client_import5(path,
url,
opt_state->depth,
opt_state->no_ignore,
opt_state->no_autoprops,
opt_state->force,
opt_state->revprop_table,
NULL, NULL, /* filter callback / baton */
(opt_state->quiet
? NULL : svn_cl__print_commit_info),
NULL,
ctx,
pool), pool));
return SVN_NO_ERROR;
}