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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254 | /* -*- 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 INCLUDED_SW_SOURCE_CORE_TEXT_PORFLD_HXX
#define INCLUDED_SW_SOURCE_CORE_TEXT_PORFLD_HXX
#include <swtypes.hxx>
#include <swfont.hxx>
#include "porexp.hxx"
#include <o3tl/enumarray.hxx>
class SvxBrushItem;
class SwFormatVertOrient;
class SwFieldPortion : public SwExpandPortion
{
friend class SwTextFormatter;
protected:
OUString m_aExpand; // The expanded field
std::unique_ptr<SwFont> m_pFont; // For multi-line fields
TextFrameIndex m_nNextOffset; // Offset of the follow in the original string
TextFrameIndex m_nNextScriptChg;
sal_uInt16 m_nViewWidth; // Screen width for empty fields
bool m_bFollow : 1; // 2nd or later part of a field
bool m_bLeft : 1; // Used by SwNumberPortion
bool m_bHide : 1; // Used by SwNumberPortion
bool m_bCenter : 1; // Used by SwNumberPortion
bool m_bHasFollow : 1; // Continues on the next line
bool m_bAnimated : 1; // Used by SwGrfNumPortion
bool m_bNoPaint : 1; // Used by SwGrfNumPortion
bool m_bReplace : 1; // Used by SwGrfNumPortion
const bool m_bPlaceHolder : 1;
bool m_bNoLength : 1; // HACK for meta suffix (no CH_TXTATR)
void SetFont( std::unique_ptr<SwFont> pNew ) { m_pFont = std::move(pNew); }
bool IsNoLength() const { return m_bNoLength; }
void SetNoLength() { m_bNoLength = true; }
public:
SwFieldPortion( const SwFieldPortion& rField );
SwFieldPortion( const OUString &rExpand, std::unique_ptr<SwFont> pFnt = nullptr, bool bPlaceHolder = false );<--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwFieldPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided.
virtual ~SwFieldPortion() override;
sal_uInt16 m_nAttrFieldType;
void TakeNextOffset( const SwFieldPortion* pField );
void CheckScript( const SwTextSizeInfo &rInf );
bool HasFont() const { return nullptr != m_pFont; }
// #i89179# - made public
const SwFont *GetFont() const { return m_pFont.get(); }
const OUString& GetExp() const { return m_aExpand; }
virtual bool GetExpText( const SwTextSizeInfo &rInf, OUString &rText ) const override;
virtual bool Format( SwTextFormatInfo &rInf ) override;
virtual void Paint( const SwTextPaintInfo &rInf ) const override;
// Empty fields are also allowed
virtual SwLinePortion *Compress() override;
virtual sal_uInt16 GetViewWidth( const SwTextSizeInfo &rInf ) const override;
bool IsFollow() const { return m_bFollow; }
void SetFollow( bool bNew ) { m_bFollow = bNew; }
bool IsLeft() const { return m_bLeft; }
void SetLeft( bool bNew ) { m_bLeft = bNew; }
bool IsHide() const { return m_bHide; }
void SetHide( bool bNew ) { m_bHide = bNew; }
bool IsCenter() const { return m_bCenter; }
void SetCenter( bool bNew ) { m_bCenter = bNew; }
bool HasFollow() const { return m_bHasFollow; }
void SetHasFollow( bool bNew ) { m_bHasFollow = bNew; }
TextFrameIndex GetNextOffset() const { return m_nNextOffset; }
void SetNextOffset(TextFrameIndex nNew) { m_nNextOffset = nNew; }
// Field cloner for SplitGlue
virtual SwFieldPortion *Clone( const OUString &rExpand ) const;
// Extra GetTextSize because of pFnt
virtual SwPosSize GetTextSize( const SwTextSizeInfo &rInfo ) const override;
// Accessibility: pass information about this portion to the PortionHandler
virtual void HandlePortion( SwPortionHandler& rPH ) const override;
};
/**
* Distinguish only for painting/hide
*/
class SwHiddenPortion : public SwFieldPortion
{
public:
SwHiddenPortion( const OUString &rExpand, std::unique_ptr<SwFont> pFntL = nullptr )<--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided. <--- Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. [+]Class 'SwHiddenPortion' has a constructor with 1 argument that is not explicit. Such constructors should in general be explicit for type safety reasons. Using the explicit keyword in the constructor means some mistakes when using the class can be avoided.
: SwFieldPortion( rExpand, std::move(pFntL) )
{ SetLen(TextFrameIndex(1)); SetWhichPor( PortionType::Hidden ); }
virtual void Paint( const SwTextPaintInfo &rInf ) const override;
virtual bool GetExpText( const SwTextSizeInfo &rInf, OUString &rText ) const override;
// Field cloner for SplitGlue
virtual SwFieldPortion *Clone( const OUString &rExpand ) const override;
};
class SwNumberPortion : public SwFieldPortion
{
protected:
sal_uInt16 nFixWidth; // See Glues
sal_uInt16 nMinDist; // Minimal distance to the text
bool mbLabelAlignmentPosAndSpaceModeActive;
public:
SwNumberPortion( const OUString &rExpand,
std::unique_ptr<SwFont> pFnt,
const bool bLeft,
const bool bCenter,
const sal_uInt16 nMinDst,
const bool bLabelAlignmentPosAndSpaceModeActive );
virtual void Paint( const SwTextPaintInfo &rInf ) const override;
virtual TextFrameIndex GetModelPositionForViewPoint(sal_uInt16 nOfst) const override;
virtual bool Format( SwTextFormatInfo &rInf ) override;
// Field cloner for SplitGlue
virtual SwFieldPortion *Clone( const OUString &rExpand ) const override;
virtual void FormatEOL( SwTextFormatInfo &rInf ) override;
};
class SwBulletPortion : public SwNumberPortion
{
public:
SwBulletPortion( const sal_Unicode cCh,
const OUString& rBulletFollowedBy,
std::unique_ptr<SwFont> pFnt,
const bool bLeft,
const bool bCenter,
const sal_uInt16 nMinDst,
const bool bLabelAlignmentPosAndSpaceModeActive );
};
class SwGrfNumPortion : public SwNumberPortion
{
std::unique_ptr<SvxBrushItem> pBrush;
long nId; // For StopAnimation
SwTwips nYPos; // _Always_ contains the current RelPos
SwTwips nGrfHeight;
sal_Int16 eOrient;
public:
SwGrfNumPortion( const OUString& rGraphicFollowedBy,
const SvxBrushItem* pGrfBrush,
OUString const & referer,
const SwFormatVertOrient* pGrfOrient,
const Size& rGrfSize,
const bool bLeft,
const bool bCenter,
const sal_uInt16 nMinDst,
const bool bLabelAlignmentPosAndSpaceModeActive );
virtual ~SwGrfNumPortion() override;
virtual void Paint( const SwTextPaintInfo &rInf ) const override;
virtual bool Format( SwTextFormatInfo &rInf ) override;
void SetBase( long nLnAscent, long nLnDescent,
long nFlyAscent, long nFlyDescent );
void StopAnimation( OutputDevice* pOut );
bool IsAnimated() const { return m_bAnimated; }
void SetAnimated( bool bNew ) { m_bAnimated = bNew; }
void SetRelPos( SwTwips nNew ) { nYPos = nNew; }
void SetId( long nNew ) const
{ const_cast<SwGrfNumPortion*>(this)->nId = nNew; }
SwTwips GetRelPos() const { return nYPos; }
SwTwips GetGrfHeight() const { return nGrfHeight; }
sal_Int16 GetOrient() const { return eOrient; }
};
/**
* Used in for asian layout specialities to display up to six characters
* in 2 rows and 2-3 columns.
* E.g.: <pre>
* A.. A.. A.B A.B A.B.C A.B.C
* ... ..B .C. C.D .D.E. D.E.F
* </pre>
*/
class SwCombinedPortion : public SwFieldPortion
{
sal_uInt16 aPos[6]; // up to six X positions
o3tl::enumarray<SwFontScript,sal_uInt16> aWidth = {}; // one width for every scripttype
SwFontScript aScrType[6]; // scripttype of every character
sal_uInt16 nUpPos; // the Y position of the upper baseline
sal_uInt16 nLowPos; // the Y position of the lower baseline
sal_uInt8 nProportion; // relative font height
public:
explicit SwCombinedPortion( const OUString &rExpand );
virtual void Paint( const SwTextPaintInfo &rInf ) const override;
virtual bool Format( SwTextFormatInfo &rInf ) override;
virtual sal_uInt16 GetViewWidth( const SwTextSizeInfo &rInf ) const override;
};
namespace sw::mark { class IFieldmark; }
class SwFieldFormDropDownPortion : public SwFieldPortion
{
public:
explicit SwFieldFormDropDownPortion(sw::mark::IFieldmark *pFieldMark, const OUString &rExpand)
: SwFieldPortion(rExpand)
, m_pFieldMark(pFieldMark)
{
}
// Field cloner for SplitGlue
virtual SwFieldPortion *Clone( const OUString &rExpand ) const override;
virtual void Paint( const SwTextPaintInfo &rInf ) const override;
private:
sw::mark::IFieldmark* m_pFieldMark;
};
class SwFieldFormDatePortion : public SwFieldPortion
{
public:
explicit SwFieldFormDatePortion(sw::mark::IFieldmark *pFieldMark, bool bStart)
: SwFieldPortion("")
, m_pFieldMark(pFieldMark)
, m_bStart(bStart)
{
}
// Field cloner for SplitGlue
virtual SwFieldPortion *Clone( const OUString &rExpand) const override;
virtual void Paint( const SwTextPaintInfo &rInf ) const override;
private:
sw::mark::IFieldmark* m_pFieldMark;
bool m_bStart;
};
#endif
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|