merge from paulmach
This commit is contained in:
commit
764dcf5f99
@ -20,7 +20,7 @@ var (
|
||||
)
|
||||
|
||||
func init() {
|
||||
IdGen = NewObjectId()
|
||||
IdGen = NewAutoIncId()
|
||||
}
|
||||
|
||||
// Status handler
|
||||
|
32
client/id.go
32
client/id.go
@ -1,35 +1,29 @@
|
||||
package client
|
||||
|
||||
import (
|
||||
"strconv"
|
||||
"labix.org/v2/mgo/bson"
|
||||
"github.com/mikespook/golib/autoinc"
|
||||
"strconv"
|
||||
"sync/atomic"
|
||||
"time"
|
||||
)
|
||||
|
||||
type IdGenerator interface {
|
||||
Id() string
|
||||
}
|
||||
|
||||
// ObjectId
|
||||
type objectId struct {}
|
||||
|
||||
func (id *objectId) Id() string {
|
||||
return bson.NewObjectId().Hex()
|
||||
}
|
||||
|
||||
func NewObjectId() IdGenerator {
|
||||
return &objectId{}
|
||||
Id() string
|
||||
}
|
||||
|
||||
// AutoIncId
|
||||
type autoincId struct {
|
||||
*autoinc.AutoInc
|
||||
value int64
|
||||
}
|
||||
|
||||
func (id *autoincId) Id() string {
|
||||
return strconv.Itoa(id.AutoInc.Id())
|
||||
func (ai *autoincId) Id() string {
|
||||
next := atomic.AddInt64(&ai.value, 1)
|
||||
return strconv.FormatInt(next, 10)
|
||||
}
|
||||
|
||||
func NewAutoIncId() IdGenerator {
|
||||
return &autoincId{autoinc.New(1, 1)}
|
||||
// we'll consider the nano fraction of a second at startup unique
|
||||
// and count up from there.
|
||||
return &autoincId{
|
||||
value: int64(time.Now().Nanosecond()) << 32,
|
||||
}
|
||||
}
|
||||
|
18
client/id_test.go
Normal file
18
client/id_test.go
Normal file
@ -0,0 +1,18 @@
|
||||
package client
|
||||
|
||||
import (
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestAutoInc(t *testing.T) {
|
||||
ai := NewAutoIncId()
|
||||
|
||||
previous := ai.Id()
|
||||
for i := 0; i < 10; i++ {
|
||||
id := ai.Id()
|
||||
if id == previous {
|
||||
t.Errorf("Id not unique, previous and current %s", id)
|
||||
}
|
||||
previous = id
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user