Aspose.Words for C++ 21.5 Release Notes
Major Features
We have added the following features from Aspose.Words for .NET on this regular monthly release:
- EQ field export to all HTML based formats was implemented.
- Added new methods to set checked and unchecked symbol for StructuredDocumentTag.
- Implemented an ability to use PDF annotations to display user comments.
- Added MailMerge.RestartListsAtEachSection property to control list numbering restart.
We have added the following features for Aspose.Words for C++:
- Added advanced typography support with HarfBuzz
Limitations and API Differences
Aspose.Words for C++ has some differences as compared to its equivalent .NET version of the API. This section contains information about all such functionality that is not available in the current release. The missing features will be added in future releases.
- The current release does not support Metered license.
- The current release does not support LINQ and Reporting features.
- The current release does not support OpenGL 3D Shapes rendering.
- The current release does not support loading PDF documents.
- The current release has limited support for database features - C++ doesn’t have common API for DB like .NET System.Data.
- The current release supports Microsoft Visual C++ version 2017 or higher.
- The current release supports GCC 6.3 or higher and Clang 3.9.1 or higher on Linux and only for the x86_x64 platform.
Full List of Issues Covering all Changes in this Release
Key | Summary | Category |
---|---|---|
WORDSCPP-793 | Add support advanced typography with HarfBuzz for C++ | New Feature |
WORDSCPP-1076 | Move public headers according to namespace names | New Feature |
WORDSNET-15678 | Export vector images to SVG when saving a document to HTML | New Feature |
WORDSNET-21645 | Add comments of Word document as annotation in PDF | New Feature |
WORDSNET-21949 | Support StylisticSet attribute in the document model | New Feature |
WORDSNET-21818 | Add feature to set content control (checkbox) checked/unchecked symbol | New Feature |
WORDSNET-22032 | Heading List Number restarts after Section Break when mail merge is performed | New Feature |
WORDSNET-17792 | EQ field is not exported in output HTML | New Feature |
WORDSNET-9121 | Write generator name (Aspose.Words x.x.x.x) in HtmlFixed format | Enhancement |
WORDSNET-6284 | Extend Structured Document Tag API | Enhancement |
WORDSNET-10021 | Give a valid GUID to custom xml parts | Enhancement |
WORDSNET-11931 | Add feature to detect either shape node is ActiveX or not | Enhancement |
WORDSNET-21596 | Support of decorative shapes for document accessibility | Enhancement |
WORDSNET-21908 | Implement ClearQuickStyleGallery() method for DOC/RTF format | Enhancement |
WORDSNET-9400 | Add feature to get styles in a document which are not currently used | Enhancement |
WORDSNET-21787 | DOCX to PDF conversion issue with text wrapping in table cell | Enhancement |
WORDSNET-7198 | Image in ODT is getting truncated at the bottom of Page in PDF | Bug |
WORDSNET-10203 | Style is changed after conversion from WordML to Doc | Bug |
WORDSNET-13076 | Mongolian text is rendered as boxes in output PDF | Bug |
WORDSNET-22027 | System.InvalidOperationException occurs upon updating fields | Bug |
WORDSNET-22028 | Performance tests fail on some Intel i7 and i9 CPU | Bug |
WORDSNET-22029 | TestBenchmark.PeakMemoryMeter fails for x86 builds | Bug |
WORDSNET-20197 | The ShapeType from the DmlShape class does not identify all shapes | Bug |
WORDSNET-22031 | Content Control (dropdown) value is changed after re-saving DOCX | Bug |
WORDSNET-21515 | Arabic Text - Applying TextShaperFactory produces garbage square boxes in PDF | Bug |
WORDSNET-21391 | Japanese text is rotated after DOCX to PDF conversion | Bug |
WORDSNET-21517 | A Textbox goes behind the background image during processing an ODT | Bug |
WORDSNET-12609 | DOCX to PDF conversion issue with Arabic Text | Bug |
WORDSNET-12920 | Saving to DOCX encodes with UTF-8+BOM instead of charset UTF-8 | Bug |
WORDSNET-20774 | Performance degrades as we increase number of threads | Bug |
WORDSNET-18929 | TxtSaveOptions converts single quote incorrectly | Bug |
WORDSNET-20217 | Chart axis tickmarks rendered incorrectly in output PDF | Bug |
WORDSNET-16109 | Khmer font rendering issue in PDF | Bug |
WORDSNET-16333 | The EQ field is not exported in output HTML | Bug |
WORDSNET-17012 | Equations (EQ fields) not preserved in generated HTML/PDF | Bug |
WORDSNET-22179 | Range.Replace hangs | Bug |
WORDSNET-22165 | GetShapeRenderer throws exception when converting SmartArt objects in parallel | Bug |
WORDSNET-22135 | Line break is removed from Variable value | Bug |
WORDSNET-17451 | Table borders got missed when comparing documents | Bug |
WORDSNET-17469 | Repeated values in Y-Axis chart appear when rendered | Bug |
WORDSNET-11335 | DOC to PDF conversion issue with Gujarati text rendering | Bug |
WORDSNET-21803 | Aspose.Words.FileCorruptedException is thrown while importing HTML | Bug |
WORDSNET-21673 | DOC to HTML conversion issue with Formula field | Bug |
WORDSNET-21675 | DOCX to HTML conversion issue with Formula field | Bug |
WORDSNET-2492 | Restricted styles are accessible after open/save the document | Bug |
WORDSNET-18819 | Issue when converting doc with image and shapes to HTML | Bug |
WORDSNET-19191 | X-Axis chart values missing in PDF | Bug |
WORDSNET-22047 | Words with noProof in some spans are not hyphenated correctly | Bug |
WORDSNET-19442 | X-Axis value and a Line in Chart missing when rendering to JPG | Bug |
WORDSNET-22063 | Performance issue upon save | Bug |
WORDSNET-21762 | GetStartPageIndex and GetEndPageIndex returns incorrect page number | Bug |
WORDSNET-22035 | Document.Compare does not mimic MS Word behavior | Bug |
WORDSNET-22066 | HiddenAttributeCache takes too much memory | Bug |
WORDSNET-4756 | Cannot use Save_4 overload in vbscript | Bug |
WORDSNET-21857 | INCLUDEPICTURE does not render the image in output DOC and PDF | Bug |
WORDSNET-22075 | Embedded PPT is converted to image after update | Bug |
WORDSNET-21721 | RevisionOptions.ShowRevisionMarks causes InvalidCastException | Bug |
WORDSNET-22068 | DOCX to PDF numbers in table pushed to the side | Bug |
WORDSNET-22081 | Horizontal Solid Lines become Dotted in PDF | Bug |
WORDSNET-21586 | Arabic Text - Applying TextShaperFactory produces garbage square boxes in PDF | Bug |
WORDSNET-21727 | Bullet lists are not processed properly when saving document in the Markdown format | Bug |
WORDSNET-22084 | Investigate failed customer test | Bug |
WORDSNET-21461 | Spacing between Laotian Words and Lines increased in PDF - Font: DokChampa & MingLiU | Bug |
WORDSNET-21724 | Footnote number is inserted at the end of Paragraph using Range.Repalce | Bug |
WORDSNET-21709 | ArgumentNullException when call document.ExtractPages | Bug |
WORDSNET-22046 | Lines with words traversing field boundaries are not hyphenated correctly | Bug |
WORDSNET-21612 | Hyperlinks are not Clickable when passed as Hidden into generated Word Document | Bug |
WORDSNET-22073 | Long conversion time to HTML for certain DOC file | Bug |
WORDSNET-22087 | Range.Fields throws System.InvalidOperationException | Bug |
WORDSNET-21629 | DOCX to HTML conversion issue with spaces between text (tabs) | Bug |
WORDSNET-21757 | Importing content from XML files to the DOCX: New style introduced in the output | Bug |
WORDSNET-21633 | DOCX-HTML-DOCX conversion issue with image position | Bug |
WORDSNET-21923 | Three rendering tests fail in parallel mode | Bug |
WORDSNET-22091 | Resaving DOCX file corrupts table in output file | Bug |
WORDSNET-22092 | FileCorruptedException is thrown while importing DOC file | Bug |
WORDSNET-22039 | Legend of chart is displayed in output PDF when Legend.Position is set to None | Bug |
WORDSNET-21934 | Color issue while converting docx to pdf in aspose.words java | Bug |
WORDSNET-22097 | Table.ConvertToHorizontallyMergedCells throws IndexOutOfRangeException for table created with DocumentBuilder | Bug |
WORDSNET-22098 | Nested EQ fields are not properly rendered | Bug |
WORDSNET-21942 | Document.UpdateFields throws System.ArgumentOutOfRangeException | Bug |
WORDSNET-14585 | Problems with MS-Word Compatibility | Bug |
WORDSNET-21728 | Vector Arrows in Latex Math Equations got Corrupted (Question Marks) during Open/Save a DOCX | Bug |
WORDSNET-21945 | DOCX to PDF Basque language word converted to English | Bug |
WORDSNET-21794 | System.Xml.XmlException is thrown by InsertHtml | Bug |
WORDSNET-22105 | Output file is corrupted after appending content | Bug |
WORDSNET-22038 | Data Label of chart does not display in output PDF | Bug |
WORDSNET-21984 | Saving invalid word document file cause hanging program | Bug |
WORDSNET-22115 | Aspose.Words.FileCorruptedException is thrown while loading DOCX | Bug |
WORDSNET-22114 | Field value is changed in output PDF | Bug |
WORDSNET-22112 | GetStartPageIndex throws System.ArgumentNullException | Bug |
WORDSNET-21992 | X axis of Chart is lost after DOCX to PDF conversion | Bug |
WORDSNET-18461 | DOCX to PDF conversion issue with hindi text | Bug |
WORDSNET-21996 | Analyze thread locks used in code | Bug |
WORDSNET-22119 | Certain RTF to HTML hangs process | Bug |
WORDSNET-22110 | RemoveContainingFields breaks SEQ functionality | Bug |
WORDSNET-22000 | DOCX to HTML: Adobe fonts displayed differently than with MS Word | Bug |
WORDSNET-22130 | Document.AcceptAllRevisions method does not work as expected | Bug |
WORDSNET-21671 | Backward HTML converter does not process external styles like inline | Bug |
WORDSNET-21745 | DOCX to PDF conversion issue with ExportDocumentStructure (incorrect table tags) | Bug |
WORDSNET-22017 | Page number using LayoutCollector.GetStartPageIndex raising exception | Bug |
WORDSNET-21521 | PDF/A-1a fails accessibility check with textbox | Bug |
WORDSNET-4585 | SYMBOL field is not properly rendered. | Bug |
WORDSNET-14734 | Incorrect Bold Run attribute after GetExpandedRunPr() | Bug |
WORDSNET-14372 | An extra list item appears in a document imported from HTML | Bug |
WORDSNET-20911 | Word2013 and Word2019 shows document differently | Bug |
WORDSNET-3389 | Range comment around a shape not preserved during open/save | Bug |
WORDSNET-19407 | List item’s indent is incorrect after roundtrip DOCX-HTML-DOCX | Bug |
WORDSNET-6412 | NodeCopier does not handle section break correctly | Bug |
WORDSNET-8987 | Incorrect position of a shape with pushed anchor | Bug |
Public API and Backward Incompatible Changes
This section lists public API changes that were introduced in Aspose.Words 21.5. It includes not only new and obsoleted public methods, but also a description of any changes in the behavior behind the scenes in Aspose.Words which may affect existing code. Any behavior introduced that could be seen as regression and modifies the existing behavior is especially important and is documented here.
Moved public C++ header files according to namespace names
Related issue: WORDSCPP-1076
Starting with this release, the public C++ header files are located according to the namespace names. i.e. Aspose::Words::Document
is now located in Aspose.Words.Cpp/Document.h
instead of Aspose.Words.Cpp/Model/Document/Document.h
. Headers on the old paths are still available and redirect to the new paths.
Added advanced typography support with HarfBuzz
Related issue: WORDSCPP-793
We have enabled advanced typography support. We have prepared Aspose.Words.Shaping.HarfBuzz package. This package uses HarfBuzz text shaping engine to perform text shaping.
Usage example:
// Open a document
auto doc = MakeObject<Document>(u"OpenType.Document.docx");
// When text shaper factory is set, layout starts to use OpenType features.
// An Instance property returns static BasicTextShaperCache object wrapping HarfBuzzTextShaperFactory
doc->get_LayoutOptions()->set_TextShaperFactory(HarfBuzzTextShaperFactory::get_Instance());
// Render the document to PDF format
doc->Save(u"OpenType.Document.pdf");
Added a new value to public enumeration StyleIdentifier
Related issue: WORDSNET-21757
A new value is added to the public enumeration StyleIdentifier:
/// <summary>
/// The Smart Link style.
/// </summary>
SmartLink = 371
Use Case: Explains how to use StyleIdentifier.SmartLink enumeration value.
auto builder = MakeObject<DocumentBuilder>();
auto normalStyle = builder->get_Document()->get_Styles()->idx_get(StyleIdentifier::Normal);
auto smartLinkStyle = builder->get_Document()->get_Styles()->idx_get(StyleIdentifier::SmartLink);
smartLinkStyle->get_Font()->set_Size(normalStyle->get_Font()->get_Size());
Added MailMerge.RestartListsAtEachSection property to control list numbering restart
Related issue: WORDSNET-22032
We have implemented the MailMerge.RestartListsAtEachSection property to control whether or not list numbering is restarted at each section when mail merge is performed. It is true by default to mimic Word behaviour, but can be set to false if the customer wants continuous numbering.
/// <summary>
/// Gets or sets a value indicating whether lists are restarted at each section after executing of a mail merge.
/// </summary>
/// <remarks>
/// The default value is <b>true</b>.
/// </remarks>
public bool RestartListsAtEachSection { get; set; }
Use Case:
auto document = MakeObject<Document>();
document->get_Lists()->Add(ListTemplate::NumberDefault);
document->get_Lists()->Add(ListTemplate::OutlineNumbers);
document->get_Lists()->Add(ListTemplate::BulletDefault);
document->get_MailMerge()->set_RestartListsAtEachSection(false);
Added new members to ShapeType enum
Related issue: WORDSNET-20197
The following new members have been added to the ShapeType enum. The members are applicable only for DML shapes.
public enum ShapeType
{
...
/// <summary>
/// Heptagon.
/// </summary>
Heptagon = 210,
/// <summary>
/// Cloud.
/// </summary>
Cloud = 211,
/// <summary>
/// Six-pointed star.
/// </summary>
Seal6 = 212,
/// <summary>
/// Seven-pointed star.
/// </summary>
Seal7 = 213,
/// <summary>
/// Ten-pointed star.
/// </summary>
Seal10 = 214,
/// <summary>
/// Twelve-pointed star.
/// </summary>
Seal12 = 215,
/// <summary>
/// Swoosh arrow.
/// </summary>
SwooshArrow = 216,
/// <summary>
/// Teardrop.
/// </summary>
Teardrop = 217,
/// <summary>
/// Square tabs.
/// </summary>
SquareTabs = 218,
/// <summary>
/// Plaque tabs.
/// </summary>
PlaqueTabs = 219,
/// <summary>
/// Pie.
/// </summary>
Pie = 220,
/// <summary>
/// Wedge pie.
/// </summary>
WedgePie = 221,
/// <summary>
/// Inverse line.
/// </summary>
InverseLine = 222,
/// <summary>
/// Math plus.
/// </summary>
MathPlus = 223,
/// <summary>
/// Math minus.
/// </summary>
MathMinus = 224,
/// <summary>
/// Math multiply.
/// </summary>
MathMultiply = 225,
/// <summary>
/// Math divide.
/// </summary>
MathDivide = 226,
/// <summary>
/// Math equal.
/// </summary>
MathEqual = 227,
/// <summary>
/// Math not equal.
/// </summary>
MathNotEqual = 228,
/// <summary>
/// Non-isosceles trapezoid.
/// </summary>
NonIsoscelesTrapezoid = 229,
/// <summary>
/// Left-right circular arrow.
/// </summary>
LeftRightCircularArrow = 230,
/// <summary>
/// Left-right ribbon.
/// </summary>
LeftRightRibbon = 231,
/// <summary>
/// Left circular arrow.
/// </summary>
LeftCircularArrow = 232,
/// <summary>
/// Frame.
/// </summary>
Frame = 233,
/// <summary>
/// Half frame.
/// </summary>
HalfFrame = 234,
/// <summary>
/// Funnel.
/// </summary>
Funnel = 235,
/// <summary>
/// Six-tooth gear.
/// </summary>
Gear6 = 236,
/// <summary>
/// Nine-tooth gear.
/// </summary>
Gear9 = 237,
/// <summary>
/// Decagon.
/// </summary>
Decagon = 238,
/// <summary>
/// Dodecagon.
/// </summary>
Dodecagon = 239,
/// <summary>
/// Diagonal stripe.
/// </summary>
DiagonalStripe = 240,
/// <summary>
/// Corner.
/// </summary>
Corner = 241,
/// <summary>
/// Corner tabs.
/// </summary>
CornerTabs = 242,
/// <summary>
/// Chord.
/// </summary>
Chord = 243,
/// <summary>
/// Chart plus.
/// </summary>
ChartPlus = 244,
/// <summary>
/// Chart star.
/// </summary>
ChartStar = 245,
/// <summary>
/// Chart X.
/// </summary>
ChartX = 246
}
Added new public methods StructuredDocumentTag.SetCheckedSymbol() and StructuredDocumentTag.SetUncheckedSymbol()
Related issue: WORDSNET-21818
New public methods SetCheckedSymbol() and SetUncheckedSymbol() have been added to the StructuredDocumentTag class:
/// <summary>
/// Sets the symbol used to represent the checked state of a check box content control.
/// </summary>
/// <param name="characterCode">The character code for the specified symbol.</param>
/// <param name="fontName">The name of the font that contains the symbol.</param>
/// <remarks>
/// <para>Accessing this method will only work for <see cref="Markup.SdtType.Checkbox"/> SDT types.</para>
/// <para>For all other SDT types exception will occur.</para>
/// </remarks>
public void SetCheckedSymbol(int characterCode, string fontName);
/// <summary>
/// Sets the symbol used to represent the unchecked state of a check box content control.
/// </summary>
/// <param name="characterCode">The character code for the specified symbol.</param>
/// <param name="fontName">The name of the font that contains the symbol.</param>
/// <remarks>
/// <para>Accessing this method will only work for <see cref="Markup.SdtType.Checkbox"/> SDT types.</para>
/// <para>For all other SDT types exception will occur.</para>
/// </remarks>
public void SetUncheckedSymbol(int characterCode, string fontName);
Use Case: Explains how to set the checked and unchecked symbols for the SDT of the ‘SdtType.Checkbox’ type.
auto doc = MakeObject<Document>();
auto tag = MakeObject<StructuredDocumentTag>(doc, SdtType::Checkbox, MarkupLevel::Block);
doc->get_Sections()->idx_get(0)->get_Body()->AppendChild(tag);
tag->SetCheckedSymbol(0x00A9, u"Times New Roman");
tag->SetUncheckedSymbol(0x00AE, u"Times New Roman");
doc->Save(u"output.docx");
Added new public property Document.LayoutOptions.CommentDisplayMode
Related issue: WORDSNET-21645
Added the ability to use PDF annotations to display user comments. The comment display mode is now set via the Document.LayoutOptions.CommentDisplayMode property:
/// <summary>
/// Gets or sets the way comments are rendered.
/// Default value is <see cref="CommentDisplayMode.ShowInBalloons"/>.
/// </summary>
/// <remarks>
/// Note that revisions are not rendered in balloons for <see cref="CommentDisplayMode .ShowInAnnotations"/>.
/// </remarks>
public CommentDisplayMode CommentDisplayMode
Document.LayoutOptions.ShowComments property was marked as obsolete:
/// <summary>
/// Gets or sets indication of whether comments are rendered.
/// Default is True.
/// This property is obsolete. Use <see cref="LayoutOptions.CommentDisplayMode"/> property instead.
/// </summary>
[Obsolete("This property is obsolete. Use CommentDisplayMode property instead.")]
public bool ShowComments
// False == CommentDisplayMode.Hide
// True == CommentDisplayMode.ShowInBalloons
The following comment display modes are now available:
/// <summary>
/// Specifies the rendering mode for document comments.
/// </summary>
public enum CommentDisplayMode
{
/// <summary>
/// No document comments are rendered.
/// </summary>
Hide,
/// <summary>
/// Renders document comments in balloons in the margin. This is the default value.
/// </summary>
ShowInBalloons,
/// <summary>
/// Renders document comments in annotations. This is only available for Pdf format.
/// </summary>
ShowInAnnotations
}
CommentDisplayMode.ShowInAnnotations is only available in Pdf1.7 and Pdf1.5 for user comments (revisions are not supported). In other formats ShowInAnnotations will work similar to Hide.
Note: It is required to rebuild the document page layout (via Document.UpdatePageLayout() method) after changing the Document.LayoutOptions values.
Use Case: Explains how to set CommentDisplayMode.
auto doc = MakeObject<Document>(u"input.docx");
doc->get_LayoutOptions()->set_CommentDisplayMode(CommentDisplayMode::ShowInAnnotations);
doc->Save(u"output.pdf");
Use Case:
auto doc = MakeObject<Document>(u"input.docx");
doc->get_LayoutOptions()->set_CommentDisplayMode(CommentDisplayMode::ShowInAnnotations);
doc->Save(u"output-pdf.pdf"); // This is a new way to display comments available for Pdf(not supported for Pdf/A).
doc->Save(u"output-xps.xps"); // When saving to any other format, it works in the same way as CommentDisplayMode.Hide.
doc->get_LayoutOptions()->set_CommentDisplayMode(CommentDisplayMode::Hide);
doc->UpdatePageLayout();
doc->Save(u"output-hide.pdf"); //This is similar to the obsolete option ShowComments=false
doc->get_LayoutOptions()->set_CommentDisplayMode(CommentDisplayMode::ShowInBalloons);
doc->UpdatePageLayout();
doc->Save(u"output-balloon.pdf"); //This is similar to the obsolete option ShowComments=true