summaryrefslogtreecommitdiff
path: root/indra
diff options
context:
space:
mode:
Diffstat (limited to 'indra')
-rw-r--r--indra/newview/llfloaterstinson.cpp103
-rw-r--r--indra/newview/llfloaterstinson.h10
-rw-r--r--indra/newview/skins/default/xui/en/floater_stinson.xml38
3 files changed, 123 insertions, 28 deletions
diff --git a/indra/newview/llfloaterstinson.cpp b/indra/newview/llfloaterstinson.cpp
index 5da1d9b242..52a4c41d0d 100644
--- a/indra/newview/llfloaterstinson.cpp
+++ b/indra/newview/llfloaterstinson.cpp
@@ -62,6 +62,7 @@
#define MATERIALS_CAP_FACE_FIELD "Face"
#define MATERIALS_CAP_MATERIAL_FIELD "Material"
#define MATERIALS_CAP_OBJECT_ID_FIELD "ID"
+#define MATERIALS_CAP_MATERIAL_ID_FIELD "MaterialID"
#define MATERIALS_CAP_NORMAL_MAP_FIELD "NormMap"
#define MATERIALS_CAP_SPECULAR_MAP_FIELD "SpecMap"
@@ -116,12 +117,15 @@ BOOL LLFloaterStinson::postBuild()
llassert(mGetButton != NULL);
mGetButton->setCommitCallback(boost::bind(&LLFloaterStinson::onGetClicked, this));
+ mGetScrollList = findChild<LLScrollListCtrl>("get_scroll_list");
+ llassert(mGetScrollList != NULL);
+
mPutButton = findChild<LLButton>("put_button");
llassert(mPutButton != NULL);
mPutButton->setCommitCallback(boost::bind(&LLFloaterStinson::onPutClicked, this));
- mMaterialsScrollList = findChild<LLScrollListCtrl>("materials_scroll_list");
- llassert(mMaterialsScrollList != NULL);
+ mPutScrollList = findChild<LLScrollListCtrl>("put_scroll_list");
+ llassert(mPutScrollList != NULL);
mWarningColor = LLUIColorTable::instance().getColor("MaterialWarningColor");
mErrorColor = LLUIColorTable::instance().getColor("MaterialErrorColor");
@@ -151,12 +155,14 @@ void LLFloaterStinson::onOpen(const LLSD& pKey)
}
checkRegionMaterialStatus();
- clearMaterialsList();
+ clearGetResults();
+ clearPutResults();
}
void LLFloaterStinson::onClose(bool pIsAppQuitting)
{
- clearMaterialsList();
+ clearGetResults();
+ clearPutResults();
if (mSelectionUpdateConnection.connected())
{
@@ -247,7 +253,7 @@ void LLFloaterStinson::onPutResponse(bool pRequestStatus, const LLSD& pContent)
if (pRequestStatus)
{
setState(kRequestCompleted);
- printResponse("PUT", pContent);
+ parsePutResponse(pContent);
}
else
{
@@ -458,7 +464,7 @@ void LLFloaterStinson::requestPutMaterials(const LLUUID& regionId)
void LLFloaterStinson::parseGetResponse(const LLSD& pContent)
{
printResponse("GET", pContent);
- clearMaterialsList();
+ clearGetResults();
LLScrollListCell::Params cellParams;
LLScrollListItem::Params rowParams;
@@ -471,16 +477,7 @@ void LLFloaterStinson::parseGetResponse(const LLSD& pContent)
llassert(material.isMap());
llassert(material.has(MATERIALS_CAP_OBJECT_ID_FIELD));
llassert(material.get(MATERIALS_CAP_OBJECT_ID_FIELD).isBinary());
-
- const LLSD::Binary &materialIDValue = material.get(MATERIALS_CAP_OBJECT_ID_FIELD).asBinary();
- unsigned int valueSize = materialIDValue.size();
-
- std::string materialID(reinterpret_cast<const char *>(&materialIDValue[0]), valueSize);
- std::string materialIDString;
- for (unsigned int i = 0; i < valueSize; ++i)
- {
- materialIDString += llformat("%02x", materialID.c_str()[i]);
- }
+ std::string materialIDString = convertToPrintableMaterialID(material.get(MATERIALS_CAP_OBJECT_ID_FIELD));
llassert(material.has(MATERIALS_CAP_MATERIAL_FIELD));
const LLSD &materialData = material.get(MATERIALS_CAP_MATERIAL_FIELD);
@@ -553,7 +550,54 @@ void LLFloaterStinson::parseGetResponse(const LLSD& pContent)
cellParams.value = (isDiffuseAlphaMask ? "True" : "False");
rowParams.columns.add(cellParams);
- mMaterialsScrollList->addRow(rowParams);
+ mGetScrollList->addRow(rowParams);
+ }
+}
+
+void LLFloaterStinson::parsePutResponse(const LLSD& pContent)
+{
+ printResponse("PUT", pContent);
+ clearPutResults();
+
+ LLScrollListCell::Params cellParams;
+ LLScrollListItem::Params rowParams;
+
+ llassert(pContent.isArray());
+ for (LLSD::array_const_iterator faceIter = pContent.beginArray(); faceIter != pContent.endArray();
+ ++faceIter)
+ {
+ const LLSD &face = *faceIter;
+ llassert(face.isMap());
+
+ llassert(face.has(MATERIALS_CAP_FACE_FIELD));
+ llassert(face.get(MATERIALS_CAP_FACE_FIELD).isInteger());
+ S32 faceId = face.get(MATERIALS_CAP_FACE_FIELD).asInteger();
+
+ llassert(face.has(MATERIALS_CAP_OBJECT_ID_FIELD));
+ llassert(face.get(MATERIALS_CAP_OBJECT_ID_FIELD).isInteger());
+ S32 objectId = face.get(MATERIALS_CAP_OBJECT_ID_FIELD).asInteger();
+
+ llassert(face.has(MATERIALS_CAP_MATERIAL_ID_FIELD));
+ llassert(face.get(MATERIALS_CAP_MATERIAL_ID_FIELD).isBinary());
+ std::string materialIDString = convertToPrintableMaterialID(face.get(MATERIALS_CAP_MATERIAL_ID_FIELD));
+
+ cellParams.font = LLFontGL::getFontMonospace();
+
+ cellParams.column = "material_id";
+ cellParams.value = materialIDString;
+ rowParams.columns.add(cellParams);
+
+ cellParams.font = LLFontGL::getFontSansSerif();
+
+ cellParams.column = "object_id";
+ cellParams.value = llformat("%d", objectId);
+ rowParams.columns.add(cellParams);
+
+ cellParams.column = "face_index";
+ cellParams.value = llformat("%d", faceId);
+ rowParams.columns.add(cellParams);
+
+ mPutScrollList->addRow(rowParams);
}
}
@@ -571,9 +615,14 @@ void LLFloaterStinson::setState(EState pState)
updateControls();
}
-void LLFloaterStinson::clearMaterialsList()
+void LLFloaterStinson::clearGetResults()
{
- mMaterialsScrollList->deleteAllItems();
+ mGetScrollList->deleteAllItems();
+}
+
+void LLFloaterStinson::clearPutResults()
+{
+ mPutScrollList->deleteAllItems();
}
void LLFloaterStinson::updateStatusMessage()
@@ -646,6 +695,22 @@ void LLFloaterStinson::updateControls()
}
}
+std::string LLFloaterStinson::convertToPrintableMaterialID(const LLSD& pBinaryHash) const
+{
+ llassert(pBinaryHash.isBinary());
+ const LLSD::Binary &materialIDValue = pBinaryHash.asBinary();
+ unsigned int valueSize = materialIDValue.size();
+
+ std::string materialID(reinterpret_cast<const char *>(&materialIDValue[0]), valueSize);
+ std::string materialIDString;
+ for (unsigned int i = 0; i < valueSize; ++i)
+ {
+ materialIDString += llformat("%02x", materialID.c_str()[i]);
+ }
+
+ return materialIDString;
+}
+
MaterialsGetResponder::MaterialsGetResponder(const std::string& pCapabilityURL, CallbackFunction pCallback)
: LLHTTPClient::Responder(),
mCapabilityURL(pCapabilityURL),
diff --git a/indra/newview/llfloaterstinson.h b/indra/newview/llfloaterstinson.h
index 5b8f157cd0..916f55c5ab 100644
--- a/indra/newview/llfloaterstinson.h
+++ b/indra/newview/llfloaterstinson.h
@@ -27,6 +27,8 @@
#ifndef LL_LLFLOATERSTINSON_H
#define LL_LLFLOATERSTINSON_H
+#include <string>
+
#include <boost/signals2.hpp>
#include "llfloater.h"
@@ -84,20 +86,24 @@ private:
void requestPutMaterials(const LLUUID& regionId);
void parseGetResponse(const LLSD& pContent);
+ void parsePutResponse(const LLSD& pContent);
void printResponse(const std::string& pRequestType, const LLSD& pContent) const;
void setState(EState pState);
inline EState getState() const;
- void clearMaterialsList();
+ void clearGetResults();
+ void clearPutResults();
void updateStatusMessage();
void updateControls();
+ std::string convertToPrintableMaterialID(const LLSD& pBinaryHash) const;
LLTextBase* mStatusText;
LLButton* mGetButton;
+ LLScrollListCtrl* mGetScrollList;
LLButton* mPutButton;
- LLScrollListCtrl* mMaterialsScrollList;
+ LLScrollListCtrl* mPutScrollList;
EState mState;
LLColor4 mWarningColor;
diff --git a/indra/newview/skins/default/xui/en/floater_stinson.xml b/indra/newview/skins/default/xui/en/floater_stinson.xml
index 559e6eb48f..fc44615602 100644
--- a/indra/newview/skins/default/xui/en/floater_stinson.xml
+++ b/indra/newview/skins/default/xui/en/floater_stinson.xml
@@ -3,9 +3,9 @@
positioning="cascading"
can_tear_off="false"
can_resize="true"
- height="315"
+ height="425"
width="1194"
- min_height="315"
+ min_height="450"
min_width="1100"
layout="topleft"
name="floater_stinson"
@@ -92,10 +92,10 @@
top_pad="10"
tab_stop="false"
multi_select="true"
- name="materials_scroll_list"
+ name="get_scroll_list"
width="1170">
<scroll_list.columns
- label="ID"
+ label="Material ID"
name="id"
dynamic_width="true" />
<scroll_list.columns
@@ -140,12 +140,12 @@
<panel
border="false"
bevel_style="none"
- follows="left|top"
+ follows="left|top|right"
layout="topleft"
left="12"
top_pad="10"
- height="22"
- width="214">
+ height="132"
+ width="700">
<button
follows="left|top"
height="22"
@@ -154,5 +154,29 @@
name="put_button"
top_pad="0"
width="214"/>
+ <scroll_list
+ column_padding="0"
+ draw_heading="true"
+ follows="left|top|right"
+ height="100"
+ layout="topleft"
+ top_pad="10"
+ tab_stop="false"
+ multi_select="true"
+ name="put_scroll_list"
+ width="700">
+ <scroll_list.columns
+ label="Object ID"
+ name="object_id"
+ width="80" />
+ <scroll_list.columns
+ label="Face Index"
+ name="face_index"
+ width="70" />
+ <scroll_list.columns
+ label="MaterialID"
+ name="material_id"
+ dynamic_width="true" />
+ </scroll_list>
</panel>
</floater>