Alien-SVN
view release on metacpan or search on metacpan
src/subversion/subversion/include/svn_repos.h view on Meta::CPAN
const char *
svn_repos_post_commit_hook(svn_repos_t *repos,
apr_pool_t *pool);
/** Return the path to @a repos's pre-revprop-change hook, allocated in
* @a pool.
*/
const char *
svn_repos_pre_revprop_change_hook(svn_repos_t *repos,
apr_pool_t *pool);
/** Return the path to @a repos's post-revprop-change hook, allocated in
* @a pool.
*/
const char *
svn_repos_post_revprop_change_hook(svn_repos_t *repos,
apr_pool_t *pool);
/** @defgroup svn_repos_lock_hooks Paths to lock hooks
* @{
* @since New in 1.2. */
/** Return the path to @a repos's pre-lock hook, allocated in @a pool. */
const char *
svn_repos_pre_lock_hook(svn_repos_t *repos,
apr_pool_t *pool);
/** Return the path to @a repos's post-lock hook, allocated in @a pool. */
const char *
svn_repos_post_lock_hook(svn_repos_t *repos,
apr_pool_t *pool);
/** Return the path to @a repos's pre-unlock hook, allocated in @a pool. */
const char *
svn_repos_pre_unlock_hook(svn_repos_t *repos,
apr_pool_t *pool);
/** Return the path to @a repos's post-unlock hook, allocated in @a pool. */
const char *
svn_repos_post_unlock_hook(svn_repos_t *repos,
apr_pool_t *pool);
/** Specify that Subversion should consult the configuration file
* located at @a hooks_env_path to determine how to setup the
* environment for hook scripts invoked for the repository @a repos.
* As a special case, if @a hooks_env_path is @c NULL, look for the
* file in its default location within the repository disk structure.
* If @a hooks_env_path is not absolute, it specifies a path relative
* to the parent of the file's default location.
*
* Use @a scratch_pool for temporary allocations.
*
* If this function is not called, or if the specified configuration
* file does not define any environment variables, hooks will run in
* an empty environment.
*
* @since New in 1.8.
*/
svn_error_t *
svn_repos_hooks_setenv(svn_repos_t *repos,
const char *hooks_env_path,
apr_pool_t *scratch_pool);
/** @} */
/* ---------------------------------------------------------------*/
/* Reporting the state of a working copy, for updates. */
/**
* Construct and return a @a report_baton that will be passed to the
* other functions in this section to describe the state of a pre-existing
* tree (typically, a working copy). When the report is finished,
* @a editor/@a edit_baton will be driven in such a way as to transform the
* existing tree to @a revnum and, if @a tgt_path is non-NULL, switch the
* reported hierarchy to @a tgt_path.
*
* @a fs_base is the absolute path of the node in the filesystem at which
* the comparison should be rooted. @a target is a single path component,
* used to limit the scope of the report to a single entry of @a fs_base,
* or "" if all of @a fs_base itself is the main subject of the report.
*
* @a tgt_path and @a revnum is the fs path/revision pair that is the
* "target" of the delta. @a tgt_path should be provided only when
* the source and target paths of the report differ. That is, @a tgt_path
* should *only* be specified when specifying that the resultant editor
* drive be one that transforms the reported hierarchy into a pristine tree
* of @a tgt_path at revision @a revnum. A @c NULL value for @a tgt_path
* will indicate that the editor should be driven in such a way as to
* transform the reported hierarchy to revision @a revnum, preserving the
* reported hierarchy.
*
* @a text_deltas instructs the driver of the @a editor to enable
* the generation of text deltas.
*
* @a ignore_ancestry instructs the driver to ignore node ancestry
* when determining how to transmit differences.
*
* @a send_copyfrom_args instructs the driver to send 'copyfrom'
* arguments to the editor's add_file() and add_directory() methods,
* whenever it deems feasible.
*
* Use @a authz_read_func and @a authz_read_baton (if not @c NULL) to
* avoid sending data through @a editor/@a edit_baton which is not
* authorized for transmission.
*
* @a zero_copy_limit controls the maximum size (in bytes) at which
* data blocks may be sent using the zero-copy code path. On that
* path, a number of in-memory copy operations have been eliminated to
* maximize throughput. However, until the whole block has been
* pushed to the network stack, other clients block, so be careful
* when using larger values here. Pass 0 for @a zero_copy_limit to
* disable this optimization altogether.
*
* @a note Never activate this optimization if @a editor might access
* any FSFS data structures (and, hence, caches). So, it is basically
* safe for networked editors only.
*
* All allocation for the context and collected state will occur in
( run in 0.682 second using v1.01-cache-2.11-cpan-cdf2f3d4e48 )