1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3  * This file is part of the LibreOffice project.
4  *
5  * This Source Code Form is subject to the terms of the Mozilla Public
6  * License, v. 2.0. If a copy of the MPL was not distributed with this
7  * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8  *
9  * This file incorporates work covered by the following license notice:
10  *
11  *   Licensed to the Apache Software Foundation (ASF) under one or more
12  *   contributor license agreements. See the NOTICE file distributed
13  *   with this work for additional information regarding copyright
14  *   ownership. The ASF licenses this file to you under the Apache
15  *   License, Version 2.0 (the "License"); you may not use this file
16  *   except in compliance with the License. You may obtain a copy of
17  *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
18  */
19 #ifndef INCLUDED_SW_INC_SWTYPES_HXX
20 #define INCLUDED_SW_INC_SWTYPES_HXX
21 #include <rtl/ustring.hxx>
22 
23 #include <limits.h>
24 #include <com/sun/star/uno/Reference.h>
25 #include <com/sun/star/i18n/CollatorOptions.hpp>
26 #include "swdllapi.h"
27 #include <o3tl/typed_flags_set.hxx>
28 #include <i18nlangtag/lang.h>
29 #include <vcl/outdev.hxx>
30 
31 namespace com::sun::star {
32     namespace linguistic2{
33         class XLinguProperties;
34         class XSpellChecker1;
35         class XHyphenator;
36         class XThesaurus;
37     }
38 }
39 namespace utl{
40     class TransliterationWrapper;
41 }
42 
43 class Size;
44 class SwPathFinder;
45 class Graphic;
46 class OutputDevice;
47 class CharClass;
48 class CollatorWrapper;
49 class LanguageTag;
50 
51 typedef tools::Long SwTwips;
52 #define INVALID_TWIPS   LONG_MAX
53 #define TWIPS_MAX       (LONG_MAX - 1)
54 
55 // Converts Millimeters to Twips (1 mm == 56.905479 twips).
56 template <typename T = SwTwips>
MmToTwips(const double mm)57 constexpr T MmToTwips(const double mm) { return static_cast<T>(mm / 0.017573); }
58 
59 #define MM50   283  // 1/2 cm in TWIPS.
60 
61 const sal_Int32 COMPLETE_STRING = SAL_MAX_INT32;
62 
63 const SwTwips cMinHdFtHeight = 56;
64 
65 #define MINFLY 23   // Minimal size for FlyFrames.
66 #define MINLAY 23   // Minimal size for other Frames.
67 
68 // Default column distance of two text columns corresponds to 0.3 cm.
69 #define DEF_GUTTER_WIDTH (MM50 / 5 * 3)
70 
71 // Minimal distance (distance to text) for border attribute
72 // in order not to crock up aligned lines.
73 // 28 Twips == 0,4mm
74 #define MIN_BORDER_DIST 28
75 
76 // Minimal document border: 20mm.
77 const SwTwips lMinBorder = 1134;
78 
79 // Margin left and above document.
80 // Half of it is gap between the pages.
81 //TODO: Replace with SwViewOption::defDocumentBorder
82 #define DOCUMENTBORDER  284
83 
84 // For inserting of captions (what and where to insert).
85 // It's here because it is not big enough to justify its own hxx
86 // and does not seem to fit somewhere else.
87 enum class SwLabelType
88 {
89     Table,    // Caption for a table.
90     Object,   // Caption for a graphic or OLE.
91     Fly,      // Caption for a text frame.
92     Draw      // Caption for a draw object.
93 };
94 
95 const sal_uInt8 MAXLEVEL = 10;
96 
97 const sal_uInt8 NO_NUMLEVEL  = 0x20;    // "or" with the levels.
98 
99 //  Values for indents at numbering and bullet lists.
100 //  (For more levels the values have to be multiplied with the levels+1;
101 //  levels 0 ..4!)
102 
103 const short lBulletIndent = 1440/4;
104 const short lBulletFirstLineOffset = -lBulletIndent;
105 const sal_uInt16 lNumberIndent = 1440/4;
106 const short lNumberFirstLineOffset = -lNumberIndent;
107 const short lOutlineMinTextDistance = 216; // 0.15 inch = 0.38 cm
108 
109 // Count of SystemField-types of SwDoc.
110 #define INIT_FLDTYPES   33
111 
112 // Count of predefined Seq-field types. It is always the last
113 // fields before INIT_FLDTYPES.
114 #define INIT_SEQ_FLDTYPES   5
115 
116 // defined in sw/source/uibase/app/swmodule.cxx
117 SW_DLLPUBLIC OUString SwResId(const char* pId);
118 OUString SwResId(const char* pId, int nCardinality);
119 
120 css::uno::Reference< css::linguistic2::XSpellChecker1 > GetSpellChecker();
121 css::uno::Reference< css::linguistic2::XHyphenator >    GetHyphenator();
122 css::uno::Reference< css::linguistic2::XThesaurus >     GetThesaurus();
123 css::uno::Reference< css::linguistic2::XLinguProperties > GetLinguPropertySet();
124 
125 // Returns the twip size of this graphic.
126 SW_DLLPUBLIC Size GetGraphicSizeTwip( const Graphic&, vcl::RenderContext* pOutDev );
127 
128 // Separator for jumps to different content types in document.
129 const sal_Unicode cMarkSeparator = '|';
130 // Sequences names for jumps are <name of sequence>!<no>
131 const char cSequenceMarkSeparator = '!';
132 /// separator for toxmarks: #<no>%19<text>%19<type><typename>|toxmark
133 sal_Unicode const toxMarkSeparator = '\u0019';
134 
135 #define DB_DELIM u'\x00ff'        // Database <-> table separator.
136 
137 enum class SetAttrMode
138 {
139     DEFAULT         = 0x0000,  // Default.
140     /// @attention: DONTEXPAND does not work very well for CHARATR
141     ///             because it can expand only the whole AUTOFMT or nothing
142     DONTEXPAND      = 0x0001,  // Don't expand text attribute any further.
143     DONTREPLACE     = 0x0002,  // Don't replace another text attribute.
144 
145     NOTXTATRCHR     = 0x0004,  // Don't insert 0xFF at attributes with no end.
146     /// attention: NOHINTADJUST prevents MergePortions!
147     /// when using this need to pay attention to ignore start/end flags of hint
148     NOHINTADJUST    = 0x0008,  // No merging of ranges.
149     NOFORMATATTR    = 0x0010,  // Do not change into format attribute.
150     APICALL         = 0x0020,  // Called from API (all UI related
151                                                         // functionality will be disabled).
152     /// Force hint expand (only matters for hints with CH_TXTATR).
153     FORCEHINTEXPAND = 0x0040,
154     /// The inserted item is a copy -- intended for use in ndtxt.cxx.
155     IS_COPY         = 0x0080,
156     /// for Undo, translated to SwInsertFlags::NOHINTEXPAND
157     NOHINTEXPAND    = 0x0100,
158 };
159 namespace o3tl
160 {
161     template<> struct typed_flags<SetAttrMode> : is_typed_flags<SetAttrMode, 0x1ff> {};
162 }
163 
SW_ISPRINTABLE(sal_Unicode c)164 constexpr bool SW_ISPRINTABLE(sal_Unicode c) { return c >= ' ' && 127 != c; }
165 
166 #define CHAR_HARDBLANK      u'\x00A0'
167 #define CHAR_HARDHYPHEN     u'\x2011'
168 #define CHAR_SOFTHYPHEN     u'\x00AD'
169 #define CHAR_RLM            u'\x200F'
170 #define CHAR_LRM            u'\x200E'
171 #define CHAR_ZWSP           u'\x200B'
172 #define CHAR_WJ             u'\x2060'
173 #define CHAR_NNBSP          u'\x202F' //NARROW NO-BREAK SPACE
174 
175 // Returns the APP - CharClass instance - used for all ToUpper/ToLower/...
176 SW_DLLPUBLIC CharClass& GetAppCharClass();
177 SW_DLLPUBLIC LanguageType GetAppLanguage();
178 SW_DLLPUBLIC const LanguageTag& GetAppLanguageTag();
179 
180 #if 0
181 // I18N doesn't get this right, can't specify more than one to ignore
182 #define SW_COLLATOR_IGNORES ( \
183     css::i18n::CollatorOptions::CollatorOptions_IGNORE_CASE | \
184     css::i18n::CollatorOptions::CollatorOptions_IGNORE_KANA | \
185     css::i18n::CollatorOptions::CollatorOptions_IGNORE_WIDTH )
186 #else
187 #define SW_COLLATOR_IGNORES ( \
188     css::i18n::CollatorOptions::CollatorOptions_IGNORE_CASE )
189 #endif
190 
191 SW_DLLPUBLIC CollatorWrapper& GetAppCollator();
192 CollatorWrapper& GetAppCaseCollator();
193 
194 SW_DLLPUBLIC const ::utl::TransliterationWrapper& GetAppCmpStrIgnore();
195 
196 // Official shortcut for Prepare() regarding notification of Content by the Layout.
197 // Content provides for calculation of minimal requirements at the next call of ::Format().
198 enum class PrepareHint
199 {
200     Clear,                     // Reformat completely.
201     WidowsOrphans,             // Only check for widows and orphans and split in case of need.
202     FixSizeChanged,            // FixSize has changed.
203     FollowFollows,             // Follow is now possibly adjacent.
204     AdjustSizeWithoutFormatting,  // Adjust size via grow/shrink without formatting.
205     FlyFrameSizeChanged,       // A FlyFrame has changed its size.
206     FlyFrameAttributesChanged, // A FlyFrame has changed its attributes (e. g. wrap).
207     FlyFrameArrive,            // A FlyFrame now overlaps range.
208     FlyFrameLeave,             // A FlyFrame has left range.
209     FootnoteInvalidation,      // Invalidation of footnotes.
210     FramePositionChanged,      // Position of Frame has changed.
211                                // (Check for Fly-break). In void* of Prepare()
212                                // a sal_Bool& is passed. If this is sal_True,
213                                // it indicates that a format has been executed.
214     ULSpaceChanged,            // UL-Space has changed, TextFrames have to
215                                // re-calculate line space.
216     MustFit,                   // Make frm fit (split) even if the attributes do
217                                // not allow that (e.g. "keep together").
218     Widows,                    // A follow realizes that the orphan rule will be applied
219                                // for it and sends a Widows to its predecessor
220                                // (Master/Follow).
221     QuoVadis,                  // If a footnote has to be split between two paragraphs
222                                // the last on the page has to receive a QUOVADIS in
223                                // order to format the text into it.
224     BossChanged,               // If a Frame changes its column/page this additional
225                                // Prepare is sent to POS_CHGD in MoveFwd/Bwd
226                                // (join Footnote-numbers etc.)
227                                // Direction is communicated via pVoid:
228                                //     MoveFwd: pVoid == 0
229                                //     MoveBwd: pVoid == pOldPage
230     Register,                  // Invalidate frames with registers.
231     FootnoteInvalidationGone,  // A Follow loses its footnote, possibly its first line can move up.
232     FootnoteMove,              // A footnote changes its page. Its contents receives at first a
233                                // height of zero in order to avoid too much noise. At formatting
234                                // it checks whether it fits and if necessary changes its page again.
235     ErgoSum,                   // Needed because of movement in FootnoteFrames. Check QuoVadis/ErgoSum.
236 };
237 
238 enum class FrameControlType
239 {
240     PageBreak,
241     Header,
242     Footer,
243     FloatingTable,
244     Outline
245 };
246 
247 #endif
248 
249 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
250