Interface Transaction
- All Superinterfaces:
AutoCloseable
,TransactionContext
One can imagine that transactions are like video game checkpoints.
- Opening a transaction with a try-with-resources block creates a checkpoint.
- Modifications to game state can then happen.
- Calling
commit()
validates the modifications that happened during the transaction, essentially discarding the checkpoint. - Calling
abort()
or doing nothing and letting the transaction be closed at the end of the try-with-resources block cancels any modification that happened during the transaction, reverting to the checkpoint. - Calling
openNested(net.fabricmc.fabric.api.transfer.v1.transaction.TransactionContext)
on a transaction creates a new nested transaction, i.e. a new checkpoint with the current state. Committing a nested transaction will validate the changes that happened, but they may still be cancelled later if a parent transaction is cancelled. Aborting a nested transaction immediately reverts the changes - cancelling any modification made after the call toopenNested(net.fabricmc.fabric.api.transfer.v1.transaction.TransactionContext)
.
This is illustrated in the following example.
try (Transaction outerTransaction = Transaction.openOuter()) {
// (A) some transaction operations
try (Transaction nestedTransaction = outerTransaction.openNested()) {
// (B) more operations
nestedTransaction.commit(); // Validate the changes that happened in this transaction.
// This is a nested transaction, so changes will only be applied if the outer
// transaction is committed too.
}
// (C) even more operations
outerTransaction.commit(); // This is an outer transaction: changes (A), (B) and (C) are applied.
}
// If we hadn't committed the outerTransaction, all changes (A), (B) and (C) would have been reverted.
Participants are responsible for upholding this contract themselves, by using TransactionContext.addCloseCallback(net.fabricmc.fabric.api.transfer.v1.transaction.TransactionContext.CloseCallback)
to react to transaction close events and properly validate or revert changes.
Any action that modifies state outside of the transaction, such as calls to markDirty()
or neighbor updates,
should be deferred until after the outer transaction is closed
to give every participant a chance to react to transaction close events.
This is very low-level for most applications, and most participants should subclass SnapshotParticipant
that will take care of properly maintaining their state.
Participants should generally be passed a TransactionContext
parameter instead of the full Transaction
,
to make sure they don't call abort()
, commit()
or close()
mistakenly.
Every transaction is only valid on the thread it was opened on, and attempts to use it on another thread will throw an exception. Consequently, transactions can be concurrent across multiple threads, as long as they don't share any state.
-
Nested Class Summary
Nested classes/interfaces inherited from interface net.fabricmc.fabric.api.transfer.v1.transaction.TransactionContext
TransactionContext.CloseCallback, TransactionContext.OuterCloseCallback, TransactionContext.Result
-
Method Summary
Modifier and TypeMethodDescriptionvoid
abort()
Deprecated.Close the current transaction, rolling back all the changes that happened during this transaction and the transactions opened withopenNested(net.fabricmc.fabric.api.transfer.v1.transaction.TransactionContext)
from this transaction.void
close()
Deprecated.Abort the current transaction if it was not closed already.void
commit()
Deprecated.Close the current transaction, committing all the changes that happened during this transaction and the committed transactions opened withopenNested(net.fabricmc.fabric.api.transfer.v1.transaction.TransactionContext)
from this transaction.static boolean
isOpen()
Deprecated.static Transaction
openNested(@Nullable TransactionContext maybeParent)
Deprecated.Open a nested transaction ifmaybeParent
is non null, or an outer transaction ifmaybeParent
is null.static Transaction
Deprecated.Open a new outer transaction.Methods inherited from interface net.fabricmc.fabric.api.transfer.v1.transaction.TransactionContext
addCloseCallback, addOuterCloseCallback, getOpenTransaction, nestingDepth, openNested
-
Method Details
-
openOuter
Deprecated.Open a new outer transaction.- Throws:
IllegalStateException
- If a transaction is already active on the current thread.
-
isOpen
static boolean isOpen()Deprecated.- Returns:
- True if a transaction is open on the current thread, and false otherwise.
-
openNested
Deprecated.Open a nested transaction ifmaybeParent
is non null, or an outer transaction ifmaybeParent
is null. -
abort
void abort()Deprecated.Close the current transaction, rolling back all the changes that happened during this transaction and the transactions opened withopenNested(net.fabricmc.fabric.api.transfer.v1.transaction.TransactionContext)
from this transaction.- Throws:
IllegalStateException
- If this function is not called on the thread this transaction was opened in.IllegalStateException
- If this transaction is not the current transaction.IllegalStateException
- If this transaction was closed.
-
commit
void commit()Deprecated.Close the current transaction, committing all the changes that happened during this transaction and the committed transactions opened withopenNested(net.fabricmc.fabric.api.transfer.v1.transaction.TransactionContext)
from this transaction. If this transaction was opened withopenOuter()
, all changes are applied. If this transaction was opened withopenNested(net.fabricmc.fabric.api.transfer.v1.transaction.TransactionContext)
, all changes will be applied when and if the changes of the parent transactions are applied.- Throws:
IllegalStateException
- If this function is not called on the thread this transaction was opened in.IllegalStateException
- If this transaction is not the current transaction.IllegalStateException
- If this transaction was closed.
-
close
void close()Deprecated.Abort the current transaction if it was not closed already.- Specified by:
close
in interfaceAutoCloseable
-