mirror of
https://github.com/ONLYOFFICE/core.git
synced 2026-04-07 13:55:33 +08:00
117 lines
4.5 KiB
C++
117 lines
4.5 KiB
C++
/*
|
|
* (c) Copyright Ascensio System SIA 2010-2017
|
|
*
|
|
* 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<std::wstring>( &(this->rgxchFPunct), fpunctBytes, 202, ENCODING_UTF16 );
|
|
|
|
unsigned char lpunctBytes[102];
|
|
memcpy( lpunctBytes, ( bytes + 208 ), 102 );
|
|
FormatUtils::GetSTLCollectionFromBytes<std::wstring>( &(this->rgxchLPunct), lpunctBytes, 102, ENCODING_UTF16 );
|
|
}
|
|
else
|
|
{
|
|
//throw new ByteParseException("Cannot parse the struct DOPTYPOGRAPHY, the length of the struct doesn't match");
|
|
}
|
|
}
|
|
};
|
|
}
|