odb/transaction: make `write_object_stream()` pluggable
How an ODB transaction handles writing objects is expected to vary between implementations. Introduce a new `write_object_stream()` callback in `struct odb_transaction` to make this function pluggable. Rename `index_blob_packfile_transaction()` to `odb_transaction_files_write_object_stream()` and wire it up for use with `struct odb_transaction_files` accordingly. Signed-off-by: Justin Tobler <jltobler@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>main
parent
45a75d6187
commit
08b6afb2a2
|
|
@ -1578,9 +1578,10 @@ clear_exit:
|
|||
* binary blobs, they generally do not want to get any conversion, and
|
||||
* callers should avoid this code path when filters are requested.
|
||||
*/
|
||||
static int index_blob_packfile_transaction(struct odb_transaction *base,
|
||||
struct odb_write_stream *stream,
|
||||
size_t size, struct object_id *result_oid)
|
||||
static int odb_transaction_files_write_object_stream(struct odb_transaction *base,
|
||||
struct odb_write_stream *stream,
|
||||
size_t size,
|
||||
struct object_id *result_oid)
|
||||
{
|
||||
struct odb_transaction_files *transaction = container_of(base,
|
||||
struct odb_transaction_files,
|
||||
|
|
@ -1664,10 +1665,10 @@ int index_fd(struct index_state *istate, struct object_id *oid,
|
|||
struct object_database *odb = the_repository->objects;
|
||||
struct odb_transaction *transaction = odb_transaction_begin(odb);
|
||||
|
||||
ret = index_blob_packfile_transaction(odb->transaction,
|
||||
&stream,
|
||||
xsize_t(st->st_size),
|
||||
oid);
|
||||
ret = odb_transaction_write_object_stream(odb->transaction,
|
||||
&stream,
|
||||
xsize_t(st->st_size),
|
||||
oid);
|
||||
odb_transaction_commit(transaction);
|
||||
} else {
|
||||
ret = hash_blob_stream(&stream,
|
||||
|
|
@ -2132,6 +2133,7 @@ struct odb_transaction *odb_transaction_files_begin(struct odb_source *source)
|
|||
transaction = xcalloc(1, sizeof(*transaction));
|
||||
transaction->base.source = source;
|
||||
transaction->base.commit = odb_transaction_files_commit;
|
||||
transaction->base.write_object_stream = odb_transaction_files_write_object_stream;
|
||||
|
||||
return &transaction->base;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -26,3 +26,10 @@ void odb_transaction_commit(struct odb_transaction *transaction)
|
|||
transaction->source->odb->transaction = NULL;
|
||||
free(transaction);
|
||||
}
|
||||
|
||||
int odb_transaction_write_object_stream(struct odb_transaction *transaction,
|
||||
struct odb_write_stream *stream,
|
||||
size_t len, struct object_id *oid)
|
||||
{
|
||||
return transaction->write_object_stream(transaction, stream, len, oid);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -12,14 +12,24 @@
|
|||
*
|
||||
* Each ODB source is expected to implement its own transaction handling.
|
||||
*/
|
||||
struct odb_transaction;
|
||||
typedef void (*odb_transaction_commit_fn)(struct odb_transaction *transaction);
|
||||
struct odb_transaction {
|
||||
/* The ODB source the transaction is opened against. */
|
||||
struct odb_source *source;
|
||||
|
||||
/* The ODB source specific callback invoked to commit a transaction. */
|
||||
odb_transaction_commit_fn commit;
|
||||
void (*commit)(struct odb_transaction *transaction);
|
||||
|
||||
/*
|
||||
* This callback is expected to write the given object stream into
|
||||
* the ODB transaction. Note that for now, only blobs support streaming.
|
||||
*
|
||||
* The resulting object ID shall be written into the out pointer. The
|
||||
* callback is expected to return 0 on success, a negative error code
|
||||
* otherwise.
|
||||
*/
|
||||
int (*write_object_stream)(struct odb_transaction *transaction,
|
||||
struct odb_write_stream *stream, size_t len,
|
||||
struct object_id *oid);
|
||||
};
|
||||
|
||||
/*
|
||||
|
|
@ -35,4 +45,13 @@ struct odb_transaction *odb_transaction_begin(struct object_database *odb);
|
|||
*/
|
||||
void odb_transaction_commit(struct odb_transaction *transaction);
|
||||
|
||||
/*
|
||||
* Writes the object in the provided stream into the transaction. The resulting
|
||||
* object ID is written into the out pointer. Returns 0 on success, a negative
|
||||
* error code otherwise.
|
||||
*/
|
||||
int odb_transaction_write_object_stream(struct odb_transaction *transaction,
|
||||
struct odb_write_stream *stream,
|
||||
size_t len, struct object_id *oid);
|
||||
|
||||
#endif
|
||||
|
|
|
|||
Loading…
Reference in New Issue