You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kbfx/src/kbfxplasmacanvasstack.cpp

180 lines
3.3 KiB

/*
* Copyright (C) 2006
* Siraj Razick <siraj@kdemail.net>
* PhobosK <phobosk@mail.kbfx.net>
* see Also AUTHORS
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU Library General Public License version 2 as
* published by the Free Software Foundation
*
* This program 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 General Public License for more details
*
* You should have received a copy of the GNU Library General Public
* License along with this program; if not, write to the
* Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
#include "kbfxplasmacanvasstack.h"
KbfxPlasmaCanvasStack::KbfxPlasmaCanvasStack()
{
m_current= 0;//set to NULL
m_count = 0;
m_height = 0;
m_width = 0;
m_groupChain.setAutoDelete ( TRUE );
m_name = "Unset:Faulty plugin";
}
KbfxPlasmaCanvasStack::~KbfxPlasmaCanvasStack()
{
//TODO: needs to manage memory here
for ( uint i = 0; i < ( uint ) m_count; ++i )
{
m_groupChain.at ( i )->~KbfxPlasmaCanvasGroupView();
m_groupChain.remove ( m_groupChain.at ( i ) );
}
Dict::Iterator it;
for ( it = m_dict.begin();it != m_dict.end();++it )
{
m_dict.remove ( it );
}
delete m_current;
}
void
KbfxPlasmaCanvasStack::raise ( uint id )
{
KbfxPlasmaCanvasGroupView * _gvPtr = m_groupChain.at ( id );
if ( !_gvPtr )
tqDebug ( "Error item not in Stack" );
else
{
for ( uint i = 0; i < m_groupChain.count (); ++i )
{
m_groupChain.at ( i )->hide();
}
m_height = _gvPtr->height();
_gvPtr->show();
}
}
bool
KbfxPlasmaCanvasStack::contains ( TQString name )
{
//FIXME:Depricated Data Structure Needs fixing
if ( m_dict.contains ( name ) == true )
return true;
else
return false;
}
void
KbfxPlasmaCanvasStack::addGroup ( KbfxPlasmaCanvasGroupView * gPtr )
{
if ( gPtr == NULL )
{
tqDebug
( "KbfxPlasmaCanvasStack.cpp:34:Null Pointer Passed to addGroup()" );
return;
}
else
{
m_groupChain.append ( gPtr );
m_height = gPtr->height();
m_width = gPtr->width();
// KbfxPlasmaDataStack stackinfo;
/// stackinfo
m_dict[gPtr->name() ] = m_count;
m_count++;
}
}
KbfxPlasmaCanvasStack::Dict
KbfxPlasmaCanvasStack::getDict()
{
return m_dict;
}
void
KbfxPlasmaCanvasStack::hide()
{
for ( uint i = 0; i < m_groupChain.count (); ++i )
{
m_groupChain.at ( i )->hide();
}
}
void
KbfxPlasmaCanvasStack::raiseByName ( TQString name )
{
for ( uint i = 0; i < m_groupChain.count (); ++i )
{
m_groupChain.at ( i )->hide();
}
for ( uint i = 0; i < m_groupChain.count (); ++i )
{
if ( m_groupChain.at ( i )->name() == name )
{
m_groupChain.at ( i )->show();
m_height = m_groupChain.at ( i )->height();
}
}
}
KbfxPlasmaCanvasGroupView *
KbfxPlasmaCanvasStack::activeViewByName ( TQString name )
{
for ( uint i = 0; i < m_groupChain.count (); ++i )
{
if ( m_groupChain.at ( i )->name() == name )
{
return m_groupChain.at ( i );
}
}
return new KbfxPlasmaCanvasGroupView();
}
TQString
KbfxPlasmaCanvasStack::getItemName ( int id )
{
return m_groupChain.at ( id )->name();
}
#include "kbfxplasmacanvasstack.moc"