diff options
author | w00t <w00t@e03df62e-2008-0410-955e-edbf42e46eb7> | 2008-04-17 12:09:15 +0000 |
---|---|---|
committer | w00t <w00t@e03df62e-2008-0410-955e-edbf42e46eb7> | 2008-04-17 12:09:15 +0000 |
commit | 57542f8488ce9f3250915d6c2aa03c243e34b7b3 (patch) | |
tree | b7f6273943f0b622286fb2c95d3b29980aae88be /src/snomasks.cpp | |
parent | 9954ce7e652fdf1bef963b3a133724e8a8eb4cad (diff) |
Add potential for local-only snotices and use them for the ones that should be local. Individual messages cannot be made local-only, but I can't think of circumstances where this is necessary. Let's write it when it *is* necessary. :)
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@9527 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/snomasks.cpp')
-rw-r--r-- | src/snomasks.cpp | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/src/snomasks.cpp b/src/snomasks.cpp index 08b98c002..de900623d 100644 --- a/src/snomasks.cpp +++ b/src/snomasks.cpp @@ -35,11 +35,11 @@ void SnomaskManager::FlushSnotices() } } -bool SnomaskManager::EnableSnomask(char letter, const std::string &type) +bool SnomaskManager::EnableSnomask(char letter, const std::string &type, bool local) { if (SnoMasks.find(letter) == SnoMasks.end()) { - Snomask *s = new Snomask(ServerInstance, letter, type); + Snomask *s = new Snomask(ServerInstance, letter, type, local); SnoMasks[letter] = s; return true; } @@ -87,11 +87,11 @@ bool SnomaskManager::IsEnabled(char letter) void SnomaskManager::SetupDefaults() { - this->EnableSnomask('c',"CONNECT"); /* Local connect notices */ + this->EnableSnomask('c',"CONNECT", true); /* Local connect notices */ this->EnableSnomask('C',"REMOTECONNECT"); /* Remote connect notices */ - this->EnableSnomask('q',"QUIT"); /* Local quit notices */ + this->EnableSnomask('q',"QUIT", true); /* Local quit notices */ this->EnableSnomask('Q',"REMOTEQUIT"); /* Remote quit notices */ - this->EnableSnomask('k',"KILL"); /* Kill notices */ + this->EnableSnomask('k',"KILL", true); /* Kill notices */ this->EnableSnomask('K',"REMOTEKILL"); /* Remote kill notices */ this->EnableSnomask('l',"LINK"); /* Link notices */ this->EnableSnomask('o',"OPER"); /* Oper up/down notices */ @@ -137,9 +137,16 @@ void Snomask::Flush() } } - ServerInstance->PI->SendSNONotice(MySnomask, this->Description + ": " + this->LastMessage); - if (Count > 1) - ServerInstance->PI->SendSNONotice(MySnomask, this->Description + ": (last message repeated " + Count + " times)"); + if (!LocalOnly) + { + // XXX this is a bit ugly. + std::string sno; + sno[0] = MySnomask; + + ServerInstance->PI->SendSNONotice(sno, this->Description + ": " + this->LastMessage); + if (Count > 1) + ServerInstance->PI->SendSNONotice(sno, this->Description + ": (last message repeated " + ConvToStr(Count) + " times)"); + } LastMessage = ""; Count = 1; |