Files
libreoffice/autodoc/inc/ary/adoc/a_docuaccess.hxx
Rüdiger Timm b5e17266b8 INTEGRATION: CWS changefileheader (1.2.22); FILE MERGED
2008/03/28 16:01:01 rt 1.2.22.1: #i87441# Change license header to LPGL v3.
2008-04-10 12:15:00 +00:00

195 lines
5.1 KiB
C++

/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2008 by Sun Microsystems, Inc.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: a_docuaccess.hxx,v $
* $Revision: 1.3 $
*
* 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.
*
************************************************************************/
#ifndef ARY_ADOC_DOCUACCESS_HXX
#define ARY_ADOC_DOCUACCESS_HXX
// USED SERVICES
// BASE CLASSES
// OTHER
#include <ary/doc/d_hypertext.hxx>
namespace ary
{
namespace doc
{
class Documentation;
class NamedList;
class Struct;
}
}
namespace ary
{
namespace adoc
{
enum E_LifeCycle
{
lc_unkown,
lc_owned,
lc_extern,
lc_refcounted
};
class TypeNameReceiver;
/** Semantic access to a documentation whose content follows the rules of
autodoc standard documentation.
*/
class DocuAccess
{
public:
enum E_TagId
{
ti_none = 0,
ti_attention,
ti_author,
ti_base,
ti_change,
ti_collab,
ti_deprecated,
ti_derive,
ti_descr,
ti_docdate,
ti_exception,
ti_instance,
ti_internal,
ti_invariant,
ti_key,
ti_life,
ti_multi,
ti_onerror,
ti_param,
ti_persistence,
ti_postcond,
ti_precond,
ti_published,
ti_resp,
ti_return,
ti_returns,
ti_see,
ti_short,
ti_since,
ti_summary,
ti_throws,
ti_todo,
ti_tpl,
ti_version,
ti_ATTENTION,
ti_UnknownAtTag,
ti_DocuReference,
ti_NVI,
ti_extra, /// Tag that is not known.
ti_MAX /// Keep this the highest value.
};
explicit DocuAccess(
ary::doc::Documentation *
io_docu = 0 );
ary::doc::Documentation *
Assign_Container( /// @return Previously assigned container.
ary::doc::Documentation *
io_docu );
ary::doc::Documentation *
Release_Container();
void Set_Deprecated();
void Set_Internal();
void Set_Published();
ary::doc::HyperText &
Add_Description();
ary::doc::HyperText &
Add_StdTag(
E_TagId i_tag );
ary::doc::HyperText &
Add_base(
const String & i_baseTypeName );
ary::doc::HyperText &
Add_collab(
const String & i_partner );
ary::doc::HyperText &
Add_key(
const String & i_keyWord );
ary::doc::HyperText &
Add_param(
const String & i_parameterName,
const String & i_validRange );
ary::doc::HyperText &
Add_see(
const String & i_referencedEntity );
ary::doc::HyperText &
Add_since(
const String & i_versionId,
const String & i_fullVersionText );
ary::doc::HyperText &
Add_throws(
const String & i_exceptionName );
ary::doc::HyperText &
Add_tpl(
const String & i_templateParameter );
ary::doc::HyperText &
Add_ExtraTag(
const String & i_tagName );
ary::doc::HyperText &
Add_TagWithMissingParameter(
E_TagId i_tag );
private:
ary::doc::Struct & Data();
ary::doc::Struct & Get_Data();
ary::doc::NamedList &
Get_List(
E_TagId i_tag );
// DATA
ary::doc::Documentation *
pContainer;
ary::doc::Struct * pData;
};
} // namespace adoc
} // namespace ary
#endif