//============================================================================= // // File : kvi_kvs_treenode_instructionblock.cpp // Created on Thu 09 Oct 2003 01:44:31 by Szymon Stefanek // // This file is part of the KVIrc IRC client distribution // Copyright (C) 2003 Szymon Stefanek // // This program is FREE software. You can redistribute it and/or // modify it under the terms of the GNU General Public License // as published by the Free Software Foundation; either version 2 // of the License, or (at your opinion) any later version. // // 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 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. // //============================================================================= #define __KVIRC__ #include "kvi_kvs_treenode_instructionblock.h" #include "kvi_kvs_runtimecontext.h" KviKvsTreeNodeInstructionBlock::KviKvsTreeNodeInstructionBlock(const TQChar * pLocation) : KviKvsTreeNodeInstruction(pLocation) { m_pInstructionList = new KviPointerList; m_pInstructionList->setAutoDelete(true); } KviKvsTreeNodeInstructionBlock::~KviKvsTreeNodeInstructionBlock() { delete m_pInstructionList; } void KviKvsTreeNodeInstructionBlock::contextDescription(TQString &szBuffer) { szBuffer = "Instruction Block"; } void KviKvsTreeNodeInstructionBlock::dump(const char * prefix) { tqDebug("%s InstructionBlock",prefix); TQString tmp = prefix; tmp.append(" "); for(KviKvsTreeNodeInstruction * i = m_pInstructionList->first();i;i = m_pInstructionList->next()) { i->dump(tmp.utf8().data()); } } KviKvsTreeNodeInstruction * KviKvsTreeNodeInstructionBlock::releaseFirst() { m_pInstructionList->setAutoDelete(false); KviKvsTreeNodeInstruction * i = m_pInstructionList->first(); if(i) { i->setParent(0); m_pInstructionList->removeFirst(); } m_pInstructionList->setAutoDelete(true); return i; } void KviKvsTreeNodeInstructionBlock::addInstruction(KviKvsTreeNodeInstruction * i) { m_pInstructionList->append(i); i->setParent(this); } bool KviKvsTreeNodeInstructionBlock::execute(KviKvsRunTimeContext * c) { // to accomodate recursion we need to use an iterator here KviPointerListIterator it(*m_pInstructionList); while(KviKvsTreeNodeInstruction * i = it.current()) { if(!i->execute(c))return false; ++it; } return true; }