Files
libreoffice/autodoc/source/parser/inc/semantic/callf.hxx
Jens-Heiner Rechtien 45ee788a4d INTEGRATION: CWS adc18 (1.4.56); FILE MERGED
2007/10/18 15:23:19 np 1.4.56.1: #i81775#
2007-11-02 16:03:44 +00:00

296 lines
7.3 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: callf.hxx,v $
*
* $Revision: 1.5 $
*
* last change: $Author: hr $ $Date: 2007-11-02 17:03:44 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
************************************************************************/
#ifndef ADC_CPP_CALLF_HXX
#define ADC_CPP_CALLF_HXX
// USED SERVICES
/** This represents a function to be called, if a specific kind of token
arrives in the semantic parser.
@descr This class is only to be used as member of PeStatus<PE>.
@template PE
The owning ParseEnvironment.
@see PeStatus, ParseEnvironment
*/
template <class PE>
class CallFunction
{
public:
typedef void (PE::*F_Tok)(const char *);
CallFunction(
F_Tok i_f2Call,
INT16 i_nTokType );
F_Tok GetF() const;
INT16 TokType() const;
private:
// DATA
F_Tok f2Call;
INT16 nTokType;
};
/** One state within a ParseEnvironment.
@template PE
The owning ParseEnvironment.
*/
template <class PE>
class PeStatus
{
public:
typedef typename CallFunction<PE>::F_Tok F_Tok;
PeStatus(
PE & i_rMyPE,
uintt i_nSize,
F_Tok * i_pFuncArray,
INT16 * i_pTokTypeArray,
F_Tok i_pDefault );
virtual ~PeStatus();
virtual void Call_Handler(
INT16 i_nTokTypeId,
const char * i_sTokenText ) const;
private:
bool CheckForCall(
uintt i_nPos,
INT16 i_nTokTypeId,
const char * i_sTokenText ) const;
PE * pMyPE;
std::vector< CallFunction<PE> >
aBranches;
F_Tok fDefault;
};
template <class PE>
class PeStatusArray
{
public:
typedef typename PE::E_State State;
PeStatusArray();
void InsertState(
State i_ePosition,
DYN PeStatus<PE> & let_drState );
~PeStatusArray();
const PeStatus<PE> &
operator[](
State i_ePosition ) const;
void SetCur(
State i_eCurState );
const PeStatus<PE> &
Cur() const;
private:
DYN PeStatus<PE> * aStati[PE::size_of_states];
State eState;
};
// IMPLEMENTATION
// CallFunction
template <class PE>
CallFunction<PE>::CallFunction( F_Tok i_f2Call,
INT16 i_nTokType )
: f2Call(i_f2Call),
nTokType(i_nTokType)
{
}
template <class PE>
inline typename CallFunction<PE>::F_Tok
CallFunction<PE>::GetF() const
{
return f2Call;
}
template <class PE>
inline INT16
CallFunction<PE>::TokType() const
{
return nTokType;
}
// PeStatus
template <class PE>
PeStatus<PE>::PeStatus( PE & i_rMyPE,
uintt i_nSize,
F_Tok * i_pFuncArray,
INT16 * i_pTokTypeArray,
F_Tok i_fDefault )
: pMyPE(&i_rMyPE),
fDefault(i_fDefault)
{
aBranches.reserve(i_nSize);
for ( uintt i = 0; i < i_nSize; ++i )
{
// csv_assert(i > 0 ? i_pTokTypeArray[i] > i_pTokTypeArray[i-1] : true);
aBranches.push_back( CallFunction<PE>( i_pFuncArray[i], i_pTokTypeArray[i]) );
} // end for
}
template <class PE>
PeStatus<PE>::~PeStatus()
{
}
template <class PE>
void
PeStatus<PE>::Call_Handler( INT16 i_nTokTypeId,
const char * i_sTokenText ) const
{
uintt nSize = aBranches.size();
uintt nPos = nSize / 2;
if ( i_nTokTypeId < aBranches[nPos].TokType() )
{
for ( --nPos; intt(nPos) >= 0; --nPos )
{
if (CheckForCall(nPos, i_nTokTypeId, i_sTokenText))
return;
}
}
else
{
for ( ; nPos < nSize; ++nPos )
{
if (CheckForCall(nPos, i_nTokTypeId, i_sTokenText))
return;
}
}
(pMyPE->*fDefault)(i_sTokenText);
}
template <class PE>
bool
PeStatus<PE>::CheckForCall( uintt i_nPos,
INT16 i_nTokTypeId,
const char * i_sTokenText ) const
{
if ( aBranches[i_nPos].TokType() == i_nTokTypeId )
{
(pMyPE->*aBranches[i_nPos].GetF())(i_sTokenText);
return true;
}
return false;
}
// PeStatusArray
template <class PE>
PeStatusArray<PE>::PeStatusArray()
: eState(PE::size_of_states)
{
memset(aStati, 0, sizeof aStati);
}
template <class PE>
void
PeStatusArray<PE>::InsertState( State i_ePosition,
DYN PeStatus<PE> & let_drState )
{
csv_assert(aStati[i_ePosition] == 0);
aStati[i_ePosition] = &let_drState;
}
template <class PE>
PeStatusArray<PE>::~PeStatusArray()
{
int i_max = PE::size_of_states;
for (int i = 0; i < i_max; i++)
{
delete aStati[i];
} // end for
}
template <class PE>
inline const PeStatus<PE> &
PeStatusArray<PE>::operator[]( State i_ePosition ) const
{
csv_assert( uintt(i_ePosition) < PE::size_of_states );
csv_assert( aStati[i_ePosition] != 0 );
return *aStati[i_ePosition];
}
template <class PE>
inline void
PeStatusArray<PE>::SetCur( State i_eCurState )
{
eState = i_eCurState;
}
template <class PE>
const PeStatus<PE> &
PeStatusArray<PE>::Cur() const
{
return (*this)[eState];
}
#define SEMPARSE_CREATE_STATUS(penv, state, default_function) \
pStati->InsertState( state, \
*new PeStatus<penv>( \
*this, \
sizeof( stateT_##state ) / sizeof (INT16), \
stateF_##state, \
stateT_##state, \
&penv::default_function ) )
#endif