Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
N
neo
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
2
Merge Requests
2
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Jobs
Commits
Open sidebar
Kirill Smelkov
neo
Commits
5c4d7868
Commit
5c4d7868
authored
Jul 20, 2018
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
821a0afc
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
132 additions
and
5 deletions
+132
-5
go/transaction/transaction.go
go/transaction/transaction.go
+125
-0
go/zodb/btree/btree.go
go/zodb/btree/btree.go
+2
-2
go/zodb/zodb.go
go/zodb/zodb.go
+5
-3
No files found.
go/transaction/transaction.go
0 → 100644
View file @
5c4d7868
// Copyright (c) 2001, 2002 Zope Foundation and Contributors.
// All Rights Reserved.
//
// Copyright (C) 2018 Nexedi SA and Contributors.
// Kirill Smelkov <kirr@nexedi.com>
//
// This software is subject to the provisions of the Zope Public License,
// Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution.
// THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
// WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
// WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
// FOR A PARTICULAR PURPOSE.
// Package transaction provides transaction management via Two-Phase transaction protocol.
//
// It is modelled after Python transaction package:
//
// http://transaction.readthedocs.org
// https://github.com/zopefoundation/transaction
package
transaction
import
(
"context"
)
// Manager manages seqeunce of transactions.
type
Manager
interface
{
// Begin begins new transaction.
//
// XXX
//
// XXX There must be no existing in progress transaction.
Begin
()
Transaction
// RegisterSynch registers synchronizer.
//
// Synchronizers are notified about major events in a transaction's life.
// See Synchronizer for details.
RegisterSynch
(
synch
Synchronizer
)
// UnregisterSynch unregisters synchronizer.
//
// XXX synchronizer must be already registered?
// XXX or make RegisterSynch return something that will allow to unregister via that?
UnregisterSynch
(
synch
Synchronizer
)
}
// Transaction represents running transaction.
//
// XXX -> concrete type?
type
Transaction
interface
{
User
()
string
// user name associated with transaction
Description
()
string
// description of transaction
Extension
()
string
// XXX
// Commit finalizes the transaction.
//
// This executes the two-phase commit algorithm for all
// IDataManager objects associated with the transaction. XXX
Commit
(
ctx
context
.
Context
)
error
// Abort aborts the transaction.
//
// This is called from the application. This can only be called XXX
// before the two-phase commit protocol has been started. XXX
Abort
()
// XXX + Doom?
// Add a data manager to the transaction. XXX
Join
(
dm
DataManager
)
// XXX SetData(oid zodb.Oid, data interface{}
// XXX GetData(oid zodb.Oid) interface{}
}
// DataManager represents transactional storage. // XXX -> transaction.Storage?
type
DataManager
interface
{
// TPCBegin should begin commit of a transaction, starting the two-phase commit.
TPCBegin
(
txn
Transaction
)
// XXX +ctx, error ?
// Commit should commit modifications to registered objects.
//
// Save changes to be made persistent if the transaction commits (if
// tpc_finish is called later). If tpc_abort is called later, changes
// must not persist.
//
// This includes conflict detection and handling. If no conflicts or
// errors occur, the data manager should be prepared to make the
// changes persist when tpc_finish is called.
Commit
(
ctx
context
.
Context
,
txn
Transaction
)
error
// TPCVote should verify that a data manager can commit the transaction.
//
// This is the last chance for a data manager to vote 'no'. A
// data manager votes 'no' by returning an error.
TPCVote
(
ctx
context
.
Context
,
txn
Transaction
)
error
// Indicate confirmation that the transaction is done.
//
// Make all changes to objects modified by this transaction persist.
//
// This should never fail. If this raises an exception, the XXX
// database is not expected to maintain consistency; it's a
// serious error.
TPCFinish
(
ctx
context
.
Context
,
txn
Transaction
)
// XXX error?
// XXX SortKey() string ?
}
// Synchronizer is the interface to participate in transaction-boundary notifications.
type
Synchronizer
interface
{
// BeforeCompletion is called by the transaction at the start of a commit.
BeforeCompletion
(
txn
Transaction
)
// AfterCompletion is called by the transaction after completing a commit.
AfterCompletion
(
txn
Transaction
)
// NewTransaction is called at the start of a transaction.
// XXX -> TxnStart ?
NewTransaction
(
txn
Transaction
)
}
go/zodb/btree/btree.go
View file @
5c4d7868
...
@@ -177,13 +177,13 @@ func (b *Bucket) get(key KEY) (interface{}, bool) {
...
@@ -177,13 +177,13 @@ func (b *Bucket) get(key KEY) (interface{}, bool) {
//
//
// In the above, key[i] means self->data[i].key, and similarly for child[i].
// In the above, key[i] means self->data[i].key, and similarly for child[i].
// DropState implements Stateful.
// DropState implements
zodb.
Stateful.
func
(
t
*
BTree
)
DropState
()
{
func
(
t
*
BTree
)
DropState
()
{
t
.
firstbucket
=
nil
t
.
firstbucket
=
nil
t
.
data
=
nil
t
.
data
=
nil
}
}
// PySetState implements PyStateful to set btree data from pystate.
// PySetState implements
zodb.
PyStateful to set btree data from pystate.
func
(
bt
*
BTree
)
PySetState
(
pystate
interface
{})
error
{
func
(
bt
*
BTree
)
PySetState
(
pystate
interface
{})
error
{
// empty btree
// empty btree
if
_
,
ok
:=
pystate
.
(
pickle
.
None
);
ok
{
if
_
,
ok
:=
pystate
.
(
pickle
.
None
);
ok
{
...
...
go/zodb/zodb.go
View file @
5c4d7868
...
@@ -50,9 +50,11 @@
...
@@ -50,9 +50,11 @@
//
//
// Operations
// Operations
//
//
// A ZODB database can be opened with OpenStorage. Once opened IStorage
// At storage level a ZODB database can be opened with OpenStorage. Once opened
// interface is returned that represents access to the database. Please see
// IStorage interface is returned that represents access to the database. Please
// documentation of IStorage, and other interfaces it embeds, for details.
// see documentation of IStorage, and other interfaces it embeds, for details.
//
// XXX DB + Connection.
//
//
//
//
// Python data
// Python data
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment