aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llfloaterproperties.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llfloaterproperties.cpp')
-rw-r--r--linden/indra/newview/llfloaterproperties.cpp35
1 files changed, 27 insertions, 8 deletions
diff --git a/linden/indra/newview/llfloaterproperties.cpp b/linden/indra/newview/llfloaterproperties.cpp
index 0d2cd5f..48232cb 100644
--- a/linden/indra/newview/llfloaterproperties.cpp
+++ b/linden/indra/newview/llfloaterproperties.cpp
@@ -65,11 +65,21 @@
65// helper class to watch the inventory. 65// helper class to watch the inventory.
66//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 66//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
67 67
68class LLPropertiesObserver : public LLInventoryObserver, public LLSingleton<LLPropertiesObserver> 68// Ugh. This can't be a singleton because it needs to remove itself
69// from the inventory observer list when destroyed, which could
70// happen after gInventory has already been destroyed if a singleton.
71// Instead, do our own ref counting and create / destroy it as needed
72class LLPropertiesObserver : public LLInventoryObserver
69{ 73{
70public: 74public:
71 LLPropertiesObserver() {} 75 LLPropertiesObserver()
72 virtual ~LLPropertiesObserver() {} 76 {
77 gInventory.addObserver(this);
78 }
79 virtual ~LLPropertiesObserver()
80 {
81 gInventory.removeObserver(this);
82 }
73 virtual void changed(U32 mask); 83 virtual void changed(U32 mask);
74}; 84};
75 85
@@ -88,7 +98,10 @@ void LLPropertiesObserver::changed(U32 mask)
88/// Class LLFloaterProperties 98/// Class LLFloaterProperties
89///---------------------------------------------------------------------------- 99///----------------------------------------------------------------------------
90 100
101// static
91LLFloaterProperties::instance_map LLFloaterProperties::sInstances; 102LLFloaterProperties::instance_map LLFloaterProperties::sInstances;
103LLPropertiesObserver* LLFloaterProperties::sPropertiesObserver = NULL;
104S32 LLFloaterProperties::sPropertiesObserverCount = 0;
92 105
93// static 106// static
94LLFloaterProperties* LLFloaterProperties::find(const LLUUID& item_id, 107LLFloaterProperties* LLFloaterProperties::find(const LLUUID& item_id,
@@ -145,12 +158,12 @@ LLFloaterProperties::LLFloaterProperties(const std::string& name, const LLRect&
145{ 158{
146 LLUICtrlFactory::getInstance()->buildFloater(this,"floater_inventory_item_properties.xml"); 159 LLUICtrlFactory::getInstance()->buildFloater(this,"floater_inventory_item_properties.xml");
147 160
148 // hack to make sure these floaters are observing the inventory. 161 if (!sPropertiesObserver)
149 if(!gInventory.containsObserver(LLPropertiesObserver::getInstance()))
150 { 162 {
151 // Note: this is where gPropertiesObserver used to be constructed. 163 sPropertiesObserver = new LLPropertiesObserver;
152 gInventory.addObserver(LLPropertiesObserver::getInstance());
153 } 164 }
165 sPropertiesObserverCount++;
166
154 // add the object to the static structure 167 // add the object to the static structure
155 LLUUID key = mItemID ^ mObjectID; 168 LLUUID key = mItemID ^ mObjectID;
156 sInstances.insert(instance_map::value_type(key, this)); 169 sInstances.insert(instance_map::value_type(key, this));
@@ -193,6 +206,12 @@ LLFloaterProperties::~LLFloaterProperties()
193 { 206 {
194 sInstances.erase(it); 207 sInstances.erase(it);
195 } 208 }
209 sPropertiesObserverCount--;
210 if (!sPropertiesObserverCount)
211 {
212 delete sPropertiesObserver;
213 sPropertiesObserver = NULL;
214 }
196} 215}
197 216
198void LLFloaterProperties::refresh() 217void LLFloaterProperties::refresh()
@@ -422,7 +441,7 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item)
422 441
423 perm_string = "G"; 442 perm_string = "G";
424 perm_string += overwrite_group ? "*: " : ": "; 443 perm_string += overwrite_group ? "*: " : ": ";
425 perm_string += perm_string += mask_to_string(group_mask); 444 perm_string += mask_to_string(group_mask);
426 childSetText("GroupMaskDebug",perm_string); 445 childSetText("GroupMaskDebug",perm_string);
427 childSetVisible("GroupMaskDebug",TRUE); 446 childSetVisible("GroupMaskDebug",TRUE);
428 447