/* * Simple transactions API * * Copyright (c) 2021 Virtuozzo International GmbH. * * Author: * Vladimir Sementsov-Ogievskiy * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . * * * = Generic transaction API = * * The intended usage is the following: you create "prepare" functions, which * represents the actions. They will usually have Transaction* argument, and * call tran_add() to register finalization callbacks. For finalization * callbacks, prepare corresponding TransactionActionDrv structures. * * Then, when you need to make a transaction, create an empty Transaction by * tran_create(), call your "prepare" functions on it, and finally call * tran_abort() or tran_commit() to finalize the transaction by corresponding * finalization actions in reverse order. * * The clean() functions registered by the drivers in a transaction are called * last, after all abort() or commit() functions have been called. */ #ifndef QEMU_TRANSACTIONS_H #define QEMU_TRANSACTIONS_H #include typedef struct TransactionActionDrv { void (*abort)(void *opaque); void (*commit)(void *opaque); void (*clean)(void *opaque); } TransactionActionDrv; typedef struct Transaction Transaction; Transaction *tran_new(void); void tran_add(Transaction *tran, TransactionActionDrv *drv, void *opaque); void tran_abort(Transaction *tran); void tran_commit(Transaction *tran); static inline void tran_finalize(Transaction *tran, int ret) { if (ret < 0) { tran_abort(tran); } else { tran_commit(tran); } } #endif /* QEMU_TRANSACTIONS_H */