/* * ==================================================================== * Copyright (c) 2004-2012 TMate Software Ltd. All rights reserved. * * This software is licensed as described in the file COPYING, which * you should have received as part of this distribution. The terms * are also available at http://svnkit.com/license.html * If newer versions of this license are posted there, you may use a * newer version instead, at your option. * ==================================================================== */ package org.tmatesoft.svn.cli.svnsync; import java.util.Collection; import java.util.LinkedList; import java.util.List; import org.tmatesoft.svn.core.SVNCancelException; import org.tmatesoft.svn.core.SVNErrorCode; import org.tmatesoft.svn.core.SVNErrorMessage; import org.tmatesoft.svn.core.SVNException; import org.tmatesoft.svn.core.internal.wc.SVNErrorManager; import org.tmatesoft.svn.core.internal.wc.SVNPath; import org.tmatesoft.svn.core.wc.SVNEvent; import org.tmatesoft.svn.core.wc.SVNRevision; import org.tmatesoft.svn.core.wc.admin.ISVNAdminEventHandler; import org.tmatesoft.svn.core.wc.admin.SVNAdminClient; import org.tmatesoft.svn.core.wc.admin.SVNAdminEvent; import org.tmatesoft.svn.core.wc.admin.SVNAdminEventAction; import org.tmatesoft.svn.util.SVNLogType; /** * @author TMate Software Ltd. * @version 1.3 */ public class SVNSyncCopyRevPropsCommand extends SVNSyncCommand implements ISVNAdminEventHandler { public SVNSyncCopyRevPropsCommand() { super("copy-revprops", null, 1); } protected Collection createSupportedOptions() { LinkedList options = new LinkedList(); options.add(SVNSyncOption.NON_INTERACTIVE); options.add(SVNSyncOption.NO_AUTH_CACHE); options.add(SVNSyncOption.USERNAME); options.add(SVNSyncOption.PASSWORD); options.add(SVNSyncOption.TRUST_SERVER_CERT); options.add(SVNSyncOption.SOURCE_USERNAME); options.add(SVNSyncOption.SOURCE_PASSWORD); options.add(SVNSyncOption.SYNC_USERNAME); options.add(SVNSyncOption.SYNC_PASSWORD); options.add(SVNSyncOption.CONFIG_DIR); options.add(SVNSyncOption.QUIET); return options; } public void run() throws SVNException { List arguments = getSVNSyncEnvironment().getArguments(); if (arguments.size() > 2) { SVNErrorMessage err = SVNErrorMessage.create(SVNErrorCode.CL_ARG_PARSING_ERROR); SVNErrorManager.error(err, SVNLogType.CLIENT); } if (arguments.isEmpty()) { SVNErrorMessage err = SVNErrorMessage.create(SVNErrorCode.CL_INSUFFICIENT_ARGS); SVNErrorManager.error(err, SVNLogType.CLIENT); } SVNRevision startRevision = null; SVNRevision endRevision = null; long startRevisionNumber = 0; long endRevisionNumber = -1; if (arguments.size() == 2) { String revString = (String) arguments.remove(arguments.size() - 1); SVNRevision[] revisions = getEnvironment().parseRevision(revString); if (revisions == null || revisions[0].isLocal() || revisions[1].isLocal()) { SVNErrorMessage err = SVNErrorMessage.create(SVNErrorCode.CL_ARG_PARSING_ERROR, "''{0}'' is not a valid revision range", revString); SVNErrorManager.error(err, SVNLogType.CLIENT); } startRevision = revisions[0]; endRevision = revisions[1]; if (startRevision == SVNRevision.HEAD) { startRevisionNumber = -1; } else { startRevisionNumber = startRevision.getNumber(); if (!SVNRevision.isValidRevisionNumber(startRevisionNumber)) { SVNErrorMessage err = SVNErrorMessage.create(SVNErrorCode.CL_ARG_PARSING_ERROR, "Invalid revision number ({0})", String.valueOf(startRevisionNumber)); SVNErrorManager.error(err, SVNLogType.CLIENT); } } if (!endRevision.isValid()) { endRevisionNumber = startRevisionNumber; } else if (endRevision != SVNRevision.HEAD) { endRevisionNumber = endRevision.getNumber(); if (!SVNRevision.isValidRevisionNumber(endRevisionNumber)) { SVNErrorMessage err = SVNErrorMessage.create(SVNErrorCode.CL_ARG_PARSING_ERROR, "Invalid revision number ({0})", String.valueOf(endRevisionNumber)); SVNErrorManager.error(err, SVNLogType.CLIENT); } } } List targets = getEnvironment().combineTargets(null, false); if (targets.size() != 1) { SVNErrorMessage err = SVNErrorMessage.create(SVNErrorCode.CL_INSUFFICIENT_ARGS); SVNErrorManager.error(err, SVNLogType.CLIENT); } SVNPath toURL = new SVNPath((String) targets.get(0)); if (!toURL.isURL()) { SVNErrorMessage err = SVNErrorMessage.create(SVNErrorCode.CL_ARG_PARSING_ERROR, "Path ''{0}'' is not a URL", toURL.getTarget()); SVNErrorManager.error(err, SVNLogType.CLIENT); } SVNAdminClient client = getEnvironment().getClientManager().getAdminClient(); client.setEventHandler(this); client.doCopyRevisionProperties(toURL.getURL(), startRevisionNumber, endRevisionNumber); } public void handleAdminEvent(SVNAdminEvent event, double progress) throws SVNException { if (event.getAction() == SVNAdminEventAction.REVISION_PROPERTIES_COPIED || event.getAction() == SVNAdminEventAction.NORMALIZED_PROPERTIES) { if (!getSVNSyncEnvironment().isQuiet()) { getSVNSyncEnvironment().getOut().println(event.getMessage()); } } } public void handleEvent(SVNEvent event, double progress) throws SVNException { } public void checkCancelled() throws SVNCancelException { } }