A Massive Experience Tools (and Unstable Branch) Merge
[XP Tools] Initial merge Cherry Pick Also modernize llfloaterauction internally, but leave the ui the same for now. Breaks out script_question_mute() in llviewermessage.cpp to better sync with upstream Adds support for UnknownScriptQuestion notification (translators need to translate this one~) RLVa note: Rewrote RLVa permissions handling block just a bit. Added 13 new capabilities from the XP Tools, I doubt all of them really exist. Minor update to LLComboBox, decided against implementing LLIconsComboBox for now. Modified LLExperienceLog::notify to lookup names and display them along with the slurls since our editors don't do that automatically. Experience tweak: Changed a few notify's to notifytips so that we can click the links to experience profiles from chat instead of via hacked in buttons Migrated LLFloaterCompileQueue to a proper Instance Tracker so we can call getKey Modernized LLSD, gives us reverse iterators and the new debugging impl. We needed the reverse iterators. Experience tweak: Added virtual destructors to responders. Updated llhandle.h to allow calling getDerivedHandle in public. Updated LLScrollContainer and LLScrollBar to be more modern. Added LLFlatListView/flat_list_view from upstream - these don't seem work though? Added some newer login/logout strings to strings.xml Thanks for the default timeout policies, Aleric~ To avoid needing to scroll through tabs, about land tabs now are as big as they need to be to display their labels, same on groups Group Members and Roles has been renamed to just Members because this allows the new Experiences tab enough room to display. Thanks to Henri Beauchamp (Cool VL Viewer) for the setupList augmentation. (without it, I'd still be stuck) Thanks to Shyotl for the helpsies~ Added the LSL constants, events, and functions that LL neglected to put in. Added click callbacks and name lookups for profile linky texts~ Merge is up to 22b4cdc Old TODO: Get the uis looking nice (profiles? Experiences... floater) - done Old TODO: Make sure flatlistviews look okay... - Not using Old TODO: Fix LLFloaterExperiencePicker, right now the panel does not show. - unsure Old TODO: Remove the llfloaterabout.cpp change. - done Merges llexperiencecache with upstream and unstable Introduces LLCoroResponder, TODO: Make everything use this. Updates Reporter floater to the latest, supports the new cap thingy Also adds these commits/changes: [XPTools] Double clicking experiences in namelists should open the profile Add List.CopyNames support for Experiences [XP Tools] Some UI work, I'll do more later [XPTools] More UI Stuff, Later is now! Allow getSLURL for experiences WIP Experience list menu Also make EXPERIENCE > OBJECT, because mainline started OBJECT already [XPTools] Add Experience support to Name UI [XPTools] Fix experience profile UI 9c3067e843265587e91c659200a8d783acf2d9b2 [XPTools] Fix experience location showing "last" and getting set to "last" [XPTools] Move Experiences floater from view menu to world menu [XPTools] Fix up more UI [XPTools] Fix experiences panels [XPTools] Hide pieces of the Experiences menu when they're not usable [XPTools] More UI work, mostly to get the menus working [XPTools] The events list is for events, not experiences, remove menu # Conflicts: # indra/llcommon/llsd.cpp - merge with unstable branch # indra/llmessage/message_prehash.cpp # indra/llmessage/message_prehash.h # indra/llui/llscrollbar.cpp # indra/llui/llscrollcontainer.cpp # indra/llui/llurlentry.cpp # indra/llui/llurlregistry.cpp # indra/newview/app_settings/keywords.ini # indra/newview/app_settings/settings.xml # indra/newview/llappviewer.cpp # indra/newview/llappviewer.h # indra/newview/llassetuploadresponders.cpp # indra/newview/llcompilequeue.* - merge stable # indra/newview/llfloaterabout.cpp # indra/newview/llfloaterland.* - merge unstable # indra/newview/llfloaterproperties.cpp # indra/newview/llfloaterregioninfo.* - merge unstable # indra/newview/llmenucommands.cpp - merge unstable # indra/newview/llpreviewscript.cpp - merge unstable # indra/newview/llviewermessage.cpp - merge unstable # indra/newview/llviewerregion.cpp - merge unstable # indra/newview/skins/default/textures/textures.xml - merge unstable # indra/newview/skins/default/xui/en-us/strings.xml - merge unstable
This commit is contained in:
committed by
Liru Færs
parent
9a53824d6d
commit
36b75b2398
@@ -121,20 +121,18 @@ LLViewerParcelMgr::LLViewerParcelMgr()
|
||||
mHoverRequestResult(0),
|
||||
mHoverWestSouth(),
|
||||
mHoverEastNorth(),
|
||||
mCollisionRegionHandle(0),
|
||||
mCollisionUpdateSignal(nullptr),
|
||||
mRenderCollision(FALSE),
|
||||
mRenderSelection(TRUE),
|
||||
mCollisionBanned(0),
|
||||
mCollisionTimer(),
|
||||
// [SL:KB] - Patch: World-MinimapOverlay | Checked: 2012-06-20 (Catznip-3.3.0)
|
||||
mCollisionRegionHandle(0),
|
||||
mCollisionUpdateSignal(NULL),
|
||||
// [/SL:KB]
|
||||
mMediaParcelId(0),
|
||||
mMediaRegionId(0),
|
||||
mHighlightSegments(NULL),
|
||||
mCollisionSegments(NULL),
|
||||
mAgentParcelOverlay(NULL),
|
||||
mParcelsPerEdge(0)
|
||||
mHighlightSegments(nullptr),
|
||||
mCollisionSegments(nullptr),
|
||||
mAgentParcelOverlay(nullptr),
|
||||
mParcelsPerEdge(0),
|
||||
mMediaRegionId(0)
|
||||
{
|
||||
mCurrentParcel = new LLParcel();
|
||||
mCurrentParcelSelection = new LLParcelSelection(mCurrentParcel);
|
||||
@@ -144,17 +142,12 @@ LLViewerParcelMgr::LLViewerParcelMgr()
|
||||
mHoverParcel = new LLParcel();
|
||||
mCollisionParcel = new LLParcel();
|
||||
|
||||
// <FS:CR> Aurora Sim
|
||||
mParcelsPerEdge = S32(8192.f / PARCEL_GRID_STEP_METERS); // 8192 is the maximum region size on WhiteCore and solves the audio problem.
|
||||
//mParcelsPerEdge = S32( REGION_WIDTH_METERS / PARCEL_GRID_STEP_METERS );
|
||||
// </FS:CR> Aurora Sim
|
||||
mHighlightSegments = new U8[(mParcelsPerEdge+1)*(mParcelsPerEdge+1)];
|
||||
resetSegments(mHighlightSegments);
|
||||
|
||||
// [SL:KB] - Patch: World-MinimapOverlay | Checked: 2012-06-20 (Catznip-3.3.0)
|
||||
mCollisionBitmap = new U8[getCollisionBitmapSize()];
|
||||
memset(mCollisionBitmap, 0, getCollisionBitmapSize());
|
||||
// [/SL:KB]
|
||||
|
||||
mCollisionSegments = new U8[(mParcelsPerEdge+1)*(mParcelsPerEdge+1)];
|
||||
resetSegments(mCollisionSegments);
|
||||
@@ -175,19 +168,14 @@ LLViewerParcelMgr::LLViewerParcelMgr()
|
||||
mAgentParcelOverlay[i] = 0;
|
||||
}
|
||||
|
||||
// <FS:CR> Aurora Sim
|
||||
mParcelsPerEdge = S32(REGION_WIDTH_METERS / PARCEL_GRID_STEP_METERS);
|
||||
// </FS:CR> Aurora Sim
|
||||
|
||||
mTeleportInProgress = TRUE; // the initial parcel update is treated like teleport
|
||||
}
|
||||
|
||||
// <FS:CR> Aurora Sim
|
||||
void LLViewerParcelMgr::init(F32 region_size)
|
||||
{
|
||||
mParcelsPerEdge = S32(region_size / PARCEL_GRID_STEP_METERS);
|
||||
}
|
||||
// </FS:CR> Aurora Sim
|
||||
|
||||
LLViewerParcelMgr::~LLViewerParcelMgr()
|
||||
{
|
||||
@@ -212,10 +200,8 @@ LLViewerParcelMgr::~LLViewerParcelMgr()
|
||||
delete[] mHighlightSegments;
|
||||
mHighlightSegments = NULL;
|
||||
|
||||
// [SL:KB] - Patch: World-MinimapOverlay | Checked: 2012-06-20 (Catznip-3.3.0)
|
||||
delete[] mCollisionBitmap;
|
||||
mCollisionBitmap = NULL;
|
||||
// [/SL:KB]
|
||||
|
||||
delete[] mCollisionSegments;
|
||||
mCollisionSegments = NULL;
|
||||
@@ -239,11 +225,9 @@ void LLViewerParcelMgr::dump()
|
||||
mCurrentParcel->dump();
|
||||
LL_INFOS() << "banning " << mCurrentParcel->mBanList.size() << LL_ENDL;
|
||||
|
||||
access_map_const_iterator cit = mCurrentParcel->mBanList.begin();
|
||||
access_map_const_iterator end = mCurrentParcel->mBanList.end();
|
||||
for ( ; cit != end; ++cit)
|
||||
for (const auto& pair : mCurrentParcel->mBanList)
|
||||
{
|
||||
LL_INFOS() << "ban id " << (*cit).first << LL_ENDL;
|
||||
LL_INFOS() << "ban id " << pair.first << LL_ENDL;
|
||||
}
|
||||
LL_INFOS() << "Hover parcel:" << LL_ENDL;
|
||||
mHoverParcel->dump();
|
||||
@@ -252,7 +236,7 @@ void LLViewerParcelMgr::dump()
|
||||
}
|
||||
|
||||
|
||||
LLViewerRegion* LLViewerParcelMgr::getSelectionRegion()
|
||||
LLViewerRegion* LLViewerParcelMgr::getSelectionRegion() const
|
||||
{
|
||||
return LLWorld::getInstance()->getRegionFromPosGlobal( mWestSouth );
|
||||
}
|
||||
@@ -472,14 +456,9 @@ LLParcelSelectionHandle LLViewerParcelMgr::selectParcelInRectangle()
|
||||
void LLViewerParcelMgr::selectCollisionParcel()
|
||||
{
|
||||
// BUG: Claim to be in the agent's region
|
||||
// <FS:CR> Aurora Sim
|
||||
//mWestSouth = gAgent.getRegion()->getOriginGlobal();
|
||||
//mEastNorth = mWestSouth;
|
||||
//mEastNorth += LLVector3d(PARCEL_GRID_STEP_METERS, PARCEL_GRID_STEP_METERS, 0.0);
|
||||
mWestSouth = getSelectionRegion()->getOriginGlobal();
|
||||
mEastNorth = mWestSouth;
|
||||
mEastNorth += LLVector3d(getSelectionRegion()->getWidth()/REGION_WIDTH_METERS * PARCEL_GRID_STEP_METERS, getSelectionRegion()->getWidth()/REGION_WIDTH_METERS * PARCEL_GRID_STEP_METERS, 0.0);
|
||||
// </FS:CR> Aurora Sim
|
||||
|
||||
// BUG: must be in the sim you are in
|
||||
LLMessageSystem *msg = gMessageSystem;
|
||||
@@ -891,8 +870,8 @@ LLParcel* LLViewerParcelMgr::getCollisionParcel() const
|
||||
|
||||
void LLViewerParcelMgr::render()
|
||||
{
|
||||
static const LLCachedControl<bool> RenderParcelSelection("RenderParcelSelection");
|
||||
if (mSelected && mRenderSelection && RenderParcelSelection)
|
||||
static const LLCachedControl<bool> render_parcel_selection(gSavedSettings, "RenderParcelSelection");
|
||||
if (mSelected && mRenderSelection && render_parcel_selection)
|
||||
{
|
||||
// Rendering is done in agent-coordinates, so need to supply
|
||||
// an appropriate offset to the render code.
|
||||
@@ -912,8 +891,8 @@ void LLViewerParcelMgr::renderParcelCollision()
|
||||
mRenderCollision = FALSE;
|
||||
}
|
||||
|
||||
static const LLCachedControl<bool> ShowBanLines("ShowBanLines");
|
||||
if (mRenderCollision && ShowBanLines)
|
||||
static const LLCachedControl<bool> render_ban_line(gSavedSettings, "ShowBanLines");
|
||||
if (mRenderCollision && render_ban_line)
|
||||
{
|
||||
LLViewerRegion* regionp = gAgent.getRegion();
|
||||
if (regionp)
|
||||
@@ -936,7 +915,7 @@ void LLViewerParcelMgr::sendParcelAccessListRequest(U32 flags)
|
||||
if (!region) return;
|
||||
|
||||
LLMessageSystem *msg = gMessageSystem;
|
||||
|
||||
|
||||
|
||||
if (flags & AL_BAN)
|
||||
{
|
||||
@@ -946,6 +925,14 @@ void LLViewerParcelMgr::sendParcelAccessListRequest(U32 flags)
|
||||
{
|
||||
mCurrentParcel->mAccessList.clear();
|
||||
}
|
||||
if (flags & AL_ALLOW_EXPERIENCE)
|
||||
{
|
||||
mCurrentParcel->clearExperienceKeysByType(EXPERIENCE_KEY_TYPE_ALLOWED);
|
||||
}
|
||||
if (flags & AL_BLOCK_EXPERIENCE)
|
||||
{
|
||||
mCurrentParcel->clearExperienceKeysByType(EXPERIENCE_KEY_TYPE_BLOCKED);
|
||||
}
|
||||
|
||||
// Only the headers differ
|
||||
msg->newMessageFast(_PREHASH_ParcelAccessListRequest);
|
||||
@@ -1322,10 +1309,13 @@ const std::string& LLViewerParcelMgr::getAgentParcelName() const
|
||||
|
||||
void LLViewerParcelMgr::sendParcelPropertiesUpdate(LLParcel* parcel, bool use_agent_region)
|
||||
{
|
||||
if(!parcel) return;
|
||||
if (!parcel)
|
||||
return;
|
||||
|
||||
LLViewerRegion *region = use_agent_region ? gAgent.getRegion() : LLWorld::getInstance()->getRegionFromPosGlobal( mWestSouth );
|
||||
if (!region) return;
|
||||
if (!region)
|
||||
return;
|
||||
|
||||
//LL_INFOS() << "found region: " << region->getName() << LL_ENDL;
|
||||
|
||||
LLSD body;
|
||||
@@ -1338,6 +1328,7 @@ void LLViewerParcelMgr::sendParcelPropertiesUpdate(LLParcel* parcel, bool use_ag
|
||||
parcel->packMessage(body);
|
||||
LL_INFOS() << "Sending parcel properties update via capability to: "
|
||||
<< url << LL_ENDL;
|
||||
|
||||
LLHTTPClient::post(url, body, new LLHTTPClient::ResponderIgnore);
|
||||
}
|
||||
else
|
||||
@@ -1365,10 +1356,8 @@ void LLViewerParcelMgr::setHoverParcel(const LLVector3d& pos)
|
||||
static U32 last_west, last_south;
|
||||
|
||||
// only request parcel info when tooltip is shown
|
||||
if (!gSavedSettings.getBOOL("ShowLandHoverTip"))
|
||||
{
|
||||
return;
|
||||
}
|
||||
if (!gSavedSettings.getBOOL("ShowLandHoverTip")) return;
|
||||
|
||||
// only request parcel info if position has changed outside of the
|
||||
// last parcel grid step
|
||||
U32 west_parcel_step = (U32) floor( pos.mdV[VX] / PARCEL_GRID_STEP_METERS );
|
||||
@@ -1390,6 +1379,7 @@ void LLViewerParcelMgr::setHoverParcel(const LLVector3d& pos)
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
// Send a rectangle around the point.
|
||||
// This means the parcel sent back is at least a rectangle around the point,
|
||||
// which is more efficient for public land. Fewer requests are sent. JC
|
||||
@@ -1437,11 +1427,7 @@ void LLViewerParcelMgr::processParcelOverlay(LLMessageSystem *msg, void **user)
|
||||
return;
|
||||
}
|
||||
|
||||
// <FS:CR> Aurora Sim
|
||||
//S32 parcels_per_edge = LLViewerParcelMgr::getInstance()->mParcelsPerEdge;
|
||||
//S32 expected_size = parcels_per_edge * parcels_per_edge / PARCEL_OVERLAY_CHUNKS;
|
||||
S32 expected_size = 1024;
|
||||
// </FS:CR> Aurora Sim
|
||||
if (packed_overlay_size != expected_size)
|
||||
{
|
||||
LL_WARNS() << "Got parcel overlay size " << packed_overlay_size
|
||||
@@ -1504,13 +1490,11 @@ void LLViewerParcelMgr::processParcelProperties(LLMessageSystem *msg, void **use
|
||||
S32 other_clean_time = 0;
|
||||
|
||||
LLViewerParcelMgr& parcel_mgr = LLViewerParcelMgr::instance();
|
||||
// <FS:CR> Aurora Sim
|
||||
LLViewerRegion* msg_region = LLWorld::getInstance()->getRegion(msg->getSender());
|
||||
if(msg_region)
|
||||
parcel_mgr.mParcelsPerEdge = S32(msg_region->getWidth() / PARCEL_GRID_STEP_METERS);
|
||||
else
|
||||
parcel_mgr.mParcelsPerEdge = S32(gAgent.getRegion()->getWidth() / PARCEL_GRID_STEP_METERS);
|
||||
// </FS:CR> Aurora Sim
|
||||
|
||||
msg->getS32Fast(_PREHASH_ParcelData, _PREHASH_RequestResult, request_result );
|
||||
msg->getS32Fast(_PREHASH_ParcelData, _PREHASH_SequenceID, sequence_id );
|
||||
@@ -1624,6 +1608,7 @@ void LLViewerParcelMgr::processParcelProperties(LLMessageSystem *msg, void **use
|
||||
|
||||
if (parcel == parcel_mgr.mAgentParcel)
|
||||
{
|
||||
// new agent parcel
|
||||
S32 bitmap_size = parcel_mgr.mParcelsPerEdge
|
||||
* parcel_mgr.mParcelsPerEdge
|
||||
/ 8;
|
||||
@@ -1636,6 +1621,7 @@ void LLViewerParcelMgr::processParcelProperties(LLMessageSystem *msg, void **use
|
||||
// Let interesting parties know about agent parcel change.
|
||||
LLViewerParcelMgr* instance = LLViewerParcelMgr::getInstance();
|
||||
|
||||
// Notify anything that wants to know when the agent changes parcels
|
||||
instance->mAgentParcelChangedSignal();
|
||||
|
||||
if (instance->mTeleportInProgress)
|
||||
@@ -1714,7 +1700,7 @@ void LLViewerParcelMgr::processParcelProperties(LLMessageSystem *msg, void **use
|
||||
}
|
||||
|
||||
// Request access list information for this land
|
||||
parcel_mgr.sendParcelAccessListRequest(AL_ACCESS | AL_BAN);
|
||||
parcel_mgr.sendParcelAccessListRequest(AL_ACCESS | AL_BAN | AL_ALLOW_EXPERIENCE | AL_BLOCK_EXPERIENCE);
|
||||
|
||||
// Request dwell for this land, if it's not public land.
|
||||
parcel_mgr.mSelectedDwell = DWELL_NAN;
|
||||
@@ -1827,12 +1813,14 @@ void LLViewerParcelMgr::processParcelProperties(LLMessageSystem *msg, void **use
|
||||
{
|
||||
LL_INFOS() << "Stopping parcel music (invalid audio stream URL)" << LL_ENDL;
|
||||
// clears the URL
|
||||
// null value causes fade out
|
||||
gAudiop->startInternetStream(LLStringUtil::null);
|
||||
}
|
||||
}
|
||||
else if (!gAudiop->getInternetStreamURL().empty())
|
||||
{
|
||||
LL_INFOS() << "Stopping parcel music (parcel stream URL is empty)" << LL_ENDL;
|
||||
// null value causes fade out
|
||||
gAudiop->startInternetStream(LLStringUtil::null);
|
||||
}
|
||||
}
|
||||
@@ -1857,7 +1845,7 @@ void optionally_start_music(LLParcel* parcel)
|
||||
// changed as part of SL-4878
|
||||
if (gOverlayBar && gOverlayBar->musicPlaying())
|
||||
{
|
||||
LLPanelNearByMedia* nearby_media_panel = LLFloaterNearbyMedia::instanceExists() ? LLFloaterNearbyMedia::getInstance()->getMediaPanel() : NULL;
|
||||
LLPanelNearByMedia* nearby_media_panel = LLFloaterNearbyMedia::instanceExists() ? LLFloaterNearbyMedia::getInstance()->getMediaPanel() : nullptr;
|
||||
if ((nearby_media_panel &&
|
||||
nearby_media_panel->getParcelAudioAutoStart()) ||
|
||||
// or they have expressed no opinion in the UI, but have autoplay on...
|
||||
@@ -1865,6 +1853,7 @@ void optionally_start_music(LLParcel* parcel)
|
||||
/*gSavedSettings.getBOOL(LLViewerMedia::AUTO_PLAY_MEDIA_SETTING) &&*/
|
||||
gSavedSettings.getBOOL("MediaTentativeAutoPlay")))
|
||||
{
|
||||
LL_INFOS() << "Starting parcel music " << parcel->getMusicURL() << LL_ENDL;
|
||||
LLViewerParcelMedia::playStreamingMusic(parcel);
|
||||
return;
|
||||
}
|
||||
@@ -1891,7 +1880,7 @@ void LLViewerParcelMgr::processParcelAccessListReply(LLMessageSystem *msg, void
|
||||
|
||||
if (parcel_id != parcel->getLocalID())
|
||||
{
|
||||
LL_WARNS() << "processParcelAccessListReply for parcel " << parcel_id
|
||||
LL_WARNS_ONCE("") << "processParcelAccessListReply for parcel " << parcel_id
|
||||
<< " which isn't the selected parcel " << parcel->getLocalID()<< LL_ENDL;
|
||||
return;
|
||||
}
|
||||
@@ -1904,6 +1893,14 @@ void LLViewerParcelMgr::processParcelAccessListReply(LLMessageSystem *msg, void
|
||||
{
|
||||
parcel->unpackAccessEntries(msg, &(parcel->mBanList) );
|
||||
}
|
||||
else if (message_flags & AL_ALLOW_EXPERIENCE)
|
||||
{
|
||||
parcel->unpackExperienceEntries(msg, EXPERIENCE_KEY_TYPE_ALLOWED);
|
||||
}
|
||||
else if (message_flags & AL_BLOCK_EXPERIENCE)
|
||||
{
|
||||
parcel->unpackExperienceEntries(msg, EXPERIENCE_KEY_TYPE_BLOCKED);
|
||||
}
|
||||
/*else if (message_flags & AL_RENTER)
|
||||
{
|
||||
parcel->unpackAccessEntries(msg, &(parcel->mRenterList) );
|
||||
@@ -1938,10 +1935,6 @@ void LLViewerParcelMgr::processParcelDwellReply(LLMessageSystem* msg, void**)
|
||||
|
||||
void LLViewerParcelMgr::sendParcelAccessListUpdate(U32 which)
|
||||
{
|
||||
|
||||
LLUUID transactionUUID;
|
||||
transactionUUID.generate();
|
||||
|
||||
if (!mSelected)
|
||||
{
|
||||
return;
|
||||
@@ -1950,125 +1943,95 @@ void LLViewerParcelMgr::sendParcelAccessListUpdate(U32 which)
|
||||
LLViewerRegion* region = LLWorld::getInstance()->getRegionFromPosGlobal( mWestSouth );
|
||||
if (!region) return;
|
||||
|
||||
LLMessageSystem* msg = gMessageSystem;
|
||||
|
||||
LLParcel* parcel = mCurrentParcel;
|
||||
if (!parcel) return;
|
||||
|
||||
if (which & AL_ACCESS)
|
||||
{
|
||||
S32 count = parcel->mAccessList.size();
|
||||
S32 num_sections = (S32) ceil(count/PARCEL_MAX_ENTRIES_PER_PACKET);
|
||||
S32 sequence_id = 1;
|
||||
BOOL start_message = TRUE;
|
||||
BOOL initial = TRUE;
|
||||
|
||||
access_map_const_iterator cit = parcel->mAccessList.begin();
|
||||
access_map_const_iterator end = parcel->mAccessList.end();
|
||||
while ( (cit != end) || initial )
|
||||
{
|
||||
if (start_message)
|
||||
{
|
||||
msg->newMessageFast(_PREHASH_ParcelAccessListUpdate);
|
||||
msg->nextBlockFast(_PREHASH_AgentData);
|
||||
msg->addUUIDFast(_PREHASH_AgentID, gAgent.getID() );
|
||||
msg->addUUIDFast(_PREHASH_SessionID, gAgent.getSessionID() );
|
||||
msg->nextBlockFast(_PREHASH_Data);
|
||||
msg->addU32Fast(_PREHASH_Flags, AL_ACCESS);
|
||||
msg->addS32(_PREHASH_LocalID, parcel->getLocalID() );
|
||||
msg->addUUIDFast(_PREHASH_TransactionID, transactionUUID);
|
||||
msg->addS32Fast(_PREHASH_SequenceID, sequence_id);
|
||||
msg->addS32Fast(_PREHASH_Sections, num_sections);
|
||||
start_message = FALSE;
|
||||
|
||||
if (initial && (cit == end))
|
||||
{
|
||||
// pack an empty block if there will be no data
|
||||
msg->nextBlockFast(_PREHASH_List);
|
||||
msg->addUUIDFast(_PREHASH_ID, LLUUID::null );
|
||||
msg->addS32Fast(_PREHASH_Time, 0 );
|
||||
msg->addU32Fast(_PREHASH_Flags, 0 );
|
||||
}
|
||||
|
||||
initial = FALSE;
|
||||
sequence_id++;
|
||||
|
||||
}
|
||||
|
||||
while ( (cit != end) && (msg->getCurrentSendTotal() < MTUBYTES))
|
||||
{
|
||||
|
||||
const LLAccessEntry& entry = (*cit).second;
|
||||
|
||||
msg->nextBlockFast(_PREHASH_List);
|
||||
msg->addUUIDFast(_PREHASH_ID, entry.mID );
|
||||
msg->addS32Fast(_PREHASH_Time, entry.mTime );
|
||||
msg->addU32Fast(_PREHASH_Flags, entry.mFlags );
|
||||
++cit;
|
||||
}
|
||||
|
||||
start_message = TRUE;
|
||||
msg->sendReliable( region->getHost() );
|
||||
}
|
||||
{
|
||||
sendParcelAccessListUpdate(AL_ACCESS, parcel->mAccessList, region, parcel->getLocalID());
|
||||
}
|
||||
|
||||
if (which & AL_BAN)
|
||||
{
|
||||
S32 count = parcel->mBanList.size();
|
||||
S32 num_sections = (S32) ceil(count/PARCEL_MAX_ENTRIES_PER_PACKET);
|
||||
S32 sequence_id = 1;
|
||||
BOOL start_message = TRUE;
|
||||
BOOL initial = TRUE;
|
||||
{
|
||||
sendParcelAccessListUpdate(AL_BAN, parcel->mBanList, region, parcel->getLocalID());
|
||||
}
|
||||
|
||||
access_map_const_iterator cit = parcel->mBanList.begin();
|
||||
access_map_const_iterator end = parcel->mBanList.end();
|
||||
while ( (cit != end) || initial )
|
||||
{
|
||||
if (start_message)
|
||||
{
|
||||
msg->newMessageFast(_PREHASH_ParcelAccessListUpdate);
|
||||
msg->nextBlockFast(_PREHASH_AgentData);
|
||||
msg->addUUIDFast(_PREHASH_AgentID, gAgent.getID() );
|
||||
msg->addUUIDFast(_PREHASH_SessionID, gAgent.getSessionID() );
|
||||
msg->nextBlockFast(_PREHASH_Data);
|
||||
msg->addU32Fast(_PREHASH_Flags, AL_BAN);
|
||||
msg->addS32(_PREHASH_LocalID, parcel->getLocalID() );
|
||||
msg->addUUIDFast(_PREHASH_TransactionID, transactionUUID);
|
||||
msg->addS32Fast(_PREHASH_SequenceID, sequence_id);
|
||||
msg->addS32Fast(_PREHASH_Sections, num_sections);
|
||||
start_message = FALSE;
|
||||
if (which & AL_ALLOW_EXPERIENCE)
|
||||
{
|
||||
sendParcelAccessListUpdate(AL_ALLOW_EXPERIENCE, parcel->getExperienceKeysByType(EXPERIENCE_KEY_TYPE_ALLOWED), region, parcel->getLocalID());
|
||||
}
|
||||
|
||||
if (initial && (cit == end))
|
||||
{
|
||||
// pack an empty block if there will be no data
|
||||
msg->nextBlockFast(_PREHASH_List);
|
||||
msg->addUUIDFast(_PREHASH_ID, LLUUID::null );
|
||||
msg->addS32Fast(_PREHASH_Time, 0 );
|
||||
msg->addU32Fast(_PREHASH_Flags, 0 );
|
||||
}
|
||||
|
||||
initial = FALSE;
|
||||
sequence_id++;
|
||||
|
||||
}
|
||||
|
||||
while ( (cit != end) && (msg->getCurrentSendTotal() < MTUBYTES))
|
||||
{
|
||||
const LLAccessEntry& entry = (*cit).second;
|
||||
|
||||
msg->nextBlockFast(_PREHASH_List);
|
||||
msg->addUUIDFast(_PREHASH_ID, entry.mID );
|
||||
msg->addS32Fast(_PREHASH_Time, entry.mTime );
|
||||
msg->addU32Fast(_PREHASH_Flags, entry.mFlags );
|
||||
++cit;
|
||||
}
|
||||
|
||||
start_message = TRUE;
|
||||
msg->sendReliable( region->getHost() );
|
||||
}
|
||||
if (which & AL_BLOCK_EXPERIENCE)
|
||||
{
|
||||
sendParcelAccessListUpdate(AL_BLOCK_EXPERIENCE, parcel->getExperienceKeysByType(EXPERIENCE_KEY_TYPE_BLOCKED), region, parcel->getLocalID());
|
||||
}
|
||||
}
|
||||
|
||||
void LLViewerParcelMgr::sendParcelAccessListUpdate(U32 flags, const LLAccessEntry::map& entries, LLViewerRegion* region, S32 parcel_local_id)
|
||||
{
|
||||
S32 count = entries.size();
|
||||
S32 num_sections = (S32) ceil(count/PARCEL_MAX_ENTRIES_PER_PACKET);
|
||||
S32 sequence_id = 1;
|
||||
BOOL start_message = TRUE;
|
||||
BOOL initial = TRUE;
|
||||
|
||||
|
||||
LLUUID transactionUUID;
|
||||
transactionUUID.generate();
|
||||
|
||||
|
||||
LLMessageSystem* msg = gMessageSystem;
|
||||
|
||||
LLAccessEntry::map::const_iterator cit = entries.begin();
|
||||
LLAccessEntry::map::const_iterator end = entries.end();
|
||||
while ( (cit != end) || initial )
|
||||
{
|
||||
if (start_message)
|
||||
{
|
||||
msg->newMessageFast(_PREHASH_ParcelAccessListUpdate);
|
||||
msg->nextBlockFast(_PREHASH_AgentData);
|
||||
msg->addUUIDFast(_PREHASH_AgentID, gAgent.getID() );
|
||||
msg->addUUIDFast(_PREHASH_SessionID, gAgent.getSessionID() );
|
||||
msg->nextBlockFast(_PREHASH_Data);
|
||||
msg->addU32Fast(_PREHASH_Flags, flags);
|
||||
msg->addS32(_PREHASH_LocalID, parcel_local_id);
|
||||
msg->addUUIDFast(_PREHASH_TransactionID, transactionUUID);
|
||||
msg->addS32Fast(_PREHASH_SequenceID, sequence_id);
|
||||
msg->addS32Fast(_PREHASH_Sections, num_sections);
|
||||
start_message = FALSE;
|
||||
|
||||
if (initial && (cit == end))
|
||||
{
|
||||
// pack an empty block if there will be no data
|
||||
msg->nextBlockFast(_PREHASH_List);
|
||||
msg->addUUIDFast(_PREHASH_ID, LLUUID::null );
|
||||
msg->addS32Fast(_PREHASH_Time, 0 );
|
||||
msg->addU32Fast(_PREHASH_Flags, 0 );
|
||||
}
|
||||
|
||||
initial = FALSE;
|
||||
sequence_id++;
|
||||
|
||||
}
|
||||
|
||||
while ( (cit != end) && (msg->getCurrentSendTotal() < MTUBYTES))
|
||||
{
|
||||
|
||||
const LLAccessEntry& entry = (*cit).second;
|
||||
|
||||
msg->nextBlockFast(_PREHASH_List);
|
||||
msg->addUUIDFast(_PREHASH_ID, entry.mID );
|
||||
msg->addS32Fast(_PREHASH_Time, entry.mTime );
|
||||
msg->addU32Fast(_PREHASH_Flags, entry.mFlags );
|
||||
++cit;
|
||||
}
|
||||
|
||||
start_message = TRUE;
|
||||
msg->sendReliable( region->getHost() );
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void LLViewerParcelMgr::deedLandToGroup()
|
||||
{
|
||||
std::string group_name;
|
||||
@@ -2597,11 +2560,9 @@ void LLViewerParcelMgr::onTeleportFailed()
|
||||
mTeleportFailedSignal();
|
||||
}
|
||||
|
||||
// [SL:KB] - Patch: World-MinimapOverlay | Checked: 2012-06-20 (Catznip-3.3.0)
|
||||
boost::signals2::connection LLViewerParcelMgr::setCollisionUpdateCallback(const collision_update_signal_t::slot_type & cb)
|
||||
{
|
||||
if (!mCollisionUpdateSignal)
|
||||
mCollisionUpdateSignal = new collision_update_signal_t();
|
||||
return mCollisionUpdateSignal->connect(cb);
|
||||
}
|
||||
// [/SL:KB]
|
||||
|
||||
Reference in New Issue
Block a user