Cherry-pick of 24a7281bef42 from viewer-development, also added missing AttachmentDrop to notifications.xml
simon@Simon-PC.lindenlab.com: MAINT-862 and ER-1781 : Sounds not playing the first time. Reviewed by Kelly.
This commit is contained in:
@@ -616,7 +616,8 @@ void LLAudioDecodeMgr::Impl::processQueue(const F32 num_secs)
|
|||||||
llwarns << mCurrentDecodep->getUUID() << " has invalid vorbis data, aborting decode" << llendl;
|
llwarns << mCurrentDecodep->getUUID() << " has invalid vorbis data, aborting decode" << llendl;
|
||||||
mCurrentDecodep->flushBadFile();
|
mCurrentDecodep->flushBadFile();
|
||||||
LLAudioData *adp = gAudiop->getAudioData(mCurrentDecodep->getUUID());
|
LLAudioData *adp = gAudiop->getAudioData(mCurrentDecodep->getUUID());
|
||||||
adp->setHasValidData(FALSE);
|
adp->setHasValidData(false);
|
||||||
|
adp->setHasCompletedDecode(true);
|
||||||
mCurrentDecodep = NULL;
|
mCurrentDecodep = NULL;
|
||||||
done = TRUE;
|
done = TRUE;
|
||||||
}
|
}
|
||||||
@@ -631,11 +632,16 @@ void LLAudioDecodeMgr::Impl::processQueue(const F32 num_secs)
|
|||||||
if (mCurrentDecodep->finishDecode())
|
if (mCurrentDecodep->finishDecode())
|
||||||
{
|
{
|
||||||
// We finished!
|
// We finished!
|
||||||
if (mCurrentDecodep->isValid() && mCurrentDecodep->isDone())
|
LLAudioData *adp = gAudiop->getAudioData(mCurrentDecodep->getUUID());
|
||||||
|
if (!adp)
|
||||||
{
|
{
|
||||||
LLAudioData *adp = gAudiop->getAudioData(mCurrentDecodep->getUUID());
|
llwarns << "Missing LLAudioData for decode of " << mCurrentDecodep->getUUID() << llendl;
|
||||||
adp->setHasDecodedData(TRUE);
|
}
|
||||||
adp->setHasValidData(TRUE);
|
else if (mCurrentDecodep->isValid() && mCurrentDecodep->isDone())
|
||||||
|
{
|
||||||
|
adp->setHasCompletedDecode(true);
|
||||||
|
adp->setHasDecodedData(true);
|
||||||
|
adp->setHasValidData(true);
|
||||||
|
|
||||||
// At this point, we could see if anyone needs this sound immediately, but
|
// At this point, we could see if anyone needs this sound immediately, but
|
||||||
// I'm not sure that there's a reason to - we need to poll all of the playing
|
// I'm not sure that there's a reason to - we need to poll all of the playing
|
||||||
@@ -644,7 +650,8 @@ void LLAudioDecodeMgr::Impl::processQueue(const F32 num_secs)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
llinfos << "Vorbis decode failed!!!" << llendl;
|
adp->setHasCompletedDecode(true);
|
||||||
|
llinfos << "Vorbis decode failed for " << mCurrentDecodep->getUUID() << llendl;
|
||||||
}
|
}
|
||||||
mCurrentDecodep = NULL;
|
mCurrentDecodep = NULL;
|
||||||
}
|
}
|
||||||
@@ -712,15 +719,18 @@ BOOL LLAudioDecodeMgr::addDecodeRequest(const LLUUID &uuid)
|
|||||||
if (gAudiop->hasDecodedFile(uuid))
|
if (gAudiop->hasDecodedFile(uuid))
|
||||||
{
|
{
|
||||||
// Already have a decoded version, don't need to decode it.
|
// Already have a decoded version, don't need to decode it.
|
||||||
|
//llinfos << "addDecodeRequest for " << uuid << " has decoded file already" << llendl;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gAssetStorage->hasLocalAsset(uuid, LLAssetType::AT_SOUND))
|
if (gAssetStorage->hasLocalAsset(uuid, LLAssetType::AT_SOUND))
|
||||||
{
|
{
|
||||||
// Just put it on the decode queue.
|
// Just put it on the decode queue.
|
||||||
|
//llinfos << "addDecodeRequest for " << uuid << " has local asset file already" << llendl;
|
||||||
mImpl->mDecodeQueue.push(uuid);
|
mImpl->mDecodeQueue.push(uuid);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//llinfos << "addDecodeRequest for " << uuid << " no file available" << llendl;
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1275,10 +1275,11 @@ void LLAudioEngine::assetCallback(LLVFS *vfs, const LLUUID &uuid, LLAssetType::E
|
|||||||
// Need to mark data as bad to avoid constant rerequests.
|
// Need to mark data as bad to avoid constant rerequests.
|
||||||
LLAudioData *adp = gAudiop->getAudioData(uuid);
|
LLAudioData *adp = gAudiop->getAudioData(uuid);
|
||||||
if (adp)
|
if (adp)
|
||||||
{
|
{ // Make sure everything is cleared
|
||||||
adp->setHasValidData(false);
|
adp->setHasValidData(false);
|
||||||
adp->setHasLocalData(false);
|
adp->setHasLocalData(false);
|
||||||
adp->setHasDecodedData(false);
|
adp->setHasDecodedData(false);
|
||||||
|
adp->setHasCompletedDecode(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -1291,6 +1292,7 @@ void LLAudioEngine::assetCallback(LLVFS *vfs, const LLUUID &uuid, LLAssetType::E
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
// llinfos << "Got asset callback with good audio data for " << uuid << ", making decode request" << llendl;
|
||||||
adp->setHasValidData(true);
|
adp->setHasValidData(true);
|
||||||
adp->setHasLocalData(true);
|
adp->setHasLocalData(true);
|
||||||
gAudioDecodeMgrp->addDecodeRequest(uuid);
|
gAudioDecodeMgrp->addDecodeRequest(uuid);
|
||||||
@@ -1380,16 +1382,18 @@ void LLAudioSource::update()
|
|||||||
|
|
||||||
if (!getCurrentBuffer())
|
if (!getCurrentBuffer())
|
||||||
{
|
{
|
||||||
if (getCurrentData())
|
LLAudioData *adp = getCurrentData();
|
||||||
|
if (adp)
|
||||||
{
|
{
|
||||||
// Hack - try and load the sound. Will do this as a callback
|
// Hack - try and load the sound. Will do this as a callback
|
||||||
// on decode later.
|
// on decode later.
|
||||||
if (getCurrentData()->load() && getCurrentData()->getBuffer())
|
if (adp->load() && adp->getBuffer())
|
||||||
{
|
{
|
||||||
play(getCurrentData()->getID());
|
play(adp->getID());
|
||||||
}
|
}
|
||||||
else
|
else if (adp->hasCompletedDecode()) // Only mark corrupted after decode is done
|
||||||
{
|
{
|
||||||
|
llwarns << "Marking LLAudioSource corrupted for " << adp->getID() << llendl;
|
||||||
mCorrupted = true ;
|
mCorrupted = true ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1812,6 +1816,7 @@ LLAudioData::LLAudioData(const LLUUID &uuid) :
|
|||||||
mBufferp(NULL),
|
mBufferp(NULL),
|
||||||
mHasLocalData(false),
|
mHasLocalData(false),
|
||||||
mHasDecodedData(false),
|
mHasDecodedData(false),
|
||||||
|
mHasCompletedDecode(false),
|
||||||
mHasValidData(true)
|
mHasValidData(true)
|
||||||
{
|
{
|
||||||
if (uuid.isNull())
|
if (uuid.isNull())
|
||||||
@@ -1823,12 +1828,13 @@ LLAudioData::LLAudioData(const LLUUID &uuid) :
|
|||||||
if (gAudiop && gAudiop->hasDecodedFile(uuid))
|
if (gAudiop && gAudiop->hasDecodedFile(uuid))
|
||||||
{
|
{
|
||||||
// Already have a decoded version, don't need to decode it.
|
// Already have a decoded version, don't need to decode it.
|
||||||
mHasLocalData = true;
|
setHasLocalData(true);
|
||||||
mHasDecodedData = true;
|
setHasDecodedData(true);
|
||||||
|
setHasCompletedDecode(true);
|
||||||
}
|
}
|
||||||
else if (gAssetStorage && gAssetStorage->hasLocalAsset(uuid, LLAssetType::AT_SOUND))
|
else if (gAssetStorage && gAssetStorage->hasLocalAsset(uuid, LLAssetType::AT_SOUND))
|
||||||
{
|
{
|
||||||
mHasLocalData = true;
|
setHasLocalData(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -408,10 +408,12 @@ public:
|
|||||||
|
|
||||||
bool hasLocalData() const { return mHasLocalData; }
|
bool hasLocalData() const { return mHasLocalData; }
|
||||||
bool hasDecodedData() const { return mHasDecodedData; }
|
bool hasDecodedData() const { return mHasDecodedData; }
|
||||||
|
bool hasCompletedDecode() const { return mHasCompletedDecode; }
|
||||||
bool hasValidData() const { return mHasValidData; }
|
bool hasValidData() const { return mHasValidData; }
|
||||||
|
|
||||||
void setHasLocalData(const bool hld) { mHasLocalData = hld; }
|
void setHasLocalData(const bool hld) { mHasLocalData = hld; }
|
||||||
void setHasDecodedData(const bool hdd) { mHasDecodedData = hdd; }
|
void setHasDecodedData(const bool hdd) { mHasDecodedData = hdd; }
|
||||||
|
void setHasCompletedDecode(const bool hcd) { mHasCompletedDecode = hcd; }
|
||||||
void setHasValidData(const bool hvd) { mHasValidData = hvd; }
|
void setHasValidData(const bool hvd) { mHasValidData = hvd; }
|
||||||
|
|
||||||
friend class LLAudioEngine; // Severe laziness, bad.
|
friend class LLAudioEngine; // Severe laziness, bad.
|
||||||
@@ -419,9 +421,10 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
LLUUID mID;
|
LLUUID mID;
|
||||||
LLAudioBuffer *mBufferp; // If this data is being used by the audio system, a pointer to the buffer will be set here.
|
LLAudioBuffer *mBufferp; // If this data is being used by the audio system, a pointer to the buffer will be set here.
|
||||||
bool mHasLocalData;
|
bool mHasLocalData; // Set true if the sound asset file is available locally
|
||||||
bool mHasDecodedData;
|
bool mHasDecodedData; // Set true if the sound file has been decoded
|
||||||
bool mHasValidData;
|
bool mHasCompletedDecode; // Set true when the sound is decoded
|
||||||
|
bool mHasValidData; // Set false if decoding failed, meaning the sound asset is bad
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -538,6 +538,20 @@ Add this Ability to '[ROLE_NAME]'?
|
|||||||
yestext="Yes"/>
|
yestext="Yes"/>
|
||||||
</notification>
|
</notification>
|
||||||
|
|
||||||
|
<notification
|
||||||
|
icon="alertmodal.tga"
|
||||||
|
name="AttachmentDrop"
|
||||||
|
type="alertmodal">
|
||||||
|
You are about to drop your attachment.
|
||||||
|
Are you sure you want to continue?
|
||||||
|
<tag>confirm</tag>
|
||||||
|
<usetemplate
|
||||||
|
ignoretext="Confirm before dropping attachments"
|
||||||
|
name="okcancelignore"
|
||||||
|
notext="No"
|
||||||
|
yestext="Yes"/>
|
||||||
|
</notification>
|
||||||
|
|
||||||
<notification
|
<notification
|
||||||
icon="alertmodal.tga"
|
icon="alertmodal.tga"
|
||||||
name="ClickPublishHelpLand"
|
name="ClickPublishHelpLand"
|
||||||
|
|||||||
Reference in New Issue
Block a user