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.
kvirc/src/kvirc/kvs/kvi_kvs_treenode_arrayrefer...

108 lines
3.2 KiB

//=============================================================================
//
// File : kvi_kvs_treenode_arrayreferenceassert.cpp
// Created on Thu 16 Oct 2003 23:46:12 by Szymon Stefanek
//
// This file is part of the KVIrc IRC client distribution
// Copyright (C) 2003 Szymon Stefanek <pragma at kvirc dot net>
//
// 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_arrayreferenceassert.h"
#include "kvi_kvs_rwevaluationresult.h"
#include "kvi_kvs_runtimecontext.h"
#include "kvi_kvs_variant.h"
#include "kvi_locale.h"
#include "kvi_kvs_object.h"
KviKvsTreeNodeArrayReferenceAssert::KviKvsTreeNodeArrayReferenceAssert(const TQChar * pLocation,KviKvsTreeNodeData * pSource)
: KviKvsTreeNodeIndirectData(pLocation,pSource)
{
}
KviKvsTreeNodeArrayReferenceAssert::~KviKvsTreeNodeArrayReferenceAssert()
{
}
bool KviKvsTreeNodeArrayReferenceAssert::isReadOnly()
{
return m_pSource->isReadOnly();
}
void KviKvsTreeNodeArrayReferenceAssert::contextDescription(TQString &szBuffer)
{
szBuffer = "Array Reference Assert";
}
void KviKvsTreeNodeArrayReferenceAssert::dump(const char * prefix)
{
#ifdef COMPILE_NEW_KVS
tqDebug("%s ArrayReferenceAssert",prefix);
#endif
}
bool KviKvsTreeNodeArrayReferenceAssert::evaluateReadOnlyInObjectScope(KviKvsObject *o,KviKvsRunTimeContext * c,KviKvsVariant * pBuffer)
{
#ifdef COMPILE_NEW_KVS
if(o)
{
if(!m_pSource->evaluateReadOnlyInObjectScope(o,c,pBuffer))return false;
} else {
if(!m_pSource->evaluateReadOnly(c,pBuffer))return false;
}
if(!pBuffer->isArray())
{
if(!pBuffer->isNothing())
{
TQString szType;
pBuffer->getTypeName(szType);
c->error(this,__tr2qs("Array reference assert failed: the variable evaluated to type '%Q'"),&szType);
return false;
}
}
#endif
return true;
}
KviKvsRWEvaluationResult * KviKvsTreeNodeArrayReferenceAssert::evaluateReadWriteInObjectScope(KviKvsObject *o,KviKvsRunTimeContext * c)
{
#ifdef COMPILE_NEW_KVS
KviKvsRWEvaluationResult * r;
if(o)r = m_pSource->evaluateReadWriteInObjectScope(o,c);
else r = m_pSource->evaluateReadWrite(c);
if(!r)return 0;
return r;
#else
return 0;
#endif
}
bool KviKvsTreeNodeArrayReferenceAssert::evaluateReadOnly(KviKvsRunTimeContext * c,KviKvsVariant * pBuffer)
{
return evaluateReadOnlyInObjectScope(0,c,pBuffer);
}
KviKvsRWEvaluationResult * KviKvsTreeNodeArrayReferenceAssert::evaluateReadWrite(KviKvsRunTimeContext * c)
{
return evaluateReadWriteInObjectScope(0,c);
}