⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 svn_path.h

📁 subversion-1.4.3-1.tar.gz 配置svn的源码
💻 H
📖 第 1 页 / 共 2 页
字号:
/** Find the common prefix of the canonicalized paths in @a targets * (an array of @a const char *'s), and remove redundant paths if @a * remove_redundancies is true. * *   - Set @a *pcommon to the absolute path of the path or URL common to *     all of the targets.  If the targets have no common prefix, or *     are a mix of URLs and local paths, set @a *pcommon to the *     empty string. * *   - If @a pcondensed_targets is non-null, set @a *pcondensed_targets *     to an array of targets relative to @a *pcommon, and if  *     @a remove_redundancies is true, omit any paths/URLs that are *     descendants of another path/URL in @a targets.  If *pcommon *     is empty, @a *pcondensed_targets will contain full URLs and/or *     absolute paths; redundancies can still be removed (from both URLs  *     and paths).  If @a pcondensed_targets is null, leave it alone.   * * Else if there is exactly one target, then * *   - Set @a *pcommon to that target, and * *   - If @a pcondensed_targets is non-null, set @a *pcondensed_targets *     to an array containing zero elements.  Else if *     @a pcondensed_targets is null, leave it alone. * * If there are no items in @a targets, set @a *pcommon and (if * applicable) @a *pcondensed_targets to @c NULL. * * @note There is no guarantee that @a *pcommon is within a working * copy.  */svn_error_t *svn_path_condense_targets(const char **pcommon,                          apr_array_header_t **pcondensed_targets,                          const apr_array_header_t *targets,                          svn_boolean_t remove_redundancies,                          apr_pool_t *pool);/** Copy a list of canonicalized @a targets, one at a time, into @a * pcondensed_targets, omitting any targets that are found earlier in * the list, or whose ancestor is found earlier in the list.  Ordering * of targets in the original list is preserved in the condensed list * of targets.  Use @a pool for any allocations. * * How does this differ in functionality from svn_path_condense_targets()? * * Here's the short version: *  * 1.  Disclaimer: if you wish to debate the following, talk to Karl. :-) *     Order matters for updates because a multi-arg update is not *     atomic, and CVS users are used to, when doing 'cvs up targetA *     targetB' seeing targetA get updated, then targetB.  I think the *     idea is that if you're in a time-sensitive or flaky-network *     situation, a user can say, "I really *need* to update *     wc/A/D/G/tau, but I might as well update my whole working copy if *     I can."  So that user will do 'svn up wc/A/D/G/tau wc', and if *     something dies in the middles of the 'wc' update, at least the *     user has 'tau' up-to-date. *  * 2.  Also, we have this notion of an anchor and a target for updates *     (the anchor is where the update editor is rooted, the target is *     the actual thing we want to update).  I needed a function that *     would NOT screw with my input paths so that I could tell the *     difference between someone being in A/D and saying 'svn up G' and *     being in A/D/G and saying 'svn up .' -- believe it or not, these *     two things don't mean the same thing.  svn_path_condense_targets() *     plays with absolute paths (which is fine, so does *     svn_path_remove_redundancies()), but the difference is that it *     actually tweaks those targets to be relative to the "grandfather *     path" common to all the targets.  Updates don't require a *     "grandfather path" at all, and even if it did, the whole *     conversion to an absolute path drops the crucial difference *     between saying "i'm in foo, update bar" and "i'm in foo/bar, *     update '.'" */svn_error_t *svn_path_remove_redundancies(apr_array_header_t **pcondensed_targets,                             const apr_array_header_t *targets,                             apr_pool_t *pool);/** Decompose the canonicalized @a path into an array of <tt>const * char *</tt> components, allocated in @a pool.  If @a path is * absolute, the first component will be a lone dir separator (the * root directory). */apr_array_header_t *svn_path_decompose(const char *path,                                       apr_pool_t *pool);/** Test that @a name is a single path component, that is: *   - not @c NULL or empty. *   - not a `/'-separated directory path *   - not empty or `..'   */svn_boolean_t svn_path_is_single_path_component(const char *name);/** * Test to see if a backpath, i.e. '..', is present in @a path. * If not, return @c FALSE. * If so, return @c TRUE. * * @since New in 1.1. */svn_boolean_t svn_path_is_backpath_present(const char *path);/** Test if @a path2 is a child of @a path1. * If not, return @c NULL. * If so, return a copy of the remainder path, allocated in @a pool. * (The remainder is the component which, added to @a path1, yields * @a path2.  The remainder does not begin with a dir separator.)   * * Both paths must be in canonical form, and must either be absolute, * or contain no ".." components. * * If @a path2 is the same as @a path1, it is not considered a child, so the * result is @c NULL; an empty string is never returned. * * ### todo: the ".." restriction is unfortunate, and would ideally * be lifted by making the implementation smarter.  But this is not * trivial: if the path is "../foo", how do you know whether or not * the current directory is named "foo" in its parent? */const char *svn_path_is_child(const char *path1,                              const char *path2,                              apr_pool_t *pool);/** Return true if @a path1 is an ancestor of @a path2 or the paths are equal * and false otherwise. * * @since New in 1.3. */svn_boolean_tsvn_path_is_ancestor(const char *path1, const char *path2);/** * Check whether @a path is a valid Subversion path. * * A valid Subversion pathname is a UTF-8 string without control * characters.  "Valid" means Subversion can store the pathname in * a repository.  There may be other, OS-specific, limitations on * what paths can be represented in a working copy. * * ASSUMPTION: @a path is a valid UTF-8 string.  This function does * not check UTF-8 validity. * * Return @c SVN_NO_ERROR if valid and @c SVN_ERR_FS_PATH_SYNTAX if * invalid. *  * @since New in 1.2. */svn_error_t *svn_path_check_valid(const char *path, apr_pool_t *pool);/** URI/URL stuff * * @defgroup svn_path_uri_stuff URI/URL stuff * @{ *//** Return @c TRUE iff @a path looks like a valid URL, @c FALSE otherwise. */svn_boolean_t svn_path_is_url(const char *path);/** Return @c TRUE iff @a path is URI-safe, @c FALSE otherwise. */svn_boolean_t svn_path_is_uri_safe(const char *path);/** Return a URI-encoded copy of @a path, allocated in @a pool. */const char *svn_path_uri_encode(const char *path, apr_pool_t *pool);/** Return a URI-decoded copy of @a path, allocated in @a pool. */const char *svn_path_uri_decode(const char *path, apr_pool_t *pool);/** Extend @a url by a single @a component, URI-encoding that @a component * before adding it to the @a url.  Return the new @a url, allocated in * @a pool.  Notes: if @a component is @c NULL, just return a copy or @a url * allocated in @a pool; if @a component is already URI-encoded, calling * code should just use <tt>svn_path_join (url, component, pool)</tt>.  @a url * does not need to be a canonical path, it may have trailing '/'. */const char *svn_path_url_add_component(const char *url,                                       const char *component,                                       apr_pool_t *pool);/** * Convert @a iri (Internationalized URI) to an URI. * The return value may be the same as @a iri if it was already * a URI.  Else, allocate the return value in @a pool. * * @since New in 1.1. */const char *svn_path_uri_from_iri(const char *iri,                                  apr_pool_t *pool);/** * URI-encode certain characters in @a uri that are not valid in an URI, but * doesn't have any special meaning in @a uri at their positions.  If no * characters need escaping, just return @a uri. * * @note Currently, this function escapes <, >, ", space, {, }, |, \, ^, and `. * This may be extended in the future to do context-dependent escaping. * * @since New in 1.1. */const char *svn_path_uri_autoescape(const char *uri,                                    apr_pool_t *pool);/** @} *//** Charset conversion stuff * * @defgroup svn_path_charset_stuff Charset conversion stuff * @{ *//** Convert @a path_utf8 from UTF-8 to the internal encoding used by APR. */svn_error_t *svn_path_cstring_from_utf8(const char **path_apr,                                        const char *path_utf8,                                        apr_pool_t *pool);/** Convert @a path_apr from the internal encoding used by APR to UTF-8. */svn_error_t *svn_path_cstring_to_utf8(const char **path_utf8,                                      const char *path_apr,                                      apr_pool_t *pool);/** @} */#ifdef __cplusplus}#endif /* __cplusplus */#endif /* SVN_PATH_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -