]> git.saurik.com Git - wxWidgets.git/blobdiff - src/html/htmlcell.cpp
SetSizeHints hacks are not needed any longer since the minsize is not
[wxWidgets.git] / src / html / htmlcell.cpp
index 0fdae44298516c483a661dcd02341c772ac287ff..90dfc46e46bcab00cdb536dca420e4cad385e76c 100644 (file)
@@ -775,7 +775,7 @@ void wxHtmlContainerCell::Layout(int w)
                 // between two cells separated by, e.g. font change, cell which
                 // is wrong
 
-                const int step = s_width - xpos;
+                int step = s_width - xpos;
                 if ( step > 0 )
                 {
                     // first count the cells which will get extra space
@@ -783,7 +783,7 @@ void wxHtmlContainerCell::Layout(int w)
 
                     const wxHtmlCell *c,
                                      *prev = NULL,
-                                     *next = NULL;
+                                     *next wxDUMMY_INITIALIZE(NULL);
                     for ( c = line; c != cell; prev = c, c = next )
                     {
                         next = c->GetNext();
@@ -800,7 +800,7 @@ void wxHtmlContainerCell::Layout(int w)
                     {
                         prev =
                         next = NULL;
-                        for ( int n = 0; line != cell; line = line->GetNext() )
+                        for ( int n = 0; line != cell; prev = line, line = line->GetNext() )
                         {
                             line->SetPos(line->GetPosX() + s_indent +
                                            ((n * step) / total),
@@ -818,8 +818,14 @@ void wxHtmlContainerCell::Layout(int w)
                             }
                         }
                     }
+                    else
+                    {
+                        // this will cause the code to enter "else branch" below:
+                        step = 0;
+                    }
                 }
-                else // no extra space to distribute
+                // else branch:
+                if ( step <= 0 ) // no extra space to distribute
                 {
                     // just set the indent properly
                     while (line != cell)