chrislu 5 months ago
parent
commit
5535b60e8c
  1. 10
      weed/storage/super_block/replica_placement.go

10
weed/storage/super_block/replica_placement.go

@ -1,7 +1,6 @@
package super_block package super_block
import ( import (
"errors"
"fmt" "fmt"
) )
@ -15,7 +14,9 @@ func NewReplicaPlacementFromString(t string) (*ReplicaPlacement, error) {
rp := &ReplicaPlacement{} rp := &ReplicaPlacement{}
for i, c := range t { for i, c := range t {
count := int(c - '0') count := int(c - '0')
if 0 <= count && count <= 2 {
if count < 0 {
return rp, fmt.Errorf("unknown replication type: %s", t)
}
switch i { switch i {
case 0: case 0:
rp.DiffDataCenterCount = count rp.DiffDataCenterCount = count
@ -24,9 +25,10 @@ func NewReplicaPlacementFromString(t string) (*ReplicaPlacement, error) {
case 2: case 2:
rp.SameRackCount = count rp.SameRackCount = count
} }
} else {
return rp, errors.New("Unknown Replication Type:" + t)
} }
value := rp.DiffDataCenterCount*100 + rp.DiffRackCount*10 + rp.SameRackCount
if value > 255 {
return rp, fmt.Errorf("unexpected replication type: %s", t)
} }
return rp, nil return rp, nil
} }

Loading…
Cancel
Save