summaryrefslogtreecommitdiffstats
path: root/kdeui/kxmlguifactory_p.cpp
diff options
context:
space:
mode:
authorTimothy Pearson <kb9vqf@pearsoncomputing.net>2011-11-06 15:56:40 -0600
committerTimothy Pearson <kb9vqf@pearsoncomputing.net>2011-11-06 15:56:40 -0600
commite16866e072f94410321d70daedbcb855ea878cac (patch)
treeee3f52eabde7da1a0e6ca845fb9c2813cf1558cf /kdeui/kxmlguifactory_p.cpp
parenta58c20c1a7593631a1b50213c805507ebc16adaf (diff)
downloadtdelibs-e16866e072f94410321d70daedbcb855ea878cac.tar.gz
tdelibs-e16866e072f94410321d70daedbcb855ea878cac.zip
Actually move the kde files that were renamed in the last commit
Diffstat (limited to 'kdeui/kxmlguifactory_p.cpp')
-rw-r--r--kdeui/kxmlguifactory_p.cpp836
1 files changed, 0 insertions, 836 deletions
diff --git a/kdeui/kxmlguifactory_p.cpp b/kdeui/kxmlguifactory_p.cpp
deleted file mode 100644
index 279753277..000000000
--- a/kdeui/kxmlguifactory_p.cpp
+++ /dev/null
@@ -1,836 +0,0 @@
-/* This file is part of the KDE libraries
- Copyright (C) 2001 Simon Hausmann <hausmann@kde.org>
-
- 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., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#include "kxmlguifactory_p.h"
-#include "kxmlguiclient.h"
-#include "kxmlguibuilder.h"
-
-#include <tqwidget.h>
-
-#include <kglobal.h>
-#include <kdebug.h>
-
-#include <assert.h>
-
-using namespace KXMLGUI;
-
-void ActionList::plug( TQWidget *container, int index ) const
-{
- ActionListIt it( *this );
- for (; it.current(); ++it )
- it.current()->plug( container, index++ );
-}
-
-void ActionList::unplug( TQWidget *container ) const
-{
- ActionListIt it( *this );
- for (; it.current(); ++it )
- it.current()->unplug( container );
-}
-
-ContainerNode::ContainerNode( TQWidget *_container, const TQString &_tagName,
- const TQString &_name, ContainerNode *_parent,
- KXMLGUIClient *_client, KXMLGUIBuilder *_builder,
- int id, const TQString &_mergingName,
- const TQString &_groupName, const TQStringList &customTags,
- const TQStringList &containerTags )
- : parent( _parent ), client( _client ), builder( _builder ),
- builderCustomTags( customTags ), builderContainerTags( containerTags ),
- container( _container ), containerId( id ), tagName( _tagName ), name( _name ),
- groupName( _groupName ), index( 0 ), mergingName( _mergingName )
-{
- children.setAutoDelete( true );
- clients.setAutoDelete( true );
-
- if ( parent )
- parent->children.append( this );
-}
-
-void ContainerNode::removeChild( ContainerNode *child )
-{
- MergingIndexList::Iterator mergingIt = findIndex( child->mergingName );
- adjustMergingIndices( -1, mergingIt );
- children.removeRef( child );
-}
-
-/*
- * Find a merging index with the given name. Used to find an index defined by <Merge name="blah"/>
- * or by a <DefineGroup name="foo" /> tag.
- */
-MergingIndexList::Iterator ContainerNode::findIndex( const TQString &name )
-{
- MergingIndexList::Iterator it( mergingIndices.begin() );
- MergingIndexList::Iterator end( mergingIndices.end() );
- for (; it != end; ++it )
- if ( (*it).mergingName == name )
- return it;
- return it;
-}
-
-/*
- * Check if the given container widget is a child of this node and return the node structure
- * if found.
- */
-ContainerNode *ContainerNode::findContainerNode( TQWidget *container )
-{
- ContainerNodeListIt it( children );
-
- for (; it.current(); ++it )
- if ( it.current()->container == container )
- return it.current();
-
- return 0L;
-}
-
-/*
- * Find a container recursively with the given name. Either compares _name with the
- * container's tag name or the value of the container's name attribute. Specified by
- * the tag bool .
- */
-ContainerNode *ContainerNode::findContainer( const TQString &_name, bool tag )
-{
- if ( ( tag && tagName == _name ) ||
- ( !tag && name == _name ) )
- return this;
-
- ContainerNodeListIt it( children );
- for (; it.current(); ++it )
- {
- ContainerNode *res = it.current()->findContainer( _name, tag );
- if ( res )
- return res;
- }
-
- return 0;
-}
-
-/*
- * Finds a child container node (not recursively) with the given name and tagname. Explicitly
- * leaves out container widgets specified in the exludeList . Also ensures that the containers
- * belongs to currClient.
- */
-ContainerNode *ContainerNode::findContainer( const TQString &name, const TQString &tagName,
- const TQPtrList<TQWidget> *excludeList,
- KXMLGUIClient * /*currClient*/ )
-{
- ContainerNode *res = 0L;
- ContainerNodeListIt nIt( children );
-
- if ( !name.isEmpty() )
- {
- for (; nIt.current(); ++nIt )
- if ( nIt.current()->name == name &&
- !excludeList->containsRef( nIt.current()->container ) )
- {
- res = nIt.current();
- break;
- }
-
- return res;
- }
-
- if ( !tagName.isEmpty() )
- for (; nIt.current(); ++nIt )
- {
- if ( nIt.current()->tagName == tagName &&
- !excludeList->containsRef( nIt.current()->container )
- /*
- * It is a bad idea to also compare the client, because
- * we don't want to do so in situations like these:
- *
- * <MenuBar>
- * <Menu>
- * ...
- *
- * other client:
- * <MenuBar>
- * <Menu>
- * ...
- *
- && nIt.current()->client == currClient )
- */
- )
- {
- res = nIt.current();
- break;
- }
- }
-
- return res;
-}
-
-ContainerClient *ContainerNode::findChildContainerClient( KXMLGUIClient *currentGUIClient,
- const TQString &groupName,
- const MergingIndexList::Iterator &mergingIdx )
-{
- if ( !clients.isEmpty() )
- {
- ContainerClientListIt clientIt( clients );
-
- for (; clientIt.current(); ++clientIt )
- if ( clientIt.current()->client == currentGUIClient )
- {
- if ( groupName.isEmpty() )
- return clientIt.current();
-
- if ( groupName == clientIt.current()->groupName )
- return clientIt.current();
- }
- }
-
- ContainerClient *client = new ContainerClient;
- client->client = currentGUIClient;
- client->groupName = groupName;
-
- if ( mergingIdx != mergingIndices.end() )
- client->mergingName = (*mergingIdx).mergingName;
-
- clients.append( client );
-
- return client;
-}
-
-void ContainerNode::plugActionList( BuildState &state )
-{
- MergingIndexList::Iterator mIt( mergingIndices.begin() );
- MergingIndexList::Iterator mEnd( mergingIndices.end() );
- for (; mIt != mEnd; ++mIt )
- plugActionList( state, mIt );
-
- TQPtrListIterator<ContainerNode> childIt( children );
- for (; childIt.current(); ++childIt )
- childIt.current()->plugActionList( state );
-}
-
-void ContainerNode::plugActionList( BuildState &state, const MergingIndexList::Iterator &mergingIdxIt )
-{
- static const TQString &tagActionList = KGlobal::staticQString( "actionlist" );
-
- MergingIndex mergingIdx = *mergingIdxIt;
-
- TQString k( mergingIdx.mergingName );
-
- if ( k.find( tagActionList ) == -1 )
- return;
-
- k = k.mid( tagActionList.length() );
-
- if ( mergingIdx.clientName != state.clientName )
- return;
-
- if ( k != state.actionListName )
- return;
-
- ContainerClient *client = findChildContainerClient( state.guiClient,
- TQString(),
- mergingIndices.end() );
-
- client->actionLists.insert( k, state.actionList );
-
- state.actionList.plug( container, mergingIdx.value );
-
- adjustMergingIndices( state.actionList.count(), mergingIdxIt );
-}
-
-void ContainerNode::unplugActionList( BuildState &state )
-{
- MergingIndexList::Iterator mIt( mergingIndices.begin() );
- MergingIndexList::Iterator mEnd( mergingIndices.end() );
- for (; mIt != mEnd; ++mIt )
- unplugActionList( state, mIt );
-
- TQPtrListIterator<ContainerNode> childIt( children );
- for (; childIt.current(); ++childIt )
- childIt.current()->unplugActionList( state );
-}
-
-void ContainerNode::unplugActionList( BuildState &state, const MergingIndexList::Iterator &mergingIdxIt )
-{
- static const TQString &tagActionList = KGlobal::staticQString( "actionlist" );
-
- MergingIndex mergingIdx = *mergingIdxIt;
-
- TQString k = mergingIdx.mergingName;
-
- if ( k.find( tagActionList ) == -1 )
- return;
-
- k = k.mid( tagActionList.length() );
-
- if ( mergingIdx.clientName != state.clientName )
- return;
-
- if ( k != state.actionListName )
- return;
-
- ContainerClient *client = findChildContainerClient( state.guiClient,
- TQString(),
- mergingIndices.end() );
-
- ActionListMap::Iterator lIt( client->actionLists.find( k ) );
- if ( lIt == client->actionLists.end() )
- return;
-
- lIt.data().unplug( container );
-
- adjustMergingIndices( -int(lIt.data().count()), mergingIdxIt );
-
- client->actionLists.remove( lIt );
-}
-
-void ContainerNode::adjustMergingIndices( int offset,
- const MergingIndexList::Iterator &it )
-{
- MergingIndexList::Iterator mergingIt = it;
- MergingIndexList::Iterator mergingEnd = mergingIndices.end();
-
- for (; mergingIt != mergingEnd; ++mergingIt )
- (*mergingIt).value += offset;
-
- index += offset;
-}
-
-bool ContainerNode::destruct( TQDomElement element, BuildState &state )
-{
- destructChildren( element, state );
-
- unplugActions( state );
-
- // remove all merging indices the client defined
- MergingIndexList::Iterator cmIt = mergingIndices.begin();
- while ( cmIt != mergingIndices.end() )
- if ( (*cmIt).clientName == state.clientName )
- cmIt = mergingIndices.remove( cmIt );
- else
- ++cmIt;
-
- // ### check for merging index count, too?
- if ( clients.count() == 0 && children.count() == 0 && container &&
- client == state.guiClient )
- {
- TQWidget *parentContainer = 0L;
-
- if ( parent && parent->container )
- parentContainer = parent->container;
-
- assert( builder );
-
- builder->removeContainer( container, parentContainer, element, containerId );
-
- client = 0L;
-
- return true;
- }
-
- if ( client == state.guiClient )
- client = 0L;
-
- return false;
-
-}
-
-void ContainerNode::destructChildren( const TQDomElement &element, BuildState &state )
-{
- TQPtrListIterator<ContainerNode> childIt( children );
- while ( childIt.current() )
- {
- ContainerNode *childNode = childIt.current();
-
- TQDomElement childElement = findElementForChild( element, childNode );
-
- // destruct returns true in case the container really got deleted
- if ( childNode->destruct( childElement, state ) )
- removeChild( childNode );
- else
- ++childIt;
- }
-}
-
-TQDomElement ContainerNode::findElementForChild( const TQDomElement &baseElement,
- ContainerNode *childNode )
-{
- static const TQString &attrName = KGlobal::staticQString( "name" );
-
- // ### slow
- for ( TQDomNode n = baseElement.firstChild(); !n.isNull();
- n = n.nextSibling() )
- {
- TQDomElement e = n.toElement();
- if ( e.tagName().lower() == childNode->tagName &&
- e.attribute( attrName ) == childNode->name )
- return e;
- }
-
- return TQDomElement();
-}
-
-void ContainerNode::unplugActions( BuildState &state )
-{
- if ( !container )
- return;
-
- ContainerClientListIt clientIt( clients );
-
- /*
- Disabled because it means in KToolBar::saveState isHidden is always true then,
- which is clearly wrong.
-
- if ( clients.count() == 1 && clientIt.current()->client == client &&
- client == state.guiClient )
- container->hide(); // this container is going to die, that's for sure.
- // in this case let's just hide it, which makes the
- // destruction faster
- */
-
- while ( clientIt.current() )
- //only unplug the actions of the client we want to remove, as the container might be owned
- //by a different client
- if ( clientIt.current()->client == state.guiClient )
- {
- unplugClient( clientIt.current() );
- clients.removeRef( clientIt.current() );
- }
- else
- ++clientIt;
-}
-
-void ContainerNode::unplugClient( ContainerClient *client )
-{
- static const TQString &tagActionList = KGlobal::staticQString( "actionlist" );
-
- assert( builder );
-
- // now quickly remove all custom elements (i.e. separators) and unplug all actions
-
- TQValueList<int>::ConstIterator custIt = client->customElements.begin();
- TQValueList<int>::ConstIterator custEnd = client->customElements.end();
- for (; custIt != custEnd; ++custIt )
- builder->removeCustomElement( container, *custIt );
-
- client->actions.unplug( container );
-
- // now adjust all merging indices
-
- MergingIndexList::Iterator mergingIt = findIndex( client->mergingName );
-
- adjustMergingIndices( - int( client->actions.count()
- + client->customElements.count() ),
- mergingIt );
-
- // unplug all actionslists
-
- ActionListMap::ConstIterator alIt = client->actionLists.begin();
- ActionListMap::ConstIterator alEnd = client->actionLists.end();
- for (; alIt != alEnd; ++alIt )
- {
- alIt.data().unplug( container );
-
- // construct the merging index key (i.e. like named merging) , find the
- // corresponding merging index and adjust all indices
- TQString mergingKey = alIt.key();
- mergingKey.prepend( tagActionList );
-
- MergingIndexList::Iterator mIt = findIndex( mergingKey );
- if ( mIt == mergingIndices.end() )
- continue;
-
- adjustMergingIndices( -int(alIt.data().count()), mIt );
-
- // remove the actionlists' merging index
- // ### still needed? we clean up below anyway?
- mergingIndices.remove( mIt );
- }
-}
-
-void ContainerNode::reset()
-{
- TQPtrListIterator<ContainerNode> childIt( children );
- for (; childIt.current(); ++childIt )
- childIt.current()->reset();
-
- if ( client )
- client->setFactory( 0L );
-}
-
-int ContainerNode::calcMergingIndex( const TQString &mergingName,
- MergingIndexList::Iterator &it,
- BuildState &state,
- bool ignoreDefaultMergingIndex )
-{
- MergingIndexList::Iterator mergingIt;
-
- if ( mergingName.isEmpty() )
- mergingIt = findIndex( state.clientName );
- else
- mergingIt = findIndex( mergingName );
-
- MergingIndexList::Iterator mergingEnd = mergingIndices.end();
- it = mergingEnd;
-
- if ( ( mergingIt == mergingEnd && state.currentDefaultMergingIt == mergingEnd ) ||
- ignoreDefaultMergingIndex )
- return index;
-
- if ( mergingIt != mergingEnd )
- it = mergingIt;
- else
- it = state.currentDefaultMergingIt;
-
- return (*it).value;
-}
-
-int BuildHelper::calcMergingIndex( const TQDomElement &element, MergingIndexList::Iterator &it, TQString &group )
-{
- static const TQString &attrGroup = KGlobal::staticQString( "group" );
-
- bool haveGroup = false;
- group = element.attribute( attrGroup );
- if ( !group.isEmpty() ) {
- group.prepend( attrGroup );
- haveGroup = true;
- }
-
- int idx;
- if ( haveGroup )
- idx = parentNode->calcMergingIndex( group, it, m_state, ignoreDefaultMergingIndex );
- else if ( m_state.currentClientMergingIt == parentNode->mergingIndices.end() )
- idx = parentNode->index;
- else
- idx = (*m_state.currentClientMergingIt).value;
-
- return idx;
-}
-
-BuildHelper::BuildHelper( BuildState &state, ContainerNode *node )
- : containerClient( 0 ), ignoreDefaultMergingIndex( false ), m_state( state ),
- parentNode( node )
-{
- static const TQString &defaultMergingName = KGlobal::staticQString( "<default>" );
-
- // create a list of supported container and custom tags
- customTags = m_state.builderCustomTags;
- containerTags = m_state.builderContainerTags;
-
- if ( parentNode->builder != m_state.builder )
- {
- customTags += parentNode->builderCustomTags;
- containerTags += parentNode->builderContainerTags;
- }
-
- if ( m_state.clientBuilder ) {
- customTags = m_state.clientBuilderCustomTags + customTags;
- containerTags = m_state.clientBuilderContainerTags + containerTags;
- }
-
- m_state.currentDefaultMergingIt = parentNode->findIndex( defaultMergingName );
- parentNode->calcMergingIndex( TQString(), m_state.currentClientMergingIt,
- m_state, /*ignoreDefaultMergingIndex*/ false );
-}
-
-void BuildHelper::build( const TQDomElement &element )
-{
- for (TQDomNode n = element.firstChild(); !n.isNull(); n = n.nextSibling() )
- {
- TQDomElement e = n.toElement();
- if (e.isNull()) continue;
- processElement( e );
- }
-}
-
-void BuildHelper::processElement( const TQDomElement &e )
-{
- // some often used QStrings
- static const TQString &tagAction = KGlobal::staticQString( "action" );
- static const TQString &tagMerge = KGlobal::staticQString( "merge" );
- static const TQString &tagState = KGlobal::staticQString( "state" );
- static const TQString &tagDefineGroup = KGlobal::staticQString( "definegroup" );
- static const TQString &tagActionList = KGlobal::staticQString( "actionlist" );
- static const TQString &attrName = KGlobal::staticQString( "name" );
-
- TQString tag( e.tagName().lower() );
- TQString currName( e.attribute( attrName ) );
-
- bool isActionTag = ( tag == tagAction );
-
- if ( isActionTag || customTags.findIndex( tag ) != -1 )
- processActionOrCustomElement( e, isActionTag );
- else if ( containerTags.findIndex( tag ) != -1 )
- processContainerElement( e, tag, currName );
- else if ( tag == tagMerge || tag == tagDefineGroup || tag == tagActionList )
- processMergeElement( tag, currName, e );
- else if ( tag == tagState )
- processStateElement( e );
-}
-
-void BuildHelper::processActionOrCustomElement( const TQDomElement &e, bool isActionTag )
-{
- if ( !parentNode->container )
- return;
-
- MergingIndexList::Iterator it( m_state.currentClientMergingIt );
-
- TQString group;
- int idx = calcMergingIndex( e, it, group );
-
- containerClient = parentNode->findChildContainerClient( m_state.guiClient, group, it );
-
- bool guiElementCreated = false;
- if ( isActionTag )
- guiElementCreated = processActionElement( e, idx );
- else
- guiElementCreated = processCustomElement( e, idx );
-
- if ( guiElementCreated )
- // adjust any following merging indices and the current running index for the container
- parentNode->adjustMergingIndices( 1, it );
-}
-
-bool BuildHelper::processActionElement( const TQDomElement &e, int idx )
-{
- assert( m_state.guiClient );
-
- // look up the action and plug it in
- KAction *action = m_state.guiClient->action( e );
-
- //kdDebug() << "BuildHelper::processActionElement " << e.attribute( "name" ) << " -> " << action << " (in " << m_state.guiClient->actionCollection() << ")" << endl;
- if ( !action )
- return false;
-
- action->plug( parentNode->container, idx );
-
- // save a reference to the plugged action, in order to properly unplug it afterwards.
- containerClient->actions.append( action );
-
- return true;
-}
-
-bool BuildHelper::processCustomElement( const TQDomElement &e, int idx )
-{
- assert( parentNode->builder );
-
- int id = parentNode->builder->createCustomElement( parentNode->container, idx, e );
- if ( id == 0 )
- return false;
-
- containerClient->customElements.append( id );
- return true;
-}
-
-void BuildHelper::processStateElement( const TQDomElement &element )
-{
- TQString stateName = element.attribute( "name" );
-
- if ( !stateName || !stateName.length() ) return;
-
- for (TQDomNode n = element.firstChild(); !n.isNull(); n = n.nextSibling() )
- {
- TQDomElement e = n.toElement();
- if (e.isNull()) continue;
-
- TQString tagName = e.tagName().lower();
-
- if ( tagName != "enable" && tagName != "disable" )
- continue;
-
- bool processingActionsToEnable = (tagName == "enable");
-
- // process action names
- for (TQDomNode n2 = n.firstChild(); !n2.isNull(); n2 = n2.nextSibling() )
- {
- TQDomElement actionEl = n2.toElement();
- if ( actionEl.tagName().lower() != "action" ) continue;
-
- TQString actionName = actionEl.attribute( "name" );
- if ( !actionName || !actionName.length() ) return;
-
- if ( processingActionsToEnable )
- m_state.guiClient->addStateActionEnabled( stateName, actionName );
- else
- m_state.guiClient->addStateActionDisabled( stateName, actionName );
-
- }
- }
-}
-
-void BuildHelper::processMergeElement( const TQString &tag, const TQString &name, const TQDomElement &e )
-{
- static const TQString &tagDefineGroup = KGlobal::staticQString( "definegroup" );
- static const TQString &tagActionList = KGlobal::staticQString( "actionlist" );
- static const TQString &defaultMergingName = KGlobal::staticQString( "<default>" );
- static const TQString &attrGroup = KGlobal::staticQString( "group" );
-
- TQString mergingName( name );
- if ( mergingName.isEmpty() )
- {
- if ( tag == tagDefineGroup )
- {
- kdError(1000) << "cannot define group without name!" << endl;
- return;
- }
- if ( tag == tagActionList )
- {
- kdError(1000) << "cannot define actionlist without name!" << endl;
- return;
- }
- mergingName = defaultMergingName;
- }
-
- if ( tag == tagDefineGroup )
- mergingName.prepend( attrGroup ); //avoid possible name clashes by prepending
- // "group" to group definitions
- else if ( tag == tagActionList )
- mergingName.prepend( tagActionList );
-
- if ( parentNode->findIndex( mergingName ) != parentNode->mergingIndices.end() )
- return; //do not allow the redefinition of merging indices!
-
- MergingIndexList::Iterator mIt( parentNode->mergingIndices.end() );
-
- TQString group( e.attribute( attrGroup ) );
- if ( !group.isEmpty() )
- group.prepend( attrGroup );
-
- // calculate the index of the new merging index. Usually this does not need any calculation,
- // we just want the last available index (i.e. append) . But in case the <Merge> tag appears
- // "inside" another <Merge> tag from a previously build client, then we have to use the
- // "parent's" index. That's why we call calcMergingIndex here.
- MergingIndex newIdx;
- newIdx.value = parentNode->calcMergingIndex( group, mIt, m_state, ignoreDefaultMergingIndex );
- newIdx.mergingName = mergingName;
- newIdx.clientName = m_state.clientName;
-
- // if that merging index is "inside" another one, then append it right after the "parent" .
- if ( mIt != parentNode->mergingIndices.end() )
- parentNode->mergingIndices.insert( ++mIt, newIdx );
- else
- parentNode->mergingIndices.append( newIdx );
-
- if ( mergingName == defaultMergingName )
-
- ignoreDefaultMergingIndex = true;
-
- // re-calculate the running default and client merging indices.
- m_state.currentDefaultMergingIt = parentNode->findIndex( defaultMergingName );
- parentNode->calcMergingIndex( TQString(), m_state.currentClientMergingIt,
- m_state, ignoreDefaultMergingIndex );
-}
-
-void BuildHelper::processContainerElement( const TQDomElement &e, const TQString &tag,
- const TQString &name )
-{
- static const TQString &defaultMergingName = KGlobal::staticQString( "<default>" );
-
- ContainerNode *containerNode = parentNode->findContainer( name, tag,
- &containerList,
- m_state.guiClient );
-
- if ( !containerNode )
- {
- MergingIndexList::Iterator it( m_state.currentClientMergingIt );
- TQString group;
-
- int idx = calcMergingIndex( e, it, group );
-
- int id;
-
- KXMLGUIBuilder *builder;
-
- TQWidget *container = createContainer( parentNode->container, idx, e, id, &builder );
-
- // no container? (probably some <text> tag or so ;-)
- if ( !container )
- return;
-
- parentNode->adjustMergingIndices( 1, it );
-
- assert( !parentNode->findContainerNode( container ) );
-
- containerList.append( container );
-
- TQString mergingName;
- if ( it != parentNode->mergingIndices.end() )
- mergingName = (*it).mergingName;
-
- TQStringList cusTags = m_state.builderCustomTags;
- TQStringList conTags = m_state.builderContainerTags;
- if ( builder != m_state.builder )
- {
- cusTags = m_state.clientBuilderCustomTags;
- conTags = m_state.clientBuilderContainerTags;
- }
-
- containerNode = new ContainerNode( container, tag, name, parentNode,
- m_state.guiClient, builder, id,
- mergingName, group, cusTags, conTags );
- }
-
- BuildHelper( m_state, containerNode ).build( e );
-
- // and re-calculate running values, for better performance
- m_state.currentDefaultMergingIt = parentNode->findIndex( defaultMergingName );
- parentNode->calcMergingIndex( TQString(), m_state.currentClientMergingIt,
- m_state, ignoreDefaultMergingIndex );
-}
-
-TQWidget *BuildHelper::createContainer( TQWidget *parent, int index,
- const TQDomElement &element, int &id,
- KXMLGUIBuilder **builder )
-{
- TQWidget *res = 0L;
-
- if ( m_state.clientBuilder )
- {
- res = m_state.clientBuilder->createContainer( parent, index, element, id );
-
- if ( res )
- {
- *builder = m_state.clientBuilder;
- return res;
- }
- }
-
- KInstance *oldInstance = m_state.builder->builderInstance();
- KXMLGUIClient *oldClient = m_state.builder->builderClient();
-
- m_state.builder->setBuilderClient( m_state.guiClient );
-
- res = m_state.builder->createContainer( parent, index, element, id );
-
- m_state.builder->setBuilderInstance( oldInstance );
- m_state.builder->setBuilderClient( oldClient );
-
- if ( res )
- *builder = m_state.builder;
-
- return res;
-}
-
-void BuildState::reset()
-{
- clientName = TQString();
- actionListName = TQString();
- actionList.clear();
- guiClient = 0;
- clientBuilder = 0;
-
- currentDefaultMergingIt = currentClientMergingIt = MergingIndexList::Iterator();
-}
-
-/* vim: et sw=4
- */