diff options
Diffstat (limited to 'linden/indra/newview/llpaneldirplaces.cpp')
-rw-r--r-- | linden/indra/newview/llpaneldirplaces.cpp | 168 |
1 files changed, 152 insertions, 16 deletions
diff --git a/linden/indra/newview/llpaneldirplaces.cpp b/linden/indra/newview/llpaneldirplaces.cpp index 3980fb4..b75218b 100644 --- a/linden/indra/newview/llpaneldirplaces.cpp +++ b/linden/indra/newview/llpaneldirplaces.cpp | |||
@@ -33,37 +33,173 @@ | |||
33 | 33 | ||
34 | #include "llpaneldirplaces.h" | 34 | #include "llpaneldirplaces.h" |
35 | 35 | ||
36 | #include "llwebbrowserctrl.h" | 36 | // linden library includes |
37 | //#include "llfontgl.h" | ||
38 | #include "message.h" | ||
39 | //#include "lldir.h" | ||
40 | #include "llparcel.h" // parcel categories | ||
41 | //#include "llregionflags.h" | ||
42 | #include "llqueryflags.h" | ||
43 | |||
44 | // viewer project includes | ||
45 | #include "llagent.h" // getID(), isTeen() | ||
46 | //#include "llbutton.h" | ||
47 | //#include "llcheckboxctrl.h" | ||
48 | //#include "llcombobox.h" | ||
49 | //#include "llfloaterdirectory.h" | ||
50 | //#include "lllineeditor.h" | ||
51 | #include "llviewerwindow.h" // alertXml() | ||
52 | #include "llpaneldirbrowser.h" | ||
53 | //#include "lltextbox.h" | ||
54 | //#include "lluiconstants.h" | ||
55 | #include "llviewercontrol.h" // gSavedSettings | ||
56 | #include "llviewermessage.h" | ||
57 | //#include "llworldmap.h" | ||
37 | 58 | ||
38 | LLPanelDirPlaces::LLPanelDirPlaces(const std::string& name, LLFloaterDirectory* floater) | 59 | LLPanelDirPlaces::LLPanelDirPlaces(const std::string& name, LLFloaterDirectory* floater) |
39 | : LLPanelDirFind(name, floater, "places_browser") | 60 | : LLPanelDirBrowser(name, floater) |
61 | { | ||
62 | // MBW -- HACK!!! | ||
63 | // This looks like some sort of compiler bug. We have a mysterious crash during initialization on powerpc boxes. | ||
64 | // The crash seems unrelated to this code, but the commit that introduced it was narrowed down to this file. | ||
65 | // Adding llinfos calls to both the constructor and destructor here makes the crash go away, even though they don't get called before the point of the crash. | ||
66 | // This is wrong on many levels and scares the hell out of me. | ||
67 | llinfos << "called" << llendl; | ||
68 | mMinSearchChars = 3; | ||
69 | } | ||
70 | |||
71 | BOOL LLPanelDirPlaces::postBuild() | ||
72 | { | ||
73 | LLPanelDirBrowser::postBuild(); | ||
74 | |||
75 | childSetKeystrokeCallback("name", &LLPanelDirBrowser::onKeystrokeName, this); | ||
76 | |||
77 | childSetAction("Search", &LLPanelDirBrowser::onClickSearchCore, this); | ||
78 | childDisable("Search"); | ||
79 | |||
80 | mCurrentSortColumn = "dwell"; | ||
81 | mCurrentSortAscending = FALSE; | ||
82 | |||
83 | // Don't prepopulate the places list, as it hurts the database as of 2006-12-04. JC | ||
84 | // initialQuery(); | ||
85 | |||
86 | return TRUE; | ||
87 | } | ||
88 | |||
89 | LLPanelDirPlaces::~LLPanelDirPlaces() | ||
40 | { | 90 | { |
91 | // MBW -- HACK!!! | ||
92 | // This looks like some sort of compiler bug. We have a mysterious crash during initialization on powerpc boxes. | ||
93 | // The crash seems unrelated to this code, but the commit that introduced it was narrowed down to this file. | ||
94 | // Adding llinfos calls to both the constructor and destructor here makes the crash go away, even though they don't get called before the point of the crash. | ||
95 | // This is wrong on many levels and scares the hell out of me. | ||
96 | llinfos << "called" << llendl; | ||
97 | // Children all cleaned up by default view destructor. | ||
41 | } | 98 | } |
42 | 99 | ||
43 | 100 | ||
44 | void LLPanelDirPlaces::search(const std::string& search_text) | 101 | // virtual |
102 | void LLPanelDirPlaces::draw() | ||
103 | { | ||
104 | // You only have a choice if you are mature | ||
105 | childSetVisible("incmature", !gAgent.isTeen()); | ||
106 | childSetValue("incmature", gSavedSettings.getBOOL("ShowMatureSims")); | ||
107 | |||
108 | LLPanelDirBrowser::draw(); | ||
109 | } | ||
110 | |||
111 | // virtual | ||
112 | void LLPanelDirPlaces::performQuery() | ||
45 | { | 113 | { |
46 | if (!search_text.empty()) | 114 | LLString place_name = childGetValue("name").asString(); |
115 | if (place_name.length() < mMinSearchChars) | ||
47 | { | 116 | { |
48 | bool mature = childGetValue( "mature_check" ).asBoolean(); | 117 | return; |
49 | std::string selected_collection = "Places"; | 118 | } |
50 | std::string url = buildSearchURL(search_text, selected_collection, mature); | 119 | |
51 | if (mWebBrowser) | 120 | // "hi " is three chars but not a long-enough search |
52 | { | 121 | std::string query_string = place_name; |
53 | mWebBrowser->navigateTo(url); | 122 | LLString::trim( query_string ); |
54 | } | 123 | bool query_was_filtered = (query_string != place_name); |
124 | |||
125 | // possible we threw away all the short words in the query so check length | ||
126 | if ( query_string.length() < mMinSearchChars ) | ||
127 | { | ||
128 | gViewerWindow->alertXml("SeachFilteredOnShortWordsEmpty"); | ||
129 | return; | ||
130 | }; | ||
131 | |||
132 | // if we filtered something out, display a popup | ||
133 | if ( query_was_filtered ) | ||
134 | { | ||
135 | LLString::format_map_t args; | ||
136 | args["[FINALQUERY]"] = query_string; | ||
137 | gViewerWindow->alertXml("SeachFilteredOnShortWords", args); | ||
138 | }; | ||
139 | |||
140 | LLString catstring = childGetValue("Category").asString(); | ||
141 | |||
142 | // Because LLParcel::C_ANY is -1, must do special check | ||
143 | S32 category = 0; | ||
144 | if (catstring == "any") | ||
145 | { | ||
146 | category = LLParcel::C_ANY; | ||
55 | } | 147 | } |
56 | else | 148 | else |
57 | { | 149 | { |
58 | // empty search text | 150 | category = LLParcel::getCategoryFromString(catstring.c_str()); |
59 | navigateToDefaultPage(); | ||
60 | } | 151 | } |
61 | 152 | ||
62 | childSetText("search_editor", search_text); | 153 | BOOL pg_only = !gSavedSettings.getBOOL("ShowMatureSims") |
154 | || gAgent.isTeen(); | ||
155 | |||
156 | queryCore(query_string, category, pg_only); | ||
63 | } | 157 | } |
64 | 158 | ||
65 | LLPanelDirPlaces::~LLPanelDirPlaces() | 159 | void LLPanelDirPlaces::initialQuery() |
66 | { | 160 | { |
67 | // Children all cleaned up by default view destructor. | 161 | // All Linden locations in PG/Mature sims, any name. |
162 | const BOOL pg_only = FALSE; | ||
163 | queryCore("", LLParcel::C_LINDEN, pg_only); | ||
164 | } | ||
165 | |||
166 | void LLPanelDirPlaces::queryCore(const LLString& name, | ||
167 | S32 category, | ||
168 | BOOL pg_only) | ||
169 | { | ||
170 | setupNewSearch(); | ||
171 | |||
172 | // send the message | ||
173 | U32 flags = 0x0; | ||
174 | |||
175 | if (pg_only) | ||
176 | { | ||
177 | flags |= DFQ_PG_PARCELS_ONLY; | ||
178 | } | ||
179 | |||
180 | // JC: Sorting by dwell severely impacts the performance of the query. | ||
181 | // Instead of sorting on the dataserver, we sort locally once the results | ||
182 | // are received. | ||
183 | // IW: Re-enabled dwell sort based on new 3-character minimum description | ||
184 | // Hopefully we'll move to next-gen Find before this becomes a big problem | ||
185 | |||
186 | flags |= DFQ_DWELL_SORT; | ||
187 | |||
188 | LLMessageSystem* msg = gMessageSystem; | ||
189 | |||
190 | msg->newMessage("DirPlacesQuery"); | ||
191 | msg->nextBlock("AgentData"); | ||
192 | msg->addUUID("AgentID", gAgent.getID()); | ||
193 | msg->addUUID("SessionID", gAgent.getSessionID()); | ||
194 | msg->nextBlock("QueryData"); | ||
195 | msg->addUUID("QueryID", getSearchID()); | ||
196 | msg->addString("QueryText", name); | ||
197 | msg->addU32("QueryFlags", flags); | ||
198 | msg->addS8("Category", (S8)category); | ||
199 | // No longer support queries by region name, too many regions | ||
200 | // for combobox, no easy way to do autocomplete. JC | ||
201 | msg->addString("SimName", ""); | ||
202 | msg->addS32Fast(_PREHASH_QueryStart,mSearchStart); | ||
203 | gAgent.sendReliableMessage(); | ||
68 | } | 204 | } |
69 | 205 | ||