all repos — fluxbox @ 50c686fa22861dcfd0182747dd422fb40ec2afd2

custom fork of the fluxbox windowmanager

transient fixes
fluxgen fluxgen
commit

50c686fa22861dcfd0182747dd422fb40ec2afd2

parent

a2f2b083f8254552713b0f31ced11f26c957a240

1 files changed, 9 insertions(+), 5 deletions(-)

jump to
M src/Workspace.ccsrc/Workspace.cc

@@ -22,7 +22,7 @@ // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING

// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER // DEALINGS IN THE SOFTWARE. -// $Id: Workspace.cc,v 1.28 2002/09/09 10:00:24 fluxgen Exp $ +// $Id: Workspace.cc,v 1.29 2002/09/10 11:03:58 fluxgen Exp $ #include "Workspace.hh"

@@ -237,8 +237,10 @@

void Workspace::raiseWindow(FluxboxWindow *w) { FluxboxWindow *win = w; - while (win->isTransient() && win->getTransientFor()) + while (win->getTransientFor()) { win = win->getTransientFor(); + assert(win != win->getTransientFor()); + } int i = 1 + countTransients(*win);

@@ -262,12 +264,14 @@

void Workspace::lowerWindow(FluxboxWindow *w) { FluxboxWindow *win = (FluxboxWindow *) 0, *bottom = w; - while (bottom->isTransient() && bottom->getTransientFor() - && bottom->getTransientFor() != bottom) //prevent infinite loop + while (bottom->getTransientFor()) { bottom = bottom->getTransientFor(); + assert(bottom != bottom->getTransientFor()); + } - int i = 1 + countTransients(*w); win = bottom; + int i = 1 + countTransients(*win); + Stack st(i); Stack::iterator stackit = st.begin();