Fix a performance issue for swiching back to folded document.

Use the _isFolding flag to fix several overlooked edge case hangs.
This pull request fixes additional hangs I found after #4867 when working with deeply-nested fully-folded files. The hangs are easy to reproduce by following these steps:

Download the sample file https://raw.githubusercontent.com/notepad-plus-plus/notepad-plus-plus/master/PowerEditor/src/Parameters.cpp
Open the downloaded file by itself in NPP and fold it using Alt-0
Create a new empty tab and remain focused on it
Perform the six actions below, each of which will produce a hang as NPP tries to change focus back to the first tab. On my machine, each hang lasts about 30 seconds. After control returns, refocus the empty tab again and try the next action.
Use File>>Open to reopen the downloaded file, even though it is already open
Drag and drop the downloaded file onto NPP to reopen it
Double-click the downloaded file to reopen it
Right-click the downloaded file and select Edit with Notepad++ in the context menu
Open the downloaded file from the command line: C:\Program Files (x86)\Notepad++\notepad++.exe" .\Parameters.cpp
Click the red [X] in the upper right corner to close NPP
After applying the patch, none of the hangs should happen any more.

Close #4999
This commit is contained in:
Chris Cammack 2018-11-08 21:16:48 -08:00 committed by Don HO
parent 6cdac077f2
commit fd51703ad8
2 changed files with 16 additions and 0 deletions

View File

@ -3722,14 +3722,22 @@ bool Notepad_plus::activateBuffer(BufferID id, int whichOne)
if (whichOne == MAIN_VIEW) if (whichOne == MAIN_VIEW)
{ {
if (_mainDocTab.activateBuffer(id)) //only activate if possible if (_mainDocTab.activateBuffer(id)) //only activate if possible
{
_isFolding = true;
_mainEditView.activateBuffer(id); _mainEditView.activateBuffer(id);
_isFolding = false;
}
else else
return false; return false;
} }
else else
{ {
if (_subDocTab.activateBuffer(id)) if (_subDocTab.activateBuffer(id))
{
_isFolding = true;
_subEditView.activateBuffer(id); _subEditView.activateBuffer(id);
_isFolding = false;
}
else else
return false; return false;
} }

View File

@ -1661,7 +1661,11 @@ bool Notepad_plus::loadSession(Session & session, bool isSnapshotMode)
} }
} }
if (mainIndex2Update != -1) if (mainIndex2Update != -1)
{
_isFolding = true;
_mainEditView.syncFoldStateWith(session._mainViewFiles[mainIndex2Update]._foldStates); _mainEditView.syncFoldStateWith(session._mainViewFiles[mainIndex2Update]._foldStates);
_isFolding = false;
}
showView(SUB_VIEW); showView(SUB_VIEW);
@ -1772,7 +1776,11 @@ bool Notepad_plus::loadSession(Session & session, bool isSnapshotMode)
} }
} }
if (subIndex2Update != -1) if (subIndex2Update != -1)
{
_isFolding = true;
_subEditView.syncFoldStateWith(session._subViewFiles[subIndex2Update]._foldStates); _subEditView.syncFoldStateWith(session._subViewFiles[subIndex2Update]._foldStates);
_isFolding = false;
}
_mainEditView.restoreCurrentPos(); _mainEditView.restoreCurrentPos();
_subEditView.restoreCurrentPos(); _subEditView.restoreCurrentPos();