mirror of
https://gitlab.com/freepascal.org/lazarus/lazarus.git
synced 2025-08-16 00:19:32 +02:00
Qt: fixed crash with checkable listview when item is deleted inside OnItemChecked event. issue #32869
git-svn-id: trunk@56888 -
This commit is contained in:
parent
528fcceaf4
commit
4ebb387946
@ -12827,8 +12827,9 @@ begin
|
||||
else
|
||||
SetItemLastCheckStateInternal(AItem, QtUnChecked);
|
||||
|
||||
SendMessage(AItem);
|
||||
// if AItem is deleted in mouse event FDelayedCheckItem becomes nil and that's fine. issue #32869
|
||||
FDelayedCheckItem := AItem;
|
||||
SendMessage(AItem);
|
||||
end;
|
||||
end;
|
||||
end else
|
||||
@ -12839,6 +12840,8 @@ begin
|
||||
SetItemLastCheckStateInternal(FDelayedCheckItem, QListWidgetItem_checkState(FDelayedCheckItem));
|
||||
SendMessage(FDelayedCheckItem);
|
||||
end;
|
||||
if FDelayedCheckItem = nil then // issue #32869
|
||||
exit;
|
||||
FDelayedCheckItem := nil;
|
||||
SetItemLastCheckStateInternal(AItem, QListWidgetItem_checkState(AItem));
|
||||
SendMessage(AItem);
|
||||
@ -13756,6 +13759,8 @@ begin
|
||||
if (getSelectionMode = QAbstractItemViewSingleSelection) then
|
||||
setCurrentRow(-1);
|
||||
Item := QListWidget_takeitem(QListWidgetH(Widget), AIndex);
|
||||
if FDelayedCheckItem = Item then
|
||||
FDelayedCheckItem := nil;
|
||||
QListWidgetItem_destroy(Item);
|
||||
end;
|
||||
|
||||
@ -14466,8 +14471,9 @@ begin
|
||||
else
|
||||
SetItemLastCheckStateInternal(AItem, QtUnChecked);
|
||||
|
||||
SendMessage(AItem);
|
||||
// if AItem is deleted in mouse event FDelayedCheckItem becomes nil and that's fine. issue #32869
|
||||
FDelayedCheckItem := AItem;
|
||||
SendMessage(AItem);
|
||||
end;
|
||||
end;
|
||||
end else
|
||||
@ -14478,6 +14484,8 @@ begin
|
||||
SetItemLastCheckStateInternal(FDelayedCheckItem, QTreeWidgetItem_checkState(FDelayedCheckItem, 0));
|
||||
SendMessage(FDelayedCheckItem);
|
||||
end;
|
||||
if FDelayedCheckItem = nil then // issue #32869
|
||||
exit;
|
||||
FDelayedCheckItem := nil;
|
||||
SetItemLastCheckStateInternal(AItem, QTreeWidgetItem_checkState(AItem, 0));
|
||||
SendMessage(AItem);
|
||||
@ -15001,6 +15009,8 @@ begin
|
||||
Index := -1;
|
||||
if Index <> -1 then
|
||||
FSelection.Remove(Item);
|
||||
if FDelayedCheckItem = Item then
|
||||
FDelayedCheckItem := nil;
|
||||
Item := takeTopLevelItem(AIndex);
|
||||
if Item <> nil then
|
||||
QTreeWidgetItem_destroy(Item);
|
||||
|
Loading…
Reference in New Issue
Block a user