mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2024-12-22 16:17:55 +08:00
30 lines
757 B
Go
30 lines
757 B
Go
|
package topic
|
||
|
|
||
|
type LocalTopic struct {
|
||
|
Topic
|
||
|
Partitions []*LocalPartition
|
||
|
}
|
||
|
|
||
|
func (localTopic *LocalTopic) findPartition(partition Partition) *LocalPartition {
|
||
|
for _, localPartition := range localTopic.Partitions {
|
||
|
if localPartition.Partition.Equals(partition) {
|
||
|
return localPartition
|
||
|
}
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
func (localTopic *LocalTopic) removePartition(partition Partition) bool {
|
||
|
foundPartitionIndex := -1
|
||
|
for i, localPartition := range localTopic.Partitions {
|
||
|
if localPartition.Partition.Equals(partition) {
|
||
|
foundPartitionIndex = i
|
||
|
break
|
||
|
}
|
||
|
}
|
||
|
if foundPartitionIndex == -1 {
|
||
|
return false
|
||
|
}
|
||
|
localTopic.Partitions = append(localTopic.Partitions[:foundPartitionIndex], localTopic.Partitions[foundPartitionIndex+1:]...)
|
||
|
return true
|
||
|
}
|