Commit 02dad3fa authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 7bc2dd46
...@@ -168,6 +168,8 @@ type Transaction interface { ...@@ -168,6 +168,8 @@ type Transaction interface {
// RegisterSync registers sync to be notified in this transaction boundary events. // RegisterSync registers sync to be notified in this transaction boundary events.
// //
// See Synchronizer for details. // See Synchronizer for details.
//
// RegisterSync must be called before transaction completion begins.
RegisterSync(sync Synchronizer) RegisterSync(sync Synchronizer)
// XXX SetData(key interface{}, data interface{}) // XXX SetData(key interface{}, data interface{})
...@@ -243,7 +245,10 @@ type DataManager interface { ...@@ -243,7 +245,10 @@ type DataManager interface {
// This should never fail. // This should never fail.
TPCAbort(ctx context.Context, txn Transaction) // XXX error? TPCAbort(ctx context.Context, txn Transaction) // XXX error?
// XXX SortKey() string ?
// XXX better do without SortKey - with it it is assumed that
// datamanagers are processed serially.
// SortKey() string
} }
// Synchronizer is the interface to participate in transaction-boundary notifications. // Synchronizer is the interface to participate in transaction-boundary notifications.
......
...@@ -81,14 +81,40 @@ func (txn *transaction) Abort() { ...@@ -81,14 +81,40 @@ func (txn *transaction) Abort() {
panic("TODO") panic("TODO")
} }
// checkNotYetCompleting asserts that transaction completion has not yet began.
//
// and panics if the assert fails.
// must be called with .mu held.
func (txn *transaction) checkNotYetCompleting(who string) {
switch txn.status {
case Active: // XXX + Doomed ?
// ok
default:
panic("transaction: " + who + ": transaction completion already began")
}
}
// Join implements Transaction. // Join implements Transaction.
func (txn *transaction) Join(dm DataManager) { func (txn *transaction) Join(dm DataManager) {
panic("TODO") txn.mu.Lock()
defer txn.mu.Unlock()
txn.checkNotYetCompleting("join")
// XXX forbid double join?
txn.datav = append(txn.datav, dm)
} }
// RegisterSync implements Transaction. // RegisterSync implements Transaction.
func (txn *transaction) RegisterSync(sync Synchronizer) { func (txn *transaction) RegisterSync(sync Synchronizer) {
panic("TODO") txn.mu.Lock()
defer txn.mu.Unlock()
txn.checkNotYetCompleting("register sync")
// XXX forbid double register?
txn.syncv = append(txn.syncv, sync)
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment