summaryrefslogtreecommitdiffstats
path: root/tqtinterface/qt4/src/widgets/tqdockarea.cpp
diff options
context:
space:
mode:
authorTimothy Pearson <[email protected]>2011-07-10 15:17:53 -0500
committerTimothy Pearson <[email protected]>2011-07-10 15:17:53 -0500
commitdda8474928bd7276e1fad8fb7a601e7c83ff2bc2 (patch)
tree7f83910598b33b12730035f086df20b5a53ab99c /tqtinterface/qt4/src/widgets/tqdockarea.cpp
parent6260b6178868c03aab1644bf93b0ef043654bdb0 (diff)
downloadexperimental-dda8474928bd7276e1fad8fb7a601e7c83ff2bc2.tar.gz
experimental-dda8474928bd7276e1fad8fb7a601e7c83ff2bc2.zip
Added TQt4 HEAD
Diffstat (limited to 'tqtinterface/qt4/src/widgets/tqdockarea.cpp')
-rw-r--r--tqtinterface/qt4/src/widgets/tqdockarea.cpp1340
1 files changed, 1340 insertions, 0 deletions
diff --git a/tqtinterface/qt4/src/widgets/tqdockarea.cpp b/tqtinterface/qt4/src/widgets/tqdockarea.cpp
new file mode 100644
index 0000000..5aed489
--- /dev/null
+++ b/tqtinterface/qt4/src/widgets/tqdockarea.cpp
@@ -0,0 +1,1340 @@
+/****************************************************************************
+**
+** Implementation of the TQDockArea class
+**
+** Created : 001010
+**
+** Copyright (C) 2010 Timothy Pearson and (C) 1992-2008 Trolltech ASA.
+**
+** This file is part of the workspace module of the TQt GUI Toolkit.
+**
+** This file may be used under the terms of the GNU General
+** Public License versions 2.0 or 3.0 as published by the Free
+** Software Foundation and appearing in the files LICENSE.GPL2
+** and LICENSE.GPL3 included in the packaging of this file.
+** Alternatively you may (at your option) use any later version
+** of the GNU General Public License if such license has been
+** publicly approved by Trolltech ASA (or its successors, if any)
+** and the KDE Free TQt Foundation.
+**
+** Please review the following information to ensure GNU General
+** Public Licensing requirements will be met:
+** http://trolltech.com/products/qt/licenses/licensing/opensource/.
+** If you are unsure which license is appropriate for your use, please
+** review the following information:
+** http://trolltech.com/products/qt/licenses/licensing/licensingoverview
+** or contact the sales department at [email protected].
+**
+** This file may be used under the terms of the Q Public License as
+** defined by Trolltech ASA and appearing in the file LICENSE.TQPL
+** included in the packaging of this file. Licensees holding valid TQt
+** Commercial licenses may use this file in accordance with the TQt
+** Commercial License Agreement provided with the Software.
+**
+** This file is provided "AS IS" with NO WARRANTY OF ANY KIND,
+** INCLUDING THE WARRANTIES OF DESIGN, MERCHANTABILITY AND FITNESS FOR
+** A PARTICULAR PURPOSE. Trolltech reserves all rights not granted
+** herein.
+**
+**********************************************************************/
+
+#include "tqdockarea.h"
+
+#ifndef TQT_NO_MAINWINDOW
+#include "tqsplitter.h"
+#include "tqlayout.h"
+#include "tqptrvector.h"
+#include "tqapplication.h"
+#include "tqpainter.h"
+#include "tqwidgetlist.h"
+#include "tqmap.h"
+#include "tqmainwindow.h"
+
+//#define TQDOCKAREA_DEBUG
+
+struct TQ_EXPORT DockData
+{
+ DockData() : w( 0 ), rect() {}
+ DockData( TQDockWindow *dw, const TQRect &r ) : w( dw ), rect( r ) {}
+ TQDockWindow *w;
+ TQRect rect;
+
+ TQ_DUMMY_COMPARISON_OPERATOR( DockData )
+};
+
+static int fix_x( TQDockWindow* w, int width = -1 ) {
+ if ( TQApplication::reverseLayout() ) {
+ if ( width < 0 )
+ width = w->width();
+ return w->parentWidget()->width() - w->x() - width;
+ }
+ return w->x();
+}
+static int fix_x( TQDockWindow* w, int x, int width = -1 ) {
+ if ( TQApplication::reverseLayout() ) {
+ if ( width < 0 )
+ width = w->width();
+ return w->parentWidget()->width() - x - width;
+ }
+ return x;
+}
+
+static TQPoint fix_pos( TQDockWindow* w ) {
+ if ( TQApplication::reverseLayout() ) {
+ TQPoint p = w->pos();
+ p.rx() = w->parentWidget()->width() - p.x() - w->width();
+ return p;
+ }
+ return w->pos();
+}
+
+/*!
+ \reimp
+*/
+int TQDockAreaLayout::count() const {
+ return 0;
+}
+
+/*!
+ \reimp
+*/
+TQLayoutItem* TQDockAreaLayout::itemAt(int index) const {
+ return 0;
+}
+
+/*!
+ \reimp
+*/
+TQLayoutItem* TQDockAreaLayout::takeAt(int index) {
+ return 0;
+}
+
+void TQDockAreaLayout::setGeometry( const TQRect &r )
+{
+ TQLayout::setGeometry( r );
+ layoutItems( r );
+}
+
+TQLayoutIterator TQDockAreaLayout::iterator()
+{
+ return 0;
+}
+
+TQSize TQDockAreaLayout::tqsizeHint() const
+{
+ if ( !dockWindows || !dockWindows->first() )
+ return TQSize( 0, 0 );
+
+ if ( dirty ) {
+ TQDockAreaLayout *that = (TQDockAreaLayout *) this;
+ that->layoutItems( tqgeometry() );
+ }
+
+ int w = 0;
+ int h = 0;
+ TQPtrListIterator<TQDockWindow> it( *dockWindows );
+ TQDockWindow *dw = 0;
+ it.toFirst();
+ int y = -1;
+ int x = -1;
+ int ph = 0;
+ int pw = 0;
+ while ( ( dw = it.current() ) != 0 ) {
+ int plush = 0, plusw = 0;
+ ++it;
+ if ( dw->isHidden() )
+ continue;
+ if ( hasHeightForWidth() ) {
+ if ( y != dw->y() )
+ plush = ph;
+ y = dw->y();
+ ph = dw->height();
+ } else {
+ if ( x != dw->x() )
+ plusw = pw;
+ x = dw->x();
+ pw = dw->width();
+ }
+ h = TQMAX( h, dw->height() + plush );
+ w = TQMAX( w, dw->width() + plusw );
+ }
+
+ if ( hasHeightForWidth() )
+ return TQSize( 0, h );
+ return TQSize( w, 0 );
+}
+
+bool TQDockAreaLayout::hasHeightForWidth() const
+{
+ return orient == Qt::Horizontal;
+}
+
+void TQDockAreaLayout::init()
+{
+ dirty = TRUE;
+ cached_width = 0;
+ cached_height = 0;
+ cached_hfw = -1;
+ cached_wfh = -1;
+}
+
+void TQDockAreaLayout::tqinvalidate()
+{
+ dirty = TRUE;
+ cached_width = 0;
+ cached_height = 0;
+}
+
+static int start_pos( const TQRect &r, Qt::Orientation o )
+{
+ if ( o == Qt::Horizontal ) {
+ return TQMAX( 0, r.x() );
+ } else {
+ return TQMAX( 0, r.y() );
+ }
+}
+
+static void add_size( int s, int &pos, Qt::Orientation o )
+{
+ if ( o == Qt::Horizontal ) {
+ pos += s;
+ } else {
+ pos += s;
+ }
+}
+
+static int space_left( const TQRect &r, int pos, Qt::Orientation o )
+{
+ if ( o == Qt::Horizontal ) {
+ return ( r.x() + r.width() ) - pos;
+ } else {
+ return ( r.y() + r.height() ) - pos;
+ }
+}
+
+static int dock_extent( TQDockWindow *w, Qt::Orientation o, int maxsize )
+{
+ if ( o == Qt::Horizontal )
+ return TQMIN( maxsize, TQMAX( w->tqsizeHint().width(), w->fixedExtent().width() ) );
+ else
+ return TQMIN( maxsize, TQMAX( w->tqsizeHint().height(), w->fixedExtent().height() ) );
+}
+
+static int dock_strut( TQDockWindow *w, Qt::Orientation o )
+{
+ if ( o != Qt::Horizontal ) {
+ int wid;
+ if ( ( wid = w->fixedExtent().width() ) != -1 )
+ return TQMAX( wid, TQMAX( w->tqminimumSize().width(), w->tqminimumSizeHint().width() ) );
+ return TQMAX( w->tqsizeHint().width(), TQMAX( w->tqminimumSize().width(), w->tqminimumSizeHint().width() ) );
+ } else {
+ int hei;
+ if ( ( hei = w->fixedExtent().height() ) != -1 )
+ return TQMAX( hei, TQMAX( w->tqminimumSizeHint().height(), w->tqminimumSize().height() ) );
+ return TQMAX( w->tqsizeHint().height(), TQMAX( w->tqminimumSizeHint().height(), w->tqminimumSize().height() ) );
+ }
+}
+
+static void set_tqgeometry( TQDockWindow *w, int pos, int sectionpos, int extent, int strut, Qt::Orientation o )
+{
+ if ( o == Qt::Horizontal )
+ w->setGeometry( fix_x( w, pos, extent), sectionpos, extent, strut );
+ else
+ w->setGeometry( sectionpos, pos, strut, extent );
+}
+
+static int size_extent( const TQSize &s, Qt::Orientation o, bool swap = FALSE )
+{
+ return o == Qt::Horizontal ? ( swap ? s.height() : s.width() ) : ( swap ? s.width() : s.height() );
+}
+
+static int point_pos( const TQPoint &p, Qt::Orientation o, bool swap = FALSE )
+{
+ return o == Qt::Horizontal ? ( swap ? p.y() : p.x() ) : ( swap ? p.x() : p.y() );
+}
+
+static void shrink_extend( TQDockWindow *dw, int &dockExtend, int /*spaceLeft*/, Qt::Orientation o )
+{
+ TQToolBar *tb = ::tqqt_cast<TQToolBar*>(dw);
+ if ( o == Qt::Horizontal ) {
+ int mw = 0;
+ if ( !tb )
+ mw = dw->minimumWidth();
+ else
+ mw = dw->tqsizeHint().width();
+ dockExtend = mw;
+ } else {
+ int mh = 0;
+ if ( !tb )
+ mh = dw->minimumHeight();
+ else
+ mh = dw->tqsizeHint().height();
+ dockExtend = mh;
+ }
+}
+
+static void place_line( TQValueList<DockData> &lastLine, Qt::Orientation o, int linestrut, int fullextent, int tbstrut, int maxsize, TQDockAreaLayout * )
+{
+ TQDockWindow *last = 0;
+ TQRect lastRect;
+ for ( TQValueList<DockData>::Iterator it = lastLine.begin(); it != lastLine.end(); ++it ) {
+ if ( tbstrut != -1 && ::tqqt_cast<TQToolBar*>((*it).w) )
+ (*it).rect.setHeight( tbstrut );
+ if ( !last ) {
+ last = (*it).w;
+ lastRect = (*it).rect;
+ continue;
+ }
+ if ( !last->isStretchable() ) {
+ int w = TQMIN( lastRect.width(), maxsize );
+ set_tqgeometry( last, lastRect.x(), lastRect.y(), w, lastRect.height(), o );
+ } else {
+ int w = TQMIN( (*it).rect.x() - lastRect.x(), maxsize );
+ set_tqgeometry( last, lastRect.x(), lastRect.y(), w,
+ last->isResizeEnabled() ? linestrut : lastRect.height(), o );
+ }
+ last = (*it).w;
+ lastRect = (*it).rect;
+ }
+ if ( !last )
+ return;
+ if ( !last->isStretchable() ) {
+ int w = TQMIN( lastRect.width(), maxsize );
+ set_tqgeometry( last, lastRect.x(), lastRect.y(), w, lastRect.height(), o );
+ } else {
+ int w = TQMIN( fullextent - lastRect.x() - ( o == Qt::Vertical ? 1 : 0 ), maxsize );
+ set_tqgeometry( last, lastRect.x(), lastRect.y(), w,
+ last->isResizeEnabled() ? linestrut : lastRect.height(), o );
+ }
+}
+
+
+TQSize TQDockAreaLayout::tqminimumSize() const
+{
+ if ( !dockWindows || !dockWindows->first() )
+ return TQSize( 0, 0 );
+
+ if ( dirty ) {
+ TQDockAreaLayout *that = (TQDockAreaLayout *) this;
+ that->layoutItems( tqgeometry() );
+ }
+
+ int s = 0;
+
+ TQPtrListIterator<TQDockWindow> it( *dockWindows );
+ TQDockWindow *dw = 0;
+ while ( ( dw = it.current() ) != 0 ) {
+ ++it;
+ if ( dw->isHidden() )
+ continue;
+ s = TQMAX( s, dock_strut( dw, orientation() ) );
+ }
+
+ return orientation() == Qt::Horizontal ? TQSize( 0, s ? s+2 : 0 ) : TQSize( s, 0 );
+}
+
+
+
+int TQDockAreaLayout::layoutItems( const TQRect &rect, bool testonly )
+{
+ if ( !dockWindows || !dockWindows->first() )
+ return 0;
+
+ dirty = FALSE;
+
+ // some corrections
+ TQRect r = rect;
+ if ( orientation() == Qt::Vertical )
+ r.setHeight( r.height() - 3 );
+
+ // init
+ lines.clear();
+ ls.clear();
+ TQPtrListIterator<TQDockWindow> it( *dockWindows );
+ TQDockWindow *dw = 0;
+ int start = start_pos( r, orientation() );
+ int pos = start;
+ int sectionpos = 0;
+ int linestrut = 0;
+ TQValueList<DockData> lastLine;
+ int tbstrut = -1;
+ int maxsize = size_extent( rect.size(), orientation() );
+ int visibleWindows = 0;
+
+ // go through all widgets in the dock
+ while ( ( dw = it.current() ) != 0 ) {
+ ++it;
+ if ( dw->isHidden() )
+ continue;
+ ++visibleWindows;
+ // tqfind position for the widget: This is the maximum of the
+ // end of the previous widget and the offset of the widget. If
+ // the position + the width of the widget dosn't fit into the
+ // dock, try moving it a bit back, if possible.
+ int op = pos;
+ int dockExtend = dock_extent( dw, orientation(), maxsize );
+ if ( !dw->isStretchable() ) {
+ pos = TQMAX( pos, dw->offset() );
+ if ( pos + dockExtend > size_extent( r.size(), orientation() ) - 1 )
+ pos = TQMAX( op, size_extent( r.size(), orientation() ) - 1 - dockExtend );
+ }
+ if ( !lastLine.isEmpty() && !dw->newLine() && space_left( rect, pos, orientation() ) < dockExtend )
+ shrink_extend( dw, dockExtend, space_left( rect, pos, orientation() ), orientation() );
+ // if the current widget doesn't fit into the line anymore and it is not the first widget of the line
+ if ( !lastLine.isEmpty() &&
+ ( space_left( rect, pos, orientation() ) < dockExtend || dw->newLine() ) ) {
+ if ( !testonly ) // place the last line, if not in test mode
+ place_line( lastLine, orientation(), linestrut, size_extent( r.size(), orientation() ), tbstrut, maxsize, this );
+ // remember the line coordinats of the last line
+ if ( orientation() == Qt::Horizontal )
+ lines.append( TQRect( 0, sectionpos, r.width(), linestrut ) );
+ else
+ lines.append( TQRect( sectionpos, 0, linestrut, r.height() ) );
+ // do some clearing for the next line
+ lastLine.clear();
+ sectionpos += linestrut;
+ linestrut = 0;
+ pos = start;
+ tbstrut = -1;
+ }
+
+ // remeber first widget of a line
+ if ( lastLine.isEmpty() ) {
+ ls.append( dw );
+ // try to make the best position
+ int op = pos;
+ if ( !dw->isStretchable() )
+ pos = TQMAX( pos, dw->offset() );
+ if ( pos + dockExtend > size_extent( r.size(), orientation() ) - 1 )
+ pos = TQMAX( op, size_extent( r.size(), orientation() ) - 1 - dockExtend );
+ }
+ // do some calculations and add the remember the rect which the docking widget requires for the placing
+ TQRect dwRect(pos, sectionpos, dockExtend, dock_strut( dw, orientation() ) );
+ lastLine.append( DockData( dw, dwRect ) );
+ if ( ::tqqt_cast<TQToolBar*>(dw) )
+ tbstrut = TQMAX( tbstrut, dock_strut( dw, orientation() ) );
+ linestrut = TQMAX( dock_strut( dw, orientation() ), linestrut );
+ add_size( dockExtend, pos, orientation() );
+ }
+
+ // if some stuff was not placed/stored yet, do it now
+ if ( !testonly )
+ place_line( lastLine, orientation(), linestrut, size_extent( r.size(), orientation() ), tbstrut, maxsize, this );
+ if ( orientation() == Qt::Horizontal )
+ lines.append( TQRect( 0, sectionpos, r.width(), linestrut ) );
+ else
+ lines.append( TQRect( sectionpos, 0, linestrut, r.height() ) );
+ if ( *(--lines.end()) == *(--(--lines.end())) )
+ lines.remove( lines.at( lines.count() - 1 ) );
+
+ it.toFirst();
+ bool hadResizable = FALSE;
+ while ( ( dw = it.current() ) != 0 ) {
+ ++it;
+ if ( !dw->isVisibleTo( parentWidget ) )
+ continue;
+ hadResizable = hadResizable || dw->isResizeEnabled();
+ dw->updateSplitterVisibility( visibleWindows > 1 ); //!dw->area()->isLastDockWindow( dw ) );
+ }
+ return sectionpos + linestrut;
+}
+
+int TQDockAreaLayout::heightForWidth( int w ) const
+{
+ if ( dockWindows->isEmpty() && parentWidget )
+ return parentWidget->minimumHeight();
+
+ if ( cached_width != w ) {
+ TQDockAreaLayout * mthis = (TQDockAreaLayout*)this;
+ mthis->cached_width = w;
+ int h = mthis->layoutItems( TQRect( 0, 0, w, 0 ), TRUE );
+ mthis->cached_hfw = h;
+ return h;
+ }
+
+ return cached_hfw;
+}
+
+int TQDockAreaLayout::widthForHeight( int h ) const
+{
+ if ( cached_height != h ) {
+ TQDockAreaLayout * mthis = (TQDockAreaLayout*)this;
+ mthis->cached_height = h;
+ int w = mthis->layoutItems( TQRect( 0, 0, 0, h ), TRUE );
+ mthis->cached_wfh = w;
+ return w;
+ }
+ return cached_wfh;
+}
+
+
+
+
+/*!
+ \class TQDockArea tqdockarea.h
+ \brief The TQDockArea class manages and lays out TQDockWindows.
+
+ \ingroup application
+
+ A TQDockArea is a container which manages a list of
+ \l{TQDockWindow}s which it lays out within its area. In cooperation
+ with the \l{TQDockWindow}s it is responsible for the docking and
+ undocking of \l{TQDockWindow}s and moving them inside the dock
+ area. TQDockAreas also handle the wrapping of \l{TQDockWindow}s to
+ fill the available space as compactly as possible. TQDockAreas can
+ contain TQToolBars since TQToolBar is a TQDockWindow subclass.
+
+ TQMainWindow tqcontains four TQDockAreas which you can use for your
+ TQToolBars and TQDockWindows, so in most situations you do not need
+ to use the TQDockArea class directly. Although TQMainWindow tqcontains
+ support for its own dock areas it isn't convenient for adding new
+ TQDockAreas. If you need to create your own dock areas we suggest
+ that you create a subclass of TQWidget and add your TQDockAreas to
+ your subclass.
+
+ \img qmainwindow-qdockareas.png TQMainWindow's TQDockAreas
+
+ \target lines
+ \e Lines. TQDockArea uses the concept of lines. A line is a
+ horizontal region which may contain dock windows side-by-side. A
+ dock area may have room for more than one line. When dock windows
+ are docked into a dock area they are usually added at the right
+ hand side of the top-most line that has room (unless manually
+ placed by the user). When users move dock windows they may leave
+ empty lines or gaps in non-empty lines. Dock windows can be lined
+ up to minimize wasted space using the lineUp() function.
+
+ The TQDockArea class maintains a position list of all its child
+ dock windows. Dock windows are added to a dock area from position
+ 0 onwards. Dock windows are laid out sequentially in position
+ order from left to right, and in the case of multiple lines of
+ dock windows, from top to bottom. If a dock window is floated it
+ still retains its position since this is where the window will
+ return if the user double clicks its caption. A dock window's
+ position can be determined with hasDockWindow(). The position can
+ be changed with moveDockWindow().
+
+ To dock or undock a dock window use TQDockWindow::dock() and
+ TQDockWindow::undock() respectively. If you want to control which
+ dock windows can dock in a dock area use setAcceptDockWindow(). To
+ see if a dock area tqcontains a particular dock window use
+ \l{hasDockWindow()}; to see how many dock windows a dock area
+ tqcontains use count().
+
+ The streaming operators can write the positions of the dock
+ windows in the dock area to a TQTextStream. The positions can be
+ read back later to restore the saved positions.
+
+ Save the positions to a TQTextStream:
+ \code
+ ts << *myDockArea;
+ \endcode
+
+ Restore the positions from a TQTextStream:
+ \code
+ ts >> *myDockArea;
+ \endcode
+*/
+
+/*!
+ \property TQDockArea::handlePosition
+ \brief where the dock window splitter handle is placed in the dock
+ area
+
+ The default position is \c Normal.
+*/
+
+/*!
+ \property TQDockArea::orientation
+ \brief the dock area's orientation
+
+ There is no default value; the orientation is specified in the
+ constructor.
+*/
+
+/*!
+ \enum TQDockArea::HandlePosition
+
+ A dock window has two kinds of handles, the dock window handle
+ used for dragging the dock window, and the splitter handle used to
+ resize the dock window in relation to other dock windows using a
+ splitter. (The splitter handle is only visible for docked
+ windows.)
+
+ This enum specifies where the dock window splitter handle is
+ placed in the dock area.
+
+ \value Normal The splitter handles of dock windows are placed at
+ the right or bottom.
+
+ \value Reverse The splitter handles of dock windows are placed at
+ the left or top.
+*/
+
+/*!
+ Constructs a TQDockArea with orientation \a o, HandlePosition \a h,
+ tqparent \a tqparent and called \a name.
+*/
+
+TQDockArea::TQDockArea( Qt::Orientation o, HandlePosition h, TQWidget *tqparent, const char *name )
+ : TQWidget( tqparent, name ), orient( o ), tqlayout( 0 ), hPos( h )
+{
+ dockWindows = new TQPtrList<TQDockWindow>;
+ tqlayout = new TQDockAreaLayout( this, o, dockWindows, 0, 0, "tooltqlayout" );
+ installEventFilter( this );
+}
+
+/*!
+ Destroys the dock area and all the dock windows docked in the dock
+ area.
+
+ Does not affect any floating dock windows or dock windows in other
+ dock areas, even if they first appeared in this dock area.
+ Floating dock windows are effectively top level windows and are
+ not child windows of the dock area. When a floating dock window is
+ docked (dragged into a dock area) its tqparent becomes the dock
+ area.
+*/
+
+TQDockArea::~TQDockArea()
+{
+ dockWindows->setAutoDelete( TRUE );
+ delete dockWindows;
+ dockWindows = 0;
+}
+
+/*!
+ Moves the TQDockWindow \a w within the dock area. If \a w is not
+ already docked in this area, \a w is docked first. If \a index is
+ -1 or larger than the number of docked widgets, \a w is appended
+ at the end, otherwise it is inserted at the position \a index.
+*/
+
+void TQDockArea::moveDockWindow( TQDockWindow *w, int index )
+{
+ invalidateFixedSizes();
+ TQDockWindow *dockWindow = 0;
+ int dockWindowIndex = tqfindDockWindow( w );
+ if ( dockWindowIndex == -1 ) {
+ dockWindow = w;
+ dockWindow->reparent( this, TQPoint( 0, 0 ), TRUE );
+ w->installEventFilter( this );
+ updateLayout();
+ tqsetSizePolicy( TQSizePolicy( orientation() == Qt::Horizontal ? TQSizePolicy::Expanding : TQSizePolicy::Minimum,
+ orientation() == Qt::Vertical ? TQSizePolicy::Expanding : TQSizePolicy::Minimum ) );
+ dockWindows->append( w );
+ } else {
+ if ( w->tqparent() != TQT_TQOBJECT(this) )
+ w->reparent( this, TQPoint( 0, 0 ), TRUE );
+ if ( index == - 1 ) {
+ dockWindows->removeRef( w );
+ dockWindows->append( w );
+ }
+ }
+
+ w->dockArea = this;
+ w->curPlace = TQDockWindow::InDock;
+ w->updateGui();
+
+ if ( index != -1 && index < (int)dockWindows->count() ) {
+ dockWindows->removeRef( w );
+ dockWindows->insert( index, w );
+ }
+}
+
+/*!
+ Returns TRUE if the dock area tqcontains the dock window \a w;
+ otherwise returns FALSE. If \a index is not 0 it will be set as
+ follows: if the dock area tqcontains the dock window \a *index is
+ set to \a w's index position; otherwise \a *index is set to -1.
+*/
+
+bool TQDockArea::hasDockWindow( TQDockWindow *w, int *index )
+{
+ int i = dockWindows->tqfindRef( w );
+ if ( index )
+ *index = i;
+ return i != -1;
+}
+
+int TQDockArea::lineOf( int index )
+{
+ TQPtrList<TQDockWindow> lineStarts = tqlayout->lineStarts();
+ int i = 0;
+ for ( TQDockWindow *w = lineStarts.first(); w; w = lineStarts.next(), ++i ) {
+ if ( dockWindows->tqfind( w ) >= index )
+ return i;
+ }
+ return i;
+}
+
+/*!
+ \overload
+
+ Moves the dock window \a w inside the dock area where \a p is the
+ new position (in global screen coordinates), \a r is the suggested
+ rectangle of the dock window and \a swap specifies whether or not
+ the orientation of the docked widget needs to be changed.
+
+ This function is used internally by TQDockWindow. You shouldn't
+ need to call it yourself.
+*/
+
+void TQDockArea::moveDockWindow( TQDockWindow *w, const TQPoint &p, const TQRect &r, bool swap )
+{
+ invalidateFixedSizes();
+ int mse = -10;
+ bool hasResizable = FALSE;
+ for ( TQDockWindow *dw = dockWindows->first(); dw; dw = dockWindows->next() ) {
+ if ( dw->isHidden() )
+ continue;
+ if ( dw->isResizeEnabled() )
+ hasResizable = TRUE;
+ if ( orientation() != Qt::Horizontal )
+ mse = TQMAX( TQMAX( dw->fixedExtent().width(), dw->width() ), mse );
+ else
+ mse = TQMAX( TQMAX( dw->fixedExtent().height(), dw->height() ), mse );
+ }
+ if ( !hasResizable && w->isResizeEnabled() ) {
+ if ( orientation() != Qt::Horizontal )
+ mse = TQMAX( w->fixedExtent().width(), mse );
+ else
+ mse = TQMAX( w->fixedExtent().height(), mse );
+ }
+
+ TQDockWindow *dockWindow = 0;
+ int dockWindowIndex = tqfindDockWindow( w );
+ TQPtrList<TQDockWindow> lineStarts = tqlayout->lineStarts();
+ TQValueList<TQRect> lines = tqlayout->lineList();
+ bool wasAloneInLine = FALSE;
+ TQPoint pos = mapFromGlobal( p );
+ TQRect lr = *lines.at( lineOf( dockWindowIndex ) );
+ if ( dockWindowIndex != -1 ) {
+ if ( lineStarts.tqfind( w ) != -1 &&
+ ( (dockWindowIndex < (int)dockWindows->count() - 1 && lineStarts.tqfind( dockWindows->at( dockWindowIndex + 1 ) ) != -1) ||
+ dockWindowIndex == (int)dockWindows->count() - 1 ) )
+ wasAloneInLine = TRUE;
+ dockWindow = dockWindows->take( dockWindowIndex );
+ if ( !wasAloneInLine ) { // only do the pre-tqlayout if the widget isn't the only one in its line
+ if ( lineStarts.tqfindRef( dockWindow ) != -1 && dockWindowIndex < (int)dockWindows->count() )
+ dockWindows->at( dockWindowIndex )->setNewLine( TRUE );
+ tqlayout->layoutItems( TQRect( 0, 0, width(), height() ), TRUE );
+ }
+ } else {
+ dockWindow = w;
+ dockWindow->reparent( this, TQPoint( 0, 0 ), TRUE );
+ if ( swap )
+ dockWindow->resize( dockWindow->height(), dockWindow->width() );
+ w->installEventFilter( this );
+ }
+
+ lineStarts = tqlayout->lineStarts();
+ lines = tqlayout->lineList();
+
+ TQRect rect = TQRect( mapFromGlobal( r.topLeft() ), r.size() );
+ if ( orientation() == Qt::Horizontal && TQApplication::reverseLayout() ) {
+ rect = TQRect( width() - rect.x() - rect.width(), rect.y(), rect.width(), rect.height() );
+ pos.rx() = width() - pos.x();
+ }
+ dockWindow->setOffset( point_pos( rect.topLeft(), orientation() ) );
+ if ( orientation() == Qt::Horizontal ) {
+ int offs = dockWindow->offset();
+ if ( width() - offs < dockWindow->minimumWidth() )
+ dockWindow->setOffset( width() - dockWindow->minimumWidth() );
+ } else {
+ int offs = dockWindow->offset();
+ if ( height() - offs < dockWindow->minimumHeight() )
+ dockWindow->setOffset( height() - dockWindow->minimumHeight() );
+ }
+
+ if ( dockWindows->isEmpty() ) {
+ dockWindows->append( dockWindow );
+ } else {
+ int dockLine = -1;
+ bool insertLine = FALSE;
+ int i = 0;
+ TQRect lineRect;
+ // tqfind the line which we touched with the mouse
+ for ( TQValueList<TQRect>::Iterator it = lines.begin(); it != lines.end(); ++it, ++i ) {
+ if ( point_pos( pos, orientation(), TRUE ) >= point_pos( (*it).topLeft(), orientation(), TRUE ) &&
+ point_pos( pos, orientation(), TRUE ) <= point_pos( (*it).topLeft(), orientation(), TRUE ) +
+ size_extent( (*it).size(), orientation(), TRUE ) ) {
+ dockLine = i;
+ lineRect = *it;
+ break;
+ }
+ }
+ if ( dockLine == -1 ) { // outside the dock...
+ insertLine = TRUE;
+ if ( point_pos( pos, orientation(), TRUE ) < 0 ) // insert as first line
+ dockLine = 0;
+ else
+ dockLine = (int)lines.count(); // insert after the last line ### size_t/int cast
+ } else { // inside the dock (we have found a dockLine)
+ if ( point_pos( pos, orientation(), TRUE ) <
+ point_pos( lineRect.topLeft(), orientation(), TRUE ) + 4 ) { // mouse was at the very beginning of the line
+ insertLine = TRUE; // insert a new line before that with the docking widget
+ } else if ( point_pos( pos, orientation(), TRUE ) >
+ point_pos( lineRect.topLeft(), orientation(), TRUE ) +
+ size_extent( lineRect.size(), orientation(), TRUE ) - 4 ) { // mouse was at the very and of the line
+ insertLine = TRUE; // insert a line after that with the docking widget
+ dockLine++;
+ }
+ }
+
+ if ( !insertLine && wasAloneInLine && lr.tqcontains( pos ) ) // if we are alone in a line and just moved in there, re-insert it
+ insertLine = TRUE;
+
+#if defined(TQDOCKAREA_DEBUG)
+ qDebug( "insert in line %d, and insert that line: %d", dockLine, insertLine );
+ qDebug( " (btw, we have %d lines)", lines.count() );
+#endif
+ TQDockWindow *dw = 0;
+ if ( dockLine >= (int)lines.count() ) { // insert after last line
+ dockWindows->append( dockWindow );
+ dockWindow->setNewLine( TRUE );
+#if defined(TQDOCKAREA_DEBUG)
+ qDebug( "insert at the end" );
+#endif
+ } else if ( dockLine == 0 && insertLine ) { // insert before first line
+ dockWindows->insert( 0, dockWindow );
+ dockWindows->at( 1 )->setNewLine( TRUE );
+#if defined(TQDOCKAREA_DEBUG)
+ qDebug( "insert at the begin" );
+#endif
+ } else { // insert somewhere in between
+ // make sure each line start has a new line
+ for ( dw = lineStarts.first(); dw; dw = lineStarts.next() )
+ dw->setNewLine( TRUE );
+
+ // tqfind the index of the first widget in the search line
+ int searchLine = dockLine;
+#if defined(TQDOCKAREA_DEBUG)
+ qDebug( "search line start of %d", searchLine );
+#endif
+ TQDockWindow *lsw = lineStarts.at( searchLine );
+ int index = dockWindows->tqfind( lsw );
+ if ( index == -1 ) { // the linestart widget hasn't been found, try to tqfind it harder
+ if ( lsw == w && dockWindowIndex <= (int)dockWindows->count())
+ index = dockWindowIndex;
+ else
+ index = 0;
+ if ( index < (int)dockWindows->count() )
+ (void)dockWindows->at( index ); // move current to index
+ }
+#if defined(TQDOCKAREA_DEBUG)
+ qDebug( " which starts at %d", index );
+#endif
+ if ( !insertLine ) { // if we insert the docking widget in the existing line
+ // tqfind the index for the widget
+ bool inc = TRUE;
+ bool firstTime = TRUE;
+ for ( dw = dockWindows->current(); dw; dw = dockWindows->next() ) {
+ if ( orientation() == Qt::Horizontal )
+ dw->setFixedExtentWidth( -1 );
+ else
+ dw->setFixedExtentHeight( -1 );
+ if ( !firstTime && lineStarts.tqfind( dw ) != -1 ) // we are in the next line, so break
+ break;
+ if ( point_pos( pos, orientation() ) <
+ point_pos( fix_pos( dw ), orientation() ) + size_extent( dw->size(), orientation() ) / 2 ) {
+ inc = FALSE;
+ }
+ if ( inc )
+ index++;
+ firstTime = FALSE;
+ }
+#if defined(TQDOCKAREA_DEBUG)
+ qDebug( "insert at index: %d", index );
+#endif
+ // if we insert it just before a widget which has a new line, transfer the newline to the docking widget
+ // but not if we didn't only mave a widget in its line which was alone in the line before
+ if ( !( wasAloneInLine && lr.tqcontains( pos ) )
+ && index >= 0 && index < (int)dockWindows->count() &&
+ dockWindows->at( index )->newLine() && lineOf( index ) == dockLine ) {
+#if defined(TQDOCKAREA_DEBUG)
+ qDebug( "get rid of the old newline and get me one" );
+#endif
+ dockWindows->at( index )->setNewLine( FALSE );
+ dockWindow->setNewLine( TRUE );
+ } else if ( wasAloneInLine && lr.tqcontains( pos ) ) {
+ dockWindow->setNewLine( TRUE );
+ } else { // if we are somewhere in a line, get rid of the newline
+ dockWindow->setNewLine( FALSE );
+ }
+ } else { // insert in a new line, so make sure the dock widget and the widget which will be after it have a newline
+#if defined(TQDOCKAREA_DEBUG)
+ qDebug( "insert a new line" );
+#endif
+ if ( index < (int)dockWindows->count() ) {
+#if defined(TQDOCKAREA_DEBUG)
+ qDebug( "give the widget at %d a newline", index );
+#endif
+ TQDockWindow* nldw = dockWindows->at( index );
+ if ( nldw )
+ nldw->setNewLine( TRUE );
+ }
+#if defined(TQDOCKAREA_DEBUG)
+ qDebug( "give me a newline" );
+#endif
+ dockWindow->setNewLine( TRUE );
+ }
+ // finally insert the widget
+ dockWindows->insert( index, dockWindow );
+ }
+ }
+
+ if ( mse != -10 && w->isResizeEnabled() ) {
+ if ( orientation() != Qt::Horizontal )
+ w->setFixedExtentWidth( TQMIN( TQMAX( w->minimumWidth(), mse ), w->tqsizeHint().width() ) );
+ else
+ w->setFixedExtentHeight( TQMIN( TQMAX( w->minimumHeight(), mse ), w->tqsizeHint().height() ) );
+ }
+
+ updateLayout();
+ tqsetSizePolicy( TQSizePolicy( orientation() == Qt::Horizontal ? TQSizePolicy::Expanding : TQSizePolicy::Minimum,
+ orientation() == Qt::Vertical ? TQSizePolicy::Expanding : TQSizePolicy::Minimum ) );
+}
+
+/*!
+ Removes the dock window \a w from the dock area. If \a
+ makeFloating is TRUE, \a w gets floated, and if \a swap is TRUE,
+ the orientation of \a w gets swapped. If \a fixNewLines is TRUE
+ (the default) newlines in the area will be fixed.
+
+ You should never need to call this function yourself. Use
+ TQDockWindow::dock() and TQDockWindow::undock() instead.
+*/
+
+void TQDockArea::removeDockWindow( TQDockWindow *w, bool makeFloating, bool swap, bool fixNewLines )
+{
+ w->removeEventFilter( this );
+ TQDockWindow *dockWindow = 0;
+ int i = tqfindDockWindow( w );
+ if ( i == -1 )
+ return;
+ dockWindow = dockWindows->at( i );
+ dockWindows->remove( i );
+ TQPtrList<TQDockWindow> lineStarts = tqlayout->lineStarts();
+ if ( fixNewLines && lineStarts.tqfindRef( dockWindow ) != -1 && i < (int)dockWindows->count() )
+ dockWindows->at( i )->setNewLine( TRUE );
+ if ( makeFloating ) {
+ TQWidget *p = parentWidget() ? parentWidget() : tqtopLevelWidget();
+ dockWindow->reparent( p, (Qt::WindowFlags)(TQt::WType_Dialog | WStyle_Customize | TQt::WStyle_NoBorder | TQt::WStyle_Tool), TQPoint( 0, 0 ), FALSE );
+ }
+ if ( swap )
+ dockWindow->resize( dockWindow->height(), dockWindow->width() );
+ updateLayout();
+ if ( dockWindows->isEmpty() )
+ tqsetSizePolicy( TQSizePolicy( TQSizePolicy::Preferred, TQSizePolicy::Preferred ) );
+}
+
+int TQDockArea::tqfindDockWindow( TQDockWindow *w )
+{
+ return dockWindows ? dockWindows->tqfindRef( w ) : -1;
+}
+
+void TQDockArea::updateLayout()
+{
+ tqlayout->tqinvalidate();
+ tqlayout->activate();
+}
+
+/*! \reimp
+ */
+
+bool TQDockArea::eventFilter( TQObject *o, TQEvent *e )
+{
+ if ( e->type() == TQEvent::Close ) {
+ if ( ::tqqt_cast<TQDockWindow*>(o) ) {
+ o->removeEventFilter( this );
+ TQApplication::sendEvent( o, e );
+ if ( ( (TQCloseEvent*)e )->isAccepted() )
+ removeDockWindow( (TQDockWindow*)o, FALSE, FALSE );
+ return TRUE;
+ }
+ }
+ return FALSE;
+}
+
+/*! \internal
+
+ Invalidates the offset of the next dock window in the dock area.
+ */
+
+void TQDockArea::invalidNextOffset( TQDockWindow *dw )
+{
+ int i = dockWindows->tqfind( dw );
+ if ( i == -1 || i >= (int)dockWindows->count() - 1 )
+ return;
+ if ( ( dw = dockWindows->at( ++i ) ) )
+ dw->setOffset( 0 );
+}
+
+/*!
+ \property TQDockArea::count
+ \brief the number of dock windows in the dock area
+*/
+int TQDockArea::count() const
+{
+ return dockWindows->count();
+}
+
+/*!
+ \property TQDockArea::empty
+ \brief whether the dock area is empty
+*/
+
+bool TQDockArea::isEmpty() const
+{
+ return dockWindows->isEmpty();
+}
+
+
+/*!
+ Returns a list of the dock windows in the dock area.
+*/
+
+TQPtrList<TQDockWindow> TQDockArea::dockWindowList() const
+{
+ return *dockWindows;
+}
+
+/*!
+ Lines up the dock windows in this dock area to minimize wasted
+ space. If \a keepNewLines is TRUE, only space within lines is
+ cleaned up. If \a keepNewLines is FALSE the number of lines might
+ be changed.
+*/
+
+void TQDockArea::lineUp( bool keepNewLines )
+{
+ for ( TQDockWindow *dw = dockWindows->first(); dw; dw = dockWindows->next() ) {
+ dw->setOffset( 0 );
+ if ( !keepNewLines )
+ dw->setNewLine( FALSE );
+ }
+ tqlayout->activate();
+}
+
+TQDockArea::DockWindowData *TQDockArea::dockWindowData( TQDockWindow *w )
+{
+ DockWindowData *data = new DockWindowData;
+ data->index = tqfindDockWindow( w );
+ if ( data->index == -1 ) {
+ delete data;
+ return 0;
+ }
+ TQPtrList<TQDockWindow> lineStarts = tqlayout->lineStarts();
+ int i = -1;
+ for ( TQDockWindow *dw = dockWindows->first(); dw; dw = dockWindows->next() ) {
+ if ( lineStarts.tqfindRef( dw ) != -1 )
+ ++i;
+ if ( dw == w )
+ break;
+ }
+ data->line = i;
+ data->offset = point_pos( TQPoint( fix_x(w), w->y() ), orientation() );
+ data->area = this;
+ data->fixedExtent = w->fixedExtent();
+ return data;
+}
+
+void TQDockArea::dockWindow( TQDockWindow *dockWindow, DockWindowData *data )
+{
+ if ( !data )
+ return;
+
+ dockWindow->reparent( this, TQPoint( 0, 0 ), FALSE );
+ dockWindow->installEventFilter( this );
+ dockWindow->dockArea = this;
+ dockWindow->updateGui();
+
+ if ( dockWindows->isEmpty() ) {
+ dockWindows->append( dockWindow );
+ } else {
+ TQPtrList<TQDockWindow> lineStarts = tqlayout->lineStarts();
+ int index = 0;
+ if ( (int)lineStarts.count() > data->line )
+ index = dockWindows->tqfind( lineStarts.at( data->line ) );
+ if ( index == -1 ) {
+ index = 0;
+ (void)dockWindows->at( index );
+ }
+ bool firstTime = TRUE;
+ int offset = data->offset;
+ for ( TQDockWindow *dw = dockWindows->current(); dw; dw = dockWindows->next() ) {
+ if ( !firstTime && lineStarts.tqfind( dw ) != -1 )
+ break;
+ if ( offset <
+ point_pos( fix_pos( dw ), orientation() ) + size_extent( dw->size(), orientation() ) / 2 )
+ break;
+ index++;
+ firstTime = FALSE;
+ }
+ if ( index >= 0 && index < (int)dockWindows->count() &&
+ dockWindows->at( index )->newLine() && lineOf( index ) == data->line ) {
+ dockWindows->at( index )->setNewLine( FALSE );
+ dockWindow->setNewLine( TRUE );
+ } else {
+ dockWindow->setNewLine( FALSE );
+ }
+
+ dockWindows->insert( index, dockWindow );
+ }
+ dockWindow->show();
+
+ dockWindow->setFixedExtentWidth( data->fixedExtent.width() );
+ dockWindow->setFixedExtentHeight( data->fixedExtent.height() );
+
+ updateLayout();
+ tqsetSizePolicy( TQSizePolicy( orientation() == Qt::Horizontal ? TQSizePolicy::Expanding : TQSizePolicy::Minimum,
+ orientation() == Qt::Vertical ? TQSizePolicy::Expanding : TQSizePolicy::Minimum ) );
+
+}
+
+/*!
+ Returns TRUE if dock window \a dw could be docked into the dock
+ area; otherwise returns FALSE.
+
+ \sa setAcceptDockWindow()
+*/
+
+bool TQDockArea::isDockWindowAccepted( TQDockWindow *dw )
+{
+ if ( !dw )
+ return FALSE;
+ if ( forbiddenWidgets.tqfindRef( dw ) != -1 )
+ return FALSE;
+
+ TQMainWindow *mw = ::tqqt_cast<TQMainWindow*>(parentWidget());
+ if ( !mw )
+ return TRUE;
+ if ( !mw->hasDockWindow( dw ) )
+ return FALSE;
+ if ( !mw->isDockEnabled( this ) )
+ return FALSE;
+ if ( !mw->isDockEnabled( dw, this ) )
+ return FALSE;
+ return TRUE;
+}
+
+/*!
+ If \a accept is TRUE, dock window \a dw can be docked in the dock
+ area. If \a accept is FALSE, dock window \a dw cannot be docked in
+ the dock area.
+
+ \sa isDockWindowAccepted()
+*/
+
+void TQDockArea::setAcceptDockWindow( TQDockWindow *dw, bool accept )
+{
+ if ( accept )
+ forbiddenWidgets.removeRef( dw );
+ else if ( forbiddenWidgets.tqfindRef( dw ) == -1 )
+ forbiddenWidgets.append( dw );
+}
+
+void TQDockArea::invalidateFixedSizes()
+{
+ for ( TQDockWindow *dw = dockWindows->first(); dw; dw = dockWindows->next() ) {
+ if ( orientation() == Qt::Horizontal )
+ dw->setFixedExtentWidth( -1 );
+ else
+ dw->setFixedExtentHeight( -1 );
+ }
+}
+
+int TQDockArea::maxSpace( int hint, TQDockWindow *dw )
+{
+ int index = tqfindDockWindow( dw );
+ if ( index == -1 || index + 1 >= (int)dockWindows->count() ) {
+ if ( orientation() == Qt::Horizontal )
+ return dw->width();
+ return dw->height();
+ }
+
+ TQDockWindow *w = 0;
+ int i = 0;
+ do {
+ w = dockWindows->at( index + (++i) );
+ } while ( i + 1 < (int)dockWindows->count() && ( !w || w->isHidden() ) );
+ if ( !w || !w->isResizeEnabled() || i >= (int)dockWindows->count() ) {
+ if ( orientation() == Qt::Horizontal )
+ return dw->width();
+ return dw->height();
+ }
+ int min = 0;
+ TQToolBar *tb = ::tqqt_cast<TQToolBar*>(w);
+ if ( orientation() == Qt::Horizontal ) {
+ w->setFixedExtentWidth( -1 );
+ if ( !tb )
+ min = TQMAX( w->tqminimumSize().width(), w->tqminimumSizeHint().width() );
+ else
+ min = w->tqsizeHint().width();
+ } else {
+ w->setFixedExtentHeight( -1 );
+ if ( !tb )
+ min = TQMAX( w->tqminimumSize().height(), w->tqminimumSizeHint().height() );
+ else
+ min = w->tqsizeHint().height();
+ }
+
+ int diff = hint - ( orientation() == Qt::Horizontal ? dw->width() : dw->height() );
+
+ if ( ( orientation() == Qt::Horizontal ? w->width() : w->height() ) - diff < min )
+ hint = ( orientation() == Qt::Horizontal ? dw->width() : dw->height() ) + ( orientation() == Qt::Horizontal ? w->width() : w->height() ) - min;
+
+ diff = hint - ( orientation() == Qt::Horizontal ? dw->width() : dw->height() );
+ if ( orientation() == Qt::Horizontal )
+ w->setFixedExtentWidth( w->width() - diff );
+ else
+ w->setFixedExtentHeight( w->height() - diff );
+ return hint;
+}
+
+void TQDockArea::setFixedExtent( int d, TQDockWindow *dw )
+{
+ TQPtrList<TQDockWindow> lst;
+ TQDockWindow *w;
+ for ( w = dockWindows->first(); w; w = dockWindows->next() ) {
+ if ( w->isHidden() )
+ continue;
+ if ( orientation() == Qt::Horizontal ) {
+ if ( dw->y() != w->y() )
+ continue;
+ } else {
+ if ( dw->x() != w->x() )
+ continue;
+ }
+ if ( orientation() == Qt::Horizontal )
+ d = TQMAX( d, w->minimumHeight() );
+ else
+ d = TQMAX( d, w->minimumWidth() );
+ if ( w->isResizeEnabled() )
+ lst.append( w );
+ }
+ for ( w = lst.first(); w; w = lst.next() ) {
+ if ( orientation() == Qt::Horizontal )
+ w->setFixedExtentHeight( d );
+ else
+ w->setFixedExtentWidth( d );
+ }
+}
+
+bool TQDockArea::isLastDockWindow( TQDockWindow *dw )
+{
+ int i = dockWindows->tqfind( dw );
+ if ( i == -1 || i >= (int)dockWindows->count() - 1 )
+ return TRUE;
+ TQDockWindow *w = 0;
+ if ( ( w = dockWindows->at( ++i ) ) ) {
+ if ( orientation() == Qt::Horizontal && dw->y() < w->y() )
+ return TRUE;
+ if ( orientation() == Qt::Vertical && dw->x() < w->x() )
+ return TRUE;
+ } else {
+ return TRUE;
+ }
+ return FALSE;
+}
+
+#ifndef TQT_NO_TEXTSTREAM
+
+/*!
+ \relates TQDockArea
+
+ Writes the tqlayout of the dock windows in dock area \a dockArea to
+ the text stream \a ts.
+
+ \sa operator>>()
+*/
+
+TQTextStream &operator<<( TQTextStream &ts, const TQDockArea &dockArea )
+{
+ TQString str;
+ TQPtrList<TQDockWindow> l = dockArea.dockWindowList();
+
+ for ( TQDockWindow *dw = l.first(); dw; dw = l.next() )
+ str += "[" + TQString( dw->caption() ) + "," + TQString::number( (int)dw->offset() ) +
+ "," + TQString::number( (int)dw->newLine() ) + "," + TQString::number( dw->fixedExtent().width() ) +
+ "," + TQString::number( dw->fixedExtent().height() ) + "," + TQString::number( (int)!dw->isHidden() ) + "]";
+ ts << str << endl;
+
+ return ts;
+}
+
+/*!
+ \relates TQDockArea
+
+ Reads the tqlayout description of the dock windows in dock area \a
+ dockArea from the text stream \a ts and restores it. The tqlayout
+ description must have been previously written by the operator<<()
+ function.
+
+ \sa operator<<()
+*/
+
+TQTextStream &operator>>( TQTextStream &ts, TQDockArea &dockArea )
+{
+ TQString s = ts.readLine();
+
+ TQString name, offset, newLine, width, height, visible;
+
+ enum State { Pre, Name, Offset, NewLine, Width, Height, Visible, Post };
+ int state = Pre;
+ TQChar c;
+ TQPtrList<TQDockWindow> l = dockArea.dockWindowList();
+
+ for ( int i = 0; i < (int)s.length(); ++i ) {
+ c = s[ i ];
+ if ( state == Pre && c == '[' ) {
+ state++;
+ continue;
+ }
+ if ( c == ',' &&
+ ( state == Name || state == Offset || state == NewLine || state == Width || state == Height ) ) {
+ state++;
+ continue;
+ }
+ if ( state == Visible && c == ']' ) {
+ for ( TQDockWindow *dw = l.first(); dw; dw = l.next() ) {
+ if ( TQString( dw->caption() ) == name ) {
+ dw->setNewLine( (bool)newLine.toInt() );
+ dw->setOffset( offset.toInt() );
+ dw->setFixedExtentWidth( width.toInt() );
+ dw->setFixedExtentHeight( height.toInt() );
+ if ( !(bool)visible.toInt() )
+ dw->hide();
+ else
+ dw->show();
+ break;
+ }
+ }
+
+ name = offset = newLine = width = height = visible = "";
+
+ state = Pre;
+ continue;
+ }
+ if ( state == Name )
+ name += c;
+ else if ( state == Offset )
+ offset += c;
+ else if ( state == NewLine )
+ newLine += c;
+ else if ( state == Width )
+ width += c;
+ else if ( state == Height )
+ height += c;
+ else if ( state == Visible )
+ visible += c;
+ }
+
+ dockArea.TQWidget::tqlayout()->tqinvalidate();
+ dockArea.TQWidget::tqlayout()->activate();
+ return ts;
+}
+#endif
+
+#endif //TQT_NO_MAINWINDOW