<table><tr><td style="">hpereiradacosta added a comment.
</td><a style="text-decoration: none; padding: 4px 8px; margin: 0 8px 8px; float: right; color: #464C5C; font-weight: bold; border-radius: 3px; background-color: #F7F7F9; background-image: linear-gradient(to bottom,#fff,#f1f0f1); display: inline-block; border: 1px solid rgba(71,87,120,.2);" href="https://phabricator.kde.org/D9227" rel="noreferrer">View Revision</a></tr></table><br /><div><div><blockquote style="border-left: 3px solid #8C98B8;
color: #6B748C;
font-style: italic;
margin: 4px 0 12px 0;
padding: 8px 12px;
background-color: #F8F9FC;">
<div style="font-style: normal;
padding-bottom: 4px;">In <a href="https://phabricator.kde.org/D9227#177017" style="background-color: #e7e7e7;
border-color: #e7e7e7;
border-radius: 3px;
padding: 0 4px;
font-weight: bold;
color: black;text-decoration: none;" rel="noreferrer">D9227#177017</a>, <a href="https://phabricator.kde.org/p/broulik/" style="
border-color: #f1f7ff;
color: #19558d;
background-color: #f1f7ff;
border: 1px solid transparent;
border-radius: 3px;
font-weight: bold;
padding: 0 4px;" rel="noreferrer">@broulik</a> wrote:</div>
<div style="margin: 0;
padding: 0;
border: 0;
color: rgb(107, 116, 140);"><p>So that in <tt style="background: #ebebeb; font-size: 13px;">polish()</tt> I change the icon for <tt style="background: #ebebeb; font-size: 13px;">QLineEditIconButton</tt> to be a <tt style="background: #ebebeb; font-size: 13px;">QIcon</tt> which has manually put the <tt style="background: #ebebeb; font-size: 13px;">QIcon::Active</tt> pixmaps in <tt style="background: #ebebeb; font-size: 13px;">QIcon::Selected</tt> category? However what are the implications of this wrt speed (how often is <tt style="background: #ebebeb; font-size: 13px;">polish</tt> called, I don't think I can "mark" the icon as "already tampered with") and when app changes the icon (need to update the thing)?</p></div>
</blockquote>
<p>Hi Kai, <br />
In principle it is not called very often. Namely once per widget, and possibly once again when things like color scheme, icon theme, etc are changed. So this should be safe. <br />
Now looking in more details at the code, the other place where one could implement the trick is in: QStyle::standardIcon(), which is called by QLineEdit_p, to asign the icon to the clear button<br />
( return q->style()->standardIcon(QStyle::SP_LineEditClearButton, &styleOption, q); )<br />
The method is already overloaded in kStyle, and can be also overloaded in breezestyle. It takes the parent widget as argument, so that this could be used to decide when to implement the trick.</p>
<p>Finally, I really consider this issue as an upstream bug. <br />
The comment: " // Note isDown should really use the active state but in most styles</p>
<div class="remarkup-code-block" style="margin: 12px 0;" data-code-lang="text" data-sigil="remarkup-code-block"><pre class="remarkup-code" style="font: 11px/15px "Menlo", "Consolas", "Monaco", monospace; padding: 12px; margin: 0; background: rgba(71, 87, 120, 0.08);">// this has no proper feedback"</pre></div>
<p>is simply not true, especially in kde, where active effects are configurable. So I do not know which "styles" they refer too.<br />
So here Qt is simply breaking its own documentation API, on purpose, and then we, in order to do the right thing, have to implement some workaround in our code to restore things to how they should be. <br />
Would it not be better to file a bug and send a patch upstream ?</p></div></div><br /><div><strong>REPOSITORY</strong><div><div>R31 Breeze</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D9227" rel="noreferrer">https://phabricator.kde.org/D9227</a></div></div><br /><div><strong>To: </strong>broulik, Plasma, VDG, hpereiradacosta<br /><strong>Cc: </strong>ngraham, plasma-devel, ZrenBot, progwolff, lesliezhai, ali-mohamed, jensreuterberg, abetts, sebas, apol, mart<br /></div>