Subversion
|
Filesystem Nodes and Node-Revisions. More...
Typedefs | |
typedef struct svn_fs_id_t | svn_fs_id_t |
An object representing a node-revision id. | |
Functions | |
int | svn_fs_compare_ids (const svn_fs_id_t *a, const svn_fs_id_t *b) |
Return -1, 0, or 1 if node revisions a and b are respectively unrelated, equivalent, or otherwise related (part of the same node). | |
svn_boolean_t | svn_fs_check_related (const svn_fs_id_t *id1, const svn_fs_id_t *id2) |
Return TRUE if node revisions id1 and id2 are related (part of the same node), else return FALSE. | |
svn_fs_id_t * | svn_fs_parse_id (const char *data, apr_size_t len, apr_pool_t *pool) |
svn_string_t * | svn_fs_unparse_id (const svn_fs_id_t *id, apr_pool_t *pool) |
Return a Subversion string containing the unparsed form of the node revision id id. |
Filesystem Nodes and Node-Revisions.
In a Subversion filesystem, a `node' corresponds roughly to an `inode' in a Unix filesystem:
A `node revision' refers to one particular version of a node's contents, that existed over a specific period of time (one or more repository revisions). Changing a node's contents always creates a new revision of that node, which is to say creates a new `node revision'. Once created, a node revision's contents never change.
When we create a node, its initial contents are the initial revision of the node. As users make changes to the node over time, we create new revisions of that same node. When a user commits a change that deletes a file from the filesystem, we don't delete the node, or any revision of it --- those stick around to allow us to recreate prior revisions of the filesystem. Instead, we just remove the reference to the node from the directory.
Each node revision is a part of exactly one node, and appears only once in the history of that node. It is uniquely identified by a node revision id, svn_fs_id_t. Its node revision id also identifies which node it is a part of.
typedef struct svn_fs_id_t svn_fs_id_t |
svn_fs_id_t* svn_fs_parse_id | ( | const char * | data, |
apr_size_t | len, | ||
apr_pool_t * | pool | ||
) |
svn_string_t* svn_fs_unparse_id | ( | const svn_fs_id_t * | id, |
apr_pool_t * | pool | ||
) |
Return a Subversion string containing the unparsed form of the node revision id id.
Allocate the string containing the unparsed form in pool.