office-gobmx/autodoc/source/display/html/aryattrs.cxx
Sebastian Spaeth e9a59da46a Add vim/emacs modelines to all source files
Fixes #fdo30794
Based on bin/add-modelines script (originally posted in mail
1286706307.1871.1399280959@webmail.messagingengine.com)

Signed-off-by: Sebastian Spaeth <Sebastian@SSpaeth.de>
2010-10-13 10:58:04 +02:00

251 lines
6.9 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* This file is part of OpenOffice.org.
*
* 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.
*
* 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).
*
* 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.
*
************************************************************************/
#include <precomp.h>
#include "aryattrs.hxx"
// NOT FULLY DEFINED SERVICES
#include <ary/getncast.hxx>
#include <ary/cpp/c_class.hxx>
#include <ary/cpp/c_enum.hxx>
#include <ary/cpp/c_funct.hxx>
#include <ary/cpp/c_gate.hxx>
#include <ary/cpp/c_namesp.hxx>
#include <ary/cpp/cp_ce.hxx>
#include <ary/cpp/cp_type.hxx>
#include "strconst.hxx"
//******************** HtmlDisplay_Impl *********************//
const char *
Get_ClassTypeKey( const ary::cpp::Class & i_rClass )
{
return i_rClass.ClassKey() == ary::cpp::CK_class
? C_sHFTypeTitle_Class
: i_rClass.ClassKey() == ary::cpp::CK_struct
? C_sHFTypeTitle_Struct
: C_sHFTypeTitle_Union;
}
const char *
Get_TypeKey( const ary::cpp::CodeEntity & i_rCe )
{
if ( ary::is_type<ary::cpp::Class>(i_rCe) )
{
return Get_ClassTypeKey(
ary::ary_cast<ary::cpp::Class>(i_rCe) );
}
if ( ary::is_type<ary::cpp::Enum>(i_rCe) )
{
return "enum";
}
return "";
}
bool
Ce_IsInternal( const ary::cpp::CodeEntity & i_rCe )
{
return NOT i_rCe.IsVisible();
}
const char *
SyntaxText_PreName( const ary::cpp::Function & i_rFunction,
const ary::cpp::Gate & i_rAryGate )
{
static StreamStr sResult( 150 );
sResult.seekp(0);
// write pre-name:
const ary::cpp::FunctionFlags & rFlags = i_rFunction.Flags();
if ( rFlags.IsStaticLocal() OR rFlags.IsStaticMember() )
sResult << "static ";
if ( rFlags.IsExplicit() )
sResult << "explicit ";
if ( rFlags.IsMutable() )
sResult << "mutable ";
if ( i_rFunction.Virtuality() != ary::cpp::VIRTUAL_none )
sResult << "virtual ";
i_rAryGate.Types().Get_TypeText( sResult, i_rFunction.ReturnType() );
sResult << " ";
return sResult.c_str();
}
const char *
SyntaxText_PostName( const ary::cpp::Function & i_rFunction,
const ary::cpp::Gate & i_rAryGate )
{
static StreamStr sResult( 850 );
sResult.seekp(0);
// parameters and con_vol
i_rAryGate.Ces().Get_SignatureText( sResult, i_rFunction.Signature(), &i_rFunction.ParamInfos() );
// write Exceptions:
const std::vector< ary::cpp::Type_id > *
pThrow = i_rFunction.Exceptions();
if ( pThrow)
{
std::vector< ary::cpp::Type_id >::const_iterator
it = pThrow->begin();
std::vector< ary::cpp::Type_id >::const_iterator
it_end = pThrow->end();
if (it != it_end)
{
sResult << " throw( ";
i_rAryGate.Types().Get_TypeText(sResult, *it);
for ( ++it; it != it_end; ++it )
{
sResult << ", ";
i_rAryGate.Types().Get_TypeText(sResult, *it);
}
sResult << " )";
}
else
{
sResult << " throw( )";
}
} // endif // pThrow
// abstractness:
if ( i_rFunction.Virtuality() == ary::cpp::VIRTUAL_abstract )
sResult << " = 0";
// finish:
sResult << ";";
return sResult.c_str();
}
bool
Get_TypeText( const char * & o_rPreName,
const char * & o_rName,
const char * & o_rPostName,
ary::cpp::Type_id i_nTypeid,
const ary::cpp::Gate & i_rAryGate )
{
static StreamStr sResult_PreName(250);
static StreamStr sResult_Name(250);
static StreamStr sResult_PostName(250);
sResult_PreName.seekp(0);
sResult_Name.seekp(0);
sResult_PostName.seekp(0);
bool ret = i_rAryGate.Types().Get_TypeText(
sResult_PreName,
sResult_Name,
sResult_PostName,
i_nTypeid );
if ( sResult_PreName.tellp() > 0 )
{
char cLast = *( sResult_PreName.c_str() + (sResult_PreName.tellp() - 1) );
if (cLast != ':' AND cLast != ' ')
sResult_PreName << " ";
}
if (ret)
{
o_rPreName = sResult_PreName.c_str();
o_rName = sResult_Name.c_str();
o_rPostName = sResult_PostName.c_str();
}
else
{
o_rPreName = o_rName = o_rPostName = "";
}
return ret;
}
//********************* FunctionParam_Iterator *****************//
FunctionParam_Iterator::FunctionParam_Iterator()
: // itTypes
// itTypes_end
// itNames_andMore
// itNames_andMore_end
eConVol(ary::cpp::CONVOL_none)
{
static std::vector<ary::cpp::Type_id> aTypesNull_;
static StringVector aNamesNull_;
itTypes = itTypes_end = aTypesNull_.end();
itNames_andMore = itNames_andMore_end = aNamesNull_.end();
}
FunctionParam_Iterator::~FunctionParam_Iterator()
{
}
FunctionParam_Iterator &
FunctionParam_Iterator::operator++()
{
if ( IsValid() )
{
++itTypes;
++itNames_andMore;
}
return *this;
}
void
FunctionParam_Iterator::Assign( const ary::cpp::Function & i_rFunction )
{
const ary::cpp::OperationSignature &
rSigna = i_rFunction.Signature();
const std::vector<ary::cpp::Type_id> &
rTypes = rSigna.Parameters();
const StringVector &
rNames = i_rFunction.ParamInfos();
if ( rTypes.size() != rNames.size() OR rTypes.size() == 0 )
return;
itTypes = rTypes.begin();
itTypes_end = rTypes.end();
itNames_andMore = rNames.begin();
itNames_andMore_end = rNames.end();
eConVol = rSigna.ConVol();
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */