6db4b818e6
Previously, `AND` expressions were the only filters which used `++s` instead of `s = StripLeft(s + 1)` making them sensitive to spacing issues. This caused nested AND expressions (like e.g. `(((A) AND (B)) AND (C))`) to needlessly be rejected with the following error message: `{find} Word expected` due to the fact that the inner AND expression would leave the cursor `s` at a space rather than the beginning of the next word (remainder was ` AND (C))` rather than `AND (C)`). This commit fixes this by consistently using `s = StripLeft(s + 1)` instead of `++s` when parsing AND expressions. Although it is not strictly necessary to resolve the AND nesting bug, the case of trivial AND expressions (consisting basically of only superfluous parentheses) is also changed to the new handling. This should be more robust although I expect that case to be even less common than the direct nesting of AND expressions. see MusicPlayerDaemon/MPD#2100 |
||
---|---|---|
.. | ||
AddedSinceSongFilter.cxx | ||
AddedSinceSongFilter.hxx | ||
AndSongFilter.cxx | ||
AndSongFilter.hxx | ||
AudioFormatSongFilter.cxx | ||
AudioFormatSongFilter.hxx | ||
BaseSongFilter.cxx | ||
BaseSongFilter.hxx | ||
DetachedSong.cxx | ||
DetachedSong.hxx | ||
Escape.cxx | ||
Escape.hxx | ||
Filter.cxx | ||
Filter.hxx | ||
ISongFilter.hxx | ||
LightSong.cxx | ||
LightSong.hxx | ||
meson.build | ||
ModifiedSinceSongFilter.cxx | ||
ModifiedSinceSongFilter.hxx | ||
NotSongFilter.hxx | ||
OptimizeFilter.cxx | ||
OptimizeFilter.hxx | ||
PrioritySongFilter.cxx | ||
PrioritySongFilter.hxx | ||
StringFilter.cxx | ||
StringFilter.hxx | ||
TagSongFilter.cxx | ||
TagSongFilter.hxx | ||
UriSongFilter.cxx | ||
UriSongFilter.hxx |