Alien-SVN
view release on metacpan or search on metacpan
src/subversion/subversion/libsvn_ra_local/ra_plugin.c view on Meta::CPAN
#include "svn_repos.h"
#include "svn_pools.h"
#include "svn_time.h"
#include "svn_props.h"
#include "svn_mergeinfo.h"
#include "svn_path.h"
#include "svn_version.h"
#include "svn_cache_config.h"
#include "svn_private_config.h"
#include "../libsvn_ra/ra_loader.h"
#include "private/svn_mergeinfo_private.h"
#include "private/svn_repos_private.h"
#include "private/svn_fspath.h"
#include "private/svn_atomic.h"
#include "private/svn_subr_private.h"
#define APR_WANT_STRFUNC
#include <apr_want.h>
/*----------------------------------------------------------------*/
/*** Miscellaneous helper functions ***/
/* Pool cleanup handler: ensure that the access descriptor of the
filesystem (svn_fs_t *) DATA is set to NULL. */
static apr_status_t
cleanup_access(void *data)
{
svn_error_t *serr;
svn_fs_t *fs = data;
serr = svn_fs_set_access(fs, NULL);
if (serr)
{
apr_status_t apr_err = serr->apr_err;
svn_error_clear(serr);
return apr_err;
}
return APR_SUCCESS;
}
/* Fetch a username for use with SESSION, and store it in SESSION->username.
*
* Allocate the username in SESSION->pool. Use SCRATCH_POOL for temporary
* allocations. */
static svn_error_t *
get_username(svn_ra_session_t *session,
apr_pool_t *scratch_pool)
{
svn_ra_local__session_baton_t *sess = session->priv;
/* If we've already found the username don't ask for it again. */
if (! sess->username)
{
/* Get a username somehow, so we have some svn:author property to
attach to a commit. */
if (sess->callbacks->auth_baton)
{
void *creds;
svn_auth_cred_username_t *username_creds;
svn_auth_iterstate_t *iterstate;
SVN_ERR(svn_auth_first_credentials(&creds, &iterstate,
SVN_AUTH_CRED_USERNAME,
sess->uuid, /* realmstring */
sess->callbacks->auth_baton,
scratch_pool));
/* No point in calling next_creds(), since that assumes that the
first_creds() somehow failed to authenticate. But there's no
challenge going on, so we use whatever creds we get back on
the first try. */
username_creds = creds;
if (username_creds && username_creds->username)
{
sess->username = apr_pstrdup(session->pool,
username_creds->username);
svn_error_clear(svn_auth_save_credentials(iterstate,
scratch_pool));
}
else
sess->username = "";
}
else
sess->username = "";
}
/* If we have a real username, attach it to the filesystem so that it can
be used to validate locks. Even if there already is a user context
associated, it may contain irrelevant lock tokens, so always create a new.
*/
if (*sess->username)
{
svn_fs_access_t *access_ctx;
SVN_ERR(svn_fs_create_access(&access_ctx, sess->username,
session->pool));
SVN_ERR(svn_fs_set_access(sess->fs, access_ctx));
/* Make sure this context is disassociated when the pool gets
destroyed. */
apr_pool_cleanup_register(session->pool, sess->fs, cleanup_access,
apr_pool_cleanup_null);
}
return SVN_NO_ERROR;
}
/* Implements an svn_atomic__init_once callback. Sets the FSFS memory
cache size. */
static svn_error_t *
cache_init(void *baton, apr_pool_t *pool)
{
apr_hash_t *config_hash = baton;
svn_config_t *config = NULL;
const char *memory_cache_size_str;
if (config_hash)
config = svn_hash_gets(config_hash, SVN_CONFIG_CATEGORY_CONFIG);
svn_config_get(config, &memory_cache_size_str, SVN_CONFIG_SECTION_MISCELLANY,
SVN_CONFIG_OPTION_MEMORY_CACHE_SIZE, NULL);
if (memory_cache_size_str)
{
apr_uint64_t memory_cache_size;
svn_cache_config_t settings = *svn_cache_config_get();
SVN_ERR(svn_error_quick_wrap(svn_cstring_atoui64(&memory_cache_size,
memory_cache_size_str),
_("memory-cache-size invalid")));
settings.cache_size = 1024 * 1024 * memory_cache_size;
svn_cache_config_set(&settings);
}
return SVN_NO_ERROR;
}
/*----------------------------------------------------------------*/
/*** The reporter vtable needed by do_update() and friends ***/
typedef struct reporter_baton_t
{
svn_ra_local__session_baton_t *sess;
void *report_baton;
} reporter_baton_t;
src/subversion/subversion/libsvn_ra_local/ra_plugin.c view on Meta::CPAN
include_merged_revisions,
revprops,
NULL, NULL,
receiver,
receiver_baton,
pool);
}
static svn_error_t *
svn_ra_local__do_check_path(svn_ra_session_t *session,
const char *path,
svn_revnum_t revision,
svn_node_kind_t *kind,
apr_pool_t *pool)
{
svn_ra_local__session_baton_t *sess = session->priv;
svn_fs_root_t *root;
const char *abs_path = svn_fspath__join(sess->fs_path->data, path, pool);
if (! SVN_IS_VALID_REVNUM(revision))
SVN_ERR(svn_fs_youngest_rev(&revision, sess->fs, pool));
SVN_ERR(svn_fs_revision_root(&root, sess->fs, revision, pool));
return svn_fs_check_path(kind, root, abs_path, pool);
}
static svn_error_t *
svn_ra_local__stat(svn_ra_session_t *session,
const char *path,
svn_revnum_t revision,
svn_dirent_t **dirent,
apr_pool_t *pool)
{
svn_ra_local__session_baton_t *sess = session->priv;
svn_fs_root_t *root;
const char *abs_path = svn_fspath__join(sess->fs_path->data, path, pool);
if (! SVN_IS_VALID_REVNUM(revision))
SVN_ERR(svn_fs_youngest_rev(&revision, sess->fs, pool));
SVN_ERR(svn_fs_revision_root(&root, sess->fs, revision, pool));
return svn_repos_stat(dirent, root, abs_path, pool);
}
static svn_error_t *
get_node_props(apr_hash_t **props,
apr_array_header_t **inherited_props,
svn_ra_local__session_baton_t *sess,
svn_fs_root_t *root,
const char *path,
apr_pool_t *result_pool,
apr_pool_t *scratch_pool)
{
svn_revnum_t cmt_rev;
const char *cmt_date, *cmt_author;
/* Create a hash with props attached to the fs node. */
if (props)
{
SVN_ERR(svn_fs_node_proplist(props, root, path, result_pool));
}
/* Get inherited properties if requested. */
if (inherited_props)
{
SVN_ERR(svn_repos_fs_get_inherited_props(inherited_props, root, path,
NULL, NULL, NULL,
result_pool, scratch_pool));
}
/* Now add some non-tweakable metadata to the hash as well... */
if (props)
{
/* The so-called 'entryprops' with info about CR & friends. */
SVN_ERR(svn_repos_get_committed_info(&cmt_rev, &cmt_date,
&cmt_author, root, path,
scratch_pool));
svn_hash_sets(*props, SVN_PROP_ENTRY_COMMITTED_REV,
svn_string_createf(result_pool, "%ld", cmt_rev));
svn_hash_sets(*props, SVN_PROP_ENTRY_COMMITTED_DATE, cmt_date ?
svn_string_create(cmt_date, result_pool) :NULL);
svn_hash_sets(*props, SVN_PROP_ENTRY_LAST_AUTHOR, cmt_author ?
svn_string_create(cmt_author, result_pool) :NULL);
svn_hash_sets(*props, SVN_PROP_ENTRY_UUID,
svn_string_create(sess->uuid, result_pool));
/* We have no 'wcprops' in ra_local, but might someday. */
}
return SVN_NO_ERROR;
}
/* Getting just one file. */
static svn_error_t *
svn_ra_local__get_file(svn_ra_session_t *session,
const char *path,
svn_revnum_t revision,
svn_stream_t *stream,
svn_revnum_t *fetched_rev,
apr_hash_t **props,
apr_pool_t *pool)
{
svn_fs_root_t *root;
svn_stream_t *contents;
svn_revnum_t youngest_rev;
svn_ra_local__session_baton_t *sess = session->priv;
const char *abs_path = svn_fspath__join(sess->fs_path->data, path, pool);
svn_node_kind_t node_kind;
/* Open the revision's root. */
if (! SVN_IS_VALID_REVNUM(revision))
{
SVN_ERR(svn_fs_youngest_rev(&youngest_rev, sess->fs, pool));
SVN_ERR(svn_fs_revision_root(&root, sess->fs, youngest_rev, pool));
( run in 1.263 second using v1.01-cache-2.11-cpan-e1769b4cff6 )