Skip to content
Snippets Groups Projects
Commit 4c364dc0 authored by Andrey Kleshchev's avatar Andrey Kleshchev
Browse files

SL-14318 MacOS __write_nocancel crash

Multiple instances of viewer could write to the same uuid.inv file at the same time.
parent 472ecc80
No related branches found
No related tags found
No related merge requests found
......@@ -5474,7 +5474,8 @@ void LLAppViewer::disconnectViewer()
{
gInventory.cache(gInventory.getRootFolderID(), gAgent.getID());
if (gInventory.getLibraryRootFolderID().notNull()
&& gInventory.getLibraryOwnerID().notNull())
&& gInventory.getLibraryOwnerID().notNull()
&& !mSecondInstance) // agent is unique, library isn't
{
gInventory.cache(
gInventory.getLibraryRootFolderID(),
......
......@@ -1953,18 +1953,20 @@ void LLInventoryModel::cache(
items,
INCLUDE_TRASH,
can_cache);
std::string inventory_filename = getInvCacheAddres(agent_id);
saveToFile(inventory_filename, categories, items);
std::string gzip_filename(inventory_filename);
// Use temporary file to avoid potential conflicts with other
// instances (even a 'read only' instance unzips into a file)
std::string temp_file = gDirUtilp->getTempFilename();
saveToFile(temp_file, categories, items);
std::string gzip_filename = getInvCacheAddres(agent_id);
gzip_filename.append(".gz");
if(gzip_file(inventory_filename, gzip_filename))
if(gzip_file(temp_file, gzip_filename))
{
LL_DEBUGS(LOG_INV) << "Successfully compressed " << inventory_filename << LL_ENDL;
LLFile::remove(inventory_filename);
LL_DEBUGS(LOG_INV) << "Successfully compressed " << temp_file << " to " << gzip_filename << LL_ENDL;
LLFile::remove(temp_file);
}
else
{
LL_WARNS(LOG_INV) << "Unable to compress " << inventory_filename << LL_ENDL;
LL_WARNS(LOG_INV) << "Unable to compress " << temp_file << " into " << gzip_filename << LL_ENDL;
}
}
......@@ -3038,6 +3040,7 @@ bool LLInventoryModel::saveToFile(const std::string& filename,
return false;
}
}
fileXML.flush();
fileXML.close();
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment