/* * (c) Copyright Ascensio System SIA 2010-2018 * * This program is a free software product. You can redistribute it and/or * modify it under the terms of the GNU Affero General Public License (AGPL) * version 3 as published by the Free Software Foundation. In accordance with * Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect * that Ascensio System SIA expressly excludes the warranty of non-infringement * of any third-party rights. * * This program is distributed WITHOUT ANY WARRANTY; without even the implied * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For * details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html * * You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia, * EU, LV-1021. * * The interactive user interfaces in modified source and object code versions * of the Program must display Appropriate Legal Notices, as required under * Section 5 of the GNU AGPL version 3. * * Pursuant to Section 7(b) of the License you must retain the original Product * logo when distributing the program. Pursuant to Section 7(e) we decline to * grant you any rights under trademark law for use of our trademarks. * * All the Product's GUI elements, including illustrations and icon sets, as * well as technical writing content are licensed under the terms of the * Creative Commons Attribution-ShareAlike 4.0 International. See the License * terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode * */ #pragma once #include "../Common/FormatUtils.h" namespace DocFileFormat { class DocumentTypographyInfo { friend class SettingsMapping; private: /// True if we're kerning punctation bool fKerningPunct; /// Kinsoku method of justification: /// 0 = always expand /// 1 = compress punctation /// 2 = compress punctation and kana short iJustification; /// Level of kinsoku: /// 0 = level 1 /// 1 = Level 2 /// 2 = Custom short iLevelOfKinsoku; /// "2 page on 1" feature is turned on bool f2on1; /// Old East Asian feature bool fOldDefineLineBaseOnGrid; /// Custom Kinsoku short iCustomKsu; /// When set to true, use strict (level 2) Kinsoku rules bool fJapaneseUseLevel2; /// Length of rgxchFPunct short cchFollowingPunct; /// Length of rgxchLPunct short cchLeadingPunct; /// Array of characters that should never appear at the start of a line std::wstring rgxchFPunct; /// Array of characters that should never appear at the end of a line std::wstring rgxchLPunct; public: virtual ~DocumentTypographyInfo() { } DocumentTypographyInfo(): fKerningPunct(false), iJustification(0), iLevelOfKinsoku(0), f2on1(false), fOldDefineLineBaseOnGrid(false), iCustomKsu(0), fJapaneseUseLevel2(false), cchFollowingPunct(0), cchLeadingPunct(0) { } /// Parses the bytes to retrieve a DocumentTypographyInfo DocumentTypographyInfo( unsigned char* bytes, int size ): fKerningPunct(false), iJustification(0), iLevelOfKinsoku(0), f2on1(false), fOldDefineLineBaseOnGrid(false), iCustomKsu(0), fJapaneseUseLevel2(false), cchFollowingPunct(0), cchLeadingPunct(0) { if ( size == 310 ) { //split unsigned char 0 and 1 into bits this->fKerningPunct = FormatUtils::GetBitFromBytes( bytes, size, 0 ); this->iJustification = (short)FormatUtils::GetUIntFromBytesBits( bytes, size, 1, 2 ); this->iLevelOfKinsoku = (short)FormatUtils::GetUIntFromBytesBits( bytes, size, 3, 2 ); this->f2on1 = FormatUtils::GetBitFromBytes( bytes, size, 5 ); this->fOldDefineLineBaseOnGrid = FormatUtils::GetBitFromBytes( bytes, size, 6 ); this->iCustomKsu = (short)FormatUtils::GetUIntFromBytesBits( bytes, size, 7, 3 ); this->fJapaneseUseLevel2 = FormatUtils::GetBitFromBytes( bytes, size, 10 ); this->cchFollowingPunct = FormatUtils::BytesToInt16( bytes, 2, size ); this->cchLeadingPunct = FormatUtils::BytesToInt16( bytes, 4, size ); unsigned char fpunctBytes[202]; memcpy( fpunctBytes, ( bytes + 6 ), 202 ); FormatUtils::GetSTLCollectionFromBytes( &(this->rgxchFPunct), fpunctBytes, 202, ENCODING_UTF16 ); unsigned char lpunctBytes[102]; memcpy( lpunctBytes, ( bytes + 208 ), 102 ); FormatUtils::GetSTLCollectionFromBytes( &(this->rgxchLPunct), lpunctBytes, 102, ENCODING_UTF16 ); } else { //throw new ByteParseException("Cannot parse the struct DOPTYPOGRAPHY, the length of the struct doesn't match"); } } }; }