mirror of
				https://github.com/seaweedfs/seaweedfs.git
				synced 2025-10-22 07:17:23 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			67 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package storage
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"sort"
 | |
| 
 | |
| 	"github.com/chrislusf/seaweedfs/weed/pb/master_pb"
 | |
| )
 | |
| 
 | |
| type VolumeInfo struct {
 | |
| 	Id               VolumeId
 | |
| 	Size             uint64
 | |
| 	ReplicaPlacement *ReplicaPlacement
 | |
| 	Ttl              *TTL
 | |
| 	Collection       string
 | |
| 	Version          Version
 | |
| 	FileCount        int
 | |
| 	DeleteCount      int
 | |
| 	DeletedByteCount uint64
 | |
| 	ReadOnly         bool
 | |
| }
 | |
| 
 | |
| func NewVolumeInfo(m *master_pb.VolumeInformationMessage) (vi VolumeInfo, err error) {
 | |
| 	vi = VolumeInfo{
 | |
| 		Id:               VolumeId(m.Id),
 | |
| 		Size:             m.Size,
 | |
| 		Collection:       m.Collection,
 | |
| 		FileCount:        int(m.FileCount),
 | |
| 		DeleteCount:      int(m.DeleteCount),
 | |
| 		DeletedByteCount: m.DeletedByteCount,
 | |
| 		ReadOnly:         m.ReadOnly,
 | |
| 		Version:          Version(m.Version),
 | |
| 	}
 | |
| 	rp, e := NewReplicaPlacementFromByte(byte(m.ReplicaPlacement))
 | |
| 	if e != nil {
 | |
| 		return vi, e
 | |
| 	}
 | |
| 	vi.ReplicaPlacement = rp
 | |
| 	vi.Ttl = LoadTTLFromUint32(m.Ttl)
 | |
| 	return vi, nil
 | |
| }
 | |
| 
 | |
| func (vi VolumeInfo) String() string {
 | |
| 	return fmt.Sprintf("Id:%d, Size:%d, ReplicaPlacement:%s, Collection:%s, Version:%v, FileCount:%d, DeleteCount:%d, DeletedByteCount:%d, ReadOnly:%v",
 | |
| 		vi.Id, vi.Size, vi.ReplicaPlacement, vi.Collection, vi.Version, vi.FileCount, vi.DeleteCount, vi.DeletedByteCount, vi.ReadOnly)
 | |
| }
 | |
| 
 | |
| /*VolumesInfo sorting*/
 | |
| 
 | |
| type volumeInfos []*VolumeInfo
 | |
| 
 | |
| func (vis volumeInfos) Len() int {
 | |
| 	return len(vis)
 | |
| }
 | |
| 
 | |
| func (vis volumeInfos) Less(i, j int) bool {
 | |
| 	return vis[i].Id < vis[j].Id
 | |
| }
 | |
| 
 | |
| func (vis volumeInfos) Swap(i, j int) {
 | |
| 	vis[i], vis[j] = vis[j], vis[i]
 | |
| }
 | |
| 
 | |
| func sortVolumeInfos(vis volumeInfos) {
 | |
| 	sort.Sort(vis)
 | |
| }
 | 
