Class SVNWCClient


  • public class SVNWCClient
    extends SVNBasicClient
    The SVNWCClient class combines a number of version control operations mainly intended for local work with Working Copy items. This class includes those operations that are destined only for local work on a Working Copy as well as those that are moreover able to access a repository.

    Here's a list of the SVNWCClient's methods matched against corresponing commands of the SVN command line client:

    SVNKit Subversion
    doAdd() 'svn add'
    doGetFileContents() 'svn cat'
    doDelete() 'svn delete'
    doCleanup() 'svn cleanup'
    doInfo() 'svn info'
    doLock() 'svn lock'
    doUnlock() 'svn unlock'
    doSetProperty() 'svn propset PROPNAME PROPVAL PATH'
    'svn propdel PROPNAME PATH'
    'svn propedit PROPNAME PATH'
    doSetRevisionProperty() 'svn propset PROPNAME --revprop -r REV PROPVAL [URL]'
    'svn propdel PROPNAME --revprop -r REV [URL]'
    'svn propedit PROPNAME --revprop -r REV [URL]'
    doGetProperty() 'svn propget PROPNAME PATH'
    'svn proplist PATH'
    doGetRevisionProperty() 'svn propget PROPNAME --revprop -r REV [URL]'
    'svn proplist --revprop -r REV [URL]'
    doResolve() 'svn resolved'
    doRevert() 'svn revert'
    Since:
    1.2
    Version:
    1.3
    See Also:
    Examples
    • Constructor Detail

      • SVNWCClient

        public SVNWCClient​(ISVNAuthenticationManager authManager,
                           ISVNOptions options)
        Constructs and initializes an SVNWCClient object with the specified run-time configuration and authentication drivers.

        If options is null, then this SVNWCClient will be using a default run-time configuration driver which takes client-side settings from the default SVN's run-time configuration area but is not able to change those settings (read more on ISVNOptions and SVNWCUtil).

        If authManager is null, then this SVNWCClient will be using a default authentication and network layers driver (see SVNWCUtil.createDefaultAuthenticationManager()) which uses server-side settings and auth storage from the default SVN's run-time configuration area (or system properties if that area is not found).

        Parameters:
        authManager - an authentication and network layers driver
        options - a run-time configuration options driver
      • SVNWCClient

        public SVNWCClient​(ISVNRepositoryPool repositoryPool,
                           ISVNOptions options)
        Constructs and initializes an SVNWCClient object with the specified run-time configuration and repository pool object.

        If options is null, then this SVNWCClient will be using a default run-time configuration driver which takes client-side settings from the default SVN's run-time configuration area but is not able to change those settings (read more on ISVNOptions and SVNWCUtil).

        If repositoryPool is null, then SVNRepositoryFactory will be used to create repository access objects.

        Parameters:
        repositoryPool - a repository pool object
        options - a run-time configuration options driver
    • Method Detail

      • setAddParameters

        public void setAddParameters​(ISVNAddParameters addParameters)
        Sets custom add parameters to this client object.
        Parameters:
        addParameters - extra parameters for add operations
        Since:
        1.2
      • setCommitHandler

        public void setCommitHandler​(ISVNCommitHandler handler)
        Sets an implementation of ISVNCommitHandler to the commit handler that will be used during commit operations to handle commit log messages. The handler will receive a clien's log message and items (represented as SVNCommitItem objects) that will be committed. Depending on implementor's aims the initial log message can be modified (or something else) and returned back.

        If using SVNWCClient without specifying any commit handler then a default one will be used - DefaultSVNCommitHandler.

        Parameters:
        handler - an implementor's handler that will be used to handle commit log messages
        See Also:
        getCommitHandler(), ISVNCommitHandler
      • setRevertMissingDirectories

        public void setRevertMissingDirectories​(boolean revertMissing)
      • isRevertMissingDirectories

        public boolean isRevertMissingDirectories()
      • doGetFileContents

        public void doGetFileContents​(java.io.File path,
                                      SVNRevision pegRevision,
                                      SVNRevision revision,
                                      boolean expandKeywords,
                                      java.io.OutputStream dst)
                               throws SVNException
        Outputs the content of file identified by path and revision to the stream dst. The actual node revision selected is determined by the path as it exists in pegRevision. If pegRevision is SVNRevision.UNDEFINED, then it defaults to SVNRevision.WORKING.

        If revision is one of:

        then the file contents are taken from the working copy file item (no network connection is needed). Otherwise the file item's contents are taken from the repository at a particular revision.
        Parameters:
        path - working copy path
        pegRevision - revision in which the file item is first looked up
        revision - target revision
        expandKeywords - if true then all keywords presenting in the file and listed in the file's SVNProperty.KEYWORDS property (if set) will be substituted, otherwise not
        dst - the destination where the file contents will be written to
        Throws:
        SVNException - if one of the following is true:
        • path refers to a directory
        • path does not exist
        • path is not under version control
        See Also:
        doGetFileContents(SVNURL,SVNRevision,SVNRevision,boolean,OutputStream)
      • doGetFileContents

        public void doGetFileContents​(SVNURL url,
                                      SVNRevision pegRevision,
                                      SVNRevision revision,
                                      boolean expandKeywords,
                                      java.io.OutputStream dst)
                               throws SVNException
        Outputs the content of file identified by url and revision to the stream dst. The actual node revision selected is determined by the path as it exists in pegRevision. If pegRevision is SVNRevision.UNDEFINED, then it defaults to SVNRevision.HEAD.
        Parameters:
        url - a file item's repository location
        pegRevision - a revision in which the file item is first looked up
        revision - a target revision
        expandKeywords - if true then all keywords presenting in the file and listed in the file's SVNProperty.KEYWORDS property (if set) will be substituted, otherwise not
        dst - the destination where the file contents will be written to
        Throws:
        SVNException - if one of the following is true:
        • url refers to a directory
        • it's impossible to create temporary files ( createTempFile() fails) necessary for file translating
        See Also:
        doGetFileContents(File,SVNRevision,SVNRevision,boolean,OutputStream)
      • doCleanup

        public void doCleanup​(java.io.File path)
                       throws SVNException
        Cleans up a working copy. This method is equivalent to a call to doCleanup(path, false).
        Parameters:
        path - a WC path to start a cleanup from
        Throws:
        SVNException - if one of the following is true:
        • path does not exist
        • path's parent directory is not under version control
        See Also:
        doCleanup(File, boolean)
      • doCleanup

        public void doCleanup​(java.io.File path,
                              boolean deleteWCProperties)
                       throws SVNException
        Recursively cleans up the working copy, removing locks and resuming unfinished operations.

        If you ever get a "working copy locked" error, use this method to remove stale locks and get your working copy into a usable state again.

        This method operates only on working copies and does not open any network connection.

        Parameters:
        path - a WC path to start a cleanup from
        deleteWCProperties - if true, removes DAV specific "svn:wc:" properties from the working copy
        Throws:
        SVNException - if one of the following is true:
        • path does not exist
        • path's parent directory is not under version control
      • doCleanup

        public void doCleanup​(java.io.File path,
                              boolean deleteWCProperties,
                              boolean breakLocks,
                              boolean vacuumPristines,
                              boolean removeUnversionedItems,
                              boolean removeIgnoredItems,
                              boolean includeExternals)
                       throws SVNException
        Throws:
        SVNException
      • doSetProperty

        public void doSetProperty​(java.io.File path,
                                  java.lang.String propName,
                                  SVNPropertyValue propValue,
                                  boolean skipChecks,
                                  SVNDepth depth,
                                  ISVNPropertyHandler handler,
                                  java.util.Collection<java.lang.String> changeLists)
                           throws SVNException
        Sets propName to propValue on path . A propValue of null will delete the property.

        If depth is SVNDepth.EMPTY, set the property on path only; if SVNDepth.FILES, set it on path and its file children (if any); if SVNDepth.IMMEDIATES, on path and all of its immediate children (both files and directories); if SVNDepth.INFINITY, on path and everything beneath it.

        If propName is an svn-controlled property (i.e. prefixed with "svn:"), then the caller is responsible for ensuring that the value uses LF line-endings.

        If skipChecks is true, this method does no validity checking. But if skipChecks is false, and propName is not a valid property for path, it throws an exception, either with an error code SVNErrorCode.ILLEGAL_TARGET (if the property is not appropriate for path), or with SVNErrorCode.BAD_MIME_TYPE (if propName is "svn:mime-type", but propVal is not a valid mime-type).

        changeLists is a collection of String changelist names, used as a restrictive filter on items whose properties are set; that is, don't set properties on any item unless it's a member of one of those changelists. If changelists is empty (or null), no changelist filtering occurs.

        This method operates only on working copies and does not open any network connection.

        Parameters:
        path - working copy path
        propName - property name
        propValue - property value
        skipChecks - true to force the operation to run without validity checking
        depth - working copy tree depth to process
        handler - a caller's property handler
        changeLists - changelist names
        Throws:
        SVNException -
        • path does not exist
        • exception with SVNErrorCode.CLIENT_PROPERTY_NAME error code - if propName is a revision property name or not a valid property name or not a regular property name (one starting with a "svn:entry" or "svn:wc" prefix)
        Since:
        1.2, SVN 1.5
        See Also:
        doSetProperty(SVNURL, String, SVNPropertyValue, SVNRevision, String, SVNProperties, boolean, ISVNPropertyHandler)
      • doSetProperty

        public SVNCommitInfo doSetProperty​(SVNURL url,
                                           java.lang.String propName,
                                           SVNPropertyValue propValue,
                                           SVNRevision baseRevision,
                                           java.lang.String commitMessage,
                                           SVNProperties revisionProperties,
                                           boolean skipChecks,
                                           ISVNPropertyHandler handler)
                                    throws SVNException
        Sets propName to propValue on path . A propValue of null will delete the property.

        baseRevision must not be null; in this case, the property will only be set if it has not changed since baseRevision.

        The authentication manager and commit handler, either provided by a caller or default ones, will be used to immediately attempt to commit the property change in the repository.

        If propName is an svn-controlled property (i.e. prefixed with "svn:"), then the caller is responsible for ensuring that the value uses LF line-endings.

        If skipChecks is true, this method does no validity checking. But if skipChecks is false, and propName is not a valid property for path, it throws an exception, either with an error code SVNErrorCode.ILLEGAL_TARGET (if the property is not appropriate for path), or with SVNErrorCode.BAD_MIME_TYPE (if propName is "svn:mime-type", but propVal is not a valid mime-type).

        If non-null, revisionProperties is an SVNProperties object holding additional, custom revision properties (String names mapped to String values) to be set on the new revision in the event that this is a committing operation. This table cannot contain any standard Subversion properties.

        Parameters:
        url - versioned item url
        propName - property name
        propValue - property value
        baseRevision - revision to change properties against
        commitMessage - commit log message
        revisionProperties - custom revision properties to set
        skipChecks - true to force the operation to run without validity checking
        handler - a caller's property handler
        Returns:
        commit information if the commit succeeds
        Throws:
        SVNException -
        Since:
        1.2, SVN 1.5
        See Also:
        doSetProperty(File, String, SVNPropertyValue, boolean, SVNDepth, ISVNPropertyHandler, Collection)
      • doSetRevisionProperty

        public void doSetRevisionProperty​(SVNURL url,
                                          SVNRevision revision,
                                          java.lang.String propName,
                                          SVNPropertyValue propValue,
                                          boolean force,
                                          ISVNPropertyHandler handler)
                                   throws SVNException
        Set propName to propValue on revision revision in the repository represented by path. A propValue of null will delete the property. The authentication manager, either provided by a caller or a default one, will be used for authentication.

        If propName is an svn-controlled property (i.e. prefixed with "svn:"), then the caller is responsible for ensuring that the value is UTF8-encoded and uses LF line-endings.

        Although this routine accepts a working copy path it doesn't affect the working copy at all; it's a pure network operation that changes an *unversioned* property attached to a revision. This can be used to tweak log messages, dates, authors, and the like. Be careful: it's a lossy operation.

        Also note that unless the administrator creates a pre-revprop-change hook in the repository, this feature will fail.

        Parameters:
        url - repository URL
        revision - revision which properties are to be modified
        propName - property name
        propValue - property value
        force - if true allows newlines in the author property
        handler - caller's property handler
        Throws:
        SVNException - if one of the following is true:
        • the operation can not be performed without forcing
        • propName is either invalid or not a regular property name (one starting with an "svn:entry" or "svn:wc" prefix)
        See Also:
        doSetRevisionProperty(File, SVNRevision, String, SVNPropertyValue, boolean, ISVNPropertyHandler)
      • doGetProperty

        public SVNPropertyData doGetProperty​(java.io.File path,
                                             java.lang.String propName,
                                             SVNRevision pegRevision,
                                             SVNRevision revision)
                                      throws SVNException
        Gets the value of the property propName for path. This method simply creates an implementation of ISVNPropertyHandler which stores the value only for path which is then used in the following call to doGetProperty(path, propName, pegRevision, revision, SVNDepth.EMPTY, handler, null) .
        Parameters:
        path - a WC item's path
        propName - an item's property name; if it's null then all the item's properties will be retrieved but only the first of them returned
        pegRevision - a revision in which the item is first looked up
        revision - a target revision;
        Returns:
        the item's property
        Throws:
        SVNException - if one of the following is true:
        • propName starts with the svn:wc: prefix
        • path is not under version control
        See Also:
        doGetProperty(File, String, SVNRevision, SVNRevision, SVNDepth, ISVNPropertyHandler, Collection)
      • doGetProperty

        public SVNPropertyData doGetProperty​(SVNURL url,
                                             java.lang.String propName,
                                             SVNRevision pegRevision,
                                             SVNRevision revision)
                                      throws SVNException
        Gets the value of the property propName for url . This method simply creates an implementation of ISVNPropertyHandler which stores the value only for path which is then used in the following call to doGetProperty(url, propName, pegRevision, revision, SVNDepth.EMPTY, handler) .
        Parameters:
        url - an item's repository location
        propName - an item's property name; if it's null then all the item's properties will be retrieved but only the first of them returned
        pegRevision - a revision in which the item is first looked up
        revision - a target revision;
        Returns:
        the item's property
        Throws:
        SVNException - if one of the following is true:
        • propName starts with the svn:wc: prefix
        • path is not under version control
        See Also:
        doGetProperty(SVNURL, String, SVNRevision, SVNRevision, SVNDepth, ISVNPropertyHandler)
      • doGetProperty

        public void doGetProperty​(java.io.File path,
                                  java.lang.String propName,
                                  SVNRevision pegRevision,
                                  SVNRevision revision,
                                  boolean recursive,
                                  ISVNPropertyHandler handler)
                           throws SVNException
        Gets an item's versioned property and passes it to a provided property handler. It's possible to get either a local property (from a Working Copy) or a remote one (located in a repository). If revision is one of: then the result is a WC item's property. Otherwise the property is taken from a repository (using the item's URL).
        Parameters:
        path - a WC item's path
        propName - an item's property name; if it's null then all the item's properties will be retrieved and passed to handler for processing
        pegRevision - a revision in which the item is first looked up
        revision - a target revision;
        recursive - true to descend recursively
        handler - a caller's property handler
        Throws:
        SVNException - if one of the following is true:
        • propName starts with the svn:wc: prefix
        • path is not under version control
      • doGetProperty

        public void doGetProperty​(java.io.File path,
                                  java.lang.String propName,
                                  SVNRevision pegRevision,
                                  SVNRevision revision,
                                  SVNDepth depth,
                                  ISVNPropertyHandler handler,
                                  java.util.Collection<java.lang.String> changeLists)
                           throws SVNException
        Invokes handler on paths covered by depth starting with the specified path.

        If both revision and pegRevision are ones of:

        then this method gets properties from the working copy without connecting to the repository. Otherwise properties are taken from the repository (using the item's URL).

        The actual node revision selected is determined by the path as it exists in pegRevision. If pegRevision is SVNRevision.UNDEFINED, then it defaults to SVNRevision.WORKING.

        If depth is SVNDepth.EMPTY, fetch the property from path only; if SVNDepth.FILES, fetch from path and its file children (if any); if SVNDepth.IMMEDIATES, from path and all of its immediate children (both files and directories); if SVNDepth.INFINITY, from path and everything beneath it.

        changeLists is a collection of String changelist names, used as a restrictive filter on items whose properties are set; that is, don't set properties on any item unless it's a member of one of those changelists. If changeLists is empty (or null), no changelist filtering occurs.

        Parameters:
        path - a WC item's path
        propName - an item's property name; if it's null then all the item's properties will be retrieved and passed to handler for processing
        pegRevision - a revision in which the item is first looked up
        revision - a target revision
        depth - tree depth
        handler - a caller's property handler
        changeLists - collection of changelist names
        Throws:
        SVNException - if one of the following is true:
        Since:
        1.2, SVN 1.5
      • doGetProperty

        public void doGetProperty​(SVNURL url,
                                  java.lang.String propName,
                                  SVNRevision pegRevision,
                                  SVNRevision revision,
                                  boolean recursive,
                                  ISVNPropertyHandler handler)
                           throws SVNException
        Gets an item's versioned property from a repository and passes it to a provided property handler. This method is useful when having no Working Copy at all.
        Parameters:
        url - an item's repository location
        propName - an item's property name; if it's null then all the item's properties will be retrieved and passed to handler for processing
        pegRevision - a revision in which the item is first looked up
        revision - a target revision
        recursive - true to descend recursively
        handler - a caller's property handler
        Throws:
        SVNException - if propName starts with the svn:wc: prefix
      • doGetProperty

        public void doGetProperty​(SVNURL url,
                                  java.lang.String propName,
                                  SVNRevision pegRevision,
                                  SVNRevision revision,
                                  SVNDepth depth,
                                  ISVNPropertyHandler handler)
                           throws SVNException
        Invokes handler on paths covered by depth starting with the specified path.

        If is SVNRevision.UNDEFINED then get properties from the repository head. Else get the properties as of revision. The actual node revision selected is determined by the path as it exists in pegRevision. If pegRevision is SVNRevision.UNDEFINED, then it defaults to SVNRevision.HEAD.

        If depth is SVNDepth.EMPTY, fetch the property from path only; if SVNDepth.FILES, fetch from path and its file children (if any); if SVNDepth.IMMEDIATES, from path and all of its immediate children (both files and directories); if SVNDepth.INFINITY, from path and everything beneath it.

        Parameters:
        url - versioned item url
        propName - an item's property name; if it's null then all the item's properties will be retrieved and passed to handler for processing
        pegRevision - a revision in which the item is first looked up
        revision - a target revision
        depth - tree depth
        handler - a caller's property handler
        Throws:
        SVNException - if one of the following is true:
        Since:
        1.2, SVN 1.5
      • doGetRevisionProperty

        public long doGetRevisionProperty​(java.io.File path,
                                          java.lang.String propName,
                                          SVNRevision revision,
                                          ISVNPropertyHandler handler)
                                   throws SVNException
        Gets an unversioned revision property from a repository (getting a repository URL from a Working Copy) and passes it to a provided property handler.
        Parameters:
        path - a local Working Copy item which repository location is used to connect to a repository
        propName - a revision property name; if this parameter is null then all the revision properties will be retrieved and passed to handler for processing
        revision - a revision which property is to be retrieved
        handler - a caller's property handler
        Throws:
        SVNException - if one of the following is true:
        • revision is invalid
        • propName starts with the svn:wc: prefix
        See Also:
        doGetRevisionProperty(SVNURL,String,SVNRevision,ISVNPropertyHandler)
      • doGetRevisionProperty

        public long doGetRevisionProperty​(SVNURL url,
                                          java.lang.String propName,
                                          SVNRevision revision,
                                          ISVNPropertyHandler handler)
                                   throws SVNException
        Gets an unversioned revision property from a repository and passes it to a provided property handler.
        Parameters:
        url - a URL pointing to a repository location which revision property is to be got
        propName - a revision property name; if this parameter is null then all the revision properties will be retrieved and passed to handler for processing
        revision - a revision which property is to be retrieved
        handler - a caller's property handler
        Returns:
        actual revision number to which revision is resolved
        Throws:
        SVNException - if one of the following is true:
        • revision is invalid
        • propName starts with the svn:wc: prefix
        See Also:
        doGetRevisionProperty(File,String,SVNRevision,ISVNPropertyHandler)
      • doDelete

        public void doDelete​(java.io.File path,
                             boolean force,
                             boolean dryRun)
                      throws SVNException
        Schedules a Working Copy item for deletion. This method is equivalent to doDelete(path, force, true, dryRun).
        Parameters:
        path - a WC item to be deleted
        force - true to force the operation to run
        dryRun - true only to try the delete operation without actual deleting
        Throws:
        SVNException - if one of the following is true:
        • path is not under version control
        • can not delete path without forcing
        See Also:
        doDelete(File,boolean,boolean,boolean)
      • doDelete

        public void doDelete​(java.io.File path,
                             boolean force,
                             boolean deleteFiles,
                             boolean dryRun)
                      throws SVNException
        Schedules a Working Copy item for deletion. This method allows to choose - whether file item(s) are to be deleted from the filesystem or not. Another version of the doDelete() method is similar to the corresponding SVN client's command - 'svn delete' as it always deletes files from the filesystem.

        This method deletes only local working copy paths without connecting to the repository.

        Parameters:
        path - a WC item to be deleted
        force - true to force the operation to run
        deleteFiles - if true then files will be scheduled for deletion as well as deleted from the filesystem, otherwise files will be only scheduled for deletion and still be present in the filesystem
        dryRun - true only to try the delete operation without actual deleting
        Throws:
        SVNException - if one of the following is true:
        • path is not under version control
        • can not delete path without forcing
      • doAdd

        public void doAdd​(java.io.File path,
                          boolean force,
                          boolean mkdir,
                          boolean climbUnversionedParents,
                          boolean recursive)
                   throws SVNException
        Schedules an unversioned item for addition to a repository thus putting it under version control.

        To create and add to version control a new directory, set mkdir to true.

        Calling this method is equivalent to doAdd(path, force, mkdir, climbUnversionedParents, recursive, false).

        Parameters:
        path - a path to be put under version control (will be added to a repository in next commit)
        force - when true forces the operation to run on already versioned files or directories without reporting error. When ran recursively, all unversioned files and directories in a tree will be scheduled for addition.
        mkdir - if true - creates a new directory and schedules it for addition
        climbUnversionedParents - if true and path is located in an unversioned parent directory then the parent will be automatically scheduled for addition, too
        recursive - true to descend recursively (relevant for directories)
        Throws:
        SVNException - if one of the following is true:
        • path doesn't belong to a Working Copy
        • path doesn't exist and mkdir is false
        • path is the root directory of the Working Copy
      • doAdd

        public void doAdd​(java.io.File path,
                          boolean force,
                          boolean mkdir,
                          boolean climbUnversionedParents,
                          boolean recursive,
                          boolean includeIgnored)
                   throws SVNException
        Schedules an unversioned item for addition to a repository thus putting it under version control.

        To create and add to version control a new directory, set mkdir to true.

        Parameters:
        path - a path to be put under version control (will be added to a repository in next commit)
        force - when true forces the operation to run on already versioned files or directories without reporting error. When ran recursively, all unversioned files and directories in a tree will be scheduled for addition.
        mkdir - if true - creates a new directory and schedules it for addition
        climbUnversionedParents - if true and path is located in an unversioned parent directory then the parent will be automatically scheduled for addition, too
        recursive - true to descend recursively (relevant for directories)
        includeIgnored - controls whether ignored items must be also added
        Throws:
        SVNException - if one of the following is true:
        • path doesn't belong to a Working Copy
        • path doesn't exist and mkdir is false
        • path is the root directory of the Working Copy
        Since:
        1.1
      • doAdd

        public void doAdd​(java.io.File path,
                          boolean force,
                          boolean mkdir,
                          boolean climbUnversionedParents,
                          SVNDepth depth,
                          boolean includeIgnored,
                          boolean makeParents)
                   throws SVNException
        Schedules a working copy path for addition to the repository.

        If depth is SVNDepth.EMPTY, adds just path and nothing below it. If SVNDepth.FILES, adds path and any file children of path. If SVNDepth.IMMEDIATES, adds path, any file children, and any immediate subdirectories (but nothing underneath those subdirectories). If SVNDepth.INFINITY, adds path and everything under it fully recursively.

        path's parent must be under revision control already (unless makeParents is true), but path is not.

        If force is set, path is a directory, depth is SVNDepth.INFINITY, then schedules for addition unversioned files and directories scattered deep within a versioned tree.

        If includeIgnored is false, doesn't add files or directories that match ignore patterns.

        If makeParents is true, recurse up path's directory and look for a versioned directory. If found, add all intermediate paths between it and path.

        Important: this is a *scheduling* operation. No changes will happen to the repository until a commit occurs. This scheduling can be removed with a call to doRevert(File[], SVNDepth, Collection).

        Parameters:
        path - working copy path
        force - if true, this method does not throw exceptions on already-versioned items
        mkdir - if true, create a directory also at path
        climbUnversionedParents - not used; make use of makeParents instead
        depth - tree depth
        includeIgnored - if true, does not apply ignore patterns to paths being added
        makeParents - if true, climb upper and schedule also all unversioned paths in the way
        Throws:
        SVNException -
        Since:
        1.2, SVN 1.5
      • doAdd

        public void doAdd​(java.io.File[] paths,
                          boolean force,
                          boolean mkdir,
                          boolean climbUnversionedParents,
                          SVNDepth depth,
                          boolean depthIsSticky,
                          boolean includeIgnored,
                          boolean makeParents)
                   throws SVNException
        Schedules working copy paths for addition to the repository.

        If depth is SVNDepth.EMPTY, adds just paths and nothing below it. If SVNDepth.FILES, adds paths and any file children of paths. If SVNDepth.IMMEDIATES, adds paths, any file children, and any immediate subdirectories (but nothing underneath those subdirectories). If SVNDepth.INFINITY, adds paths and everything under it fully recursively.

        paths' parent must be under revision control already (unless makeParents is true), but paths are not.

        If force is set, path is a directory, depth is SVNDepth.INFINITY, then schedules for addition unversioned files and directories scattered deep within a versioned tree.

        If includeIgnored is false, doesn't add files or directories that match ignore patterns.

        If makeParents is true, recurse up path's directory and look for a versioned directory. If found, add all intermediate paths between it and the path.

        Important: this is a *scheduling* operation. No changes will happen to the repository until a commit occurs. This scheduling can be removed with a call to doRevert(File[], SVNDepth, Collection).

        Parameters:
        paths - working copy paths to add
        force - if true, this method does not throw exceptions on already-versioned items
        mkdir - if true, create a directory also at path
        climbUnversionedParents - not used; make use of makeParents instead
        depth - tree depth
        depthIsSticky - if depth should be recorded to the working copy
        includeIgnored - if true, does not apply ignore patterns to paths being added
        makeParents - if true, climb upper and schedule also all unversioned paths in the way
        Throws:
        SVNException -
        Since:
        1.3
      • doAdd

        public void doAdd​(java.io.File[] paths,
                          boolean force,
                          boolean mkdir,
                          boolean climbUnversionedParents,
                          SVNDepth depth,
                          boolean depthIsSticky,
                          boolean includeIgnored,
                          boolean makeParents,
                          boolean applyAutoProperties)
                   throws SVNException
        Schedules working copy paths for addition to the repository.

        If depth is SVNDepth.EMPTY, adds just paths and nothing below it. If SVNDepth.FILES, adds paths and any file children of paths. If SVNDepth.IMMEDIATES, adds paths, any file children, and any immediate subdirectories (but nothing underneath those subdirectories). If SVNDepth.INFINITY, adds paths and everything under it fully recursively.

        paths' parent must be under revision control already (unless makeParents is true), but paths are not.

        If force is set, path is a directory, depth is SVNDepth.INFINITY, then schedules for addition unversioned files and directories scattered deep within a versioned tree.

        If includeIgnored is false, doesn't add files or directories that match ignore patterns.

        If makeParents is true, recurse up path's directory and look for a versioned directory. If found, add all intermediate paths between it and the path.

        Important: this is a *scheduling* operation. No changes will happen to the repository until a commit occurs. This scheduling can be removed with a call to doRevert(File[], SVNDepth, Collection).

        Parameters:
        paths - working copy paths to add
        force - if true, this method does not throw exceptions on already-versioned items
        mkdir - if true, create a directory also at path
        climbUnversionedParents - not used; make use of makeParents instead
        depth - tree depth
        depthIsSticky - if depth should be recorded to the working copy
        includeIgnored - if true, does not apply ignore patterns to paths being added
        makeParents - if true, climb upper and schedule also all unversioned paths in the way
        applyAutoProperties - if true, applies auto-properties on file addition otherwise auto-properties application is disabled
        Throws:
        SVNException -
        Since:
        1.8
      • doAdd

        public void doAdd​(java.io.File path,
                          boolean force,
                          boolean mkdir,
                          boolean climbUnversionedParents,
                          SVNDepth depth,
                          boolean depthIsSticky,
                          boolean includeIgnored,
                          boolean makeParents)
                   throws SVNException
        Schedules a working copy path for addition to the repository.

        If depth is SVNDepth.EMPTY, adds just path and nothing below it. If SVNDepth.FILES, adds path and any file children of path. If SVNDepth.IMMEDIATES, adds path, any file children, and any immediate subdirectories (but nothing underneath those subdirectories). If SVNDepth.INFINITY, adds path and everything under it fully recursively.

        path's parent must be under revision control already (unless makeParents is true), but path is not.

        If force is set, path is a directory, depth is SVNDepth.INFINITY, then schedules for addition unversioned files and directories scattered deep within a versioned tree.

        If includeIgnored is false, doesn't add files or directories that match ignore patterns.

        If makeParents is true, recurse up path's directory and look for a versioned directory. If found, add all intermediate paths between it and path.

        Important: this is a *scheduling* operation. No changes will happen to the repository until a commit occurs. This scheduling can be removed with a call to doRevert(File[], SVNDepth, Collection).

        Parameters:
        path - working copy path
        force - if true, this method does not throw exceptions on already-versioned items
        mkdir - if true, create a directory also at path
        climbUnversionedParents - not used; make use of makeParents instead
        depth - tree depth
        depthIsSticky - if depth should be recorded to the working copy
        includeIgnored - if true, does not apply ignore patterns to paths being added
        makeParents - if true, climb upper and schedule also all unversioned paths in the way
        Throws:
        SVNException -
        Since:
        1.3
      • doMarkReplaced

        public void doMarkReplaced​(java.io.File path)
                            throws SVNException
        Schedules path as being replaced. This method does not perform any deletion\addition in the filesysem nor does it require a connection to the repository. It just marks the current path item as being replaced.
        Parameters:
        path - working copy path to mark as
        Throws:
        SVNException
        Since:
        1.2
      • doRevert

        public void doRevert​(java.io.File path,
                             boolean recursive)
                      throws SVNException
        Reverts all local changes made to a Working Copy item(s) thus bringing it to a 'pristine' state.
        Parameters:
        path - a WC path to perform a revert on
        recursive - true to descend recursively (relevant for directories)
        Throws:
        SVNException - if one of the following is true:
        • path is not under version control
        • when trying to revert an addition of a directory from within the directory itself
        See Also:
        doRevert(File[],boolean)
      • doRevert

        public void doRevert​(java.io.File[] paths,
                             boolean recursive)
                      throws SVNException
        Reverts all local changes made to a Working Copy item(s) thus bringing it to a 'pristine' state.
        Parameters:
        paths - a WC paths to perform a revert on
        recursive - true to descend recursively (relevant for directories)
        Throws:
        SVNException - if one of the following is true:
        • path is not under version control
        • when trying to revert an addition of a directory from within the directory itself

        Exception will not be thrown if there are multiple paths passed. Instead caller should process events received by ISVNEventHandler instance to get information on whether certain path was reverted or not.

      • doRevert

        public void doRevert​(java.io.File[] paths,
                             SVNDepth depth,
                             java.util.Collection<java.lang.String> changeLists)
                      throws SVNException
        Restores the pristine version of working copy paths, effectively undoing any local mods. For each path in paths, reverts it if it is a file. Else if it is a directory, reverts according to depth:

        If depth is SVNDepth.EMPTY, reverts just the properties on the directory; else if SVNDepth.FILES, reverts the properties and any files immediately under the directory; else if SVNDepth.IMMEDIATES, reverts all of the preceding plus properties on immediate subdirectories; else if SVNDepth.INFINITY, reverts path and everything under it fully recursively.

        changeLists is a collection of String changelist names, used as a restrictive filter on items reverted; that is, doesn't revert any item unless it's a member of one of those changelists. If changeLists is empty (or null), no changelist filtering occurs.

        If an item specified for reversion is not under version control, then does not fail with an exception, just invokes ISVNEventHandler using notification code SVNEventAction.SKIP.

        Parameters:
        paths - working copy paths to revert
        depth - tree depth
        changeLists - collection with changelist names
        Throws:
        SVNException
        Since:
        1.2, SVN 1.5
      • doResolve

        public void doResolve​(java.io.File path,
                              boolean recursive)
                       throws SVNException
        Resolves a 'conflicted' state on a Working Copy item.
        Parameters:
        path - a WC item to be resolved
        recursive - true to descend recursively (relevant for directories) - this will resolve the entire tree
        Throws:
        SVNException - if path is not under version control
      • doResolve

        public void doResolve​(java.io.File path,
                              SVNDepth depth,
                              boolean resolveContents,
                              boolean resolveProperties,
                              boolean resolveTree,
                              SVNConflictChoice conflictChoice)
                       throws SVNException
        Performs automatic conflict resolution on a working copy path.

        If depth is SVNDepth.EMPTY, acts only on path; if SVNDepth.FILES, resolves path and its conflicted file children (if any); if SVNDepth.IMMEDIATES , resolves path and all its immediate conflicted children (both files and directories, if any); if SVNDepth.INFINITY, resolves path and every conflicted file or directory anywhere beneath it.

        If conflictChoice is SVNConflictChoice.BASE, resolves the conflict with the old file contents; if SVNConflictChoice.MINE_FULL, uses the original working contents; if SVNConflictChoice.THEIRS_FULL, the new contents; and if SVNConflictChoice.MERGED, doesn't change the contents at all, just removes the conflict status, which is the pre-1.2 (pre-SVN 1.5) behavior.

        SVNConflictChoice.THEIRS_CONFLICT and SVNConflictChoice.MINE_CONFLICT are not legal for binary files or properties.

        If path is not in a state of conflict to begin with, does nothing. If path's conflict state is removed and caller's ISVNEntryHandler is not null, then an SVNEventAction.RESOLVED event is dispatched to the handler.

        Parameters:
        path - working copy path
        depth - tree depth
        resolveContents - resolve content conflict
        resolveProperties - resolve property conflict
        resolveTree - n resolve any tree conlicts
        conflictChoice - choice object for making decision while resolving
        Throws:
        SVNException
        Since:
        1.3, SVN 1.6
      • doLock

        public void doLock​(java.io.File[] paths,
                           boolean stealLock,
                           java.lang.String lockMessage)
                    throws SVNException
        Locks file items in a Working Copy as well as in a repository so that no other user can commit changes to them.
        Parameters:
        paths - an array of local WC file paths that should be locked
        stealLock - if true then all existing locks on the specified paths will be "stolen"
        lockMessage - an optional lock comment
        Throws:
        SVNException - if one of the following is true:
        • a path to be locked is not under version control
        • can not obtain a URL of a local path to lock it in the repository - there's no such entry
        • paths to be locked belong to different repositories
        See Also:
        doLock(SVNURL[],boolean,String)
      • doLock

        public void doLock​(SVNURL[] urls,
                           boolean stealLock,
                           java.lang.String lockMessage)
                    throws SVNException
        Locks file items in a repository so that no other user can commit changes to them.
        Parameters:
        urls - an array of URLs to be locked
        stealLock - if true then all existing locks on the specified urls will be "stolen"
        lockMessage - an optional lock comment
        Throws:
        SVNException
        See Also:
        doLock(File[],boolean,String)
      • doUnlock

        public void doUnlock​(java.io.File[] paths,
                             boolean breakLock)
                      throws SVNException
        Unlocks file items in a Working Copy as well as in a repository.
        Parameters:
        paths - an array of local WC file paths that should be unlocked
        breakLock - if true and there are locks that belong to different users then those locks will be also unlocked - that is "broken"
        Throws:
        SVNException - if one of the following is true:
        • a path is not under version control
        • can not obtain a URL of a local path to unlock it in the repository - there's no such entry
        • if a path is not locked in the Working Copy and breakLock is false
        • paths to be unlocked belong to different repositories
        See Also:
        doUnlock(SVNURL[],boolean)
      • doUnlock

        public void doUnlock​(SVNURL[] urls,
                             boolean breakLock)
                      throws SVNException
        Unlocks file items in a repository.
        Parameters:
        urls - an array of URLs that should be unlocked
        breakLock - if true and there are locks that belong to different users then those locks will be also unlocked - that is "broken"
        Throws:
        SVNException
        See Also:
        doUnlock(File[],boolean)
      • doInfo

        public void doInfo​(java.io.File path,
                           SVNRevision revision,
                           boolean recursive,
                           ISVNInfoHandler handler)
                    throws SVNException
        Collects information about Working Copy item(s) and passes it to an info handler.

        If revision is valid and not local, then information will be collected on remote items (that is taken from a repository). Otherwise information is gathered on local items not accessing a repository.

        Parameters:
        path - a WC item on which info should be obtained
        revision - a target revision
        recursive - true to descend recursively (relevant for directories)
        handler - a caller's info handler
        Throws:
        SVNException - if one of the following is true:
        • path is not under version control
        • can not obtain a URL corresponding to path to get its information from the repository - there's no such entry
        • if a remote info: path is an item that does not exist in the specified revision
      • doInfo

        public void doInfo​(java.io.File path,
                           SVNRevision pegRevision,
                           SVNRevision revision,
                           boolean recursive,
                           ISVNInfoHandler handler)
                    throws SVNException
        Collects information about Working Copy item(s) and passes it to an info handler.

        If revision & pegRevision are valid and not local, then information will be collected on remote items (that is taken from a repository). Otherwise information is gathered on local items not accessing a repository.

        Parameters:
        path - a WC item on which info should be obtained
        pegRevision - a revision in which path is first looked up
        revision - a target revision
        recursive - true to descend recursively (relevant for directories)
        handler - a caller's info handler
        Throws:
        SVNException - if one of the following is true:
        • path is not under version control
        • can not obtain a URL corresponding to path to get its information from the repository - there's no such entry
        • if a remote info: path is an item that does not exist in the specified revision
      • doInfo

        public void doInfo​(java.io.File path,
                           SVNRevision pegRevision,
                           SVNRevision revision,
                           SVNDepth depth,
                           java.util.Collection<java.lang.String> changeLists,
                           ISVNInfoHandler handler)
                    throws SVNException
        Invokes handler to return information about path in revision. The information returned is system-generated metadata, not the sort of "property" metadata created by users. See SVNInfo.

        If both revision arguments are either null or local, or invalid, then information will be pulled solely from the working copy; no network connections will be made.

        Otherwise, information will be pulled from a repository. The actual node revision selected is determined by the path as it exists in pegRevision. If pegRevision is SVNRevision.UNDEFINED, then it defaults to SVNRevision.WORKING.

        If path is a file, just invokes handler on it. If it is a directory, then descends according to depth. If depth is SVNDepth.EMPTY, invokes handler on path and nothing else; if SVNDepth.FILES, on path and its immediate file children; if SVNDepth.IMMEDIATES, the preceding plus on each immediate subdirectory; if SVNDepth.INFINITY, then recurses fully, invoking handler on path and everything beneath it.

        changeLists is a collection of String changelist names, used as a restrictive filter on items whose info is reported; that is, doesn't report info about any item unless it's a member of one of those changelists. If changeLists is empty (or null), no changelist filtering occurs.

        Parameters:
        path - a WC item on which info should be obtained
        pegRevision - a revision in which path is first looked up
        revision - a target revision
        depth - tree depth
        changeLists - collection changelist names
        handler - caller's info handler
        Throws:
        SVNException
        Since:
        1.2, SVN 1.5
      • doInfo

        public void doInfo​(SVNURL url,
                           SVNRevision pegRevision,
                           SVNRevision revision,
                           boolean recursive,
                           ISVNInfoHandler handler)
                    throws SVNException
        Collects information about item(s) in a repository and passes it to an info handler.
        Parameters:
        url - a URL of an item which information is to be obtained and processed
        pegRevision - a revision in which the item is first looked up
        revision - a target revision
        recursive - true to descend recursively (relevant for directories)
        handler - a caller's info handler
        Throws:
        SVNException - if url is an item that does not exist in the specified revision
      • doInfo

        public void doInfo​(SVNURL url,
                           SVNRevision pegRevision,
                           SVNRevision revision,
                           SVNDepth depth,
                           ISVNInfoHandler handler)
                    throws SVNException
        Invokes handler to return information about url in revision. The information returned is system-generated metadata, not the sort of "property" metadata created by users. See SVNInfo.

        If revision argument is either null or invalid, it defaults to SVNRevision.HEAD. If revision is SVNRevision.PREVIOUS (or some other kind that requires a local path), an error will be returned, because the desired revision cannot be determined. If pegRevision argument is either null or invalid, it defaults to revision.

        Information will be pulled from the repository. The actual node revision selected is determined by the url as it exists in pegRevision. If pegRevision is SVNRevision.UNDEFINED, then it defaults to SVNRevision.WORKING.

        If url is a file, just invokes handler on it. If it is a directory, then descends according to depth. If depth is SVNDepth.EMPTY, invokes handler on url and nothing else; if SVNDepth.FILES, on url and its immediate file children; if SVNDepth.IMMEDIATES, the preceding plus on each immediate subdirectory; if SVNDepth.INFINITY, then recurses fully, invoking handler on url and everything beneath it.

        Parameters:
        url - versioned item url
        pegRevision - revision in which path is first looked up
        revision - target revision
        depth - tree depth
        handler - caller's info handler
        Throws:
        SVNException
        Since:
        1.2, SVN 1.5
      • doGetWorkingCopyID

        public java.lang.String doGetWorkingCopyID​(java.io.File path,
                                                   java.lang.String trailURL)
                                            throws SVNException
        Returns the current Working Copy min- and max- revisions as well as changes and switch status within a single string.

        This method is the same as doGetWorkingCopyID(path, trailURL, false).

        Parameters:
        path - a local path
        trailURL - optional: if not null specifies the name of the item that should be met in the URL corresponding to the repository location of the path; if that URL ends with something different than this optional parameter - the Working Copy will be considered "switched"
        Returns:
        brief info on the Working Copy or the string "exported" if path is a clean directory
        Throws:
        SVNException - if path is neither versioned nor even exported
        See Also:
        doGetWorkingCopyID(File, String, boolean)
      • doGetWorkingCopyID

        public java.lang.String doGetWorkingCopyID​(java.io.File path,
                                                   java.lang.String trailURL,
                                                   boolean committed)
                                            throws SVNException
        Returns the current Working Copy min- and max- revisions as well as changes and switch status within a single string.

        A return string has a form of "minR[:maxR][M][S]" where:

        • minR - is the smallest revision number met in the Working Copy
        • maxR - is the biggest revision number met in the Working Copy; appears only if there are different revision in the Working Copy
        • M - appears only if there're local edits to the Working Copy - that means 'Modified'
        • S - appears only if the Working Copy is switched against a different URL
        If path is a directory - this method recursively descends into the Working Copy, collects and processes local information.

        This method operates on local working copies only without accessing a repository.

        Parameters:
        path - a local path
        trailURL - optional: if not null specifies the name of the item that should be met in the URL corresponding to the repository location of the path; if that URL ends with something different than this optional parameter - the Working Copy will be considered "switched"
        committed - if true committed (last chaned) revisions instead of working copy ones are reported
        Returns:
        brief info on the Working Copy or the string "exported" if path is a clean directory
        Throws:
        SVNException - if path is neither versioned nor even exported
        Since:
        1.2
      • doInfo

        public SVNInfo doInfo​(java.io.File path,
                              SVNRevision revision)
                       throws SVNException
        Collects and returns information on a single Working Copy item.

        This method is the same as doInfo(path, SVNRevision.UNDEFINED, revision, SVNDepth.EMPTY, null, handler) where handler just stores SVNInfo for the path and then returns it to the caller.

        Parameters:
        path - a WC item on which info should be obtained
        revision - a target revision
        Returns:
        collected info
        Throws:
        SVNException - if one of the following is true:
        • path is not under version control
        • can not obtain a URL corresponding to path to get its information from the repository - there's no such entry
        • if a remote info: path is an item that does not exist in the specified revision
        See Also:
        doInfo(File, SVNRevision, SVNRevision, SVNDepth, Collection, ISVNInfoHandler)
      • doInfo

        public SVNInfo doInfo​(SVNURL url,
                              SVNRevision pegRevision,
                              SVNRevision revision)
                       throws SVNException
        Collects and returns information on a single item in a repository.

        This method is the same as doInfo(url, pegRevision, revision, SVNDepth.EMPTY, handler) where handler just stores SVNInfo for the url.

        Parameters:
        url - a URL of an item which information is to be obtained
        pegRevision - a revision in which the item is first looked up
        revision - a target revision
        Returns:
        collected info
        Throws:
        SVNException - if url is an item that does not exist in the specified revision
        See Also:
        doInfo(SVNURL, SVNRevision, SVNRevision, SVNDepth, ISVNInfoHandler)
      • doCleanupWCProperties

        public void doCleanupWCProperties​(java.io.File directory)
                                   throws SVNException
        Recursively removes all DAV-specific "svn:wc:" properties from the directory and beneath.

        This method does not connect to a repository, it's a local operation only. Nor does it change any user's versioned data. Changes are made only in administrative version control files.

        Parameters:
        directory - working copy path
        Throws:
        SVNException
        Since:
        1.2
      • doSetWCFormat

        public void doSetWCFormat​(java.io.File directory,
                                  int format)
                           throws SVNException
        Changes working copy format. This method may be used to upgrade\downgrade working copy formats.

        If externals are not ignored then external working copies are also converted to the new working copy format.

        This method does not connect to a repository, it's a local operation only. Nor does it change any user's versioned data. Changes are made only in administrative version control files.

        Once upgraded to 1.7 format (12) working copy format could not be downgraded.

        Parameters:
        directory - working copy directory
        format - format to set, supported formats are: 12 (SVN 1.7), 10 (SVN 1.6), 9 (SVN 1.5), 8 (SVN 1.4) and 4 (SVN 1.2)
        Throws:
        SVNException
        Since:
        1.2