106 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			106 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
package hbase
 | 
						|
 | 
						|
import (
 | 
						|
	"strings"
 | 
						|
 | 
						|
	pb "github.com/golang/protobuf/proto"
 | 
						|
	"github.com/juju/errors"
 | 
						|
	"github.com/pingcap/go-hbase/proto"
 | 
						|
)
 | 
						|
 | 
						|
type Get struct {
 | 
						|
	Row         []byte
 | 
						|
	Families    set
 | 
						|
	FamilyQuals map[string]set
 | 
						|
	Versions    int32
 | 
						|
	TsRangeFrom uint64
 | 
						|
	TsRangeTo   uint64
 | 
						|
}
 | 
						|
 | 
						|
func NewGet(row []byte) *Get {
 | 
						|
	return &Get{
 | 
						|
		Row:         append([]byte(nil), row...),
 | 
						|
		Families:    newSet(),
 | 
						|
		FamilyQuals: make(map[string]set),
 | 
						|
		Versions:    1,
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func (g *Get) GetRow() []byte {
 | 
						|
	return g.Row
 | 
						|
}
 | 
						|
 | 
						|
func (g *Get) AddString(famqual string) error {
 | 
						|
	parts := strings.Split(famqual, ":")
 | 
						|
 | 
						|
	if len(parts) > 2 {
 | 
						|
		return errors.Errorf("Too many colons were found in the family:qualifier string. '%s'", famqual)
 | 
						|
	} else if len(parts) == 2 {
 | 
						|
		g.AddStringColumn(parts[0], parts[1])
 | 
						|
	} else {
 | 
						|
		g.AddStringFamily(famqual)
 | 
						|
	}
 | 
						|
 | 
						|
	return nil
 | 
						|
}
 | 
						|
 | 
						|
func (g *Get) AddColumn(family, qual []byte) *Get {
 | 
						|
	g.AddFamily(family)
 | 
						|
	g.FamilyQuals[string(family)].add(string(qual))
 | 
						|
	return g
 | 
						|
}
 | 
						|
 | 
						|
func (g *Get) AddStringColumn(family, qual string) *Get {
 | 
						|
	return g.AddColumn([]byte(family), []byte(qual))
 | 
						|
}
 | 
						|
 | 
						|
func (g *Get) AddFamily(family []byte) *Get {
 | 
						|
	g.Families.add(string(family))
 | 
						|
	if _, ok := g.FamilyQuals[string(family)]; !ok {
 | 
						|
		g.FamilyQuals[string(family)] = newSet()
 | 
						|
	}
 | 
						|
	return g
 | 
						|
}
 | 
						|
 | 
						|
func (g *Get) AddStringFamily(family string) *Get {
 | 
						|
	return g.AddFamily([]byte(family))
 | 
						|
}
 | 
						|
 | 
						|
func (g *Get) AddTimeRange(from uint64, to uint64) *Get {
 | 
						|
	g.TsRangeFrom = from
 | 
						|
	g.TsRangeTo = to
 | 
						|
	return g
 | 
						|
}
 | 
						|
 | 
						|
func (g *Get) SetMaxVersion(maxVersion int32) *Get {
 | 
						|
	g.Versions = maxVersion
 | 
						|
	return g
 | 
						|
}
 | 
						|
 | 
						|
func (g *Get) ToProto() pb.Message {
 | 
						|
	get := &proto.Get{
 | 
						|
		Row: g.Row,
 | 
						|
	}
 | 
						|
 | 
						|
	if g.TsRangeFrom != 0 && g.TsRangeTo != 0 && g.TsRangeFrom <= g.TsRangeTo {
 | 
						|
		get.TimeRange = &proto.TimeRange{
 | 
						|
			From: pb.Uint64(g.TsRangeFrom),
 | 
						|
			To:   pb.Uint64(g.TsRangeTo),
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	for v := range g.Families {
 | 
						|
		col := &proto.Column{
 | 
						|
			Family: []byte(v),
 | 
						|
		}
 | 
						|
		var quals [][]byte
 | 
						|
		for qual := range g.FamilyQuals[v] {
 | 
						|
			quals = append(quals, []byte(qual))
 | 
						|
		}
 | 
						|
		col.Qualifier = quals
 | 
						|
		get.Column = append(get.Column, col)
 | 
						|
	}
 | 
						|
	get.MaxVersions = pb.Uint32(uint32(g.Versions))
 | 
						|
	return get
 | 
						|
}
 |