diff options
Diffstat (limited to 'linden/indra/newview/llmutelist.cpp')
-rw-r--r-- | linden/indra/newview/llmutelist.cpp | 124 |
1 files changed, 102 insertions, 22 deletions
diff --git a/linden/indra/newview/llmutelist.cpp b/linden/indra/newview/llmutelist.cpp index bca9080..b5764c5 100644 --- a/linden/indra/newview/llmutelist.cpp +++ b/linden/indra/newview/llmutelist.cpp | |||
@@ -189,11 +189,11 @@ BOOL LLMuteList::isLinden(const LLString& name) const | |||
189 | } | 189 | } |
190 | 190 | ||
191 | 191 | ||
192 | BOOL LLMuteList::add(const LLMute& mute) | 192 | BOOL LLMuteList::add(const LLMute& mute, U32 flags) |
193 | { | 193 | { |
194 | // Can't mute Lindens | 194 | // Can't mute text from Lindens |
195 | if ((mute.mType == LLMute::AGENT || mute.mType == LLMute::BY_NAME) | 195 | if ((mute.mType == LLMute::AGENT || mute.mType == LLMute::BY_NAME) |
196 | && isLinden(mute.mName)) | 196 | && isLinden(mute.mName) && (flags & LLMute::flagTextChat || flags == 0)) |
197 | { | 197 | { |
198 | gViewerWindow->alertXml("MuteLinden"); | 198 | gViewerWindow->alertXml("MuteLinden"); |
199 | return FALSE; | 199 | return FALSE; |
@@ -238,25 +238,59 @@ BOOL LLMuteList::add(const LLMute& mute) | |||
238 | } | 238 | } |
239 | else | 239 | else |
240 | { | 240 | { |
241 | std::pair<mute_set_t::iterator, bool> result = mMutes.insert(mute); | 241 | // Need a local (non-const) copy to set up flags properly. |
242 | if (result.second) | 242 | LLMute localmute = mute; |
243 | |||
244 | // If an entry for the same entity is already in the list, remove it, saving flags as necessary. | ||
245 | mute_set_t::iterator it = mMutes.find(localmute); | ||
246 | if (it != mMutes.end()) | ||
243 | { | 247 | { |
244 | llinfos << "Muting " << mute.mName << " id " << mute.mID << llendl; | 248 | // This mute is already in the list. Save the existing entry's flags if that's warranted. |
245 | updateAdd(mute); | 249 | localmute.mFlags = it->mFlags; |
246 | notifyObservers(); | 250 | |
247 | //Kill all particle systems owned by muted task | 251 | mMutes.erase(it); |
248 | if(mute.mType == LLMute::AGENT || mute.mType == LLMute::OBJECT) | 252 | // Don't need to call notifyObservers() here, since it will happen after the entry has been re-added below. |
249 | { | 253 | } |
250 | gWorldPointer->mPartSim.cleanMutedParticles(mute.mID); | 254 | else |
251 | } | 255 | { |
256 | // There was no entry in the list previously. Fake things up by making it look like the previous entry had all properties unmuted. | ||
257 | localmute.mFlags = LLMute::flagAll; | ||
258 | } | ||
252 | 259 | ||
253 | return TRUE; | 260 | if(flags) |
261 | { | ||
262 | // The user passed some combination of flags. Make sure those flag bits are turned off (i.e. those properties will be muted). | ||
263 | localmute.mFlags &= (~flags); | ||
254 | } | 264 | } |
255 | else | 265 | else |
256 | { | 266 | { |
257 | return FALSE; | 267 | // The user passed 0. Make sure all flag bits are turned off (i.e. all properties will be muted). |
268 | localmute.mFlags = 0; | ||
269 | } | ||
270 | |||
271 | // (re)add the mute entry. | ||
272 | { | ||
273 | std::pair<mute_set_t::iterator, bool> result = mMutes.insert(localmute); | ||
274 | if (result.second) | ||
275 | { | ||
276 | llinfos << "Muting " << localmute.mName << " id " << localmute.mID << " flags " << localmute.mFlags << llendl; | ||
277 | updateAdd(mute); | ||
278 | notifyObservers(); | ||
279 | if(!(localmute.mFlags & LLMute::flagParticles)) | ||
280 | { | ||
281 | //Kill all particle systems owned by muted task | ||
282 | if(localmute.mType == LLMute::AGENT || localmute.mType == LLMute::OBJECT) | ||
283 | { | ||
284 | gWorldPointer->mPartSim.cleanMutedParticles(localmute.mID); | ||
285 | } | ||
286 | } | ||
287 | return TRUE; | ||
288 | } | ||
258 | } | 289 | } |
259 | } | 290 | } |
291 | |||
292 | // If we were going to return success, we'd have done it by now. | ||
293 | return FALSE; | ||
260 | } | 294 | } |
261 | 295 | ||
262 | void LLMuteList::updateAdd(const LLMute& mute) | 296 | void LLMuteList::updateAdd(const LLMute& mute) |
@@ -271,14 +305,14 @@ void LLMuteList::updateAdd(const LLMute& mute) | |||
271 | msg->addUUIDFast(_PREHASH_MuteID, mute.mID); | 305 | msg->addUUIDFast(_PREHASH_MuteID, mute.mID); |
272 | msg->addStringFast(_PREHASH_MuteName, mute.mName); | 306 | msg->addStringFast(_PREHASH_MuteName, mute.mName); |
273 | msg->addS32("MuteType", mute.mType); | 307 | msg->addS32("MuteType", mute.mType); |
274 | msg->addU32("MuteFlags", 0x0); // future | 308 | msg->addU32("MuteFlags", mute.mFlags); |
275 | gAgent.sendReliableMessage(); | 309 | gAgent.sendReliableMessage(); |
276 | 310 | ||
277 | mIsLoaded = TRUE; | 311 | mIsLoaded = TRUE; |
278 | } | 312 | } |
279 | 313 | ||
280 | 314 | ||
281 | BOOL LLMuteList::remove(const LLMute& mute) | 315 | BOOL LLMuteList::remove(const LLMute& mute, U32 flags) |
282 | { | 316 | { |
283 | BOOL found = FALSE; | 317 | BOOL found = FALSE; |
284 | 318 | ||
@@ -286,8 +320,46 @@ BOOL LLMuteList::remove(const LLMute& mute) | |||
286 | mute_set_t::iterator it = mMutes.find(mute); | 320 | mute_set_t::iterator it = mMutes.find(mute); |
287 | if (it != mMutes.end()) | 321 | if (it != mMutes.end()) |
288 | { | 322 | { |
289 | updateRemove(*it); | 323 | LLMute localmute = *it; |
324 | bool remove = true; | ||
325 | if(flags) | ||
326 | { | ||
327 | // If the user passed mute flags, we may only want to turn some flags on. | ||
328 | localmute.mFlags |= flags; | ||
329 | |||
330 | if(localmute.mFlags == LLMute::flagAll) | ||
331 | { | ||
332 | // Every currently available mute property has been masked out. | ||
333 | // Remove the mute entry entirely. | ||
334 | } | ||
335 | else | ||
336 | { | ||
337 | // Only some of the properties are masked out. Update the entry. | ||
338 | remove = false; | ||
339 | } | ||
340 | } | ||
341 | else | ||
342 | { | ||
343 | // The caller didn't pass any flags -- just remove the mute entry entirely. | ||
344 | } | ||
345 | |||
346 | // Always remove the entry from the set -- it will be re-added with new flags if necessary. | ||
290 | mMutes.erase(it); | 347 | mMutes.erase(it); |
348 | |||
349 | if(remove) | ||
350 | { | ||
351 | // The entry was actually removed. Notify the server. | ||
352 | updateRemove(localmute); | ||
353 | llinfos << "Unmuting " << localmute.mName << " id " << localmute.mID << " flags " << localmute.mFlags << llendl; | ||
354 | } | ||
355 | else | ||
356 | { | ||
357 | // Flags were updated, the mute entry needs to be retransmitted to the server and re-added to the list. | ||
358 | mMutes.insert(localmute); | ||
359 | updateAdd(localmute); | ||
360 | llinfos << "Updating mute entry " << localmute.mName << " id " << localmute.mID << " flags " << localmute.mFlags << llendl; | ||
361 | } | ||
362 | |||
291 | // Must be after erase. | 363 | // Must be after erase. |
292 | notifyObservers(); | 364 | notifyObservers(); |
293 | found = TRUE; | 365 | found = TRUE; |
@@ -381,7 +453,7 @@ BOOL LLMuteList::loadFromFile(const LLString& filename) | |||
381 | buffer, " %d %254s %254[^|]| %u\n", &type, id_buffer, name_buffer, | 453 | buffer, " %d %254s %254[^|]| %u\n", &type, id_buffer, name_buffer, |
382 | &flags); | 454 | &flags); |
383 | LLUUID id = LLUUID(id_buffer); | 455 | LLUUID id = LLUUID(id_buffer); |
384 | LLMute mute(id, name_buffer, (LLMute::EType)type); | 456 | LLMute mute(id, name_buffer, (LLMute::EType)type, flags); |
385 | if (mute.mID.isNull() | 457 | if (mute.mID.isNull() |
386 | || mute.mType == LLMute::BY_NAME) | 458 | || mute.mType == LLMute::BY_NAME) |
387 | { | 459 | { |
@@ -430,19 +502,27 @@ BOOL LLMuteList::saveToFile(const LLString& filename) | |||
430 | { | 502 | { |
431 | it->mID.toString(id_string); | 503 | it->mID.toString(id_string); |
432 | const LLString& name = it->mName; | 504 | const LLString& name = it->mName; |
433 | fprintf(fp, "%d %s %s|\n", (S32)it->mType, id_string, name.c_str()); | 505 | fprintf(fp, "%d %s %s|%u\n", (S32)it->mType, id_string, name.c_str(), it->mFlags); |
434 | } | 506 | } |
435 | fclose(fp); | 507 | fclose(fp); |
436 | return TRUE; | 508 | return TRUE; |
437 | } | 509 | } |
438 | 510 | ||
439 | 511 | ||
440 | BOOL LLMuteList::isMuted(const LLUUID& id, const LLString& name) const | 512 | BOOL LLMuteList::isMuted(const LLUUID& id, const LLString& name, U32 flags) const |
441 | { | 513 | { |
442 | // don't need name or type for lookup | 514 | // don't need name or type for lookup |
443 | LLMute mute(id); | 515 | LLMute mute(id); |
444 | mute_set_t::const_iterator mute_it = mMutes.find(mute); | 516 | mute_set_t::const_iterator mute_it = mMutes.find(mute); |
445 | if (mute_it != mMutes.end()) return TRUE; | 517 | if (mute_it != mMutes.end()) |
518 | { | ||
519 | // If any of the flags the caller passed are set, this item isn't considered muted for this caller. | ||
520 | if(flags & mute_it->mFlags) | ||
521 | { | ||
522 | return FALSE; | ||
523 | } | ||
524 | return TRUE; | ||
525 | } | ||
446 | 526 | ||
447 | // empty names can't be legacy-muted | 527 | // empty names can't be legacy-muted |
448 | if (name.empty()) return FALSE; | 528 | if (name.empty()) return FALSE; |