-
Notifications
You must be signed in to change notification settings - Fork 55
fix: correct iterator position calculation in DockGlobalElementModel #1190
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
1. Fixed incorrect calculation of position when removing elements from m_data 2. Changed from using m_data.end() to m_data.begin() for proper position determination 3. This ensures correct row removal behavior in the model's data management 4. Prevents potential crashes or incorrect model states due to invalid position calculations fix: 修复 DockGlobalElementModel 中的迭代器位置计算问题 1. 修复了从 m_data 中移除元素时位置计算错误的问题 2. 将 m_data.end() 改为使用 m_data.begin() 以正确确定位置 3. 确保模型数据管理中的正确行移除行为 4. 防止由于无效位置计算导致的潜在崩溃或模型状态错误 Pms: BUG-318455 BUG-319543
Reviewer's GuideRefines the row removal logic in DockGlobalElementModel by recalculating the element index using m_data.begin() rather than m_data.end(), ensuring accurate removal of entries and preventing invalid iterator-based positions. Sequence diagram for corrected row removal in DockGlobalElementModelsequenceDiagram
participant Model as DockGlobalElementModel
participant Data as m_data
participant Qt as QtView
Model->>Data: Find iterator 'it' for element
Model->>Model: Calculate pos = it - m_data.begin()
Model->>Qt: beginRemoveRows(pos, pos)
Model->>Data: remove(pos)
Model->>Qt: endRemoveRows()
Class diagram for DockGlobalElementModel row removal logicclassDiagram
class DockGlobalElementModel {
- m_data
- m_appsModel
+ DockGlobalElementModel(QAbstractItemModel *appsModel, DockGlobalElementModel *parent)
+ removeRow()
}
class m_data {
<<container>>
}
DockGlobalElementModel --> m_data : manages
DockGlobalElementModel --> QAbstractItemModel : uses
File-Level Changes
Tips and commandsInteracting with Sourcery
Customizing Your ExperienceAccess your dashboard to:
Getting Help
|
deepin pr auto review关键摘要:
是否建议立即修改:
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
|
[APPROVALNOTIFIER] This PR is NOT APPROVED This pull-request has been approved by: BLumia, wjyrich The full list of commands accepted by this bot can be found here. DetailsNeeds approval from an approver in each of these files:Approvers can indicate their approval by writing |
|
/forcemerge |
|
This pr force merged! (status: blocked) |
fix: 修复 DockGlobalElementModel 中的迭代器位置计算问题
Pms: BUG-318455 BUG-319543
Summary by Sourcery
Bug Fixes: