|  | /* | 
|  | * Simple transactions API | 
|  | * | 
|  | * Copyright (c) 2021 Virtuozzo International GmbH. | 
|  | * | 
|  | * Author: | 
|  | *  Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com> | 
|  | * | 
|  | * 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 <http://www.gnu.org/licenses/>. | 
|  | * | 
|  | * | 
|  | * = 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 <gmodule.h> | 
|  |  | 
|  | 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 */ |