/* -*- 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_INC_SWTYPES_HXX #define INCLUDED_SW_INC_SWTYPES_HXX #include #include #include #include #include "swdllapi.h" #include #include #include namespace com::sun::star { namespace linguistic2{ class XLinguProperties; class XSpellChecker1; class XHyphenator; class XThesaurus; } } namespace utl{ class TransliterationWrapper; } class Size; class SwPathFinder; class Graphic; class OutputDevice; class CharClass; class CollatorWrapper; class LanguageTag; typedef tools::Long SwTwips; #define INVALID_TWIPS LONG_MAX #define TWIPS_MAX (LONG_MAX - 1) // Converts Millimeters to Twips (1 mm == 56.905479 twips). template constexpr T MmToTwips(const double mm) { return static_cast(mm / 0.017573); } #define MM50 283 // 1/2 cm in TWIPS. const sal_Int32 COMPLETE_STRING = SAL_MAX_INT32; const SwTwips cMinHdFtHeight = 56; #define MINFLY 23 // Minimal size for FlyFrames. #define MINLAY 23 // Minimal size for other Frames. // Default column distance of two text columns corresponds to 0.3 cm. #define DEF_GUTTER_WIDTH (MM50 / 5 * 3) // Minimal distance (distance to text) for border attribute // in order not to crock up aligned lines. // 28 Twips == 0,4mm #define MIN_BORDER_DIST 28 // Minimal document border: 20mm. const SwTwips lMinBorder = 1134; // Margin left and above document. // Half of it is gap between the pages. //TODO: Replace with SwViewOption::defDocumentBorder #define DOCUMENTBORDER 284 // For inserting of captions (what and where to insert). // It's here because it is not big enough to justify its own hxx // and does not seem to fit somewhere else. enum class SwLabelType { Table, // Caption for a table. Object, // Caption for a graphic or OLE. Fly, // Caption for a text frame. Draw // Caption for a draw object. }; const sal_uInt8 MAXLEVEL = 10; const sal_uInt8 NO_NUMLEVEL = 0x20; // "or" with the levels. // Values for indents at numbering and bullet lists. // (For more levels the values have to be multiplied with the levels+1; // levels 0 ..4!) const short lBulletIndent = 1440/4; const short lBulletFirstLineOffset = -lBulletIndent; const sal_uInt16 lNumberIndent = 1440/4; const short lNumberFirstLineOffset = -lNumberIndent; const short lOutlineMinTextDistance = 216; // 0.15 inch = 0.38 cm // Count of SystemField-types of SwDoc. #define INIT_FLDTYPES 33 // Count of predefined Seq-field types. It is always the last // fields before INIT_FLDTYPES. #define INIT_SEQ_FLDTYPES 5 // defined in sw/source/uibase/app/swmodule.cxx SW_DLLPUBLIC OUString SwResId(const char* pId); OUString SwResId(const char* pId, int nCardinality); css::uno::Reference< css::linguistic2::XSpellChecker1 > GetSpellChecker(); css::uno::Reference< css::linguistic2::XHyphenator > GetHyphenator(); css::uno::Reference< css::linguistic2::XThesaurus > GetThesaurus(); css::uno::Reference< css::linguistic2::XLinguProperties > GetLinguPropertySet(); // Returns the twip size of this graphic. SW_DLLPUBLIC Size GetGraphicSizeTwip( const Graphic&, vcl::RenderContext* pOutDev ); // Separator for jumps to different content types in document. const sal_Unicode cMarkSeparator = '|'; // Sequences names for jumps are ! const char cSequenceMarkSeparator = '!'; #define DB_DELIM u'\x00ff' // Database <-> table separator. enum class SetAttrMode { DEFAULT = 0x0000, // Default. /// @attention: DONTEXPAND does not work very well for CHARATR /// because it can expand only the whole AUTOFMT or nothing DONTEXPAND = 0x0001, // Don't expand text attribute any further. DONTREPLACE = 0x0002, // Don't replace another text attribute. NOTXTATRCHR = 0x0004, // Don't insert 0xFF at attributes with no end. /// attention: NOHINTADJUST prevents MergePortions! /// when using this need to pay attention to ignore start/end flags of hint NOHINTADJUST = 0x0008, // No merging of ranges. NOFORMATATTR = 0x0010, // Do not change into format attribute. APICALL = 0x0020, // Called from API (all UI related // functionality will be disabled). /// Force hint expand (only matters for hints with CH_TXTATR). FORCEHINTEXPAND = 0x0040, /// The inserted item is a copy -- intended for use in ndtxt.cxx. IS_COPY = 0x0080, /// for Undo, translated to SwInsertFlags::NOHINTEXPAND NOHINTEXPAND = 0x0100, }; namespace o3tl { template<> struct typed_flags : is_typed_flags {}; } constexpr bool SW_ISPRINTABLE(sal_Unicode c) { return c >= ' ' && 127 != c; } #define CHAR_HARDBLANK u'\x00A0' #define CHAR_HARDHYPHEN u'\x2011' #define CHAR_SOFTHYPHEN u'\x00AD' #define CHAR_RLM u'\x200F' #define CHAR_LRM u'\x200E' #define CHAR_ZWSP u'\x200B' #define CHAR_ZWNBSP u'\x2060' #define CHAR_NNBSP u'\x202F' //NARROW NO-BREAK SPACE // Returns the APP - CharClass instance - used for all ToUpper/ToLower/... SW_DLLPUBLIC CharClass& GetAppCharClass(); SW_DLLPUBLIC LanguageType GetAppLanguage(); SW_DLLPUBLIC const LanguageTag& GetAppLanguageTag(); #if 0 // I18N doesn't get this right, can't specify more than one to ignore #define SW_COLLATOR_IGNORES ( \ css::i18n::CollatorOptions::CollatorOptions_IGNORE_CASE | \ css::i18n::CollatorOptions::CollatorOptions_IGNORE_KANA | \ css::i18n::CollatorOptions::CollatorOptions_IGNORE_WIDTH ) #else #define SW_COLLATOR_IGNORES ( \ css::i18n::CollatorOptions::CollatorOptions_IGNORE_CASE ) #endif SW_DLLPUBLIC CollatorWrapper& GetAppCollator(); CollatorWrapper& GetAppCaseCollator(); SW_DLLPUBLIC const ::utl::TransliterationWrapper& GetAppCmpStrIgnore(); // Official shortcut for Prepare() regarding notification of Content by the Layout. // Content provides for calculation of minimal requirements at the next call of ::Format(). enum class PrepareHint { Clear, // Reformat completely. WidowsOrphans, // Only check for widows and orphans and split in case of need. FixSizeChanged, // FixSize has changed. FollowFollows, // Follow is now possibly adjacent. AdjustSizeWithoutFormatting, // Adjust size via grow/shrink without formatting. FlyFrameSizeChanged, // A FlyFrame has changed its size. FlyFrameAttributesChanged, // A FlyFrame has changed its attributes (e. g. wrap). FlyFrameArrive, // A FlyFrame now overlaps range. FlyFrameLeave, // A FlyFrame has left range. FootnoteInvalidation, // Invalidation of footnotes. FramePositionChanged, // Position of Frame has changed. // (Check for Fly-break). In void* of Prepare() // a sal_Bool& is passed. If this is sal_True, // it indicates that a format has been executed. ULSpaceChanged, // UL-Space has changed, TextFrames have to // re-calculate line space. MustFit, // Make frm fit (split) even if the attributes do // not allow that (e.g. "keep together"). Widows, // A follow realizes that the orphan rule will be applied // for it and sends a Widows to its predecessor // (Master/Follow). QuoVadis, // If a footnote has to be split between two paragraphs // the last on the page has to receive a QUOVADIS in // order to format the text into it. BossChanged, // If a Frame changes its column/page this additional // Prepare is sent to POS_CHGD in MoveFwd/Bwd // (join Footnote-numbers etc.) // Direction is communicated via pVoid: // MoveFwd: pVoid == 0 // MoveBwd: pVoid == pOldPage Register, // Invalidate frames with registers. FootnoteInvalidationGone, // A Follow loses its footnote, possibly its first line can move up. FootnoteMove, // A footnote changes its page. Its contents receives at first a // height of zero in order to avoid too much noise. At formatting // it checks whether it fits and if necessary changes its page again. ErgoSum, // Needed because of movement in FootnoteFrames. Check QuoVadis/ErgoSum. }; enum class FrameControlType { PageBreak, Header, Footer, FloatingTable, Outline }; #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab: */