Browse Source

for issue #10; an IdGenerator interface, use bson.ObjectId as default

tags/0.2
mikespook 11 years ago
parent
commit
7a8a5d4a6a
3 changed files with 50 additions and 21 deletions
  1. +3
    -4
      client/client.go
  2. +37
    -0
      client/id.go
  3. +10
    -17
      example/client.go

+ 3
- 4
client/client.go View File

@@ -12,16 +12,15 @@ import (
"time"
"bytes"
"strconv"
"github.com/mikespook/golib/autoinc"
"github.com/mikespook/gearman-go/common"
)

var (
ai *autoinc.AutoInc
IdGen IdGenerator
)

func init() {
ai = autoinc.New(0, 1)
IdGen = NewObjectId()
}

// Status handler
@@ -316,7 +315,7 @@ flag byte, jobhandler JobHandler) (handle string) {
default:
datatype = common.SUBMIT_JOB
}
id := strconv.Itoa(int(ai.Id()))
id := IdGen.Id()
handle = client.do(funcname, data, datatype, id)
if jobhandler != nil {
client.jobhandlers[id] = jobhandler


+ 37
- 0
client/id.go View File

@@ -0,0 +1,37 @@
package client

import (
"strconv"
"labix.org/v2/mgo/bson"
"github.com/mikespook/golib/autoinc"
)

type IdGenerator interface {
Id() string
}

// ObjectId
type objectId struct {
bson.ObjectId
}

func (id *objectId) Id() string {
return id.String()
}

func NewObjectId() IdGenerator {
return &objectId{bson.NewObjectId()}
}

// AutoIncId
type autoincId struct {
*autoinc.AutoInc
}

func (id *autoincId) Id() string {
return strconv.Itoa(id.AutoInc.Id())
}

func NewAutoIncId() IdGenerator {
return &autoincId{autoinc.New(1, 1)}
}

+ 10
- 17
example/client.go View File

@@ -8,39 +8,32 @@ import (

func main() {
var wg sync.WaitGroup
// Set the autoinc id generator
// You can write your own id generator
// by implementing IdGenerator interface.
client.IdGen = client.NewAutoIncId()

c, err := client.New("127.0.0.1:4730")
if err != nil {
log.Fatalln(err)
}
defer c.Close()
echo := []byte("Hello\x00 world")
c.JobHandler = func(job *client.Job) error {
log.Printf("%s", job.Data)
wg.Done()
return nil
}

c.ErrHandler = func(e error) {
log.Println(e)
panic(e)
}
echo := []byte("Hello\x00 world")
wg.Add(1)
c.Echo(echo)
wg.Add(1)
handle, err := c.Do("ToUpper", echo, client.JOB_NORMAL)
if err != nil {
log.Fatalln(err)
} else {
log.Println(handle)
}

c.StatusHandler = func(handle string, known, running bool, numerator, denominator uint64) {
log.Printf("%s: %b, %b, %d, %d", handle, known, running, numerator, denominator)
jobHandler := func(job *client.Job) {
log.Printf("%s", job.Data)
wg.Done()
}
handle := c.Do("ToUpper", echo, client.JOB_NORMAL, jobHandler)

wg.Add(1)
c.Status(handle)
log.Printf("%t", c.Status(handle))

wg.Wait()
}

Loading…
Cancel
Save