add remove buses when empty
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
package models
|
||||
|
||||
import "slices"
|
||||
import (
|
||||
"slices"
|
||||
)
|
||||
|
||||
// driver model
|
||||
type Driver struct {
|
||||
@@ -46,9 +48,11 @@ func (d *Driver) RemoveBuses(buses []*Bus) {
|
||||
}
|
||||
|
||||
currentBus.RemoveAddress(bus.Address...)
|
||||
|
||||
if bus.Topic != nil {
|
||||
currentBus.RemoveSubscription(bus.Topic.Subscribe...)
|
||||
currentBus.RemovePublish(bus.Topic.Publish...)
|
||||
|
||||
if len(currentBus.Address) == 0 {
|
||||
var remove bool = true
|
||||
if currentBus.Topic != nil {
|
||||
|
@@ -23,6 +23,12 @@ func (d *Drivers) AddDriver(drv *Driver) {
|
||||
func (d *Drivers) RemoveDriver(drv *Driver) {
|
||||
if driver, ok := (*d)[drv.Type]; ok {
|
||||
driver.RemoveBuses(drv.Buses)
|
||||
if len(driver.Buses) == 1 {
|
||||
if len(driver.Buses[0].Address) == 0 && driver.Buses[0].Topic == nil {
|
||||
(*d)[drv.Type] = &Driver{}
|
||||
return
|
||||
}
|
||||
}
|
||||
(*d)[drv.Type] = driver
|
||||
return
|
||||
}
|
||||
|
@@ -1,6 +1,8 @@
|
||||
package models
|
||||
|
||||
import "slices"
|
||||
import (
|
||||
"slices"
|
||||
)
|
||||
|
||||
// topic model
|
||||
type Topic struct {
|
||||
@@ -33,6 +35,7 @@ func (t *Topic) RemoveSubscription(subs ...string) {
|
||||
t.Subscribe = []string{}
|
||||
return
|
||||
}
|
||||
|
||||
for _, toDelete := range subs {
|
||||
for i, a := range t.Subscribe {
|
||||
if a == toDelete {
|
||||
|
Reference in New Issue
Block a user