Review Request 121831: libksysguard: process.h: encapsulate private fields

Gregor Mi codestruct at posteo.org
Sun Feb 15 16:35:58 GMT 2015



> On Jan. 21, 2015, 10:10 a.m., Dominik Haumann wrote:
> > processcore/processes_linux_p.cpp, line 171
> > <https://git.reviewboard.kde.org/r/121831/diff/3/?file=343197#file343197line171>
> >
> >     Don't you change behavior here?
> >     
> >     Before, we just wrote into the varialbes.
> >     
> >     Now, we use the setters, which also sets 'changes |= Process::Gids;'
> >     
> >     Is that maybe an issue? I myself don't know the code well enough to see this here.
> 
> Gregor Mi wrote:
>     True. Thanks for noticing. The changes will be read in ProcessModelPrivate::processChanged when a change is signaled by KSysGuard::Process::processChanged. Then GUI model updates are triggered. So probably the worst that can happen is one additional GUI update when processChanged is emitted.
> 
> Gregor Mi wrote:
>     I did some analysis. There is no visible change in behaviour ksysguard.
>     
>     ProcessesLocal::Private::readProcStatus where the change in discussion was made (setter method with change detection instead of direct assignment).
>     
>     is called by ProcessesLocal::updateProcessInfo in the same file:
>     
>     ```
>     bool ProcessesLocal::updateProcessInfo( long pid, Process *process)
>     {
>         bool success = true;
>         QString dir = "/proc/" + QString::number(pid) + '/';
>         if(!d->readProcStat(dir, process)) success = false;
>         if(!d->readProcStatus(dir, process)) success = false;  <------------
>        ...
>     ```
>     
>     Then there is
>     
>     ```
>     bool Processes::updateProcess( Process *ps, long ppid)
>         ...
>         ...
>     
>         bool success = updateProcessInfo(ps); <--------
>         emit processChanged(ps, false);  <-------
>     
>         return success;
>     }
>     ```
>     
>     ```
>     bool Processes::updateOrAddProcess( long pid)
>     ...
>     ...
>         Process *ps = d->mProcesses.value(pid);
>         if(!ps)
>             return addProcess(pid, ppid);
>         else
>             return updateProcess(ps, ppid); <---------
>     }
>     ```
>     
>     which is called e.g. every second.
>     
>     
>     The emitted processChanged signal is connected here:
>     
>     ```
>     connect( mProcesses, SIGNAL(processChanged(KSysGuard::Process*,bool)), this, SLOT(processChanged(KSysGuard::Process*,bool)));
>     ```
>     
>     void ProcessModelPrivate::processChanged(KSysGuard::Process *process, bool onlyTotalCpu):
>     
>     Each change on a field that was recored in ProcessesLocal::Private::readProcStatus will emit dataChanged signal, e.g.:
>     
>     ```
>             if(process->changes() & KSysGuard::Process::Uids) {
>                 totalUpdated++;
>                 QModelIndex index = q->createIndex(row, ProcessModel::HeadingUser, process);
>                 emit q->dataChanged(index, index);
>             }
>     ```
>     
>     The dataChanged signal is from QAbstractItemModel. So as far as I can see the worst thing could happen that the GUI is updated at more places than needed.
>     
>     When I start ksysguard the processChanged method is called about 300 times (1 time for each process in the list) in the update interval (every second).
>     
>     I tried to update everything at once and circument the dataChanged of individual items with
>     ```
>             QModelIndex index1 = q->createIndex(row, 0, process);
>             QModelIndex index2 = q->createIndex(row, q->columnCount() - 1, process);
>             emit q->dataChanged(index1, index2);
>             return;
>     ```
>     which had not visible effect.
>     
>     So what now? Leave the setters and have maybe a performance penalty? Remove the setters again and use references getters? Change the Process API otherwise?

any new input?


- Gregor


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/121831/#review74463
-----------------------------------------------------------


On Feb. 15, 2015, 4:35 p.m., Gregor Mi wrote:
> 
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://git.reviewboard.kde.org/r/121831/
> -----------------------------------------------------------
> 
> (Updated Feb. 15, 2015, 4:35 p.m.)
> 
> 
> Review request for KDE Base Apps, Dominik Haumann, Eike Hein, and John Tapsell.
> 
> 
> Repository: libksysguard
> 
> 
> Description
> -------
> 
> This is a follow-up to https://git.reviewboard.kde.org/r/121717/:
> 
> In process.h there are several public fields which easily trigger BIC changes. This RR introduces a d-ptr.
> 
> (In a separate commit I would add the .reviewboardrc file)
> 
> 
> Diffs
> -----
> 
>   processui/scripting.h 2445c0ab0d81af3283c0f6e9c5f349a3d70b0de9 
>   processui/scripting.cpp 76291b0ae0a26e486aa81a4ca3976ff4a47cb3c0 
>   processcore/processes_solaris_p.cpp f054df4b1e762e9cbec1ff8dea78f467b878bee0 
>   processui/ProcessFilter.cpp ec520593fb67c777d56817f2493d40dc5ade0347 
>   processui/ProcessModel.cpp 53bc041110c9cdb686fef783895104969b661889 
>   processui/ksysguardprocesslist.cpp 4dc142e864d8353ceafc3a6735ffa81e48291420 
>   processcore/processes.cpp 580df8db152040f1ad075430fdce08fe7ad4ae2d 
>   processcore/processes_atop_p.cpp 24c76e3e35f62bd8e9e705ad32cc11cbd3662601 
>   processcore/processes_base_p.h 71b8a9cc6ee14bf7934a0a9d3199b257b5ce1be7 
>   processcore/processes_linux_p.cpp 898d4fa491873fe95a8b32a5c1b85642b2e46ad5 
>   processcore/processes.h d09c3265333fe7e2702deaa910c5fbe4bc3ac9e6 
>   tests/processtest.cpp f9b36e9a3a3c2048b51f1d935f8c40de2ad8a9b8 
>   .reviewboardrc PRE-CREATION 
>   CMakeLists.txt cefc86f12be684e195bd148641483e9e1734e636 
>   processcore/process.h b6695c0ed301dc5f0fad8ba847da811f19ebfd9a 
>   processcore/process.cpp a38b8be71da1a51cb87f636664ebac817b1d20ab 
> 
> Diff: https://git.reviewboard.kde.org/r/121831/diff/
> 
> 
> Testing
> -------
> 
> Compiles and runs. Data is still shown; no visible error. Unit tests succeed.
> 
> 
> Thanks,
> 
> Gregor Mi
> 
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kde-core-devel/attachments/20150215/208f6fd3/attachment.htm>


More information about the kde-core-devel mailing list