#include <apr_general.h>
#include "svn_wc.h"
#include "svn_client.h"
#include "svn_path.h"
#include "svn_error.h"
#include "svn_config.h"
#include "cl.h"
svn_error_t *
svn_cl__commit(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;
apr_array_header_t *condensed_targets;
const char *base_dir;
svn_config_t *cfg;
svn_boolean_t no_unlock = FALSE;
svn_commit_info_t *commit_info = NULL;
SVN_ERR(svn_opt_args_to_target_array2(&targets, os,
opt_state->targets, pool));
svn_opt_push_implicit_dot_target(targets, pool);
SVN_ERR(svn_path_condense_targets(&base_dir,
&condensed_targets,
targets,
TRUE,
pool));
if ((! condensed_targets) || (! condensed_targets->nelts))
{
const char *parent_dir, *base_name;
SVN_ERR(svn_wc_get_actual_target(base_dir, &parent_dir,
&base_name, pool));
if (*base_name)
base_dir = apr_pstrdup(pool, parent_dir);
}
if (! opt_state->quiet)
svn_cl__get_notifier(&ctx->notify_func2, &ctx->notify_baton2, FALSE,
FALSE, FALSE, pool);
cfg = apr_hash_get(ctx->config, SVN_CONFIG_CATEGORY_CONFIG,
APR_HASH_KEY_STRING);
if (cfg)
SVN_ERR(svn_config_get_bool(cfg, &no_unlock,
SVN_CONFIG_SECTION_MISCELLANY,
SVN_CONFIG_OPTION_NO_UNLOCK, FALSE));
SVN_ERR(svn_cl__make_log_msg_baton(&(ctx->log_msg_baton2),
opt_state, base_dir,
ctx->config, pool));
SVN_ERR(svn_cl__cleanup_log_msg
(ctx->log_msg_baton2, svn_client_commit3(&commit_info,
targets,
opt_state->nonrecursive
? FALSE : TRUE,
no_unlock,
ctx,
pool)));
if (commit_info && ! opt_state->quiet)
SVN_ERR(svn_cl__print_commit_info(commit_info, pool));
return SVN_NO_ERROR;
}