1 /* temp_serializer.h : serialization functions for caching of FSFS structures
3 * ====================================================================
4 * Licensed to the Apache Software Foundation (ASF) under one
5 * or more contributor license agreements. See the NOTICE file
6 * distributed with this work for additional information
7 * regarding copyright ownership. The ASF licenses this file
8 * to you under the Apache License, Version 2.0 (the
9 * "License"); you may not use this file except in compliance
10 * with the License. You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing,
15 * software distributed under the License is distributed on an
16 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17 * KIND, either express or implied. See the License for the
18 * specific language governing permissions and limitations
20 * ====================================================================
23 #ifndef SVN_LIBSVN_FS__TEMP_SERIALIZER_H
24 #define SVN_LIBSVN_FS__TEMP_SERIALIZER_H
29 * Prepend the @a number to the @a string in a space efficient way such that
30 * no other (number,string) combination can produce the same result.
31 * Allocate temporaries as well as the result from @a pool.
34 svn_fs_fs__combine_number_and_string(apr_int64_t number,
39 * Serialize a @a noderev_p within the serialization @a context.
42 svn_fs_fs__noderev_serialize(struct svn_temp_serializer__context_t *context,
43 node_revision_t * const *noderev_p);
46 * Deserialize a @a noderev_p within the @a buffer.
49 svn_fs_fs__noderev_deserialize(void *buffer,
50 node_revision_t **noderev_p);
53 * #svn_txdelta_window_t is not sufficient for caching the data it
54 * represents because data read process needs auxilliary information.
58 /* the txdelta window information cached / to be cached */
59 svn_txdelta_window_t *window;
61 /* the revision file read pointer position right after reading the window */
63 } svn_fs_fs__txdelta_cached_window_t;
66 * Implements #svn_cache__serialize_func_t for
67 * #svn_fs_fs__txdelta_cached_window_t.
70 svn_fs_fs__serialize_txdelta_window(void **buffer,
71 apr_size_t *buffer_size,
76 * Implements #svn_cache__deserialize_func_t for
77 * #svn_fs_fs__txdelta_cached_window_t.
80 svn_fs_fs__deserialize_txdelta_window(void **item,
82 apr_size_t buffer_size,
86 * Implements #svn_cache__serialize_func_t for a manifest
87 * (@a in is an #apr_array_header_t of apr_off_t elements).
90 svn_fs_fs__serialize_manifest(void **data,
96 * Implements #svn_cache__deserialize_func_t for a manifest
97 * (@a *out is an #apr_array_header_t of apr_off_t elements).
100 svn_fs_fs__deserialize_manifest(void **out,
106 * Implements #svn_cache__serialize_func_t for a properties hash
107 * (@a in is an #apr_hash_t of svn_string_t elements, keyed by const char*).
110 svn_fs_fs__serialize_properties(void **data,
111 apr_size_t *data_len,
116 * Implements #svn_cache__deserialize_func_t for a properties hash
117 * (@a *out is an #apr_hash_t of svn_string_t elements, keyed by const char*).
120 svn_fs_fs__deserialize_properties(void **out,
126 * Implements #svn_cache__serialize_func_t for #svn_fs_id_t
129 svn_fs_fs__serialize_id(void **data,
130 apr_size_t *data_len,
135 * Implements #svn_cache__deserialize_func_t for #svn_fs_id_t
138 svn_fs_fs__deserialize_id(void **out,
144 * Implements #svn_cache__serialize_func_t for #node_revision_t
147 svn_fs_fs__serialize_node_revision(void **buffer,
148 apr_size_t *buffer_size,
153 * Implements #svn_cache__deserialize_func_t for #node_revision_t
156 svn_fs_fs__deserialize_node_revision(void **item,
158 apr_size_t buffer_size,
162 * Implements #svn_cache__serialize_func_t for a directory contents hash
165 svn_fs_fs__serialize_dir_entries(void **data,
166 apr_size_t *data_len,
171 * Implements #svn_cache__deserialize_func_t for a directory contents hash
174 svn_fs_fs__deserialize_dir_entries(void **out,
180 * Implements #svn_cache__partial_getter_func_t. Set (apr_off_t) @a *out
181 * to the element indexed by (apr_int64_t) @a *baton within the
182 * serialized manifest array @a data and @a data_len. */
184 svn_fs_fs__get_sharded_offset(void **out,
191 * Implements #svn_cache__partial_getter_func_t for a single
192 * #svn_fs_dirent_t within a serialized directory contents hash,
193 * identified by its name (const char @a *baton).
196 svn_fs_fs__extract_dir_entry(void **out,
203 * Describes the change to be done to a directory: Set the entry
204 * identify by @a name to the value @a new_entry. If the latter is
205 * @c NULL, the entry shall be removed if it exists. Otherwise it
206 * will be replaced or automatically added, respectively.
208 typedef struct replace_baton_t
210 /** name of the directory entry to modify */
213 /** directory entry to insert instead */
214 svn_fs_dirent_t *new_entry;
218 * Implements #svn_cache__partial_setter_func_t for a single
219 * #svn_fs_dirent_t within a serialized directory contents hash,
220 * identified by its name in the #replace_baton_t in @a baton.
223 svn_fs_fs__replace_dir_entry(void **data,
224 apr_size_t *data_len,
229 * Implements #svn_cache__serialize_func_t for an #apr_array_header_t of
233 svn_fs_fs__serialize_changes(void **data,
234 apr_size_t *data_len,
239 * Implements #svn_cache__deserialize_func_t for an #apr_array_header_t of
243 svn_fs_fs__deserialize_changes(void **out,
249 * Implements #svn_cache__serialize_func_t for #svn_mergeinfo_t objects.
252 svn_fs_fs__serialize_mergeinfo(void **data,
253 apr_size_t *data_len,
258 * Implements #svn_cache__deserialize_func_t for #svn_mergeinfo_t objects.
261 svn_fs_fs__deserialize_mergeinfo(void **out,