<table><tr><td style="">mpyne created this revision.<br />Restricted Application added a project: Frameworks.
</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/D7170" rel="noreferrer">View Revision</a></tr></table><br /><div><strong>REVISION SUMMARY</strong><div><p>As reported in bug 310674, the Desktop Entry spec says that whitespace surrounding the = sign that separates the key and value in .desktop files should be ignored when interpreting the key and value portions.</p>

<p>That is, all four of these lines should be equivalent:</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);">Type=Application
Type =Application
Type= Application
Type = Application</pre></div>

<p>DesktopFileParser handles this for most key/value entries already (e.g. at src/lib/plugin/desktopfileparser.cpp:266), but there is a specific function to handle reading <tt style="background: #ebebeb; font-size: 13px;">Type=</tt> entries from desktop files which doesn't handle spaces (and even has a TODO asking whether it should).</p>

<p>This patch implements the spec here by using <tt style="background: #ebebeb; font-size: 13px;">QRegularExpression</tt> to match the part of the string after <tt style="background: #ebebeb; font-size: 13px;">=\s*</tt>.</p></div></div><br /><div><strong>TEST PLAN</strong><div><p>Existing autotests have been modified to include spaces around some of the <tt style="background: #ebebeb; font-size: 13px;">Type=</tt> entries, and the updated autotests now pass.</p></div></div><br /><div><strong>REPOSITORY</strong><div><div>R244 KCoreAddons</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D7170" rel="noreferrer">https://phabricator.kde.org/D7170</a></div></div><br /><div><strong>AFFECTED FILES</strong><div><div>autotests/desktoptojsontest.cpp<br />
src/lib/plugin/desktopfileparser.cpp</div></div></div><br /><div><strong>To: </strong>mpyne, Frameworks, arichardson<br /></div>