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);
54 * Adds position information to the the raw window data in WINDOW.
58 /* the (unprocessed) txdelta window byte sequence cached / to be cached */
61 /* the offset within the representation right after reading the window */
63 } svn_fs_fs__raw_cached_window_t;
66 * Implements #svn_cache__serialize_func_t for
67 * #svn_fs_fs__raw_cached_window_t.
70 svn_fs_fs__serialize_raw_window(void **buffer,
71 apr_size_t *buffer_size,
76 * Implements #svn_cache__deserialize_func_t for
77 * #svn_fs_fs__raw_cached_window_t.
80 svn_fs_fs__deserialize_raw_window(void **item,
82 apr_size_t buffer_size,
86 * #svn_txdelta_window_t is not sufficient for caching the data it
87 * represents because data read process needs auxiliary information.
91 /* the txdelta window information cached / to be cached */
92 svn_txdelta_window_t *window;
94 /* the revision file read pointer position right after reading the window */
96 } svn_fs_fs__txdelta_cached_window_t;
99 * Implements #svn_cache__serialize_func_t for
100 * #svn_fs_fs__txdelta_cached_window_t.
103 svn_fs_fs__serialize_txdelta_window(void **buffer,
104 apr_size_t *buffer_size,
109 * Implements #svn_cache__deserialize_func_t for
110 * #svn_fs_fs__txdelta_cached_window_t.
113 svn_fs_fs__deserialize_txdelta_window(void **item,
115 apr_size_t buffer_size,
119 * Implements #svn_cache__serialize_func_t for a manifest
120 * (@a in is an #apr_array_header_t of apr_off_t elements).
123 svn_fs_fs__serialize_manifest(void **data,
124 apr_size_t *data_len,
129 * Implements #svn_cache__deserialize_func_t for a manifest
130 * (@a *out is an #apr_array_header_t of apr_off_t elements).
133 svn_fs_fs__deserialize_manifest(void **out,
139 * Implements #svn_cache__serialize_func_t for a properties hash
140 * (@a in is an #apr_hash_t of svn_string_t elements, keyed by const char*).
143 svn_fs_fs__serialize_properties(void **data,
144 apr_size_t *data_len,
149 * Implements #svn_cache__deserialize_func_t for a properties hash
150 * (@a *out is an #apr_hash_t of svn_string_t elements, keyed by const char*).
153 svn_fs_fs__deserialize_properties(void **out,
159 * Implements #svn_cache__serialize_func_t for #svn_fs_id_t
162 svn_fs_fs__serialize_id(void **data,
163 apr_size_t *data_len,
168 * Implements #svn_cache__deserialize_func_t for #svn_fs_id_t
171 svn_fs_fs__deserialize_id(void **out,
177 * Implements #svn_cache__serialize_func_t for #node_revision_t
180 svn_fs_fs__serialize_node_revision(void **buffer,
181 apr_size_t *buffer_size,
186 * Implements #svn_cache__deserialize_func_t for #node_revision_t
189 svn_fs_fs__deserialize_node_revision(void **item,
191 apr_size_t buffer_size,
195 * Implements #svn_cache__serialize_func_t for a directory contents array
198 svn_fs_fs__serialize_dir_entries(void **data,
199 apr_size_t *data_len,
204 * Implements #svn_cache__deserialize_func_t for a directory contents array
207 svn_fs_fs__deserialize_dir_entries(void **out,
213 * Implements #svn_cache__partial_getter_func_t. Set (apr_off_t) @a *out
214 * to the element indexed by (apr_int64_t) @a *baton within the
215 * serialized manifest array @a data and @a data_len. */
217 svn_fs_fs__get_sharded_offset(void **out,
224 * Implements #svn_cache__partial_getter_func_t for a single
225 * #svn_fs_dirent_t within a serialized directory contents hash,
226 * identified by its name (const char @a *baton).
229 svn_fs_fs__extract_dir_entry(void **out,
236 * Describes the change to be done to a directory: Set the entry
237 * identify by @a name to the value @a new_entry. If the latter is
238 * @c NULL, the entry shall be removed if it exists. Otherwise it
239 * will be replaced or automatically added, respectively.
241 typedef struct replace_baton_t
243 /** name of the directory entry to modify */
246 /** directory entry to insert instead */
247 svn_fs_dirent_t *new_entry;
251 * Implements #svn_cache__partial_setter_func_t for a single
252 * #svn_fs_dirent_t within a serialized directory contents hash,
253 * identified by its name in the #replace_baton_t in @a baton.
256 svn_fs_fs__replace_dir_entry(void **data,
257 apr_size_t *data_len,
262 * Implements #svn_cache__serialize_func_t for a #svn_fs_fs__rep_header_t.
265 svn_fs_fs__serialize_rep_header(void **data,
266 apr_size_t *data_len,
271 * Implements #svn_cache__deserialize_func_t for a #svn_fs_fs__rep_header_t.
274 svn_fs_fs__deserialize_rep_header(void **out,
280 * Implements #svn_cache__serialize_func_t for an #apr_array_header_t of
284 svn_fs_fs__serialize_changes(void **data,
285 apr_size_t *data_len,
290 * Implements #svn_cache__deserialize_func_t for an #apr_array_header_t of
294 svn_fs_fs__deserialize_changes(void **out,
300 * Implements #svn_cache__serialize_func_t for #svn_mergeinfo_t objects.
303 svn_fs_fs__serialize_mergeinfo(void **data,
304 apr_size_t *data_len,
309 * Implements #svn_cache__deserialize_func_t for #svn_mergeinfo_t objects.
312 svn_fs_fs__deserialize_mergeinfo(void **out,