3
0
mirror of https://github.com/ergochat/ergo.git synced 2024-11-29 07:29:31 +01:00
RENAME (channel rename) that was a simple case change (e.g.
renaming #chan to #CHAN) would delete the channel :-|
This commit is contained in:
Shivaram Lingamneni 2021-07-13 08:47:16 -04:00
parent 907f82a27e
commit 5b317d4846

View File

@ -320,10 +320,12 @@ func (cm *ChannelManager) Rename(name string, newName string) (err error) {
defer func() { defer func() {
if channel != nil && info.Founder != "" { if channel != nil && info.Founder != "" {
channel.Store(IncludeAllAttrs) channel.Store(IncludeAllAttrs)
if oldCfname != newCfname {
// we just flushed the channel under its new name, therefore this delete // we just flushed the channel under its new name, therefore this delete
// cannot be overwritten by a write to the old name: // cannot be overwritten by a write to the old name:
cm.server.channelRegistry.Delete(info) cm.server.channelRegistry.Delete(info)
} }
}
}() }()
cm.Lock() cm.Lock()