2001-03-15 05:30:43 -06:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-11 04:26:05 -05:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2001-03-15 05:30:43 -06:00
|
|
|
*
|
2010-02-12 08:01:35 -06:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2001-03-15 05:30:43 -06:00
|
|
|
*
|
2008-04-11 04:26:05 -05:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2001-03-15 05:30:43 -06:00
|
|
|
*
|
2008-04-11 04:26:05 -05:00
|
|
|
* This file is part of OpenOffice.org.
|
2001-03-15 05:30:43 -06:00
|
|
|
*
|
2008-04-11 04:26:05 -05:00
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
2001-03-15 05:30:43 -06:00
|
|
|
*
|
2008-04-11 04:26:05 -05:00
|
|
|
* OpenOffice.org 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 version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
2001-03-15 05:30:43 -06:00
|
|
|
*
|
2008-04-11 04:26:05 -05:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2001-03-15 05:30:43 -06:00
|
|
|
*
|
|
|
|
************************************************************************/
|
2006-09-17 02:10:45 -05:00
|
|
|
|
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
|
|
#include "precompiled_idlc.hxx"
|
2001-03-15 05:30:43 -06:00
|
|
|
#include <idlc/astarray.hxx>
|
|
|
|
|
|
|
|
using namespace ::rtl;
|
|
|
|
|
|
|
|
AstArray::AstArray(const OString& name, AstType* pType, const ExprList& rDimExpr, AstScope* pScope)
|
|
|
|
: AstType(NT_array, name, pScope)
|
|
|
|
, m_pType(pType)
|
2004-06-17 06:48:10 -05:00
|
|
|
, m_dimension((sal_uInt32)(rDimExpr.size()))
|
2001-03-15 05:30:43 -06:00
|
|
|
, m_dimExpressions(rDimExpr)
|
|
|
|
{
|
|
|
|
if ( m_pType )
|
|
|
|
setName(makeName());
|
|
|
|
}
|
|
|
|
|
|
|
|
AstArray::AstArray(AstType* pType, const ExprList& rDimExpr, AstScope* pScope)
|
|
|
|
: AstType(NT_array, OString("arrary_"), pScope)
|
|
|
|
, m_pType(pType)
|
2004-06-17 06:48:10 -05:00
|
|
|
, m_dimension((sal_uInt32)(rDimExpr.size()))
|
2001-03-15 05:30:43 -06:00
|
|
|
, m_dimExpressions(rDimExpr)
|
|
|
|
{
|
|
|
|
if ( m_pType )
|
|
|
|
setName(makeName());
|
|
|
|
}
|
|
|
|
|
|
|
|
OString AstArray::makeName()
|
|
|
|
{
|
|
|
|
if ( m_pType )
|
|
|
|
{
|
|
|
|
OString name(m_pType->getScopedName());
|
|
|
|
OString openBracket("[");
|
|
|
|
OString closeBracket("]");
|
|
|
|
ExprList::iterator iter = m_dimExpressions.begin();
|
|
|
|
ExprList::iterator end = m_dimExpressions.end();
|
|
|
|
|
|
|
|
while ( iter != end )
|
|
|
|
{
|
|
|
|
name += openBracket;
|
|
|
|
name += (*iter)->toString();
|
|
|
|
name += closeBracket;
|
2001-04-11 01:29:27 -05:00
|
|
|
++iter;
|
2001-03-15 05:30:43 -06:00
|
|
|
}
|
|
|
|
return name;
|
|
|
|
}
|
|
|
|
return OString();
|
|
|
|
}
|