3 * ====================================================================
4 * Copyright (c) 2000-2008 CollabNet. All rights reserved.
6 * This software is licensed as described in the file COPYING, which
7 * you should have received as part of this distribution. The terms
8 * are also available at http://subversion.tigris.org/license-1.html.
9 * If newer versions of this license are posted there, you may use a
10 * newer version instead, at your option.
12 * This software consists of voluntary contributions made by many
13 * individuals. For exact contribution history, see the revision
14 * history and logs, available at http://subversion.tigris.org/.
15 * ====================================================================
19 * @brief tools built on top of the filesystem.
26 #include <apr_pools.h>
29 #include "svn_delta.h"
30 #include "svn_types.h"
31 #include "svn_error.h"
32 #include "svn_version.h"
37 #endif /* __cplusplus */
39 /* ---------------------------------------------------------------*/
42 * Get libsvn_repos version information.
46 const svn_version_t
*svn_repos_version(void);
50 /** Callback type for checking authorization on paths produced by (at
51 * least) svn_repos_dir_delta2().
53 * Set @a *allowed to TRUE to indicate that some operation is
54 * authorized for @a path in @a root, or set it to FALSE to indicate
55 * unauthorized (presumably according to state stored in @a baton).
57 * Do not assume @a pool has any lifetime beyond this call.
59 * The exact operation being authorized depends on the callback
60 * implementation. For read authorization, for example, the caller
61 * would implement an instance that does read checking, and pass it as
62 * a parameter named [perhaps] 'authz_read_func'. The receiver of
63 * that parameter might also take another parameter named
64 * 'authz_write_func', which although sharing this type, would be a
65 * different implementation.
67 * @note If someday we want more sophisticated authorization states
68 * than just yes/no, @a allowed can become an enum type.
70 typedef svn_error_t
*(*svn_repos_authz_func_t
)(svn_boolean_t
*allowed
,
77 /** An enum defining the kinds of access authz looks up.
86 /** Path can be read. */
89 /** Path can be altered. */
92 /** The other access credentials are recursive. */
93 svn_authz_recursive
= 4
94 } svn_repos_authz_access_t
;
97 /** Callback type for checking authorization on paths produced by
98 * the repository commit editor.
100 * Set @a *allowed to TRUE to indicate that the @a required access on
101 * @a path in @a root is authorized, or set it to FALSE to indicate
102 * unauthorized (presumable according to state stored in @a baton).
104 * If @a path is NULL, the callback should perform a global authz
105 * lookup for the @a required access. That is, the lookup should
106 * check if the @a required access is granted for at least one path of
107 * the repository, and set @a *allowed to TRUE if so. @a root may
108 * also be NULL if @a path is NULL.
110 * This callback is very similar to svn_repos_authz_func_t, with the
111 * exception of the addition of the @a required parameter.
112 * This is due to historical reasons: when authz was first implemented
113 * for svn_repos_dir_delta2(), it seemed there would need only checks
114 * for read and write operations, hence the svn_repos_authz_func_t
115 * callback prototype and usage scenario. But it was then realized
116 * that lookups due to copying needed to be recursive, and that
117 * brute-force recursive lookups didn't square with the O(1)
118 * performances a copy operation should have.
120 * So a special way to ask for a recursive lookup was introduced. The
121 * commit editor needs this capability to retain acceptable
122 * performance. Instead of revving the existing callback, causing
123 * unnecessary revving of functions that don't actually need the
124 * extended functionality, this second, more complete callback was
125 * introduced, for use by the commit editor.
127 * Some day, it would be nice to reunite these two callbacks and do
128 * the necessary revving anyway, but for the time being, this dual
129 * callback mechanism will do.
131 typedef svn_error_t
*(*svn_repos_authz_callback_t
)
132 (svn_repos_authz_access_t required
,
133 svn_boolean_t
*allowed
,
140 * Similar to @c svn_file_rev_handler_t, but without the @a
141 * result_of_merge parameter.
143 * @deprecated Provided for backward compatibility with 1.4 API.
146 typedef svn_error_t
*(*svn_repos_file_rev_handler_t
)
150 apr_hash_t
*rev_props
,
151 svn_txdelta_window_handler_t
*delta_handler
,
153 apr_array_header_t
*prop_diffs
,
157 /** The repository object. */
158 typedef struct svn_repos_t svn_repos_t
;
160 /* Opening and creating repositories. */
163 /** Find the root path of the repository that contains @a path.
165 * If a repository was found, the path to the root of the repository
166 * is returned, else @c NULL. The pointer to the returned path may be
170 svn_repos_find_root_path(const char *path
,
173 /** Set @a *repos_p to a repository object for the repository at @a path.
175 * Allocate @a *repos_p in @a pool.
177 * Acquires a shared lock on the repository, and attaches a cleanup
178 * function to @a pool to remove the lock. If no lock can be acquired,
179 * returns error, with undefined effect on @a *repos_p. If an exclusive
180 * lock is present, this blocks until it's gone.
183 svn_repos_open(svn_repos_t
**repos_p
,
187 /** Create a new Subversion repository at @a path, building the necessary
188 * directory structure, creating the filesystem, and so on.
189 * Return the repository object in @a *repos_p, allocated in @a pool.
191 * @a config is a client configuration hash of @c svn_config_t * items
192 * keyed on config category names, and may be NULL.
194 * @a fs_config is passed to the filesystem, and may be NULL.
196 * @a unused_1 and @a unused_2 are not used and should be NULL.
199 svn_repos_create(svn_repos_t
**repos_p
,
201 const char *unused_1
,
202 const char *unused_2
,
204 apr_hash_t
*fs_config
,
208 * Upgrade the Subversion repository (and its underlying versioned
209 * filesystem) located in the directory @a path to the latest version
210 * supported by this library. If the requested upgrade is not
211 * supported due to the current state of the repository or it
212 * underlying filesystem, return @c SVN_ERR_REPOS_UNSUPPORTED_UPGRADE
213 * or @c SVN_ERR_FS_UNSUPPORTED_UPGRADE (respectively) and make no
214 * changes to the repository or filesystem.
216 * Acquires an exclusive lock on the repository, upgrades the
217 * repository, and releases the lock. If an exclusive lock can't be
218 * acquired, returns error.
220 * If @a nonblocking is TRUE, an error of type EWOULDBLOCK is
221 * returned if the lock is not immediately available.
223 * If @a start_callback is not NULL, it will be called with @a
224 * start_callback_baton as argument before the upgrade starts, but
225 * after the exclusive lock has been acquired.
227 * Use @a pool for necessary allocations.
229 * @note This functionality is provided as a convenience for
230 * administrators wishing to make use of new Subversion functionality
231 * without a potentially costly full repository dump/load. As such,
232 * the operation performs only the minimum amount of work needed to
233 * accomplish this while maintaining the integrity of the repository.
234 * It does *not* guarantee the most optimized repository state as a
235 * dump and subsequent load would.
240 svn_repos_upgrade(const char *path
,
241 svn_boolean_t nonblocking
,
242 svn_error_t
*(*start_callback
)(void *baton
),
243 void *start_callback_baton
,
246 /** Destroy the Subversion repository found at @a path, using @a pool for any
247 * necessary allocations.
249 svn_error_t
*svn_repos_delete(const char *path
, apr_pool_t
*pool
);
252 * Set @a *has to TRUE if @a repos has @a capability (one of the
253 * capabilities beginning with @c "SVN_REPOS_CAPABILITY_"), else set
256 * If @a capability isn't recognized, throw @c SVN_ERR_UNKNOWN_CAPABILITY,
257 * with the effect on @a *has undefined.
259 * Use @a pool for all allocation.
264 svn_repos_has_capability(svn_repos_t
*repos
,
266 const char *capability
,
270 * The capability of doing the right thing with merge-tracking
271 * information, both storing it and responding to queries about it.
275 #define SVN_REPOS_CAPABILITY_MERGEINFO "mergeinfo"
276 /* *** PLEASE READ THIS IF YOU ADD A NEW CAPABILITY ***
278 * @c SVN_REPOS_CAPABILITY_foo strings should not include colons, to
279 * be consistent with @c SVN_RA_CAPABILITY_foo strings, which forbid
280 * colons for their own reasons. While this RA limitation has no
281 * direct impact on repository capabilities, there's no reason to be
282 * gratuitously different either.
286 /** Return the filesystem associated with repository object @a repos. */
287 svn_fs_t
*svn_repos_fs(svn_repos_t
*repos
);
290 /** Make a hot copy of the Subversion repository found at @a src_path
293 * Copy a possibly live Subversion repository from @a src_path to
294 * @a dst_path. If @a clean_logs is @c TRUE, perform cleanup on the
295 * source filesystem as part of the copy operation; currently, this
296 * means deleting copied, unused logfiles for a Berkeley DB source
300 svn_repos_hotcopy(const char *src_path
,
301 const char *dst_path
,
302 svn_boolean_t clean_logs
,
306 * Run database recovery procedures on the repository at @a path,
307 * returning the database to a consistent state. Use @a pool for all
310 * Acquires an exclusive lock on the repository, recovers the
311 * database, and releases the lock. If an exclusive lock can't be
312 * acquired, returns error.
314 * If @a nonblocking is TRUE, an error of type EWOULDBLOCK is
315 * returned if the lock is not immediately available.
317 * If @a start_callback is not NULL, it will be called with @a
318 * start_callback_baton as argument before the recovery starts, but
319 * after the exclusive lock has been acquired.
321 * If @a cancel_func is not @c NULL, it is called periodically with
322 * @a cancel_baton as argument to see if the client wishes to cancel
325 * @note On some platforms the exclusive lock does not exclude other
326 * threads in the same process so this function should only be called
327 * by a single threaded process, or by a multi-threaded process when
328 * no other threads are accessing the repository.
333 svn_repos_recover3(const char *path
,
334 svn_boolean_t nonblocking
,
335 svn_error_t
*(*start_callback
)(void *baton
),
336 void *start_callback_baton
,
337 svn_cancel_func_t cancel_func
,
342 * Similar to svn_repos_recover3(), but without cancellation support.
344 * @deprecated Provided for backward compatibility with the 1.4 API.
347 svn_repos_recover2(const char *path
,
348 svn_boolean_t nonblocking
,
349 svn_error_t
*(*start_callback
)(void *baton
),
350 void *start_callback_baton
,
354 * Similar to svn_repos_recover2(), but with nonblocking set to FALSE, and
355 * with no callbacks provided.
357 * @deprecated Provided for backward compatibility with the 1.0 API.
359 svn_error_t
*svn_repos_recover(const char *path
, apr_pool_t
*pool
);
361 /** This function is a wrapper around svn_fs_berkeley_logfiles(),
362 * returning log file paths relative to the root of the repository.
364 * @copydoc svn_fs_berkeley_logfiles()
367 svn_repos_db_logfiles(apr_array_header_t
**logfiles
,
369 svn_boolean_t only_unused
,
374 /* Repository Paths */
376 /** Return the top-level repository path allocated in @a pool. */
377 const char *svn_repos_path(svn_repos_t
*repos
, apr_pool_t
*pool
);
379 /** Return the path to @a repos's filesystem directory, allocated in
382 const char *svn_repos_db_env(svn_repos_t
*repos
, apr_pool_t
*pool
);
384 /** Return path to @a repos's config directory, allocated in @a pool. */
385 const char *svn_repos_conf_dir(svn_repos_t
*repos
, apr_pool_t
*pool
);
387 /** Return path to @a repos's svnserve.conf, allocated in @a pool. */
388 const char *svn_repos_svnserve_conf(svn_repos_t
*repos
, apr_pool_t
*pool
);
390 /** Return path to @a repos's lock directory, allocated in @a pool. */
391 const char *svn_repos_lock_dir(svn_repos_t
*repos
, apr_pool_t
*pool
);
393 /** Return path to @a repos's db lockfile, allocated in @a pool. */
394 const char *svn_repos_db_lockfile(svn_repos_t
*repos
, apr_pool_t
*pool
);
396 /** Return path to @a repos's db logs lockfile, allocated in @a pool. */
397 const char *svn_repos_db_logs_lockfile(svn_repos_t
*repos
, apr_pool_t
*pool
);
399 /** Return the path to @a repos's hook directory, allocated in @a pool. */
400 const char *svn_repos_hook_dir(svn_repos_t
*repos
, apr_pool_t
*pool
);
402 /** Return the path to @a repos's start-commit hook, allocated in @a pool. */
403 const char *svn_repos_start_commit_hook(svn_repos_t
*repos
, apr_pool_t
*pool
);
405 /** Return the path to @a repos's pre-commit hook, allocated in @a pool. */
406 const char *svn_repos_pre_commit_hook(svn_repos_t
*repos
, apr_pool_t
*pool
);
408 /** Return the path to @a repos's post-commit hook, allocated in @a pool. */
409 const char *svn_repos_post_commit_hook(svn_repos_t
*repos
, apr_pool_t
*pool
);
411 /** Return the path to @a repos's pre-revprop-change hook, allocated in
415 svn_repos_pre_revprop_change_hook(svn_repos_t
*repos
,
418 /** Return the path to @a repos's post-revprop-change hook, allocated in
422 svn_repos_post_revprop_change_hook(svn_repos_t
*repos
,
426 /** @defgroup svn_repos_lock_hooks Paths to lock hooks
428 * @since New in 1.2. */
430 /** Return the path to @a repos's pre-lock hook, allocated in @a pool. */
431 const char *svn_repos_pre_lock_hook(svn_repos_t
*repos
, apr_pool_t
*pool
);
433 /** Return the path to @a repos's post-lock hook, allocated in @a pool. */
434 const char *svn_repos_post_lock_hook(svn_repos_t
*repos
, apr_pool_t
*pool
);
436 /** Return the path to @a repos's pre-unlock hook, allocated in @a pool. */
437 const char *svn_repos_pre_unlock_hook(svn_repos_t
*repos
, apr_pool_t
*pool
);
439 /** Return the path to @a repos's post-unlock hook, allocated in @a pool. */
440 const char *svn_repos_post_unlock_hook(svn_repos_t
*repos
, apr_pool_t
*pool
);
444 /* ---------------------------------------------------------------*/
446 /* Reporting the state of a working copy, for updates. */
450 * Construct and return a @a report_baton that will be passed to the
451 * other functions in this section to describe the state of a pre-existing
452 * tree (typically, a working copy). When the report is finished,
453 * @a editor/@a edit_baton will be driven in such a way as to transform the
454 * existing tree to @a revnum and, if @a tgt_path is non-NULL, switch the
455 * reported hierarchy to @a tgt_path.
457 * @a fs_base is the absolute path of the node in the filesystem at which
458 * the comparison should be rooted. @a target is a single path component,
459 * used to limit the scope of the report to a single entry of @a fs_base,
460 * or "" if all of @a fs_base itself is the main subject of the report.
462 * @a tgt_path and @a revnum is the fs path/revision pair that is the
463 * "target" of the delta. @a tgt_path should be provided only when
464 * the source and target paths of the report differ. That is, @a tgt_path
465 * should *only* be specified when specifying that the resultant editor
466 * drive be one that transforms the reported hierarchy into a pristine tree
467 * of @a tgt_path at revision @a revnum. A @c NULL value for @a tgt_path
468 * will indicate that the editor should be driven in such a way as to
469 * transform the reported hierarchy to revision @a revnum, preserving the
470 * reported hierarchy.
472 * @a text_deltas instructs the driver of the @a editor to enable
473 * the generation of text deltas.
475 * @a ignore_ancestry instructs the driver to ignore node ancestry
476 * when determining how to transmit differences.
478 * @a send_copyfrom_args instructs the driver to send 'copyfrom'
479 * arguments to the editor's add_file() and add_directory() methods,
480 * whenever it deems feasible.
482 * The @a authz_read_func and @a authz_read_baton are passed along to
483 * svn_repos_dir_delta2(); see that function for how they are used.
485 * All allocation for the context and collected state will occur in
488 * @a depth is the requested depth of the editor drive.
490 * If @a depth is @c svn_depth_unknown, the editor will affect only the
491 * paths reported by the individual calls to @c svn_repos_set_path3 and
492 * @c svn_repos_link_path3.
494 * For example, if the reported tree is the @c A subdir of the Greek Tree
495 * (see Subversion's test suite), at depth @c svn_depth_empty, but the
496 * @c A/B subdir is reported at depth @c svn_depth_infinity, then
497 * repository-side changes to @c A/mu, or underneath @c A/C and @c
498 * A/D, would not be reflected in the editor drive, but changes
499 * underneath @c A/B would be.
501 * Additionally, the editor driver will call @c add_directory and
502 * and @c add_file for directories with an appropriate depth. For
503 * example, a directory reported at @c svn_depth_files will receive
504 * file (but not directory) additions. A directory at @c svn_depth_empty
505 * will receive neither.
507 * If @a depth is @c svn_depth_files, @c svn_depth_immediates or
508 * @c svn_depth_infinity and @a depth is greater than the reported depth
509 * of the working copy, then the editor driver will emit editor
510 * operations so as to upgrade the working copy to this depth.
512 * If @a depth is @c svn_depth_empty, @c svn_depth_files,
513 * @c svn_depth_immediates and @a depth is lower
514 * than or equal to the depth of the working copy, then the editor
515 * operations will affect only paths at or above @a depth.
520 svn_repos_begin_report2(void **report_baton
,
525 const char *tgt_path
,
526 svn_boolean_t text_deltas
,
528 svn_boolean_t ignore_ancestry
,
529 svn_boolean_t send_copyfrom_args
,
530 const svn_delta_editor_t
*editor
,
532 svn_repos_authz_func_t authz_read_func
,
533 void *authz_read_baton
,
537 * The same as svn_repos_begin_report2(), but taking a boolean
538 * @a recurse flag, and sending FALSE for @a send_copyfrom_args.
540 * If @a recurse is TRUE, the editor driver will drive the editor with
541 * a depth of @c svn_depth_infinity; if FALSE, then with a depth of
542 * @c svn_depth_files.
544 * @note @a username is ignored, and has been removed in a revised
545 * version of this API.
547 * @deprecated Provided for backward compatibility with the 1.4 API.
550 svn_repos_begin_report(void **report_baton
,
552 const char *username
,
556 const char *tgt_path
,
557 svn_boolean_t text_deltas
,
558 svn_boolean_t recurse
,
559 svn_boolean_t ignore_ancestry
,
560 const svn_delta_editor_t
*editor
,
562 svn_repos_authz_func_t authz_read_func
,
563 void *authz_read_baton
,
568 * Given a @a report_baton constructed by svn_repos_begin_report2(),
569 * record the presence of @a path, at @a revision with depth @a depth,
570 * in the current tree.
572 * @a path is relative to the anchor/target used in the creation of the
575 * @a revision may be SVN_INVALID_REVNUM if (for example) @a path
576 * represents a locally-added path with no revision number, or @a
577 * depth is @c svn_depth_exclude.
579 * @a path may not be underneath a path on which svn_repos_set_path3()
580 * was previously called with @c svn_depth_exclude in this report.
582 * The first call of this in a given report usually passes an empty
583 * @a path; this is used to set up the correct root revision for the editor
586 * A depth of @c svn_depth_unknown is not allowed, and results in an
589 * If @a start_empty is TRUE and @a path is a directory, then require the
590 * caller to explicitly provide all the children of @a path - do not assume
591 * that the tree also contains all the children of @a path at @a revision.
592 * This is for 'low confidence' client reporting.
594 * If the caller has a lock token for @a path, then @a lock_token should
595 * be set to that token. Else, @a lock_token should be NULL.
597 * All temporary allocations are done in @a pool.
602 svn_repos_set_path3(void *report_baton
,
604 svn_revnum_t revision
,
606 svn_boolean_t start_empty
,
607 const char *lock_token
,
611 * Similar to svn_repos_set_path3(), but with @a depth set to
612 * @c svn_depth_infinity.
614 * @deprecated Provided for backward compatibility with the 1.4 API.
617 svn_repos_set_path2(void *report_baton
,
619 svn_revnum_t revision
,
620 svn_boolean_t start_empty
,
621 const char *lock_token
,
625 * Similar to svn_repos_set_path2(), but with @a lock_token set to @c NULL.
627 * @deprecated Provided for backward compatibility with the 1.1 API.
630 svn_repos_set_path(void *report_baton
,
632 svn_revnum_t revision
,
633 svn_boolean_t start_empty
,
637 * Given a @a report_baton constructed by svn_repos_begin_report2(),
638 * record the presence of @a path in the current tree, containing the contents
639 * of @a link_path at @a revision with depth @a depth.
641 * A depth of @c svn_depth_unknown is not allowed, and results in an
644 * @a path may not be underneath a path on which svn_repos_set_path3()
645 * was previously called with @c svn_depth_exclude in this report.
647 * Note that while @a path is relative to the anchor/target used in the
648 * creation of the @a report_baton, @a link_path is an absolute filesystem
651 * If @a start_empty is TRUE and @a path is a directory, then require the
652 * caller to explicitly provide all the children of @a path - do not assume
653 * that the tree also contains all the children of @a link_path at
654 * @a revision. This is for 'low confidence' client reporting.
656 * If the caller has a lock token for @a link_path, then @a lock_token
657 * should be set to that token. Else, @a lock_token should be NULL.
659 * All temporary allocations are done in @a pool.
664 svn_repos_link_path3(void *report_baton
,
666 const char *link_path
,
667 svn_revnum_t revision
,
669 svn_boolean_t start_empty
,
670 const char *lock_token
,
674 * Similar to svn_repos_link_path3(), but with @a depth set to
675 * @c svn_depth_infinity.
677 * @deprecated Provided for backward compatibility with the 1.4 API.
680 svn_repos_link_path2(void *report_baton
,
682 const char *link_path
,
683 svn_revnum_t revision
,
684 svn_boolean_t start_empty
,
685 const char *lock_token
,
689 * Similar to svn_repos_link_path2(), but with @a lock_token set to @c NULL.
691 * @deprecated Provided for backward compatibility with the 1.1 API.
694 svn_repos_link_path(void *report_baton
,
696 const char *link_path
,
697 svn_revnum_t revision
,
698 svn_boolean_t start_empty
,
701 /** Given a @a report_baton constructed by svn_repos_begin_report2(),
702 * record the non-existence of @a path in the current tree.
704 * @a path may not be underneath a path on which svn_repos_set_path3()
705 * was previously called with @c svn_depth_exclude in this report.
707 * (This allows the reporter's driver to describe missing pieces of a
708 * working copy, so that 'svn up' can recreate them.)
710 * All temporary allocations are done in @a pool.
713 svn_repos_delete_path(void *report_baton
,
717 /** Given a @a report_baton constructed by svn_repos_begin_report2(),
718 * finish the report and drive the editor as specified when the report
719 * baton was constructed.
721 * If an error occurs during the driving of the editor, do NOT abort the
722 * edit; that responsibility belongs to the caller of this function, if
725 * After the call to this function, @a report_baton is no longer valid;
726 * it should not be passed to any other reporting functions, including
727 * svn_repos_abort_report().
730 svn_repos_finish_report(void *report_baton
,
734 /** Given a @a report_baton constructed by svn_repos_begin_report2(),
735 * abort the report. This function can be called anytime before
736 * svn_repos_finish_report() is called.
738 * After the call to this function, @a report_baton is no longer valid;
739 * it should not be passed to any other reporting functions.
742 svn_repos_abort_report(void *report_baton
,
746 /* ---------------------------------------------------------------*/
748 /* The magical dir_delta update routines. */
750 /** Use the provided @a editor and @a edit_baton to describe the changes
751 * necessary for making a given node (and its descendants, if it is a
752 * directory) under @a src_root look exactly like @a tgt_path under
753 * @a tgt_root. @a src_entry is the node to update. If @a src_entry
754 * is empty, then compute the difference between the entire tree
755 * anchored at @a src_parent_dir under @a src_root and @a tgt_path
756 * under @a tgt_root. Else, describe the changes needed to update
757 * only that entry in @a src_parent_dir. Typically, callers of this
758 * function will use a @a tgt_path that is the concatenation of @a
759 * src_parent_dir and @a src_entry.
761 * @a src_root and @a tgt_root can both be either revision or transaction
762 * roots. If @a tgt_root is a revision, @a editor's set_target_revision()
763 * will be called with the @a tgt_root's revision number, else it will
764 * not be called at all.
766 * If @a authz_read_func is non-NULL, invoke it before any call to
768 * @a editor->open_root
769 * @a editor->add_directory
770 * @a editor->open_directory
771 * @a editor->add_file
772 * @a editor->open_file
774 * passing @a tgt_root, the same path that would be passed to the
775 * editor function in question, and @a authz_read_baton. If the
776 * @a *allowed parameter comes back TRUE, then proceed with the planned
777 * editor call; else if FALSE, then invoke @a editor->absent_file or
778 * @a editor->absent_directory as appropriate, except if the planned
779 * editor call was open_root, throw SVN_ERR_AUTHZ_ROOT_UNREADABLE.
781 * If @a text_deltas is @c FALSE, send a single @c NULL txdelta window to
782 * the window handler returned by @a editor->apply_textdelta().
784 * If @a depth is @c svn_depth_empty, invoke @a editor calls only on
785 * @a src_entry (or @a src_parent_dir, if @a src_entry is empty).
786 * If @a depth is @c svn_depth_files, also invoke the editor on file
787 * children, if any; if @c svn_depth_immediates, invoke it on
788 * immediate subdirectories as well as files; if @c svn_depth_infinity,
791 * If @a entry_props is @c TRUE, accompany each opened/added entry with
792 * propchange editor calls that relay special "entry props" (this
793 * is typically used only for working copy updates).
795 * @a ignore_ancestry instructs the function to ignore node ancestry
796 * when determining how to transmit differences.
798 * Before completing successfully, this function calls @a editor's
799 * close_edit(), so the caller should expect its @a edit_baton to be
800 * invalid after its use with this function.
802 * Do any allocation necessary for the delta computation in @a pool.
803 * This function's maximum memory consumption is at most roughly
804 * proportional to the greatest depth of the tree under @a tgt_root, not
805 * the total size of the delta.
807 * ### svn_repos_dir_delta2 is mostly superceded by the reporter
808 * ### functionality (svn_repos_begin_report2 and friends).
809 * ### svn_repos_dir_delta2 does allow the roots to be transaction
810 * ### roots rather than just revision roots, and it has the
811 * ### entry_props flag. Almost all of Subversion's own code uses the
812 * ### reporter instead; there are some stray references to the
813 * ### svn_repos_dir_delta[2] in comments which should probably
814 * ### actually refer to the reporter.
817 svn_repos_dir_delta2(svn_fs_root_t
*src_root
,
818 const char *src_parent_dir
,
819 const char *src_entry
,
820 svn_fs_root_t
*tgt_root
,
821 const char *tgt_path
,
822 const svn_delta_editor_t
*editor
,
824 svn_repos_authz_func_t authz_read_func
,
825 void *authz_read_baton
,
826 svn_boolean_t text_deltas
,
828 svn_boolean_t entry_props
,
829 svn_boolean_t ignore_ancestry
,
833 * Similar to svn_repos_dir_delta2(), but if @a recurse is TRUE, pass
834 * @c svn_depth_infinity for @a depth, and if @a recurse is FALSE,
835 * pass @c svn_depth_files for @a depth.
837 * @deprecated Provided for backward compatibility with the 1.4 API.
840 svn_repos_dir_delta(svn_fs_root_t
*src_root
,
841 const char *src_parent_dir
,
842 const char *src_entry
,
843 svn_fs_root_t
*tgt_root
,
844 const char *tgt_path
,
845 const svn_delta_editor_t
*editor
,
847 svn_repos_authz_func_t authz_read_func
,
848 void *authz_read_baton
,
849 svn_boolean_t text_deltas
,
850 svn_boolean_t recurse
,
851 svn_boolean_t entry_props
,
852 svn_boolean_t ignore_ancestry
,
856 /** Use the provided @a editor and @a edit_baton to describe the
857 * skeletal changes made in a particular filesystem @a root
858 * (revision or transaction).
860 * Changes will be limited to those within @a base_dir, and if
861 * @a low_water_mark is set to something other than @c SVN_INVALID_REVNUM
862 * it is assumed that the client has no knowledge of revisions prior to
863 * @a low_water_mark. Together, these two arguments define the portion of
864 * the tree that the client is assumed to have knowledge of, and thus any
865 * copies of data from outside that part of the tree will be sent in their
866 * entirety, not as simple copies or deltas against a previous version.
868 * The @a editor passed to this function should be aware of the fact
869 * that, if @a send_deltas is FALSE, calls to its change_dir_prop(),
870 * change_file_prop(), and apply_textdelta() functions will not
871 * contain meaningful data, and merely serve as indications that
872 * properties or textual contents were changed.
874 * If @a send_deltas is @c TRUE, the text and property deltas for changes
875 * will be sent, otherwise NULL text deltas and empty prop changes will be
878 * If @a authz_read_func is non-NULL, it will be used to determine if the
879 * user has read access to the data being accessed. Data that the user
880 * cannot access will be skipped.
882 * @note This editor driver passes SVN_INVALID_REVNUM for all
883 * revision parameters in the editor interface except the copyfrom
884 * parameter of the add_file() and add_directory() editor functions.
889 svn_repos_replay2(svn_fs_root_t
*root
,
890 const char *base_dir
,
891 svn_revnum_t low_water_mark
,
892 svn_boolean_t send_deltas
,
893 const svn_delta_editor_t
*editor
,
895 svn_repos_authz_func_t authz_read_func
,
896 void *authz_read_baton
,
900 * Similar to svn_repos_replay2(), but with @a base_dir set to @c "",
901 * @a low_water_mark set to @c SVN_INVALID_REVNUM, @a send_deltas
902 * set to @c FALSE, and @a authz_read_func and @a authz_read_baton
905 * @deprecated Provided for backward compatibility with the 1.3 API.
908 svn_repos_replay(svn_fs_root_t
*root
,
909 const svn_delta_editor_t
*editor
,
913 /* ---------------------------------------------------------------*/
915 /* Making commits. */
918 * Return an @a editor and @a edit_baton to commit changes to the
919 * filesystem of @a repos, beginning at location 'rev:@a base_path',
920 * where "rev" is the argument given to open_root().
922 * @a repos is a previously opened repository. @a repos_url is the
923 * decoded URL to the base of the repository, and is used to check
924 * copyfrom paths. @a txn is a filesystem transaction object to use
925 * during the commit, or @c NULL to indicate that this function should
926 * create (and fully manage) a new transaction.
928 * Store the contents of @a revprop_table, a hash mapping <tt>const
929 * char *</tt> property names to @c svn_string_t values, as properties
930 * of the commit transaction, including author and log message if
933 * @note @c SVN_PROP_REVISION_DATE may be present in @a revprop_table, but
934 * it will be overwritten when the transaction is committed.
936 * Iff @a authz_callback is provided, check read/write authorizations
937 * on paths accessed by editor operations. An operation which fails
938 * due to authz will return SVN_ERR_AUTHZ_UNREADABLE or
939 * SVN_ERR_AUTHZ_UNWRITABLE.
941 * Calling @a (*editor)->close_edit completes the commit. Before
942 * @c close_edit returns, but after the commit has succeeded, it will
943 * invoke @a callback with the new revision number, the commit date (as a
944 * <tt>const char *</tt>), commit author (as a <tt>const char *</tt>), and
945 * @a callback_baton as arguments. If @a callback returns an error, that
946 * error will be returned from @c close_edit, otherwise if there was a
947 * post-commit hook failure, then that error will be returned and will
948 * have code SVN_ERR_REPOS_POST_COMMIT_HOOK_FAILED.
950 * Calling @a (*editor)->abort_edit aborts the commit, and will also
951 * abort the commit transaction unless @a txn was supplied (not @c
952 * NULL). Callers who supply their own transactions are responsible
953 * for cleaning them up (either by committing them, or aborting them).
958 svn_repos_get_commit_editor5(const svn_delta_editor_t
**editor
,
962 const char *repos_url
,
963 const char *base_path
,
964 apr_hash_t
*revprop_table
,
965 svn_commit_callback2_t callback
,
966 void *callback_baton
,
967 svn_repos_authz_callback_t authz_callback
,
972 * Similar to svn_repos_get_commit_editor5(), but with @a revprop_table
973 * set to a hash containing @a user and @a log_msg as the
974 * @c SVN_PROP_REVISION_AUTHOR and @c SVN_PROP_REVISION_LOG properties,
975 * respectively. @a user and @a log_msg may both be @c NULL.
979 * @deprecated Provided for backward compatibility with the 1.4 API.
982 svn_repos_get_commit_editor4(const svn_delta_editor_t
**editor
,
986 const char *repos_url
,
987 const char *base_path
,
990 svn_commit_callback2_t callback
,
991 void *callback_baton
,
992 svn_repos_authz_callback_t authz_callback
,
997 * Similar to svn_repos_get_commit_editor4(), but
998 * uses the svn_commit_callback_t type.
1000 * @since New in 1.3.
1002 * @deprecated Provided for backward compatibility with the 1.3 API.
1005 svn_repos_get_commit_editor3(const svn_delta_editor_t
**editor
,
1009 const char *repos_url
,
1010 const char *base_path
,
1012 const char *log_msg
,
1013 svn_commit_callback_t callback
,
1014 void *callback_baton
,
1015 svn_repos_authz_callback_t authz_callback
,
1020 * Similar to svn_repos_get_commit_editor3(), but with @a
1021 * authz_callback and @a authz_baton set to @c NULL.
1023 * @deprecated Provided for backward compatibility with the 1.2 API.
1026 svn_repos_get_commit_editor2(const svn_delta_editor_t
**editor
,
1030 const char *repos_url
,
1031 const char *base_path
,
1033 const char *log_msg
,
1034 svn_commit_callback_t callback
,
1035 void *callback_baton
,
1040 * Similar to svn_repos_get_commit_editor2(), but with @a txn always
1043 * @deprecated Provided for backward compatibility with the 1.1 API.
1046 svn_repos_get_commit_editor(const svn_delta_editor_t
**editor
,
1049 const char *repos_url
,
1050 const char *base_path
,
1052 const char *log_msg
,
1053 svn_commit_callback_t callback
,
1054 void *callback_baton
,
1057 /* ---------------------------------------------------------------*/
1059 /* Finding particular revisions. */
1061 /** Set @a *revision to the revision number in @a repos's filesystem that was
1062 * youngest at time @a tm.
1065 svn_repos_dated_revision(svn_revnum_t
*revision
,
1071 /** Given a @a root/@a path within some filesystem, return three pieces of
1072 * information allocated in @a pool:
1074 * - set @a *committed_rev to the revision in which the object was
1075 * last modified. (In fs parlance, this is the revision in which
1076 * the particular node-rev-id was 'created'.)
1078 * - set @a *committed_date to the date of said revision, or @c NULL
1081 * - set @a *last_author to the author of said revision, or @c NULL
1085 svn_repos_get_committed_info(svn_revnum_t
*committed_rev
,
1086 const char **committed_date
,
1087 const char **last_author
,
1088 svn_fs_root_t
*root
,
1094 * Set @a *dirent to an @c svn_dirent_t associated with @a path in @a
1095 * root. If @a path does not exist in @a root, set @a *dirent to
1096 * NULL. Use @a pool for memory allocation.
1098 * @since New in 1.2.
1101 svn_repos_stat(svn_dirent_t
**dirent
,
1102 svn_fs_root_t
*root
,
1108 * Given @a path which exists at revision @a start in @a fs, set
1109 * @a *deleted to the revision @a path was first deleted, within the
1110 * inclusive revision range set by @a start and @a end. If @a path
1111 * does not exist at revision @a start or was not deleted within the
1112 * specified range, then set @a *deleted to SVN_INVALID_REVNUM.
1113 * Use @a pool for memory allocation.
1115 * @since New in 1.5.
1118 svn_repos_deleted_rev(svn_fs_t
*fs
,
1122 svn_revnum_t
*deleted
,
1126 /** Callback type for use with svn_repos_history(). @a path and @a
1127 * revision represent interesting history locations in the lifetime
1128 * of the path passed to svn_repos_history(). @a baton is the same
1129 * baton given to svn_repos_history(). @a pool is provided for the
1130 * convenience of the implementor, who should not expect it to live
1131 * longer than a single callback call.
1133 * Signal to callback driver to stop processing/invoking this callback
1134 * by returning the @c SVN_ERR_CEASE_INVOCATION error code.
1136 typedef svn_error_t
*(*svn_repos_history_func_t
)(void *baton
,
1138 svn_revnum_t revision
,
1142 * Call @a history_func (with @a history_baton) for each interesting
1143 * history location in the lifetime of @a path in @a fs, from the
1144 * youngest of @a end and @a start to the oldest. Stop processing if
1145 * @a history_func returns @c SVN_ERR_CEASE_INVOCATION. Only cross
1146 * filesystem copy history if @a cross_copies is @c TRUE. And do all
1147 * of this in @a pool.
1149 * If @a authz_read_func is non-NULL, then use it (and @a
1150 * authz_read_baton) to verify that @a path in @a end is readable; if
1151 * not, return SVN_ERR_AUTHZ_UNREADABLE. Also verify the readability
1152 * of every ancestral path/revision pair before pushing them at @a
1153 * history_func. If a pair is deemed unreadable, then do not send
1154 * them; instead, immediately stop traversing history and return
1157 * @since New in 1.1.
1160 svn_repos_history2(svn_fs_t
*fs
,
1162 svn_repos_history_func_t history_func
,
1163 void *history_baton
,
1164 svn_repos_authz_func_t authz_read_func
,
1165 void *authz_read_baton
,
1168 svn_boolean_t cross_copies
,
1172 * Similar to svn_repos_history2(), but with @a authz_read_func
1173 * and @a authz_read_baton always set to NULL.
1175 * @deprecated Provided for backward compatibility with the 1.0 API.
1178 svn_repos_history(svn_fs_t
*fs
,
1180 svn_repos_history_func_t history_func
,
1181 void *history_baton
,
1184 svn_boolean_t cross_copies
,
1189 * Set @a *locations to be a mapping of the revisions to the paths of
1190 * the file @a fs_path present at the repository in revision
1191 * @a peg_revision, where the revisions are taken out of the array
1192 * @a location_revisions.
1194 * @a location_revisions is an array of svn_revnum_t's and @a *locations
1195 * maps 'svn_revnum_t *' to 'const char *'.
1197 * If optional @a authz_read_func is non-NULL, then use it (and @a
1198 * authz_read_baton) to verify that the peg-object is readable. If not,
1199 * return SVN_ERR_AUTHZ_UNREADABLE. Also use the @a authz_read_func
1200 * to check that every path returned in the hash is readable. If an
1201 * unreadable path is encountered, stop tracing and return
1204 * @a pool is used for all allocations.
1206 * @since New in 1.1.
1209 svn_repos_trace_node_locations(svn_fs_t
*fs
,
1210 apr_hash_t
**locations
,
1211 const char *fs_path
,
1212 svn_revnum_t peg_revision
,
1213 apr_array_header_t
*location_revisions
,
1214 svn_repos_authz_func_t authz_read_func
,
1215 void *authz_read_baton
,
1220 * Call @a receiver and @a receiver_baton to report successive
1221 * location segments in revisions between @a start_rev and @a end_rev
1222 * (inclusive) for the line of history identified by the peg-object @a
1223 * path in @a peg_revision (and in @a repos).
1225 * @a end_rev may be @c SVN_INVALID_REVNUM to indicate that you want
1226 * to trace the history of the object to its origin.
1228 * @a start_rev may be @c SVN_INVALID_REVNUM to indicate "the HEAD
1229 * revision". Otherwise, @a start_rev must be younger than @a end_rev
1230 * (unless @a end_rev is @c SVN_INVALID_REVNUM).
1232 * @a peg_revision may be @c SVN_INVALID_REVNUM to indicate "the HEAD
1233 * revision", and must evaluate to be at least as young as @a start_rev.
1235 * If optional @a authz_read_func is not @c NULL, then use it (and @a
1236 * authz_read_baton) to verify that the peg-object is readable. If
1237 * not, return @c SVN_ERR_AUTHZ_UNREADABLE. Also use the @a
1238 * authz_read_func to check that every path reported in a location
1239 * segment is readable. If an unreadable path is encountered, report
1240 * a final (possibly truncated) location segment (if any), stop
1241 * tracing history, and return @c SVN_NO_ERROR.
1243 * @a pool is used for all allocations.
1245 * @since New in 1.5.
1248 svn_repos_node_location_segments(svn_repos_t
*repos
,
1250 svn_revnum_t peg_revision
,
1251 svn_revnum_t start_rev
,
1252 svn_revnum_t end_rev
,
1253 svn_location_segment_receiver_t receiver
,
1254 void *receiver_baton
,
1255 svn_repos_authz_func_t authz_read_func
,
1256 void *authz_read_baton
,
1260 /* ### other queries we can do someday --
1262 * fetch the last revision created by <user>
1263 (once usernames become revision properties!)
1264 * fetch the last revision where <path> was modified
1270 /* ---------------------------------------------------------------*/
1272 /* Retrieving log messages. */
1276 * Invoke @a receiver with @a receiver_baton on each log message from
1277 * @a start to @a end in @a repos's filesystem. @a start may be greater
1278 * or less than @a end; this just controls whether the log messages are
1279 * processed in descending or ascending revision number order.
1281 * If @a start or @a end is @c SVN_INVALID_REVNUM, it defaults to youngest.
1283 * If @a paths is non-NULL and has one or more elements, then only show
1284 * revisions in which at least one of @a paths was changed (i.e., if
1285 * file, text or props changed; if dir, props or entries changed or any node
1286 * changed below it). Each path is a <tt>const char *</tt> representing
1287 * an absolute path in the repository.
1289 * If @a limit is non-zero then only invoke @a receiver on the first
1292 * If @a discover_changed_paths, then each call to @a receiver passes a
1293 * hash mapping paths committed in that revision to information about them
1294 * as the receiver's @a changed_paths argument.
1295 * Otherwise, each call to @a receiver passes NULL for @a changed_paths.
1297 * If @a strict_node_history is set, copy history (if any exists) will
1298 * not be traversed while harvesting revision logs for each path.
1300 * If @a revprops is NULL, retrieve all revprops; else, retrieve only the
1301 * revprops named in the array (i.e. retrieve none if the array is empty).
1303 * If any invocation of @a receiver returns error, return that error
1304 * immediately and without wrapping it.
1306 * If @a start or @a end is a non-existent revision, return the error
1307 * @c SVN_ERR_FS_NO_SUCH_REVISION, without ever invoking @a receiver.
1309 * If optional @a authz_read_func is non-NULL, then use this function
1310 * (along with optional @a authz_read_baton) to check the readability
1311 * of each changed-path in each revision about to be "pushed" at
1312 * @a receiver. If a revision has some changed-paths readable and
1313 * others unreadable, unreadable paths are omitted from the
1314 * changed_paths field and only svn:author and svn:date will be
1315 * available in the revprops field. If a revision has no
1316 * changed-paths readable at all, then all paths are omitted and no
1317 * revprops are available.
1319 * See also the documentation for @c svn_log_entry_receiver_t.
1321 * Use @a pool for temporary allocations.
1323 * @since New in 1.5.
1326 svn_repos_get_logs4(svn_repos_t
*repos
,
1327 const apr_array_header_t
*paths
,
1331 svn_boolean_t discover_changed_paths
,
1332 svn_boolean_t strict_node_history
,
1333 svn_boolean_t include_merged_revisions
,
1334 const apr_array_header_t
*revprops
,
1335 svn_repos_authz_func_t authz_read_func
,
1336 void *authz_read_baton
,
1337 svn_log_entry_receiver_t receiver
,
1338 void *receiver_baton
,
1342 * Same as svn_repos_get_logs4(), but with @a receiver being @c
1343 * svn_log_message_receiver_t instead of @c svn_log_entry_receiver_t.
1344 * Also, @a include_merged_revisions is set to @c FALSE and @a revprops is
1345 * svn:author, svn:date, and svn:log.
1347 * @since New in 1.2.
1348 * @deprecated Provided for backward compatibility with the 1.4 API.
1351 svn_repos_get_logs3(svn_repos_t
*repos
,
1352 const apr_array_header_t
*paths
,
1356 svn_boolean_t discover_changed_paths
,
1357 svn_boolean_t strict_node_history
,
1358 svn_repos_authz_func_t authz_read_func
,
1359 void *authz_read_baton
,
1360 svn_log_message_receiver_t receiver
,
1361 void *receiver_baton
,
1366 * Same as svn_repos_get_logs3(), but with @a limit always set to 0.
1368 * @deprecated Provided for backward compatibility with the 1.1 API.
1371 svn_repos_get_logs2(svn_repos_t
*repos
,
1372 const apr_array_header_t
*paths
,
1375 svn_boolean_t discover_changed_paths
,
1376 svn_boolean_t strict_node_history
,
1377 svn_repos_authz_func_t authz_read_func
,
1378 void *authz_read_baton
,
1379 svn_log_message_receiver_t receiver
,
1380 void *receiver_baton
,
1384 * Same as svn_repos_get_logs2(), but with @a authz_read_func and
1385 * @a authz_read_baton always set to NULL.
1387 * @deprecated Provided for backward compatibility with the 1.0 API.
1390 svn_repos_get_logs(svn_repos_t
*repos
,
1391 const apr_array_header_t
*paths
,
1394 svn_boolean_t discover_changed_paths
,
1395 svn_boolean_t strict_node_history
,
1396 svn_log_message_receiver_t receiver
,
1397 void *receiver_baton
,
1402 /* ---------------------------------------------------------------*/
1404 /* Retrieving mergeinfo. */
1407 * Fetch the mergeinfo for @a paths at @a rev, and save it to @a
1408 * *catalog. It will never be @c NULL but may be empty.
1410 * @a inherit indicates whether explicit, explicit or inherited, or
1411 * only inherited mergeinfo for @a paths is fetched.
1413 * If @a revision is @c SVN_INVALID_REVNUM, it defaults to youngest.
1415 * If @a include_descendants is TRUE, then additionally return the
1416 * mergeinfo for any descendant of any element of @a paths which has
1417 * the @c SVN_PROP_MERGEINFO property explicitly set on it. (Note
1418 * that inheritance is only taken into account for the elements in @a
1419 * paths; descendants of the elements in @a paths which get their
1420 * mergeinfo via inheritance are not included in @a *mergeoutput.)
1422 * If optional @a authz_read_func is non-NULL, then use this function
1423 * (along with optional @a authz_read_baton) to check the readability
1424 * of each path which mergeinfo was requested for (from @a paths).
1425 * Silently omit unreadable paths from the request for mergeinfo.
1427 * Use @a pool for temporary allocations.
1429 * @since New in 1.5.
1432 svn_repos_fs_get_mergeinfo(svn_mergeinfo_catalog_t
*catalog
,
1434 const apr_array_header_t
*paths
,
1435 svn_revnum_t revision
,
1436 svn_mergeinfo_inheritance_t inherit
,
1437 svn_boolean_t include_descendants
,
1438 svn_repos_authz_func_t authz_read_func
,
1439 void *authz_read_baton
,
1443 /* ---------------------------------------------------------------*/
1445 /* Retrieving multiple revisions of a file. */
1448 * Retrieve a subset of the interesting revisions of a file @a path in
1449 * @a repos as seen in revision @a end. Invoke @a handler with
1450 * @a handler_baton as its first argument for each such revision.
1451 * @a pool is used for all allocations. See svn_fs_history_prev() for
1452 * a discussion of interesting revisions.
1454 * If optional @a authz_read_func is non-NULL, then use this function
1455 * (along with optional @a authz_read_baton) to check the readability
1456 * of the rev-path in each interesting revision encountered.
1458 * Revision discovery happens from @a end to @a start, and if an
1459 * unreadable revision is encountered before @a start is reached, then
1460 * revision discovery stops and only the revisions from @a end to the
1461 * oldest readable revision are returned (So it will appear that @a
1462 * path was added without history in the latter revision).
1464 * If there is an interesting revision of the file that is less than or
1465 * equal to start, the iteration will start at that revision. Else, the
1466 * iteration will start at the first revision of the file in the repository,
1467 * which has to be less than or equal to end. Note that if the function
1468 * succeeds, @a handler will have been called at least once.
1470 * In a series of calls, the file contents for the first interesting revision
1471 * will be provided as a text delta against the empty file. In the following
1472 * calls, the delta will be against the contents for the previous call.
1474 * If @a include_merged_revisions is TRUE, revisions which a included as a
1475 * result of a merge between @a start and @a end will be included.
1477 * @since New in 1.5.
1480 svn_repos_get_file_revs2(svn_repos_t
*repos
,
1484 svn_boolean_t include_merged_revisions
,
1485 svn_repos_authz_func_t authz_read_func
,
1486 void *authz_read_baton
,
1487 svn_file_rev_handler_t handler
,
1488 void *handler_baton
,
1492 * Similar to svn_repos_get_file_revs2(), with @a include_merged_revisions
1495 * @deprecated Provided for backward compatibility with the 1.4 API.
1496 * @since New in 1.1.
1499 svn_repos_get_file_revs(svn_repos_t
*repos
,
1503 svn_repos_authz_func_t authz_read_func
,
1504 void *authz_read_baton
,
1505 svn_repos_file_rev_handler_t handler
,
1506 void *handler_baton
,
1510 /* ---------------------------------------------------------------*/
1513 * @defgroup svn_repos_hook_wrappers Hook-sensitive wrappers for libsvn_fs \
1518 /** Like svn_fs_commit_txn(), but invoke the @a repos's pre- and
1519 * post-commit hooks around the commit. Use @a pool for any necessary
1522 * If the pre-commit hook or svn_fs_commit_txn() fails, throw the
1523 * original error to caller. If an error occurs when running the
1524 * post-commit hook, return the original error wrapped with
1525 * SVN_ERR_REPOS_POST_COMMIT_HOOK_FAILED. If the caller sees this
1526 * error, it knows that the commit succeeded anyway.
1528 * @a conflict_p, @a new_rev, and @a txn are as in svn_fs_commit_txn().
1531 svn_repos_fs_commit_txn(const char **conflict_p
,
1533 svn_revnum_t
*new_rev
,
1537 /** Like svn_fs_begin_txn(), but use @a revprop_table, a hash mapping
1538 * <tt>const char *</tt> property names to @c svn_string_t values, to
1539 * set the properties on transaction @a *txn_p. @a repos is the
1540 * repository object which contains the filesystem. @a rev, @a
1541 * *txn_p, and @a pool are as in svn_fs_begin_txn().
1543 * Before a txn is created, the repository's start-commit hooks are
1544 * run; if any of them fail, no txn is created, @a *txn_p is unaffected,
1545 * and @c SVN_ERR_REPOS_HOOK_FAILURE is returned.
1547 * @note @a revprop_table may contain an @c SVN_PROP_REVISION_DATE property,
1548 * which will be set on the transaction, but that will be overwritten
1549 * when the transaction is committed.
1551 * @since New in 1.5.
1554 svn_repos_fs_begin_txn_for_commit2(svn_fs_txn_t
**txn_p
,
1557 apr_hash_t
*revprop_table
,
1562 * Same as svn_repos_fs_begin_txn_for_commit2(), but with @a revprop_table
1563 * set to a hash containing @a author and @a log_msg as the
1564 * @c SVN_PROP_REVISION_AUTHOR and @c SVN_PROP_REVISION_LOG properties,
1565 * respectively. @a author and @a log_msg may both be @c NULL.
1567 * @deprecated Provided for backward compatibility with the 1.4 API.
1570 svn_repos_fs_begin_txn_for_commit(svn_fs_txn_t
**txn_p
,
1574 const char *log_msg
,
1578 /** Like svn_fs_begin_txn(), but use @a author to set the corresponding
1579 * property on transaction @a *txn_p. @a repos is the repository object
1580 * which contains the filesystem. @a rev, @a *txn_p, and @a pool are as in
1581 * svn_fs_begin_txn().
1583 * ### Someday: before a txn is created, some kind of read-hook could
1587 svn_repos_fs_begin_txn_for_update(svn_fs_txn_t
**txn_p
,
1594 /** @defgroup svn_repos_fs_locks Repository lock wrappers
1596 * @since New in 1.2. */
1598 /** Like svn_fs_lock(), but invoke the @a repos's pre- and
1599 * post-lock hooks before and after the locking action. Use @a pool
1600 * for any necessary allocations.
1602 * If the pre-lock hook or svn_fs_lock() fails, throw the original
1603 * error to caller. If an error occurs when running the post-lock
1604 * hook, return the original error wrapped with
1605 * SVN_ERR_REPOS_POST_LOCK_HOOK_FAILED. If the caller sees this
1606 * error, it knows that the lock succeeded anyway.
1609 svn_repos_fs_lock(svn_lock_t
**lock
,
1613 const char *comment
,
1614 svn_boolean_t is_dav_comment
,
1615 apr_time_t expiration_date
,
1616 svn_revnum_t current_rev
,
1617 svn_boolean_t steal_lock
,
1621 /** Like svn_fs_unlock(), but invoke the @a repos's pre- and
1622 * post-unlock hooks before and after the unlocking action. Use @a
1623 * pool for any necessary allocations.
1625 * If the pre-unlock hook or svn_fs_unlock() fails, throw the original
1626 * error to caller. If an error occurs when running the post-unlock
1627 * hook, return the original error wrapped with
1628 * SVN_ERR_REPOS_POST_UNLOCK_HOOK_FAILED. If the caller sees this
1629 * error, it knows that the unlock succeeded anyway.
1632 svn_repos_fs_unlock(svn_repos_t
*repos
,
1635 svn_boolean_t break_lock
,
1640 /** Look up all the locks in and under @a path in @a repos, setting @a
1641 * *locks to a hash which maps <tt>const char *</tt> paths to the @c
1642 * svn_lock_t locks associated with those paths. Use @a
1643 * authz_read_func and @a authz_read_baton to "screen" all returned
1644 * locks. That is: do not return any locks on any paths that are
1645 * unreadable in HEAD, just silently omit them.
1648 svn_repos_fs_get_locks(apr_hash_t
**locks
,
1651 svn_repos_authz_func_t authz_read_func
,
1652 void *authz_read_baton
,
1658 * Like svn_fs_change_rev_prop(), but invoke the @a repos's pre- and
1659 * post-revprop-change hooks around the change as specified by @a
1660 * use_pre_revprop_change_hook and @a use_post_revprop_change_hook
1661 * (respectively). Use @a pool for temporary allocations.
1663 * @a rev is the revision whose property to change, @a name is the
1664 * name of the property, and @a new_value is the new value of the
1665 * property. @a author is the authenticated username of the person
1666 * changing the property value, or NULL if not available.
1668 * If @a authz_read_func is non-NULL, then use it (with @a
1669 * authz_read_baton) to validate the changed-paths associated with @a
1670 * rev. If the revision contains any unreadable changed paths, then
1671 * return SVN_ERR_AUTHZ_UNREADABLE.
1673 * @since New in 1.5.
1676 svn_repos_fs_change_rev_prop3(svn_repos_t
*repos
,
1680 const svn_string_t
*new_value
,
1682 use_pre_revprop_change_hook
,
1684 use_post_revprop_change_hook
,
1685 svn_repos_authz_func_t
1687 void *authz_read_baton
,
1691 * Similar to svn_repos_fs_change_rev_prop3(), but with the @a
1692 * use_pre_revprop_change_hook and @a use_post_revprop_change_hook
1693 * always set to @c TRUE.
1695 * @deprecated Provided for backward compatibility with the 1.4 API.
1698 svn_repos_fs_change_rev_prop2(svn_repos_t
*repos
,
1702 const svn_string_t
*new_value
,
1703 svn_repos_authz_func_t
1705 void *authz_read_baton
,
1709 * Similar to svn_repos_fs_change_rev_prop2(), but with the
1710 * @a authz_read_func parameter always NULL.
1712 * @deprecated Provided for backward compatibility with the 1.0 API.
1715 svn_repos_fs_change_rev_prop(svn_repos_t
*repos
,
1719 const svn_string_t
*new_value
,
1725 * Set @a *value_p to the value of the property named @a propname on
1726 * revision @a rev in the filesystem opened in @a repos. If @a rev
1727 * has no property by that name, set @a *value_p to zero. Allocate
1728 * the result in @a pool.
1730 * If @a authz_read_func is non-NULL, then use it (with @a
1731 * authz_read_baton) to validate the changed-paths associated with @a
1732 * rev. If the changed-paths are all unreadable, then set @a *value_p
1733 * to zero unconditionally. If only some of the changed-paths are
1734 * unreadable, then allow 'svn:author' and 'svn:date' propvalues to be
1735 * fetched, but return 0 for any other property.
1737 * @since New in 1.1.
1740 svn_repos_fs_revision_prop(svn_string_t
**value_p
,
1743 const char *propname
,
1744 svn_repos_authz_func_t
1746 void *authz_read_baton
,
1751 * Set @a *table_p to the entire property list of revision @a rev in
1752 * filesystem opened in @a repos, as a hash table allocated in @a
1753 * pool. The table maps <tt>char *</tt> property names to @c
1754 * svn_string_t * values; the names and values are allocated in @a
1757 * If @a authz_read_func is non-NULL, then use it (with @a
1758 * authz_read_baton) to validate the changed-paths associated with @a
1759 * rev. If the changed-paths are all unreadable, then return an empty
1760 * hash. If only some of the changed-paths are unreadable, then return
1761 * an empty hash, except for 'svn:author' and 'svn:date' properties
1762 * (assuming those properties exist).
1764 * @since New in 1.1.
1767 svn_repos_fs_revision_proplist(apr_hash_t
**table_p
,
1770 svn_repos_authz_func_t
1772 void *authz_read_baton
,
1777 /* ---------------------------------------------------------------*/
1779 /* Prop-changing wrappers for libsvn_fs routines. */
1781 /* NOTE: svn_repos_fs_change_rev_prop() also exists, but is located
1782 above with the hook-related functions. */
1785 /** Validating wrapper for svn_fs_change_node_prop() (which see for
1786 * argument descriptions).
1789 svn_repos_fs_change_node_prop(svn_fs_root_t
*root
,
1792 const svn_string_t
*value
,
1795 /** Validating wrapper for svn_fs_change_txn_prop() (which see for
1796 * argument descriptions).
1799 svn_repos_fs_change_txn_prop(svn_fs_txn_t
*txn
,
1801 const svn_string_t
*value
,
1804 /** Validating wrapper for svn_fs_change_txn_props() (which see for
1805 * argument descriptions).
1807 * @since New in 1.5.
1810 svn_repos_fs_change_txn_props(svn_fs_txn_t
*txn
,
1811 apr_array_header_t
*props
,
1816 /* ---------------------------------------------------------------*/
1819 * @defgroup svn_repos_inspection Data structures and editor things for
1820 * repository inspection.
1823 * As it turns out, the svn_repos_dir_delta2() interface can be
1824 * extremely useful for examining the repository, or more exactly,
1825 * changes to the repository. svn_repos_dir_delta2() allows for
1826 * differences between two trees to be described using an editor.
1828 * By using the editor obtained from svn_repos_node_editor() with
1829 * svn_repos_dir_delta2(), the description of how to transform one tree
1830 * into another can be used to build an in-memory linked-list tree,
1831 * which each node representing a repository node that was changed as a
1832 * result of having svn_repos_dir_delta2() drive that editor.
1835 /** A node in the repository. */
1836 typedef struct svn_repos_node_t
1838 /** Node type (file, dir, etc.) */
1839 svn_node_kind_t kind
;
1841 /** How this node entered the node tree: 'A'dd, 'D'elete, 'R'eplace */
1844 /** Were there any textual mods? (files only) */
1845 svn_boolean_t text_mod
;
1847 /** Where there any property mods? */
1848 svn_boolean_t prop_mod
;
1850 /** The name of this node as it appears in its parent's entries list */
1853 /** The filesystem revision where this was copied from (if any) */
1854 svn_revnum_t copyfrom_rev
;
1856 /** The filesystem path where this was copied from (if any) */
1857 const char *copyfrom_path
;
1859 /** Pointer to the next sibling of this node */
1860 struct svn_repos_node_t
*sibling
;
1862 /** Pointer to the first child of this node */
1863 struct svn_repos_node_t
*child
;
1865 /** Pointer to the parent of this node */
1866 struct svn_repos_node_t
*parent
;
1871 /** Set @a *editor and @a *edit_baton to an editor that, when driven by
1872 * svn_repos_dir_delta2(), builds an <tt>svn_repos_node_t *</tt> tree
1873 * representing the delta from @a base_root to @a root in @a repos's
1876 * Invoke svn_repos_node_from_baton() on @a edit_baton to obtain the root
1879 * Note that the delta includes "bubbled-up" directories; that is,
1880 * many of the directory nodes will have no prop_mods.
1882 * Allocate the tree and its contents in @a node_pool; do all other
1883 * allocation in @a pool.
1886 svn_repos_node_editor(const svn_delta_editor_t
**editor
,
1889 svn_fs_root_t
*base_root
,
1890 svn_fs_root_t
*root
,
1891 apr_pool_t
*node_pool
,
1894 /** Return the root node of the linked-list tree generated by driving
1895 * the editor created by svn_repos_node_editor() with
1896 * svn_repos_dir_delta2(), which is stored in @a edit_baton. This is
1897 * only really useful if used *after* the editor drive is completed.
1899 svn_repos_node_t
*svn_repos_node_from_baton(void *edit_baton
);
1903 /* ---------------------------------------------------------------*/
1906 * @defgroup svn_repos_dump_load Dumping and loading filesystem data
1909 * The filesystem 'dump' format contains nothing but the abstract
1910 * structure of the filesystem -- independent of any internal node-id
1911 * schema or database back-end. All of the data in the dumpfile is
1912 * acquired by public function calls into svn_fs.h. Similarly, the
1913 * parser which reads the dumpfile is able to reconstruct the
1914 * filesystem using only public svn_fs.h routines.
1916 * Thus the dump/load feature's main purpose is for *migrating* data
1917 * from one svn filesystem to another -- presumably two filesystems
1918 * which have different internal implementations.
1920 * If you simply want to backup your filesystem, you're probably
1921 * better off using the built-in facilities of the DB backend (using
1922 * Berkeley DB's hot-backup feature, for example.)
1924 * For a description of the dumpfile format, see
1925 * /trunk/notes/fs_dumprestore.txt.
1928 /* The RFC822-style headers in our dumpfile format. */
1929 #define SVN_REPOS_DUMPFILE_MAGIC_HEADER "SVN-fs-dump-format-version"
1930 #define SVN_REPOS_DUMPFILE_FORMAT_VERSION 3
1931 #define SVN_REPOS_DUMPFILE_UUID "UUID"
1932 #define SVN_REPOS_DUMPFILE_CONTENT_LENGTH "Content-length"
1934 #define SVN_REPOS_DUMPFILE_REVISION_NUMBER "Revision-number"
1936 #define SVN_REPOS_DUMPFILE_NODE_PATH "Node-path"
1937 #define SVN_REPOS_DUMPFILE_NODE_KIND "Node-kind"
1938 #define SVN_REPOS_DUMPFILE_NODE_ACTION "Node-action"
1939 #define SVN_REPOS_DUMPFILE_NODE_COPYFROM_PATH "Node-copyfrom-path"
1940 #define SVN_REPOS_DUMPFILE_NODE_COPYFROM_REV "Node-copyfrom-rev"
1941 #define SVN_REPOS_DUMPFILE_TEXT_COPY_SOURCE_CHECKSUM "Text-copy-source-md5"
1942 #define SVN_REPOS_DUMPFILE_TEXT_CONTENT_CHECKSUM "Text-content-md5"
1944 #define SVN_REPOS_DUMPFILE_PROP_CONTENT_LENGTH "Prop-content-length"
1945 #define SVN_REPOS_DUMPFILE_TEXT_CONTENT_LENGTH "Text-content-length"
1947 /* @since New in 1.1. */
1948 #define SVN_REPOS_DUMPFILE_PROP_DELTA "Prop-delta"
1949 /* @since New in 1.1. */
1950 #define SVN_REPOS_DUMPFILE_TEXT_DELTA "Text-delta"
1951 /* @since New in 1.5. */
1952 #define SVN_REPOS_DUMPFILE_TEXT_DELTA_BASE_CHECKSUM "Text-delta-base-md5"
1954 /** The different "actions" attached to nodes in the dumpfile. */
1955 enum svn_node_action
1957 svn_node_action_change
,
1958 svn_node_action_add
,
1959 svn_node_action_delete
,
1960 svn_node_action_replace
1963 /** The different policies for processing the UUID in the dumpfile. */
1964 enum svn_repos_load_uuid
1966 svn_repos_load_uuid_default
,
1967 svn_repos_load_uuid_ignore
,
1968 svn_repos_load_uuid_force
1973 * Verify the contents of the file system in @a repos.
1975 * If @a feedback_stream is not @c NULL, write feedback to it (lines of
1976 * the form "* Verified revision %ld\n").
1978 * If @a start_rev is @c SVN_INVALID_REVNUM, then start verifying at
1979 * revision 0. If @a end_rev is @c SVN_INVALID_REVNUM, then verify
1980 * through the @c HEAD revision.
1982 * If @a cancel_func is not @c NULL, call it periodically with @a
1983 * cancel_baton as argument to see if the caller wishes to cancel the
1986 * @since New in 1.6.
1989 svn_repos_verify_fs(svn_repos_t
*repos
,
1990 svn_stream_t
*feedback_stream
,
1991 svn_revnum_t start_rev
,
1992 svn_revnum_t end_rev
,
1993 svn_cancel_func_t cancel_func
,
1999 * Dump the contents of the filesystem within already-open @a repos into
2000 * writable @a dumpstream. Begin at revision @a start_rev, and dump every
2001 * revision up through @a end_rev. Use @a pool for all allocation. If
2002 * non-@c NULL, send feedback to @a feedback_stream. If @a dumpstream is
2003 * @c NULL, this is effectively a primitive verify. It is not complete,
2004 * however; see svn_fs_verify instead.
2006 * If @a start_rev is @c SVN_INVALID_REVNUM, then start dumping at revision
2007 * 0. If @a end_rev is @c SVN_INVALID_REVNUM, then dump through the @c HEAD
2010 * If @a incremental is @c TRUE, the first revision dumped will be a diff
2011 * against the previous revision (usually it looks like a full dump of
2014 * If @a use_deltas is @c TRUE, output only node properties which have
2015 * changed relative to the previous contents, and output text contents
2016 * as svndiff data against the previous contents. Regardless of how
2017 * this flag is set, the first revision of a non-incremental dump will
2018 * be done with full plain text. A dump with @a use_deltas set cannot
2019 * be loaded by Subversion 1.0.x.
2021 * If @a cancel_func is not @c NULL, it is called periodically with
2022 * @a cancel_baton as argument to see if the client wishes to cancel
2025 * @since New in 1.1.
2028 svn_repos_dump_fs2(svn_repos_t
*repos
,
2029 svn_stream_t
*dumpstream
,
2030 svn_stream_t
*feedback_stream
,
2031 svn_revnum_t start_rev
,
2032 svn_revnum_t end_rev
,
2033 svn_boolean_t incremental
,
2034 svn_boolean_t use_deltas
,
2035 svn_cancel_func_t cancel_func
,
2041 * Similar to svn_repos_dump_fs2(), but with the @a use_deltas
2042 * parameter always set to @c FALSE.
2044 * @deprecated Provided for backward compatibility with the 1.0 API.
2047 svn_repos_dump_fs(svn_repos_t
*repos
,
2048 svn_stream_t
*dumpstream
,
2049 svn_stream_t
*feedback_stream
,
2050 svn_revnum_t start_rev
,
2051 svn_revnum_t end_rev
,
2052 svn_boolean_t incremental
,
2053 svn_cancel_func_t cancel_func
,
2059 * Read and parse dumpfile-formatted @a dumpstream, reconstructing
2060 * filesystem revisions in already-open @a repos, handling uuids
2061 * in accordance with @a uuid_action.
2063 * Read and parse dumpfile-formatted @a dumpstream, reconstructing
2064 * filesystem revisions in already-open @a repos. Use @a pool for all
2065 * allocation. If non-@c NULL, send feedback to @a feedback_stream.
2067 * If the dumpstream contains copy history that is unavailable in the
2068 * repository, an error will be thrown.
2070 * The repository's UUID will be updated iff
2071 * the dumpstream contains a UUID and
2072 * @a uuid_action is not equal to @c svn_repos_load_uuid_ignore and
2073 * either the repository contains no revisions or
2074 * @a uuid_action is equal to @c svn_repos_load_uuid_force.
2076 * If the dumpstream contains no UUID, then @a uuid_action is
2077 * ignored and the repository UUID is not touched.
2079 * If @a parent_dir is not NULL, then the parser will reparent all the
2080 * loaded nodes, from root to @a parent_dir. The directory @a parent_dir
2081 * must be an existing directory in the repository.
2083 * If @a use_pre_commit_hook is set, call the repository's pre-commit
2084 * hook before committing each loaded revision.
2086 * If @a use_post_commit_hook is set, call the repository's
2087 * post-commit hook after committing each loaded revision.
2089 * If @a cancel_func is not @c NULL, it is called periodically with
2090 * @a cancel_baton as argument to see if the client wishes to cancel
2093 * @since New in 1.2.
2096 svn_repos_load_fs2(svn_repos_t
*repos
,
2097 svn_stream_t
*dumpstream
,
2098 svn_stream_t
*feedback_stream
,
2099 enum svn_repos_load_uuid uuid_action
,
2100 const char *parent_dir
,
2101 svn_boolean_t use_pre_commit_hook
,
2102 svn_boolean_t use_post_commit_hook
,
2103 svn_cancel_func_t cancel_func
,
2108 * Similar to svn_repos_load_fs2(), but with @a use_pre_commit_hook and
2109 * @a use_post_commit_hook always @c FALSE.
2111 * @deprecated Provided for backward compatibility with the 1.0 API.
2114 svn_repos_load_fs(svn_repos_t
*repos
,
2115 svn_stream_t
*dumpstream
,
2116 svn_stream_t
*feedback_stream
,
2117 enum svn_repos_load_uuid uuid_action
,
2118 const char *parent_dir
,
2119 svn_cancel_func_t cancel_func
,
2125 * A vtable that is driven by svn_repos_parse_dumpstream2().
2127 * @since New in 1.1.
2129 typedef struct svn_repos_parse_fns2_t
2131 /** The parser has discovered a new revision record within the
2132 * parsing session represented by @a parse_baton. All the headers are
2133 * placed in @a headers (allocated in @a pool), which maps <tt>const
2134 * char *</tt> header-name ==> <tt>const char *</tt> header-value.
2135 * The @a revision_baton received back (also allocated in @a pool)
2136 * represents the revision.
2138 svn_error_t
*(*new_revision_record
)(void **revision_baton
,
2139 apr_hash_t
*headers
,
2143 /** The parser has discovered a new uuid record within the parsing
2144 * session represented by @a parse_baton. The uuid's value is
2145 * @a uuid, and it is allocated in @a pool.
2147 svn_error_t
*(*uuid_record
)(const char *uuid
,
2151 /** The parser has discovered a new node record within the current
2152 * revision represented by @a revision_baton. All the headers are
2153 * placed in @a headers (as with @c new_revision_record), allocated in
2154 * @a pool. The @a node_baton received back is allocated in @a pool
2155 * and represents the node.
2157 svn_error_t
*(*new_node_record
)(void **node_baton
,
2158 apr_hash_t
*headers
,
2159 void *revision_baton
,
2162 /** For a given @a revision_baton, set a property @a name to @a value. */
2163 svn_error_t
*(*set_revision_property
)(void *revision_baton
,
2165 const svn_string_t
*value
);
2167 /** For a given @a node_baton, set a property @a name to @a value. */
2168 svn_error_t
*(*set_node_property
)(void *node_baton
,
2170 const svn_string_t
*value
);
2172 /** For a given @a node_baton, delete property @a name. */
2173 svn_error_t
*(*delete_node_property
)(void *node_baton
, const char *name
);
2175 /** For a given @a node_baton, remove all properties. */
2176 svn_error_t
*(*remove_node_props
)(void *node_baton
);
2178 /** For a given @a node_baton, receive a writable @a stream capable of
2179 * receiving the node's fulltext. After writing the fulltext, call
2180 * the stream's close() function.
2182 * If a @c NULL is returned instead of a stream, the vtable is
2183 * indicating that no text is desired, and the parser will not
2184 * attempt to send it.
2186 svn_error_t
*(*set_fulltext
)(svn_stream_t
**stream
,
2189 /** For a given @a node_baton, set @a handler and @a handler_baton
2190 * to a window handler and baton capable of receiving a delta
2191 * against the node's previous contents. A NULL window will be
2192 * sent to the handler after all the windows are sent.
2194 * If a @c NULL is returned instead of a handler, the vtable is
2195 * indicating that no delta is desired, and the parser will not
2196 * attempt to send it.
2198 svn_error_t
*(*apply_textdelta
)(svn_txdelta_window_handler_t
*handler
,
2199 void **handler_baton
,
2202 /** The parser has reached the end of the current node represented by
2203 * @a node_baton, it can be freed.
2205 svn_error_t
*(*close_node
)(void *node_baton
);
2207 /** The parser has reached the end of the current revision
2208 * represented by @a revision_baton. In other words, there are no more
2209 * changed nodes within the revision. The baton can be freed.
2211 svn_error_t
*(*close_revision
)(void *revision_baton
);
2213 } svn_repos_parse_fns2_t
;
2215 /** @deprecated Provided for backward compatibility with the 1.2 API. */
2216 typedef svn_repos_parse_fns2_t svn_repos_parser_fns2_t
;
2220 * Read and parse dumpfile-formatted @a stream, calling callbacks in
2221 * @a parse_fns/@a parse_baton, and using @a pool for allocations.
2223 * If @a cancel_func is not @c NULL, it is called periodically with
2224 * @a cancel_baton as argument to see if the client wishes to cancel
2227 * This parser has built-in knowledge of the dumpfile format, but only
2228 * in a general sense:
2230 * * it recognizes revision and node records by looking for either
2231 * a REVISION_NUMBER or NODE_PATH headers.
2233 * * it recognizes the CONTENT-LENGTH headers, so it knows if and
2234 * how to suck up the content body.
2236 * * it knows how to parse a content body into two parts: props
2237 * and text, and pass the pieces to the vtable.
2239 * This is enough knowledge to make it easy on vtable implementors,
2240 * but still allow expansion of the format: most headers are ignored.
2242 * @since New in 1.1.
2245 svn_repos_parse_dumpstream2(svn_stream_t
*stream
,
2246 const svn_repos_parse_fns2_t
*parse_fns
,
2248 svn_cancel_func_t cancel_func
,
2254 * Set @a *parser and @a *parse_baton to a vtable parser which commits new
2255 * revisions to the fs in @a repos. The constructed parser will treat
2256 * UUID records in a manner consistent with @a uuid_action. Use @a pool
2257 * to operate on the fs.
2259 * If @a use_history is set, then the parser will require relative
2260 * 'copyfrom' history to exist in the repository when it encounters
2261 * nodes that are added-with-history.
2263 * If @a parent_dir is not NULL, then the parser will reparent all the
2264 * loaded nodes, from root to @a parent_dir. The directory @a parent_dir
2265 * must be an existing directory in the repository.
2267 * Print all parsing feedback to @a outstream (if non-@c NULL).
2270 * @since New in 1.1.
2273 svn_repos_get_fs_build_parser2(const svn_repos_parse_fns2_t
**parser
,
2276 svn_boolean_t use_history
,
2277 enum svn_repos_load_uuid uuid_action
,
2278 svn_stream_t
*outstream
,
2279 const char *parent_dir
,
2284 * A vtable that is driven by svn_repos_parse_dumpstream().
2285 * Similar to @c svn_repos_parse_fns2_t except that it lacks
2286 * the delete_node_property and apply_textdelta callbacks.
2288 * @deprecated Provided for backward compatibility with the 1.0 API.
2290 typedef struct svn_repos_parse_fns_t
2292 /** Same as the corresponding field in @c svn_repos_parse_fns2_t. */
2293 svn_error_t
*(*new_revision_record
)(void **revision_baton
,
2294 apr_hash_t
*headers
,
2297 /** Same as the corresponding field in @c svn_repos_parse_fns2_t. */
2298 svn_error_t
*(*uuid_record
)(const char *uuid
,
2301 /** Same as the corresponding field in @c svn_repos_parse_fns2_t. */
2302 svn_error_t
*(*new_node_record
)(void **node_baton
,
2303 apr_hash_t
*headers
,
2304 void *revision_baton
,
2306 /** Same as the corresponding field in @c svn_repos_parse_fns2_t. */
2307 svn_error_t
*(*set_revision_property
)(void *revision_baton
,
2309 const svn_string_t
*value
);
2310 /** Same as the corresponding field in @c svn_repos_parse_fns2_t. */
2311 svn_error_t
*(*set_node_property
)(void *node_baton
,
2313 const svn_string_t
*value
);
2314 /** Same as the corresponding field in @c svn_repos_parse_fns2_t. */
2315 svn_error_t
*(*remove_node_props
)(void *node_baton
);
2316 /** Same as the corresponding field in @c svn_repos_parse_fns2_t. */
2317 svn_error_t
*(*set_fulltext
)(svn_stream_t
**stream
,
2319 /** Same as the corresponding field in @c svn_repos_parse_fns2_t. */
2320 svn_error_t
*(*close_node
)(void *node_baton
);
2321 /** Same as the corresponding field in @c svn_repos_parse_fns2_t. */
2322 svn_error_t
*(*close_revision
)(void *revision_baton
);
2323 } svn_repos_parser_fns_t
;
2327 * Similar to svn_repos_parse_dumpstream2(), but uses the more limited
2328 * @c svn_repos_parser_fns_t vtable type.
2330 * @deprecated Provided for backward compatibility with the 1.0 API.
2333 svn_repos_parse_dumpstream(svn_stream_t
*stream
,
2334 const svn_repos_parser_fns_t
*parse_fns
,
2336 svn_cancel_func_t cancel_func
,
2342 * Similar to svn_repos_get_fs_build_parser2(), but yields the more
2343 * limited svn_repos_parser_fns_t vtable type.
2345 * @deprecated Provided for backward compatibility with the 1.0 API.
2348 svn_repos_get_fs_build_parser(const svn_repos_parser_fns_t
**parser
,
2351 svn_boolean_t use_history
,
2352 enum svn_repos_load_uuid uuid_action
,
2353 svn_stream_t
*outstream
,
2354 const char *parent_dir
,
2360 /** A data type which stores the authz information.
2362 * @since New in 1.3.
2364 typedef struct svn_authz_t svn_authz_t
;
2366 /** Read authz configuration data from @a file (a file or registry
2367 * path) into @a *authz_p, allocated in @a pool.
2369 * If @a file is not a valid authz rule file, then return
2370 * SVN_AUTHZ_INVALID_CONFIG. The contents of @a *authz_p is then
2371 * undefined. If @a must_exist is TRUE, a missing authz file is also
2374 * @since New in 1.3.
2377 svn_repos_authz_read(svn_authz_t
**authz_p
,
2379 svn_boolean_t must_exist
,
2383 * Check whether @a user can access @a path in the repository @a
2384 * repos_name with the @a required_access. @a authz lists the ACLs to
2385 * check against. Set @a *access_granted to indicate if the requested
2386 * access is granted.
2388 * If @a path is NULL, then check whether @a user has the @a
2389 * required_access anywhere in the repository. Set @a *access_granted
2390 * to TRUE if at least one path is accessible with the @a
2393 * @since New in 1.3.
2396 svn_repos_authz_check_access(svn_authz_t
*authz
,
2397 const char *repos_name
,
2400 svn_repos_authz_access_t required_access
,
2401 svn_boolean_t
*access_granted
,
2406 /** Revision Access Levels
2408 * Like most version control systems, access to versioned objects in
2409 * Subversion is determined on primarily path-based system. Users either
2410 * do or don't have the ability to read a given path.
2412 * However, unlike many version control systems where versioned objects
2413 * maintain their own distinct version information (revision numbers,
2414 * authors, log messages, change timestamps, etc.), Subversion binds
2415 * multiple paths changed as part of a single commit operation into a
2416 * set, calls the whole thing a revision, and hangs commit metadata
2417 * (author, date, log message, etc.) off of that revision. So, commit
2418 * metadata is shared across all the paths changed as part of a given
2421 * It is common (or, at least, we hope it is) for log messages to give
2422 * detailed information about changes made in the commit to which the log
2423 * message is attached. Such information might include a mention of all
2424 * the files changed, what was changed in them, and so on. But this
2425 * causes a problem when presenting information to readers who aren't
2426 * authorized to read every path in the repository. Simply knowing that
2427 * a given path exists may be a security leak, even if the user can't see
2428 * the contents of the data located at that path.
2430 * So Subversion does what it reasonably can to prevent the leak of this
2431 * information, and does so via a staged revision access policy. A
2432 * reader can be said to have one of three levels of access to a given
2433 * revision's metadata, based solely on the reader's access rights to the
2434 * paths changed or copied in that revision:
2436 * 'full access' -- Granted when the reader has access to all paths
2437 * changed or copied in the revision, or when no paths were
2438 * changed in the revision at all, this access level permits
2439 * full visibility of all revision property names and values,
2440 * and the full changed-paths information.
2442 * 'no access' -- Granted when the reader does not have access to any
2443 * paths changed or copied in the revision, this access level
2444 * denies the reader access to all revision properties and all
2445 * changed-paths information.
2447 * 'partial access' -- Granted when the reader has access to at least
2448 * one, but not all, of the paths changed or copied in the revision,
2449 * this access level permits visibility of the svn:date and
2450 * svn:author revision properties and only the paths of the
2451 * changed-paths information to which the reader has access.
2456 /** An enum defining levels of revision access.
2458 * @since New in 1.5.
2462 svn_repos_revision_access_none
,
2463 svn_repos_revision_access_partial
,
2464 svn_repos_revision_access_full
2466 svn_repos_revision_access_level_t
;
2470 * Set @a access to the access level granted for @a revision in @a
2471 * repos, as determined by consulting the @a authz_read_func callback
2472 * function and its associated @a authz_read_baton.
2474 * @a authz_read_func may be @c NULL, in which case @a access will be
2475 * set to @c svn_repos_revision_access_full.
2477 * @since New in 1.5.
2480 svn_repos_check_revision_access(svn_repos_revision_access_level_t
*access_level
,
2482 svn_revnum_t revision
,
2483 svn_repos_authz_func_t authz_read_func
,
2484 void *authz_read_baton
,
2489 /** Capabilities **/
2492 * Store in @a repos the client-reported capabilities @a capabilities,
2493 * which must be allocated in memory at least as long-lived as @a repos.
2495 * The elements of @a capabilities are 'const char *', a subset of
2496 * the constants beginning with @c SVN_RA_CAPABILITY_.
2497 * @a capabilities is not copied, so changing it later will affect
2498 * what is remembered by @a repos.
2500 * @note The capabilities are passed along to the start-commit hook;
2501 * see that hook's template for details.
2503 * @note As of Subversion 1.5, there are no error conditions defined,
2504 * so this always returns SVN_NO_ERROR. In future releases it may
2505 * return error, however, so callers should check.
2507 * @since New in 1.5.
2510 svn_repos_remember_client_capabilities(svn_repos_t
*repos
,
2511 apr_array_header_t
*capabilities
);
2517 #endif /* __cplusplus */
2519 #endif /* SVN_REPOS_H */