Source: kxmlguifactory_p.h
|
|
|
|
/* This file is part of the KDE libraries
Copyright (C) 2001 Simon Hausmann
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
*/
#ifndef __kxmlguifactory_p_h__
#define __kxmlguifactory_p_h__
#include
#include
#include
#include
#include
class QWidget;
class KXMLGUIClient;
class KXMLGUIBuilder;
class KXMLGUIFactory;
namespace KXMLGUI
{
struct BuildState;
class ActionList : public QPtrList
{
public:
ActionList() {}
ActionList( const QPtrList &rhs )
: QPtrList( rhs )
{}
ActionList &operator=( const QPtrList &rhs )
{ QPtrList::operator=( rhs ); return *this; }
void plug( QWidget *container, int index ) const;
void unplug( QWidget *container ) const;
};
typedef QPtrListIterator ActionListIt;
typedef QMap< QString, ActionList > ActionListMap;
/*
* This structure is used to know to which client certain actions and custom elements
* (i.e. menu separators) belong.
* We do not only use a ContainerClient per GUIClient but also per merging group.
*
* groupName : Used for grouped merging. Specifies the group name to which these actions/elements
* belong to.
* actionLists : maps from action list name to action list.
* mergingName : The (named) merging point.
*
* A ContainerClient always belongs to a ContainerNode.
*/
struct ContainerClient
{
KXMLGUIClient *client;
ActionList actions;
QValueList customElements;
QString groupName; //is empty if no group client
ActionListMap actionLists;
QString mergingName;
};
typedef QPtrList ContainerClientList;
typedef QPtrListIterator ContainerClientListIt;
class ContainerNode;
struct MergingIndex
{
int value; // the actual index value, used as index for plug() or createContainer() calls
QString mergingName; // the name of the merging index (i.e. the name attribute of the
// Merge or DefineGroup tag)
QString clientName; // the name of the client that defined this index
};
typedef QValueList MergingIndexList;
/*
* Here we store detailed information about a container, its clients (client=a guiclient having actions
* plugged into the container), child nodes, naming information (tagname and name attribute) and
* merging index information, to plug/insert new actions/items a the correct position.
*
* The builder variable is needed for using the proper GUIBuilder for destruction ( to use the same for
* con- and destruction ). The builderCustomTags and builderContainerTags variables are cached values
* of what the corresponding methods of the GUIBuilder which built the container return. The stringlists
* is shared all over the place, so there's no need to worry about memory consumption for these
* variables :-)
*
* The mergingIndices list contains the merging indices ;-) , as defined by ,
* or by tags. The order of these index structures within the mergingIndices list
* is (and has to be) identical with the order in the DOM tree.
*
* Beside the merging indices we have the "real" index of the container. It points to the next free
* position.
* (used when no merging index is used for a certain action, custom element or sub-container)
*/
struct ContainerNode
{
ContainerNode( QWidget *_container, const QString &_tagName, const QString &_name,
ContainerNode *_parent = 0L, KXMLGUIClient *_client = 0L,
KXMLGUIBuilder *_builder = 0L, int id = -1,
const QString &_mergingName = QString::null,
const QString &groupName = QString::null,
const QStringList &customTags = QStringList(),
const QStringList &containerTags = QStringList() );
ContainerNode *parent;
KXMLGUIClient *client;
KXMLGUIBuilder *builder;
QStringList builderCustomTags;
QStringList builderContainerTags;
QWidget *container;
int containerId;
QString tagName;
QString name;
QString groupName; //is empty if the container is in no group
ContainerClientList clients;
QPtrList children;
int index;
MergingIndexList mergingIndices;
QString mergingName;
void clearChildren() { children.clear(); }
void removeChild( ContainerNode *child );
MergingIndexList::Iterator findIndex( const QString &name );
ContainerNode *findContainerNode( QWidget *container );
ContainerNode *findContainer( const QString &_name, bool tag );
ContainerNode *findContainer( const QString &name, const QString &tagName,
const QPtrList *excludeList,
KXMLGUIClient *currClient );
ContainerClient *findChildContainerClient( KXMLGUIClient *currentGUIClient,
const QString &groupName,
const MergingIndexList::Iterator &mergingIdx );
void plugActionList( BuildState &state );
void plugActionList( BuildState &state, const MergingIndexList::Iterator &mergingIdxIt );
void unplugActionList( BuildState &state );
void unplugActionList( BuildState &state, const MergingIndexList::Iterator &mergingIdxIt );
void adjustMergingIndices( int offset, const MergingIndexList::Iterator &it );
bool destruct( QDomElement element, BuildState &state );
void destructChildren( const QDomElement &element, BuildState &state );
QDomElement findElementForChild( const QDomElement &baseElement,
ContainerNode *childNode );
void unplugActions( BuildState &state );
void unplugClient( ContainerClient *client );
void reset();
int calcMergingIndex( const QString &mergingName,
MergingIndexList::Iterator &it,
BuildState &state,
bool ignoreDefaultMergingIndex );
};
typedef QPtrList ContainerNodeList;
typedef QPtrListIterator ContainerNodeListIt;
class BuildHelper
{
public:
BuildHelper( BuildState &state,
ContainerNode *node );
void build( const QDomElement &element );
private:
void processElement( const QDomElement &element );
void processActionOrCustomElement( const QDomElement &e, bool isActionTag );
bool processActionElement( const QDomElement &e, int idx );
bool processCustomElement( const QDomElement &e, int idx );
void processStateElement( const QDomElement &element );
void processMergeElement( const QString &tag, const QString &name, const QDomElement &e );
void processContainerElement( const QDomElement &e, const QString &tag,
const QString &name );
QWidget *createContainer( QWidget *parent, int index, const QDomElement &element,
int &id, KXMLGUIBuilder **builder );
QStringList customTags;
QStringList containerTags;
QPtrList containerList;
ContainerClient *containerClient;
bool ignoreDefaultMergingIndex;
BuildState &m_state;
ContainerNode *parentNode;
};
struct BuildState
{
BuildState() : guiClient( 0 ), builder( 0 ), clientBuilder( 0 ) {}
void reset();
QString clientName;
QString actionListName;
ActionList actionList;
KXMLGUIClient *guiClient;
MergingIndexList::Iterator currentDefaultMergingIt;
MergingIndexList::Iterator currentClientMergingIt;
KXMLGUIBuilder *builder;
QStringList builderCustomTags;
QStringList builderContainerTags;
KXMLGUIBuilder *clientBuilder;
QStringList clientBuilderCustomTags;
QStringList clientBuilderContainerTags;
};
typedef QValueStack BuildStateStack;
};
#endif
/* vim: et sw=4
*/
Generated by: caleb on tcdevel on Tue Jan 28 12:54:10 2003, using kdoc $. |