1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#ifndef ARY_IDL_IT_XNAMEROOM_HXX
#define ARY_IDL_IT_XNAMEROOM_HXX
// BASE CLASSES
#include <ary/idl/i_type.hxx>
#include <nametreenode.hxx>
namespace ary
{
namespace idl
{
/** A namespace for ->Type s, as they are explicitly written in code.
The search/identification string is usually the local name of
the Type. But for templated structs, the search string has this
pattern:
<LocalName> '<' <StringOfTemplateTypeId>
*/
class ExplicitNameRoom : public Type
{
public:
enum E_ClassId { class_id = 2204 };
// LIFECYCLE
ExplicitNameRoom();
ExplicitNameRoom(
const String & i_sName,
const ExplicitNameRoom &
i_rParent );
virtual ~ExplicitNameRoom();
// OPERATIONS
/** @param i_sSearchString
A local type name usually.
For templated types see class docu.
@see ExplicitNameRoom
*/
void Add_Name(
const String & i_sSearchString,
Type_id i_nId )
{ aImpl.Add_Name(i_sSearchString,i_nId); }
// INQUIRY
const String & Name() const { return aImpl.Name(); }
intt Depth() const { return aImpl.Depth(); }
void Get_FullName(
StringVector & o_rText,
Ce_idList * o_pRelatedCes,
const Gate & i_rGate ) const;
bool IsAbsolute() const { return Depth() > 0
? (*NameChain_Begin()).empty()
: false; }
/** @param i_sSearchString
A local type name usually.
For templated types see class docu.
@see ExplicitNameRoom
*/
Type_id Search_Name(
const String & i_sSearchString ) const
{ return aImpl.Search_Name(i_sSearchString); }
StringVector::const_iterator
NameChain_Begin() const
{ return aImpl.NameChain_Begin(); }
StringVector::const_iterator
NameChain_End() const
{ return aImpl.NameChain_End(); }
private:
// Interface csv::ConstProcessorClient:
virtual void do_Accept(
csv::ProcessorIfc & io_processor ) const;
// Interface Object:
virtual ClassId get_AryClass() const;
// Interface Type:
virtual void inq_Get_Text(
StringVector & o_module,
String & o_name,
Ce_id & o_nRelatedCe,
int & o_nSequemceCount,
const Gate & i_rGate ) const;
// DATA
NameTreeNode<Type_id>
aImpl;
};
} // namespace idl
} // namespace ary
#endif
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|