本文整理匯總了Golang中encoding/binary.PutUvarint函數的典型用法代碼示例。如果您正苦於以下問題:Golang PutUvarint函數的具體用法?Golang PutUvarint怎麽用?Golang PutUvarint使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了PutUvarint函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestNoMergeExtensionMerge
func TestNoMergeExtensionMerge(t *testing.T) {
bigm := prototests.AContainer
m := &prototests.Small{SmallField: proto.Int64(1)}
data, err := proto.Marshal(bigm)
if err != nil {
panic(err)
}
mdata, err := proto.Marshal(m)
if err != nil {
panic(err)
}
key := uint32(101)<<3 | uint32(2)
datakey := make([]byte, 10)
n := binary.PutUvarint(datakey, uint64(key))
datakey = datakey[:n]
datalen := make([]byte, 10)
n = binary.PutUvarint(datalen, uint64(len(mdata)))
datalen = datalen[:n]
data = append(data, append(datakey, append(datalen, mdata...)...)...)
err = noMerge(data, bigm.Description(), "prototests", "Container")
if err == nil || !strings.Contains(err.Error(), "FieldB requires merging") {
t.Fatalf("FieldB should require merging, but error is %v", err)
}
t.Log(err)
}
示例2: appendRec
func (b *Batch) appendRec(kt kType, key, value []byte) {
n := 1 + binary.MaxVarintLen32 + len(key)
if kt == ktVal {
n += binary.MaxVarintLen32 + len(value)
}
b.grow(n)
off := len(b.data)
data := b.data[:off+n]
data[off] = byte(kt)
off += 1
off += binary.PutUvarint(data[off:], uint64(len(key)))
copy(data[off:], key)
off += len(key)
if kt == ktVal {
off += binary.PutUvarint(data[off:], uint64(len(value)))
copy(data[off:], value)
off += len(value)
}
b.data = data[:off]
=======
off := len(b.buf)
if off == 0 {
// include headers
off = kBatchHdrLen
n += off
}
if cap(b.buf)-off >= n {
return
}
buf := make([]byte, 2*cap(b.buf)+n)
copy(buf, b.buf)
b.buf = buf[:off]
}
示例3: writeMetaData
func writeMetaData(outPath string) {
outFile, err := os.Create(outPath)
defer outFile.Close()
if err != nil {
panic(err)
}
var buf []byte = make([]byte, 4)
var posBuf []byte = make([]byte, 8)
binary.PutUvarint(buf, uint64(uniqueTerms))
outFile.Write(buf)
buf = []byte{0, 0, 0, 0}
binary.PutUvarint(buf, uint64(docId))
outFile.Write(buf)
buf = []byte{0, 0, 0, 0}
var docIdInt int = int(docId)
for i := 0; i < docIdInt; i++ {
binary.PutUvarint(buf, uint64(iDocInfos[i].length))
outFile.Write(buf)
buf = []byte{0, 0, 0, 0}
binary.PutUvarint(posBuf, uint64(iDocInfos[i].pos))
outFile.Write(posBuf)
posBuf = []byte{0, 0, 0, 0, 0, 0, 0, 0}
}
}
示例4: writeIndex
func writeIndex(outPath string) {
outFile, err := os.Create(outPath)
defer outFile.Close()
if err != nil {
panic(err)
}
writer := bufio.NewWriterSize(io.Writer(outFile), writerBufSize)
var v *list.List
dBuf := make([]byte, 4)
tfBuf := make([]byte, 4)
pBuf := make([]byte, 4)
for _, k := range dictionary.keys {
v = dictionary.m[k]
writer.WriteString(k + ",")
var posting *Posting
for el := v.Front(); el != nil; el = el.Next() {
posting = el.Value.(*Posting)
binary.PutUvarint(dBuf, uint64(posting.doc))
writer.Write(dBuf)
dBuf = []byte{0, 0, 0, 0}
binary.PutUvarint(tfBuf, uint64(posting.tf))
writer.Write(tfBuf)
tfBuf = []byte{0, 0, 0, 0}
for posEl := posting.pos.Front(); posEl != nil; posEl = posEl.Next() {
pos := posEl.Value.(uint32)
binary.PutUvarint(pBuf, uint64(pos))
writer.Write(pBuf)
pBuf = []byte{0, 0, 0, 0}
}
}
writer.Write([]byte{0, 0, 0, 0})
}
writer.Flush()
}
示例5: appendRec
func (b *Batch) appendRec(kt keyType, key, value []byte) {
n := 1 + binary.MaxVarintLen32 + len(key)
if kt == keyTypeVal {
n += binary.MaxVarintLen32 + len(value)
}
b.grow(n)
index := batchIndex{keyType: kt}
o := len(b.data)
data := b.data[:o+n]
data[o] = byte(kt)
o++
o += binary.PutUvarint(data[o:], uint64(len(key)))
index.keyPos = o
index.keyLen = len(key)
o += copy(data[o:], key)
if kt == keyTypeVal {
o += binary.PutUvarint(data[o:], uint64(len(value)))
index.valuePos = o
index.valueLen = len(value)
o += copy(data[o:], value)
}
b.data = data[:o]
b.index = append(b.index, index)
b.internalLen += index.keyLen + index.valueLen + 8
}
示例6: ToBuf
// ToBuf serializes a frame into a byte array
func (f FrameWindowUpdate) ToBuf() ([]byte, error) {
buf := make([]byte, 1+4+8)
buf[0] = WindowUpdateFrame
binary.PutUvarint(buf[1:5], f.StreamID)
binary.PutUvarint(buf[5:13], f.ByteOffset)
return buf, nil
}
示例7: WriteTo
// WriteTo writes the header to w and returns the number of bytes
// actually written to w. Header size can be 16 and it will be
// recalculated if the size is bigger.
func (header *Header) WriteTo(w io.Writer) (n int64, err error) {
buf := bytes.NewBuffer(nil)
bin := make([]byte, binary.MaxVarintLen64)
// Write uint64 binary encoding of the snapshot size to buf.
buf.Write(bin[0:binary.PutUvarint(bin, uint64(len(header.Snapshots)))])
// Write each snapshot to buf.
for _, snapshot := range header.Snapshots {
binary.Write(buf, binary.BigEndian, snapshot.Timestamp)
buf.Write(bin[0:binary.PutUvarint(bin, snapshot.ByteSize)])
}
// Find the variable size of header size.
headerSizeSize := uint64(binary.PutUvarint(bin, header.ByteSize))
// Recalculate header byte size until it gets right.
for header.ByteSize < headerSizeSize+uint64(buf.Len()) {
header.ByteSize = headerSizeSize + uint64(buf.Len())
headerSizeSize = uint64(binary.PutUvarint(bin, header.ByteSize))
}
n1, err := w.Write(bin[0:headerSizeSize])
n += int64(n1)
if err != nil {
return
}
n1, err = w.Write(buf.Bytes())
n += int64(n1)
for uint64(n) < header.ByteSize {
n1, err = w.Write([]byte{0})
n += int64(n1)
if err != nil {
return
}
}
return
}
示例8: inc
func (mc *memoryCache) inc(c context.Context, key string, delta int64, initialValue uint64) (uint64, error) {
mc.Lock()
defer mc.Unlock()
item, ok := mc.items[key]
if !ok {
var z time.Time
b := make([]byte, binary.Size(initialValue))
binary.PutUvarint(b, initialValue)
item = &cacheItem{b, z}
mc.items[key] = item
}
v, n := binary.Uvarint(item.data)
if n <= 0 {
return 0, fmt.Errorf("inc: binary.Uvarint error: %d", n)
}
switch {
case delta < 0 && v < uint64(delta):
v = 0
case delta < 0:
v -= uint64(delta)
case delta > 0:
v += uint64(delta)
}
binary.PutUvarint(item.data, v)
return v, nil
}
示例9: TestNoMergeExtensionMerge
func TestNoMergeExtensionMerge(t *testing.T) {
r := rand.New(rand.NewSource(time.Now().UnixNano()))
bigm := test.NewPopulatedMyExtendable(r, true)
m := test.NewPopulatedNinOptNative(r, true)
err := proto.SetExtension(bigm, test.E_FieldB, m)
if err != nil {
panic(err)
}
data, err := proto.Marshal(bigm)
if err != nil {
panic(err)
}
key := uint32(101)<<3 | uint32(2)
data2 := make([]byte, 10)
n := binary.PutUvarint(data2, uint64(key))
data2 = data2[:n]
data = append(data, data2...)
data4, err := proto.Marshal(test.NewPopulatedNinOptNative(r, true))
if err != nil {
panic(err)
}
data3 := make([]byte, 10)
n = binary.PutUvarint(data3, uint64(len(data4)))
data3 = data3[:n]
data = append(data, data3...)
data = append(data, data4...)
err = fieldpath.NoMerge(data, test.ThetestDescription(), "test", "MyExtendable")
if err == nil || !strings.Contains(err.Error(), "requires merging") {
t.Fatalf("should require merging")
}
}
示例10: write
func (x *msgDial) write(w io.Writer) (err error) {
q := make([]byte, maxMsgDialLen)
n1 := binary.PutUvarint(q, uint64(x.ID))
n2 := binary.PutUvarint(q[n1:], uint64(x.SeqNo))
_, err = w.Write(q[:n1+n2])
return err
}
示例11: MarshalBinary
// MarshalBinary implements binary marshalling for Addresses.
//
// A marshalled Address only carries its identifier. When unmarshalled on
// the same node, the unmarshalled address will be reconnected to the
// original Mailbox. If unmarshalled on a different node, a reference to
// the remote mailbox will be unmarshaled.
func (a Address) MarshalBinary() ([]byte, error) {
address := a.getAddress()
if address == nil {
return nil, ErrIllegalAddressFormat
}
switch mbox := address.(type) {
case *Mailbox:
b := make([]byte, 10, 10)
written := binary.PutUvarint(b, uint64(mbox.id))
return append([]byte("<"), b[:written]...), nil
case noMailbox:
return []byte("X"), nil
case boundRemoteAddress:
b := make([]byte, 10, 10)
written := binary.PutUvarint(b, uint64(mbox.mailboxID))
return append([]byte("<"), b[:written]...), nil
case registryMailbox:
return []byte("\"" + string(mbox)), nil
default:
return nil, ErrIllegalAddressFormat
}
}
示例12: Diff
// Diff computes a delta from data1 to data2. The
// result is such that Patch(data1, Diff(data1, data2)) == data2.
func Diff(data1, data2 []byte) []byte {
// Store lengths of inputs.
patch := make([]byte, 32)
n1 := binary.PutUvarint(patch, uint64(len(data1)))
n2 := binary.PutUvarint(patch[n1:], uint64(len(data2)))
patch = patch[:n1+n2]
// First hash chunks of data1.
hashes := hashChunks(data1)
// Compute rolling hashes of data2 and see whether
// we recognize parts of data1.
var p uint32
lastmatch := -1
for i := 0; i < len(data2); i++ {
b := data2[i]
if i < _W {
p = (p << 8) ^ uint32(b) ^ _T[uint8(p>>(degree-8))]
continue
}
// Invariant: i >= W and p == hashRabin(data2[i-W:i])
//if p != hashRabin(data2[i-_W:i]) {
// println(p, hashRabin(data2[i-_W:i]))
// panic("p != hashRabin(data2[i-_W:i])")
//}
refi, ok := hashes.Get(p)
if ok && bytes.Equal(data1[refi:refi+_W], data2[i-_W:i]) {
// We have a match! Try to extend it left and right.
testi := i - _W
for refi > 0 && testi > lastmatch+1 && data1[refi-1] == data2[testi-1] {
refi--
testi--
}
refj, testj := refi+i-testi, i
for refj < len(data1) && testj < len(data2) && data1[refj] == data2[testj] {
refj++
testj++
}
// Now data1[refi:refj] == data2[testi:testj]
patch = appendInlineData(patch, data2[lastmatch+1:testi])
patch = appendRefData(patch, uint32(refi), uint32(refj-refi))
// Skip bytes and update hash.
i = testj + _W - 1
lastmatch = testj - 1
if i >= len(data2) {
break
}
p = hashRabin(data2[testj : testj+_W])
continue
}
// Cancel out data2[i-W] and take data2[i]
p ^= _U[data2[i-_W]]
p = (p << 8) ^ uint32(b) ^ _T[uint8(p>>(degree-8))]
}
patch = appendInlineData(patch, data2[lastmatch+1:])
return patch
}
示例13: init
func init() {
var buffer bytes.Buffer
b := make([]byte, 16)
// Get the current user name.
osU, err := user.Current()
user := "UNKNOW"
if err == nil {
user = osU.Username
}
buffer.WriteString(user)
// Create the constant to make build a unique ID.
start := uint64(time.Now().UnixNano())
binary.PutUvarint(b, start)
buffer.Write(b)
pid := uint64(os.Getpid())
binary.PutUvarint(b, pid)
buffer.Write(b)
// Set the node.
if !uuid.SetNodeID(buffer.Bytes()) {
os.Exit(-1)
}
// Initialize the channel and blank node type.
nextVal, tBlank = make(chan uuid.UUID, chanSize), Type("/_")
go func() {
for {
nextVal <- uuid.NewRandom()
}
}()
}
示例14: SignatureWriter
// Return a signature writer. The call itself does not write anything.
// Use with a Signature header.
func (w *Writer) SignatureWriter() rsync.SignatureWriter {
if w.t != TypeSignature {
// This is a program structure issue, so panic.
panic(ErrInvalidCall)
}
buffer := make([]byte, 2048)
return func(block rsync.BlockHash) error {
var n int
var err error
n = binary.PutUvarint(buffer, block.Index)
binary.BigEndian.PutUint32(buffer[n:], block.WeakHash)
n += 4
n += binary.PutUvarint(buffer[n:], uint64(len(block.StrongHash)))
_, err = w.body.Write(buffer[:n])
if err != nil {
return err
}
_, err = w.body.Write(block.StrongHash)
if err != nil {
return err
}
return nil
}
}
示例15: writeProto
// writeProto writes a uvarint size and then a protobuf to w.
// If the data takes no space (like rpc.InvalidRequest),
// only a zero size is written.
func writeProto(w io.Writer, pb proto.Message) error {
// Allocate enough space for the biggest uvarint
var size [binary.MaxVarintLen64]byte
if pb == nil {
n := binary.PutUvarint(size[:], uint64(0))
if _, err := w.Write(size[:n]); err != nil {
return err
}
return nil
}
// Marshal the protobuf
data, err := proto.Marshal(pb)
if err != nil {
return err
}
// Write the size and data
n := binary.PutUvarint(size[:], uint64(len(data)))
if _, err = w.Write(size[:n]); err != nil {
return err
}
if _, err = w.Write(data); err != nil {
return err
}
return nil
}