Fix a bug that got revealed by 604c51f1fc5c79b7fad12cda911b06b9e6e5005f
authorJan-Arve Sæther <jan-arve.saether@nokia.com>
Fri, 17 Dec 2010 13:41:43 +0000 (14:41 +0100)
committerJan-Arve Sæther <jan-arve.saether@nokia.com>
Thu, 13 Jan 2011 08:19:56 +0000 (09:19 +0100)
commit7fbf1829e11504eca6a55f1e5dbddf2f658b5302
tree034d300799c338ee21d74cb157b4b52a9f1552ea
parent19b6e2b944a0d1eeef0fb707a00f567e4ee870e6
Fix a bug that got revealed by 604c51f1fc5c79b7fad12cda911b06b9e6e5005f

The bug has been around for a while, but change 604c51f1fc5c7 made it
emerge.
The problem was that stretches were combined by always *maxing* them.
The values of 'stretch' can be interpreted as this:

-1: (the default) it means that the items should be stretched with
    the stretch factor dervived from the size hints. (In practice this
    means that they are distributed fairly).
 0: Means that the item should not be stretched
>0: Means that the item should be stretch with that number as a factor.

This meant that combining one item with a fixed size(0) and another
item with a default stretch (-1) the combined row stretch would end
up being fixed.

This also fixes how stretches are combined for spanning items too.

Task-number: QTBUG-13551
Reviewed-by: John Tapsell
src/gui/graphicsview/qgridlayoutengine.cpp
tests/auto/qgraphicslinearlayout/tst_qgraphicslinearlayout.cpp