Difference between revisions of "Muting Objects and Agents"
Jump to navigation
Jump to search
Able Whitman (talk | contribs) m (ui classes) |
Able Whitman (talk | contribs) m |
||
Line 6: | Line 6: | ||
* '''''LLMuteList''''' -- a single global instance of this class is used to manage the list of object and agents that are muted | * '''''LLMuteList''''' -- a single global instance of this class is used to manage the list of object and agents that are muted | ||
Both of these classes are declared in ''llmutelist.h'' and implemented in ''llmutelist.cpp''. | Both of these classes are declared in ''llmutelist.h'' and implemented in ''llmutelist.cpp''. | ||
<br /> | |||
There are two classes that are used to manage the UI related to the mute list: | There are two classes that are used to manage the UI related to the mute list: | ||
* '''''LLObjectMute''''' -- handles the "Mute" menu items in the Object and Avatar pie menus (implemented in ''llviewermenu.cpp'') | * '''''LLObjectMute''''' -- handles the "Mute" menu items in the Object and Avatar pie menus (implemented in ''llviewermenu.cpp'') |
Revision as of 10:28, 13 June 2007
The viewer is responsible for implementing the muting on agents and objects. When the viewer initiates a new session, it requests the Mute List from the Second Life service. Once this list has been received and processed, each chat message that the viewer receives is compared against a list of muted items. If a chat message originates from a muted item, it is suppressed.
Mute List Classes
There are two primary classes that are used to implement and manage the viewer's mute list:
- LLMute -- each muted object or agent is represented by an instance of this class
- LLMuteList -- a single global instance of this class is used to manage the list of object and agents that are muted
Both of these classes are declared in llmutelist.h and implemented in llmutelist.cpp.
There are two classes that are used to manage the UI related to the mute list:
- LLObjectMute -- handles the "Mute" menu items in the Object and Avatar pie menus (implemented in llviewermenu.cpp)
- LLFloaterMute -- manages the display of the "Muted Residents & Objects" floater (declared in llfloatermute.h, implemented in llfloatermute.cpp and in floater_mute.xml)
Loading the Mute List
The viewer's mute list is internally represented by the global LLMuteList* gMuteListp.
Requesting the Mute List from the service
- The viewer requests the agent's mute list by calling LLMuteList::requestFromServer() in llmutelist.cpp
- The viewer sends a MuteListRequest message to the service
- The service replies with either:
- A MuteListUpdate message, indicating that the viewer should request a new mute list file from the service, or
- A UseCachedMuteList message, indicating that the viewer should use its cached copy of the mute list file
Loading a new Mute List
- The viewer recevies a MuteListUpdate message from the serice
- The mute list file specified in the message is requested by the viewer
- Upon receipt of the mute list file, the callback LLMuteList::onFileMuteList() is invoked
- The viewer opens the received file, and invokes LLMuteList::loadFromFile() to parse it
Loading a cached Mute List
- The viewer receives a UseCachedMuteList message from the service
- The viewer opens the cached file, and invokes LLMuteList::loadFromFile() to parse it
Populating the Global Mute List
- The mute list file, whether new or cached, is opened by LLMuteList::loadFromFile()
- Each mute entry in the pipe-delimited list is parsed
- A new LLMute instance is created for each entry, and this instance is added to gMuteListp.