This programmer's reference gives complete and detailed infomation on the pysvn API.
The pysvn Programmer's Guide gives an tutorial introduction to the pysvn module.
This document covers pysvn version 1.6. Features offered by pysvn depend on the version of SVN that is being used. Full functionality is only available with SVN 1.6.0 or later.
Click one of the buttons below to show the pysvn API as supported by a particular version of the SVN.
Showing the PySVN API supported by SVN 1.6.0. Unsupported parts of the API are show like: This.
The recommended way to test for a feature is to use the python hasattr() builtin. Working out what is and is not support from the version number information is quite complex and unnessesary. For example to test for lock and unlock support:
client = pysvn.Client()
if hasattr( client, 'lock' ):
    # use lock
The pysvn module has the following variables:
The pysvn module has six classes:
The following enumerations are provided:
Use python builtin dir() to list all available values in an enumeration:
    print dir( pysvn.wc_notify_action )
Interface summary:
client = pysvn.Client() client = pysvn.Client( config_dir )
The default subversion configuration directory is used if the config_dir is omitted or set to ''.
The configuration directory is automatically created if it is missing.
A Client object can only be used on one thread at a time. If two threads attempt to call methods of Client at the same time one of the threads will get a pysvn.ClientError exception with the value 'client in use on another thread'.
| Variables | Callbacks | Methods | 
exception_style allows you to control the style of exception raised by pysvn.
commit_info_style allows you to control the style of commit_info returned by pysvn.
exception_style is used to control how pysvn raises ClientError exceptions.
The default value, 0, makes pysvn raise exceptions as it did prior to pysvn 1.1.2.
exception_style can be set to 0 or 1, see ClientError for details of effect of the style on the exception raised.
commit_info_style is used to control how pysvn return commit information.
commit_info_style can be set to 0 or 1. The default value, 0, makes pysvn return only the commit revision.
When set to 1 pysvn returns a dictionary of commit information including date, author, revision and post_commit_err.
pysvn uses callback functions to allow for realtime feedback and credential handling.
callback_cancel allows you to cancel a long running subversion command.
callback_notify gives feedback as commands runs.
callback_get_log_message is called when a log message is required.
callback_get_login is called to get a username and password to access a repository.
callback_ssl_server_trust_prompt is called when using HTTPS to a server whoes certificate needs is trust verifing.
callback_conflict_resolver is called to handle conflicts.
It is possible to use the Client object without setting up any calls backs. Make sure that all nessesary usernames, passwords and SSL certificate information are stored in the subversion configuration directory.
import pysvn
cancel_command = False
def cancel():
    return cancel_command
client = pysvn.Client()
client.callback_cancel = cancel
The callback_cancel function is called frequently during long running commands. Return True to cause the command to cancel, return False to allow the command to continue.
import pysvn
log_message = "reason for change"
def get_log_message():
    return rc, log_message
client = pysvn.Client()
client.callback_get_log_message = get_log_message
The callback_get_log_message is called when a log message is required to complete the current command. Return the True in rc and a log message as a string. Returning False in rc will cause the command to be cancelled. An empty log_message is not allowed and may cause the command to be cancelled.
Unicode strings cannot be handled. If you have a unicode string, convert it to UTF-8.
import pysvn
def get_login( realm, username, may_save ):
    return retcode, username, password, save
client = pysvn.Client()
client.callback_get_login = get_login
callback_get_login is called each time subversion needs a username and password in the realm to access a repository and has no cached credentials.
The may_save parameter is true if subversion is willing to save the answers returned by the callback_get_login function.
pysvn expect the callback_get_login to return a tuple of four values (retcode, username, password, save).
import pysvn
def notify( event_dict ):
    return
client = pysvn.Client()
client.callback_notify = notify
The callback_notify is called as a command runs each time an interesting event occurs. The details of the event are passed to the callback_notify function as a dictionary.
The dictionary contains the following values:
import pysvn
def ssl_client_cert_password_prompt( realm, may_save ):
    return retcode, password, save
client = pysvn.Client()
client.callback_ssl_client_cert_password_prompt = ssl_client_cert_password_prompt
callback_ssl_client_cert_password_prompt is called each time subversion needs a password in the realm to use a client certificate and has no cached credentials.
The may_save parameter is true if subversion is willing to save the answers returned by the callback_ssl_client_cert_password_prompt function.
pysvn expect the callback_ssl_client_cert_password_prompt to return a tuple of three values (retcode, password, save).
import pysvn
def ssl_client_cert_prompt( realm, may_save ):
    return retcode, certfile, may_save
client = pysvn.Client()
client.callback_ssl_client_cert_prompt = ssl_client_cert_prompt
callback_ssl_client_cert_prompt is called each time subversion needs a client certificate.
pysvn expect the callback_ssl_client_cert_prompt to return a tuple of three values (retcode, certfile, may_save).
import pysvn
def ssl_server_prompt( ):
    return 
client = pysvn.Client()
client.callback_ssl_server_prompt = ssl_server_prompt
NOT IMPLEMENTED - what it used for?
import pysvn
def ssl_server_trust_prompt( trust_dict ):
    return retcode, accepted_failures, save
client = pysvn.Client()
client.callback_ssl_server_trust_prompt = ssl_server_trust_prompt
The callback_ssl_server_trust_prompt is called each time an HTTPS server presents a certificate and subversion is not sure if it should be trusted. callback_ssl_server_trust_prompt is called with information about the certificate in trust dict.
pysvn expect the callback_ssl_server_trust_prompt to return a tuple of three values (retcode, accepted_failures, save).
import pysvn
def conflict_resolver( conflict_description ):
    return conflict_choice, merge_file, save_merged
client = pysvn.Client()
client.callback_conflict_resolver = conflict_resolver
The callback_conflict_resolver is called each time a conflict needs resolving. It is passed the conflict_description and must return a conflict_choice, merge_file and save_merged.
The members of the conflict_description dictionary are:
add_to_changelist( path,
                   changelist,
                   depth=QQQ,
                   changelists=[] )
TBD
depth is one of the pysvn.depth enums.
add( path,
     recurse=True,
     force=False,
     ignore=False,
     depth=None )
add( [path,path],
     recurse=True,
     force=False,
     ignore=True,
     depth=None )
Schedules all the files or directories specfied in the paths for addition to the repository. Set recurse to True to recursively add a directory's children. Set force to True to force operation to run. Set ignore to False to disregard default and svn:ignore property ignores. Files are added at the next checkin.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
file_annotation = \
annotate( url_or_path,
          revision_start=pysvn.Revision( opt_revision_kind.number, 0 ),
          revision_end=pysvn.Revision( opt_revision_kind.head ),
          peg_revision=pysvn.Revision( opt_revision_kind.unspecified ) )
 )
Return the annotation for each line in the url_or_path from revision_start to revision_end.
peg_revision indicates in which revision url_or_path is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
The file_annotation is a list of dictionaries. Each dictionary contains:
file_text = \
cat( url_or_path,
     revision=pysvn.Revision( opt_revision_kind.head ),
     peg_revision=pysvn.Revision( opt_revision_kind.unspecified ) )
Return the contents of url_or_path for the specified revision as a string, file_text.
peg_revision indicates in which revision url_or_path is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
revision = \
checkin( path,
        log_message,
        recurse=True,
        keep_locks=False,
        depth,
        keep_changelist,
        changelists,
        revprops )
revision = \
checkin( [path,path],
        log_message,
        recurse=True,
        keep_locks=False,
        depth,
        keep_changelist,
        changelists,
        revprops )
checkin the files in the path_list to the repository with the specifed log_message. Set recurse to True to recursively checkin a directory's children with the same log message. Set keep_locks to True to prevent locks in the path being unlocked.
checkin returns a pysvn.Revision containing the number of the checked in revision.
depth, keep_changelist, changelists, revprops TBD
revision = \
checkout( url,
          path,
          recurse=True,
          revision=pysvn.Revision( opt_revision_kind.head ),
          peg_revision=pysvn.Revision( opt_revision_kind.unspecified ),
          ignore_externals=False )
checkout the repository at url into the location specified by path. Set recurse to True to recursively check out a directory's children. Specify a revision to check out a particular version of the source tree. Set ignore_externals to True to ignore externals definitions.
peg_revision indicates in which revision url is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
checkout returns a pysvn.Revision containing the number of the checked out revision.
Note: Subversion seems to return 0 rather then the actual revision. Use a notify callback and record the revision reported for the pysvn.wc_notify_action.update_completed event. This is what the svn command does.
cleanup( path )
Clean up any locks in the working copy at path. Usually such locks are the result of a failed or interrupted operation.
copy( src_url_or_path,
      dest_url_or_path,
      src_revision=pysvn.Revision( opt_revision_kind.head ))
Duplicate something in working copy or repos, remembering history. The src_revision defaults to pysvn.Revision( opt_revision_kind.head ) if the src_path is a URL otherwise to pysvn.Revision( opt_revision_kind.working ).
src_url_or_path and dest_url_or_path can each be either a working copy (WC) path or URL:
If the destination is a URL the client_get_log_message callback must be implemented to return a log message.
copy2( sources,
       dest_url_or_path,
       copy_as_child=False,
       make_parents=False,
       revprops,
       ignore_externals=False )
Duplicate something in working copy or repos, remembering history. The src_revision defaults to pysvn.Revision( opt_revision_kind.head ) if the src_path is a URL otherwise to pysvn.Revision( opt_revision_kind.working ).
sources is a list of tuples of (url_or_path, rev), you can ommit rev by passing (url_or_path,). TBD better docs here.
revprops TBD
set ignore_externals to True to ignore externals.
src_url_or_path and dest_url_or_path can each be either a working copy (WC) path or URL:
If the destination is a URL the client_get_log_message callback must be implemented to return a log message.
diff_text = \
diff( tmp_path,
      url_or_path,
      revision1=pysvn.Revision( opt_revision_kind.base ),
      url_or_path2=url_or_path,
      revision2=pysvn.Revision( opt_revision_kind.working ),
      recurse=True,
      ignore_ancestry=False,
      diff_deleted=True,
      ignore_content_type=False,
      header_encoding="",
      diff_options=[],
      depth=depth,,
      relative_to_dir=None,
      changelists=None )
Return the differences between revision1 of url_or_path and revision2 of url_or_path2. diff_text is a string containing the diff output.
diff uses tmp_path to form the filename when creating any temporary files needed. The names are formed using tmp_path + unique_string + ".tmp". For example tmp_path=/tmp/diff_prefix will create files like /tmp/diff_prefix.tmp and /tmp/diff_prefix1.tmp.
Diff output will not be generated for binary files, unless ignore_content_type is true, in which case diffs will be shown regardless of the content types.
Generated headers are encoded using header_encoding.
The list of diff_options strings are passed to the external diff program that subversion uses. Typical options are -b (ignore space changes) and -w (ignore all white space). The exact options that work depend on the version of subversion used and its configuration.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
If relative_to_dir is not None, the original_path and modified_path will have the relative_to_dir stripped from the front of the respective paths.
If relative_to_dir is not None but relative_to_dir is not a parent path of the target, an error is returned.
diff_text = \
diff_peg( tmp_path,
          url_or_path,
          peg_revision=pysvn.Revision( opt_revision_kind.unspecified ),
          revision_start=pysvn.Revision( opt_revision_kind.base ),
          revision_end=pysvn.Revision( opt_revision_kind.working ),
          recurse=True,
          ignore_ancestry=False,
          diff_deleted=True,
          ignore_content_type=False,
          header_encoding="",
          diff_options=[],
          depth=depth )
return the differences between two revisions of the url_or_path. diff_text is a string containing the diff output.
diff uses tmp_path to form the filename when creating any temporary files needed. The names are formed using tmp_path + unique_string + ".tmp". For example tmp_path=/tmp/diff_prefix will create files like /tmp/diff_prefix.tmp and /tmp/diff_prefix1.tmp.
Set recurse to True to recursively diff a directory's children. diff_text is a string containing the diff.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
peg_revision indicates in which revision url_or_path is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
Diff output will not be generated for binary files, unless ignore_content_type is true, in which case diffs will be shown regardless of the content types.
Generated headers are encoded using header_encoding.
The list of diff_options strings are passed to the external diff program that subversion uses. Typical options are -b (ignore space changes) and -w (ignore all white space). The exact options that work depend on the version of subversion used and its configuration.
summary = \
diff_summarize( url_or_path1,
                revision1=pysvn.Revision( opt_revision_kind.base ),
                url_or_path2=url_or_path,
                revision2=pysvn.Revision( opt_revision_kind.working ),
                recurse=True,
                ignore_ancestry=False,
                depth=depth )
Produce a diff summary which lists the changed items between url_or_path1 revision1 and url_or_path2 revision2 without creating text deltas. url_or_path1 and url_or_path2 can be either working-copy paths or URLs.
The function may report false positives if ignore_ancestry is False, since a file might have been modified between two revisions, but still have the same contents.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
diff_text = \
diff_summarize_peg( url_or_path,
                    peg_revision=pysvn.Revision( opt_revision_kind.unspecified ),
                    revision_start=pysvn.Revision( opt_revision_kind.base ),
                    revision_end=pysvn.Revision( opt_revision_kind.working ),
                    recurse=True,
                    ignore_ancestry=False,
                    depth=depth )
Produce a diff summary which lists the changed items between the filesystem object url_or_path in peg revision peg_revision, as it changed between revision_start and revision_end. url_or_path can be either a working-copy path or URL.
If peg_revision is opt_revision_unspecified, behave identically to svn_client_diff_summarize(), using path for both of that function's url_or_path1 and url_or_path2 argments.
The function may report false positives if ignore_ancestry is False, as described in the documentation for diff_summarize().
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
revision = \
export( src_url_or_path,
        dest_path,
        force=False,
        revision=pysvn.Revision(),
        native_eol=None,
        ignore_externals=False,
        recurse=True,
        peg_revision=pysvn.Revision( opt_revision_kind.unspecified ),
        depth=depth,
        ignore_keywords=False )
Create an unversioned copy of the src_path at revision in dest_path. Set recurse to False to export a single file. Set ignore_externals to True to ignore externals definitions. Set ignore_keywords to True to prevnet keyword replacement.
peg_revision indicates in which revision src_url_or_path is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
native_eol parameter allows the line ending of files with svn:eol-style propery set to native to be overriden. Use None to use the eol-style of the Operating System, use "LF" to use "\n", "CR" to use "\r" and "CRLF" to use "\r\n".
export returns a pysvn.Revision containing the number of the checked in revision.
Note: The native_eol parameter is only available for svn 1.1.0 or later.
enabled = get_auth_cache()
return true if credential caching is enabled, otherwise return false.
enabled = get_auto_props()
Returns true if svn will automatically set properties when adding files, otherwise returns false.
changelist_list = \
get_changelist( path,
                changelist,
                depth=depth,
                changelists=[] )
TBD
The depth is one of the pysvn.depth enums.
password = get_default_password()
Returns None if no default is set otherwise returns the password as a string.
username = get_default_username()
Returns None if no default is set otherwise returns the username as a string.
enabled = get_interactive()
Returns true if svn will prompt for missing credential information, otherwise returns false.
enabled = get_store_passwords()
Returns true if svn will store passwords after prompting for them, otherwise returns false.
revision = \
import_( path,
         url,
         log_message,
         recurse=True,
         ignore=False,
         revprops )
Commit an unversioned file or tree into the repository.
Recursively commit a copy of PATH to URL. Parent directories are created as necessary in the repository. Set ignore to False to disregard default and svn:ignore property ignores.
revprops TBD
import_ returns a pysvn.Revision containing the number of the checked in revision.
entry = info( path )
return information on path as a Entry object.
entry_list = \
info2( url_or_path,
       revision=pysvn.Revision( opt_revision_kind.unspecified ),
       peg_revision=pysvn.Revision( opt_revision_kind.unspecified ),
       recurse=True,
       depth=depth )
return information on url_or_path as a list of (path, info_dict) tuples. To return information about a URL revision must be opt_revision_kind.head or opt_revision_kind.number.
peg_revision indicates in which revision url_or_path is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
The info_dict contains:
Note: The info2 command is only available with svn 1.2.0 or later.
rc = \ is_adm_dir( name )
Return True is the name is an subversion admin directory.
root_url = \
    root_url_from_path( url_or_path )
Return the root URL of the repository given the url_or_path.
rc = \ is_url( url )
return True if the url is a known subversion url.
entries_list = \
list( url_or_path,
      peg_revision=pysvn.Revision( opt_revision_kind.unspecified ) )
      revision=pysvn.Revision( opt_revision_kind.head ),
      recurse=True,
      dirent_fields=pysvn.SVN_DIRENT_ALL,
      fetch_locks=False,
      depth=depth )
Returns a list with a tuple of information for each file in the given path at the provided revision.
peg_revision indicates in which revision url_or_path is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
dirent_fields controls which dirent fields will return. Use pysvn.SVN_DIRENT_ALL to return all fields. Bit-wise or one of these values to return only the selected fields:
The tuple contains:
The PysvnList object contains the requested dirent fields:
The PysvnList object obtains the lock information:
lock( url_or_path,
      lock_comment, 
      force=False )
lock the url_or_path with lock_comment. Set force to True to override any lock held by another user.
log_messages = \
log( url_or_path,
     revision_start=pysvn.Revision( opt_revision_kind.head ),
     revision_end=pysvn.Revision( opt_revision_kind.number, 0 ),
     discover_changed_paths=False,
     strict_node_history=True,
     limit=0,
     peg_revision=pysvn.Revision( opt_revision_kind.unspecified ),
     include_merged_revisions=False,
     revprops=list_of_revprop_names )
Return the log messages for the specified url_or_path between revisions start and end. Set limit to the maximum number of log messages to be returned, 0 means return all messages.
If discover_changed_paths is set, the changed_paths dictionary entry is filled with a list of changed paths. If strict_node_history is set, log entries will not cross copies.
If url_or_path no longer exists in the repos of WC then pass in a peg_revision of a revision where it did exist.
include_merged_revisions TBD
revprops is a list of strings that name the revprops to be returned.
log returns a list of log entries; each log entry is a dictionary. The dictionary contains:
entries_list = \
ls( url_or_path,
    revision=pysvn.Revision( opt_revision_kind.head ),
    recurse=True,
    peg_revision=pysvn.Revision( opt_revision_kind.unspecified ) )
Use the list method in new code as it fixes performance and ambiguity problems with the ls method.
Returns a list of dictionaries for each file the given path at the provided revision.
peg_revision indicates in which revision url_or_path is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
The dictionary contains:
merge( url_or_path1,
       revision1,
       url_or_path2,
       revision2,
       local_path,
       force=False,
       recurse=True,
       notice_ancestry=False,
       dry_run=False,,
       depth=depth,
       record_only=False,
       merge_options=[] )
Apply the differences between two sources to a working copy path.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
merge_options (a list of strings), is used to pass additional command line arguments to the merge processes (internal or external).
The internal subversion diff supports the following options:
merge_peg( url_or_path,
           revision1,
           revision2,
           peg_revision,
           local_path,
           recurse=True,
           notice_ancestry,
           force=False,
           dry_run=False,
           depth=depth,
           record_only=False,
           merge_options=[] )
Apply the differences between two sources to a working copy path.
peg_revision indicates in which revision url_or_path is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
merge_options (a list of strings), is used to pass additional command line arguments to the merge processes (internal or external).
The internal subversion diff supports the following options:
merge_peg2( sources,
            ranges_to_merge,
            peg_revision,
            tareget_wcpath,
            depth=depth,
            notice_ancestry=False,
            force=False,
            dry_run=False,
            record_only=True,
            merge_options=[] )
Apply the differences between the ranges_to_merge in sources to a working copy path, target_wcpath. ranges_to_merge is a list of tuples with the start and end revisions to be merged.
peg_revision indicates in which revision url_or_path is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
The depth is one of the pysvn.depth enums.
merge_options (a list of strings), is used to pass additional command line arguments to the merge processes (internal or external).
The internal subversion diff supports the following options:
merge_reintegrate( url_or_path,
                   revision,
                   local_path,
                   dry_run=False,
                   merge_options=[] )
Lump-merge all of url_or_path unmerged changes into local_path.
merge_options (a list of strings), is used to pass additional command line arguments to the merge processes (internal or external).
The internal subversion diff supports the following options:
mkdir( url_or_path,
       log_message,
       make_parents,
       revprops )
mkdir( [url_or_path,url_or_path],
       log_message,
       make_parents,
       revprops )
Create a new directory under revision control.
url_or_path can be a list of URLs and paths
make_parents and revprops TBD
If url_or_path is a path, each directory is scheduled for addition upon the next commit.
If url_or_path is a URL, the directories are created in the repository via an immediate commit.
In both cases, all the intermediate directories must already exist.
move( src_url_or_path,
      dest_url_or_path,
      force=False )
Move (rename) something in working copy or HEAD revision of repository.
NOTE: this command is equivalent to a 'copy' and 'delete'.
src_path and dest_path can both be working copy (WC) paths or URLs:
If src_url_or_path is a path, each item is scheduled for deletion upon the next commit. Files, and directories that have not been committed, are immediately removed from the working copy. The command will not remove PATHs that are, or contain, unversioned or modified items; set force=True to override this behaviour.
If src_url_or_path is a URL, the items are deleted from the repository via an immediate commit.
move2( sources,
       dest_url_or_path,
       move_as_child=False,
       make_parents=False,
       revprops )
Duplicate something in working copy or repos, remembering history. The src_revision defaults to pysvn.Revision( opt_revision_kind.head ) if the src_path is a URL otherwise to pysvn.Revision( opt_revision_kind.working ).
revprops TBD
src_url_or_path and dest_url_or_path can each be either a working copy (WC) path or URL:
If the destination is a URL the client_get_log_message callback must be implemented to return a log message.
svn_client_patch(patch_abspath,
                 wc_dir_abspath,
                 dry_run=False,
                 strip_count=0,
                 reverse=False,
                 ignore_whitespace=False,
                 remove_tempfiles=False)
Apply a unidiff patch that's located at absolute path patch_abspath to the working copy directory at wc_dir_abspath.
This function makes a best-effort attempt at applying the patch. It might skip patch targets which cannot be patched (e.g. targets that are outside of the working copy). It will also reject hunks which cannot be applied to a target in case the hunk's context does not match anywhere in the patch target.
If dry_run is True, the patching process is carried out, and full notification feedback is provided, but the working copy is not modified.
strip_count specifies how many leading path components should be stripped from paths obtained from the patch. It is an error if a negative strip count is passed.
If reverse is True, apply patches in reverse, deleting lines the patch would add and adding lines the patch would delete.
If ignore_whitespace is True, allow patches to be applied if they only differ from the target by whitespace.
If remove_tempfiles is True, lifetimes of temporary files created during patching will be managed internally. Otherwise, the caller should take ownership of these files, the names of which can be obtained by passing a patch_func callback.
If notify_func is not None, invoke notify_func as patching progresses.
If cancel_func is not None, invoke it at various places during the operation.
rev = \
propdel( prop_name,
         url_or_path,
         revision=pysvn.Revision(),
         recurse=False,
         skip_checks=False,
         depth=depth,
         base_revision_for_url=[0 for URL, -1 for path],
         revprops )
Delete the property prop_name from url_or_path.
If skip_checks is true, do no validity checking. But if skip_checks is false, and propname is not a valid property for target, return an error, either SVN_ERR_ILLEGAL_TARGET (if the property is not appropriate for target), or SVN_ERR_BAD_MIME_TYPE (if propname is "svn:mime-type", but propval is not a valid mime-type).
The url_or_path may only be an URL if base_revision_for_url is not -1; in this case, the property will only be set if it has not changed since revision base_revision_for_url. base_revision_for_url must be -1 if url_or_path is not an URL.
The src_revision defaults to pysvn.Revision( opt_revision_kind.head ) if the src_path is a URL otherwise to pysvn.Revision( opt_revision_kind.working ).
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
revprops TBD
prop_list = \
propget( prop_name,
         url_or_path,
         revision=pysvn.Revision(),
         recurse=False,
         peg_revision=pysvn.Revision( opt_revision_kind.unspecified ),
         depth=depth )
Returns a dictionary with keys of url_or_path and values of the prop_name.
The src_revision defaults to pysvn.Revision( opt_revision_kind.head ) if the url_or_path is a URL otherwise to pysvn.Revision( opt_revision_kind.working ).
peg_revision indicates in which revision url_or_path is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
prop_list = \
proplist( url_or_path,
          revision=pysvn.Revision(),
          recurse=False,
          peg_revision=pysvn.Revision( opt_revision_kind.unspecified ),
          depth=depth )
Returns a list of tuples (path, prop_dict). The prop_dict contains the prop_names and their values if set on the path.
The src_revision defaults to pysvn.Revision( opt_revision_kind.head ) if the url_or_path is a URL otherwise to pysvn.Revision( opt_revision_kind.working ).
peg_revision indicates in which revision url_or_path is valid. If peg_revision.kind is opt_revision_kind.unspecified, then it defaults to opt_revision_kind.head for URLs or opt_revision_kind.working for WC targets.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
commit_info = \ propset( prop_name, prop_value, url_or_path, revision=pysvn.Revision(), recurse=False, skip_checks=False, depth=depth, base_revision_for_url=[0 for URL, -1 for path], allow_unver_obstructions=False, revprops )
Set the property prop_name to prop_value in url_or_path.
If skip_checks is true, do no validity checking. But if skip_checks is false, and propname is not a valid property for target, return an error, either SVN_ERR_ILLEGAL_TARGET (if the property is not appropriate for target), or SVN_ERR_BAD_MIME_TYPE (if propname is "svn:mime-type", but propval is not a valid mime-type).
The revision defaults to pysvn.Revision( opt_revision_kind.head ) if the url_or_path is a URL otherwise to pysvn.Revision( opt_revision_kind.working ).
The url_or_path may only be an URL if base_revision_for_url is not -1; in this case, the property will only be set if it has not changed since revision base_revision_for_url. base_revision_for_url must be -1 if url_or_path is not an URL.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
If allow_unver_obstructions is False then the update will abort if there are any unversioned obstructing items.
revprops TBD
relocate( from_url,
          to_url,
          path,
          recurse=True,
          depth=depth )
Relocate the working copy from from_url to to_url of path.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
remove( url_or_path_list,
        force=False,
        keep_local=False,
        revprops )
If url_or_path is a path, each item is scheduled for deletion upon the next commit. Files, and directories that have not been committed, are immediately removed from the working copy. The command will not remove paths that are, or contain, unversioned or modified items; set force=True to override this behaviour.
Set keep_local to True to prevent the local file from being delete.
revprops TBD
If url_or_path is a URL, the items are deleted from the repository via an immediate commit.
remove_from_changelists( path,
                         changelist,
                         depth=pysvn.depth.infinite,
                         changelists=[] )
TBD
resolved( path,
          recurse=True,
          depth=depth )
Mark the conflicted file at path as resolved.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
revert( path,
        recurse=False,
        depth=depth )
revert( [path,path],
        recurse=False,
        depth=depth )
Discard any changes in the working copy at path. Set recurse to True to recursively revert a directory's children.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
rev = \
revpropdel( prop_name,
            url,
            revision=pysvn.Revision( opt_revision_kind.head ),
            force=False )
Delete the revision property prop_name from url.
rev_prop = \
revpropget( prop_name,
            url,
            revision=pysvn.Revision( opt_revision_kind.head ) )
Returns a tuple (rev, prop_val) where the prop_val contains the revision property value.
rev_prop_dict = \
revproplist( url,
             revision=pysvn.Revision( opt_revision_kind.head ) )
Returns a tuple (revision, prop_dict) where the prop_dict contains the revision properies and their values.
rev = \
revpropset( prop_name,
            prop_value,
            url,
            revision=pysvn.Revision( opt_revision_kind.head ),
            force=False )
set the revision property prop_name to prop_value in path. The revision updated is returned.
set_adm_dir( name )
Set the name of the subverion admin directory. ".svn" is the normal admin dir use and "_svn" is used on Windows to work around problems with .NET.
set_auth_cache( enable )
When enable is True subversion will remember authentication credentials in the configuration directory.
set_auto_props( enable )
When enabled, subversion will automatically set properties when adding files; otherwise when disabled it will not.
set_default_password( password )
Set the default password to be used if there is no stored password.
set_default_username( username )
Set the default username to be used if there is no stored username.
set_interactive( enable )
When enable is True subversion will prompt for authentication credentials when there are no valid store credentials.
set_store_passwords( enable )
When enable is True subversion will store any passwords that subversion prompted for.
status_list = \
status( path,
        recurse=True,
        get_all=True,
        update=False,
        ignore=False,
        ignore_externals=False,
        depth=depth )
If path is a directory status is returned for all files in the directory in status_list. If path is a single file status is returned for that single file in status_list. Set ignore_externals to True to ignore externals definitions.
The status_list is a list of PysvnStatus objects.
Options:
depth - can be used as in place of recurse. depth is one of the pysvn.depth enums.
switch( path,
        url,
        recurse=True,
        revision=pysvn.Revision( opt_revision_kind.head ),
        depth=depth,
        peg_revision=revision,
        depth_is_sticky=False,
        ignore_externals=False,
        allow_unver_obstructions=False )
Update the working copy to a different URL.
The depth can be used as in place of recurse. depth is one of the pysvn.depth enums.
If depth_is_sticky is set and depth is not svn_depth_unknown, then in addition to switching PATH, also set its sticky ambient depth value to @a depth.
If ignore_externals is set, do not process externals definitions as part of this operation.
If allow_unver_obstructions is True then the switch tolerates existing unversioned items that obstruct added paths. Only obstructions of the same type (file or dir) as the added item are tolerated. The text of obstructing files is left as-is, effectively treating it as a user modification after the switch. Working properties of obstructing items are set equal to the base properties.
If allow_unver_obstructions is False then the switch will abort if there are any unversioned obstructing items.
unlock( url_or_path,
        force=False )
Unlock the url_or_path. Set force to True to unlock any lock held by another user.
revision = \
update( path,
        recurse=True,
        revision=pysvn.Revision( opt_revision_kind.head ),
        ignore_externals=False,
        depth=depth )
Update the file in the working copy at path to the specified revision. Set recurse to True to recursively update a directory's children. Set ignore_externals to True to ignore externals definitions.
path can be a single path string or a list of path strings.
The depth can be used in place of recurse. depth is one of the pysvn.depth enums. Use pysvn.depth.unknown to update all files and folders in the working copy honoring the current depths. Use pysvn.depth.infinity to upadate all files and folders adding any that are missing ignoring the current depths.
update returns a pysvn.Revision containing the number of the revision the working copy was updated to.
This command is typically used to get the latest changes from the repository.
Note: updating to an older revision does not change the current revision. To make the current version identical to an older revision, use a merge followed by a commit.
upgrade( path )
Recursively upgrade a working copy from any older format to the current WC metadata storage format. path is the path to the WC root.
Interface summary:
transaction = pysvn.Transaction() transaction = pysvn.Transaction( repos_path, transaction_name, [is_revision=False] )
The Transaction object allows you to implement hook code for the SVN repository. The pre-commit and pre-revprop-change hooks are the only hooks that are currently appropriate in SVN. See the SVN documentation for details on hook scripts.
A Transaction object can only be used on one thread at a time. If two threads attempt to call methods of Transaction at the same time one of the threads will get a pysvn.TransactionError exception with the value 'transaction in use on another thread'.
When the optional parameter is_revision is True, than the transaction_name parameter will be interpreted as a revision number and all subsequent operation will be performed on this revision. Note that the propdel and propset operations will fail than. This option lets you use the Transation object to write post-commit hooks with the same API than pre-commit hooks, and lets you easily test your pre-commit hook on revisions.
| cat | changed | list | ||
| propdel | propget | proplist | propset | |
| revpropdel | revpropget | revproplist | revpropset | 
file_text = \ cat( path )
Return the contents of path as a string, file_text.
file_text = \ changed( [copy_info=False] )
Return a dict of all changes in the transaction. The keys in the dict are the path names and the values are tuples containing action, kind, text_mod, prop_mod.
The optional copy_info parameter when True will return the copy from revision and copy from path information.
path_content = list( [path] )
Return a dict of all entries in the directory 'path'. The keys in the dict are the path names and the value contains the kind (one of the pysvn.node_kind values). If 'path' is not given the root of the repository will be examined. This is a same as '' and '/' as path.
propdel( prop_name,
         path )
Delete the property prop_name from path in the transaction.
prop_value = \
propget( prop_name,
         path )
Returns the prop_value as a string or None if the prop_name is not in the transaction.
prop_dict = \ proplist( path )
Returns a prop_dict. The prop_dict contains the prop_names and their values if set on the path in the transaction.
propset( prop_name,
         prop_value,
         path )
Set the property prop_name to prop_value in path in the transaction.
revpropdel( prop_name )
Delete the revision property prop_name in the transaction.
prop_val = \ revpropget( prop_name )
Returns the prop_val with the revision property value or None if not set in the transaction.
prop_dict = \ revproplist()
Returns a prop_dict where the prop_dict contains the revision properies and their values in the transaction.
rev = \
revpropset( prop_name,
            prop_value )
set the revision property prop_name to prop_value in path in the transaction. The revision updated is returned.
The Revision object has three member variables:
Interface summary:
import pysvn import time revhead = pysvn.Revision( pysvn.opt_revision_kind.head ) revdate = pysvn.Revision( pysvn.opt_revision_kind.date, time.time() ) revnum = pysvn.Revision( pysvn.opt_revision_kind.number, 4721 )
ClientError exception is raised when any of the subversion functions called by pysvn return an error.
The Client.exception_style variable controls the information stored in the ClientError object.
The args property is set to a single string parameter containing the whole error message. '\n' is used to seperate message parts.
Use str() to get the string description of the exception raised by pysvn.
import pysvn
client = pysvn.Client()
client.exception_style = 0
try:
    client.update( '.' )
except pysvn.ClientError, e:
    # convert to a string
    print str(e)
    # or access the string in args directly
    print e.args
The arg property is set to a tuple contain two values.
arg[0] is set to a string parameter containing the whole error message. '\n' is used to seperate message parts.
arg[1] is set to a list of tuples containing the message string and the error code. The error code values are defined by SVN and APR.
import pysvn
client = pysvn.Client()
client.exception_style = 1
try:
    client.update( '' )
except pysvn.ClientError, e:
    # print the whole message
    print e.args[0]
    # or process the error list
    for message, code in e.args[1]:
        print 'Code:',code,'Message:',message
Each status object has the following fields:
Copyright © 2004-2009 Barry A. Scott. All rigths reserved.