Editing tab closure activates MRU tab instead of rightmost tab, if MRU behaviour enabled
MRU = Most Recently Used/Active Thanks to gstavi's patch: https://github.com/gstavi/npp/blob/master/patch/0005-Use-MRU-when-choosing-new-file-to-activate-after-clo.patch Close #885, close #8059
This commit is contained in:
parent
3ca82bebf1
commit
d36ea6124a
|
@ -3578,6 +3578,21 @@ bool Notepad_plus::removeBufferFromView(BufferID id, int whichOne)
|
||||||
{
|
{
|
||||||
toActivate = active; //activate the 'active' index. Since we remove the tab first, the indices shift (on the right side)
|
toActivate = active; //activate the 'active' index. Since we remove the tab first, the indices shift (on the right side)
|
||||||
}
|
}
|
||||||
|
if (NppParameters::getInstance().getNppGUI()._styleMRU)
|
||||||
|
{
|
||||||
|
// After closing a file choose the file to activate based on MRU list and not just last file in the list.
|
||||||
|
TaskListInfo taskListInfo;
|
||||||
|
::SendMessage(_pPublicInterface->getHSelf(), WM_GETTASKLISTINFO, (WPARAM)&taskListInfo, 0);
|
||||||
|
size_t i, n = taskListInfo._tlfsLst.size();
|
||||||
|
for (i = 0; i < n; i++)
|
||||||
|
{
|
||||||
|
TaskLstFnStatus& F = taskListInfo._tlfsLst[i];
|
||||||
|
if (F._iView != whichOne || F._bufID == (void*)id)
|
||||||
|
continue;
|
||||||
|
toActivate = F._docIndex >= active ? F._docIndex - 1 : F._docIndex;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
tabToClose->deletItemAt((size_t)index); //delete first
|
tabToClose->deletItemAt((size_t)index); //delete first
|
||||||
_isFolding = true; // So we can ignore events while folding is taking place
|
_isFolding = true; // So we can ignore events while folding is taking place
|
||||||
activateBuffer(tabToClose->getBufferByIndex(toActivate), whichOne); //then activate. The prevent jumpy tab behaviour
|
activateBuffer(tabToClose->getBufferByIndex(toActivate), whichOne); //then activate. The prevent jumpy tab behaviour
|
||||||
|
|
Loading…
Reference in New Issue