aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/github.com/syndtr/goleveldb/leveldb/comparer/bytes_comparer.go
blob: 14dddf88dd207d0e9f7a0f6635fd6bd46682da1b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
// Copyright (c) 2012, Suryandaru Triandana <syndtr@gmail.com>
// All rights reserved.
//
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

package comparer

import "bytes"

type bytesComparer struct{}

func (bytesComparer) Compare(a, b []byte) int {
    return bytes.Compare(a, b)
}

func (bytesComparer) Name() string {
    return "leveldb.BytewiseComparator"
}

func (bytesComparer) Separator(dst, a, b []byte) []byte {
    i, n := 0, len(a)
    if n > len(b) {
        n = len(b)
    }
    for ; i < n && a[i] == b[i]; i++ {
    }
    if i >= n {
        // Do not shorten if one string is a prefix of the other
    } else if c := a[i]; c < 0xff && c+1 < b[i] {
        dst = append(dst, a[:i+1]...)
        dst[i]++
        return dst
    }
    return nil
}

func (bytesComparer) Successor(dst, b []byte) []byte {
    for i, c := range b {
        if c != 0xff {
            dst = append(dst, b[:i+1]...)
            dst[i]++
            return dst
        }
    }
    return nil
}

// DefaultComparer are default implementation of the Comparer interface.
// It uses the natural ordering, consistent with bytes.Compare.
var DefaultComparer = bytesComparer{}