Aspose.Words for C++ 20.11 Release Notes
Major Features
Starting from this release, we are beginning to publish the Windows x86 version of Aspose.Words for C++.
We have added the following features from Aspose.Words for .NET on this regular monthly release:
- Document.SpellingChecked and Document.GrammarChecked properties were exposed publicly.
- Charts data points API was extended.
- Implemented basic support for rendering fonts with legacy Arabic encodings.
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 a 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 advanced typography based on the HarfBuzz shaper.
- The current release does not support loading PDF documents.
- The current release has limited support for database features - C++ does not have a 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-805 | Provide Apose.Words for C++ 32 bit version | New Feature |
WORDSCPP-1027 | Provide a step by step guide to configure Aspose.Words for C++ in Linux projects | Bug |
WORDSCPP-1029 | Check Compatibility of Words & Slides C++ APIs when used in the same Linux Project | Bug |
WORDSCPP-1032 | Provide example to convert System::IO::MemoryStream to our own type, such as vector<unsigned char> |
Bug |
WORDSNET-10130 | Implement table row wrapping around floaters as MS Word 2013 does | New Feature |
WORDSNET-16527 | Incorrect RTL table row wrapping around a floater in 2013 mode | New Feature |
WORDSNET-18416 | DOCX to PDF conversion issue with table position | Enhancement |
WORDSNET-20148 | Table row does not break across pages | Enhancement |
WORDSNET-20626 | Converting DOC/DOCX to PDF - Page break issue | Enhancement |
WORDSNET-21179 | Saving requires a seekable stream | Enhancement |
WORDSNET-14311 | Font type is changed after converting Word to PDF | Enhancement |
WORDSNET-21147 | Expected a value between 0 and 22024 error occurs during Rendering a DOC | Bug |
WORDSNET-21198 | Creating instance of LayoutEnumerator throws System.NullReferenceException | Bug |
WORDSNET-13856 | DOCX to PDF conversion issue with Arabic font rendering | Bug |
WORDSNET-21240 | Font size of the text is changed after re-saving BIDI RTF | Bug |
WORDSNET-21265 | Missing half of file when saving same DOCX file twice | Bug |
WORDSNET-5827 | Table overflow problem, while saving a document with PdfSaveOptions | Bug |
WORDSNET-18262 | Charts x-axis values and their layout is incorrect in PDF | Bug |
WORDSNET-4745 | Export theme fonts to RTF | Bug |
WORDSNET-11765 | Some characters are not rendering in PS | Bug |
WORDSNET-18874 | ChartSeries.DataPoints.Count returns incorrect value | Bug |
WORDSNET-21201 | Field result incorrectly compared | Bug |
WORDSNET-11769 | Some characters are not rendering in PostScript | Bug |
WORDSNET-21007 | Content misplaced after DOC to PDF conversion | Bug |
WORDSNET-21013 | DivideByZeroException when call UpdatePageLayout for attached document | Bug |
WORDSNET-13875 | Spell check disabled after a document save | Bug |
WORDSNET-18286 | The font is missing in the output PDF document | Bug |
WORDSNET-21209 | Content control does not lock after inserting HTML | Bug |
WORDSNET-17381 | Arabic Fonts not rendering correctly in PDF | Bug |
WORDSNET-21217 | Some tests failed upon converting | Bug |
WORDSNET-11515 | AW layout may not match to MS Word when a font Spacing is negative (condensed) | Bug |
WORDSNET-21220 | Empty SDT rendered as a control to PDF leads to incorrect aps tree structure | Bug |
WORDSNET-21045 | System.NullReferenceException during DOCX to PDF conversion | Bug |
WORDSNET-20203 | Property inheritance issue of chart data labels | Bug |
WORDSNET-18656 | Issue with SDT blocks when Section break inside it | Bug |
WORDSNET-21225 | PDF can not be opened | Bug |
WORDSNET-21226 | Incorrect position of SVG images grouped together | Bug |
WORDSNET-20427 | Page number renders incorrectly in output PDF | Bug |
WORDSNET-19794 | Large memory consumption during get document statistics | Bug |
WORDSNET-20429 | Document’s text is pushed down to next pages in output PDF | Bug |
WORDSNET-20952 | Investigate whether SkiaSharp blur effect can improve performance in .NET Standard version | Bug |
WORDSNET-20125 | DOCX to PDF conversion issue with font rendering | Bug |
WORDSNET-21042 | Custom properties do not export in output PDF | Bug |
WORDSNET-21074 | Implement conversion of images from EMF to PNG during import for DOC format | Bug |
WORDSNET-21075 | Cropping SVG images is ignored | Bug |
WORDSNET-21076 | DOCX to HTML conversion hangs | Bug |
WORDSNET-21079 | DOCX to PDF conversion issue with text position | Bug |
WORDSNET-20809 | Large memory consumption during DOCX to PDF conversion | Bug |
WORDSNET-21204 | Image RelativeHorizontalPosition does not set correctly in ODT | Bug |
WORDSNET-20305 | Content overlaps hides header’s content in PDF | Bug |
WORDSNET-21141 | MailMerge.ExecuteWithRegions throws System.ArgumentException | Bug |
WORDSNET-21031 | EMF converted from SVG is truncated in output Word document | Bug |
WORDSNET-21099 | Incorrect X-Axis tickmarks in charts when converting DOCX to PDF | Bug |
WORDSNET-21214 | System.IndexOutOfRangeException is thrown when Noto font is set using TextWatermarkOptions | Bug |
WORDSNET-20924 | Incorrect page range extraction | Bug |
WORDSNET-21122 | Debug.Assert fires during fields updates | Bug |
WORDSNET-21126 | Image size is reduced after inserting RTF into a document using InsertDocument | Bug |
WORDSNET-21128 | DOCX to PDF conversion: System.InvalidOperationException | Bug |
WORDSNET-21131 | INDEX field - customizing the separator between item name and page number | Bug |
WORDSNET-21134 | Protected document crashes the MS Word | Bug |
WORDSNET-21136 | Images (pages) are lost after DOCX to PDF conversion | Bug |
WORDSNET-21138 | Content in the last cell of the table get duplicated after breaking the mapping | Bug |
WORDSNET-21267 | Can not convert from PDF to Markdown | Bug |
WORDSNET-21150 | Debug.Assert fires in UpdateTableBlockRow method | Bug |
WORDSNET-21104 | Hyperlink inserted via ReportingEngine does not navigate to the bookmarked location | Bug |
WORDSNET-21195 | System.NullReferenceException occurs upon DOCX to PDF conversion | Bug |
WORDSNET-21152 | System.ArgumentException while save DOCX to Html | Bug |
WORDSNET-21233 | Table.InsertAfter throws System.InvalidOperationException | Bug |
WORDSNET-20403 | Horizontal Category Axis Text of Chart has Incorrect Angle when Converting to Image | Bug |
WORDSNET-21160 | Exception raised when reading CHM file | Bug |
WORDSNET-21162 | Data labels of the category axis are rendered horizontally after converting to PDF | Bug |
WORDSNET-21167 | Contents are pushed down to next pages after DOCX to PDF conversion | Bug |
WORDSNET-21202 | Incorrect cropping of textbox contents | Bug |
WORDSNET-21281 | RemoveStaticFields with MailMerge: The hyperlinks are no longer working in the output | Bug |
WORDSNET-21270 | Aspose.Words cannot open WordML with <w:tab w:val=“start” /> | Bug |
WORDSNET-20548 | Transparent images in generated RTF have black background | Bug |
WORDSNET-8318 | FieldCode of a deleted REF field appears in fixed page formats | Bug |
WORDSNET-8215 | Hebrew content in dropdown form fields is inverted during Doc to TIFF conversion | Bug |
WORDSNET-8532 | RenderedDocument.Pages.Count return incorrect value | Bug |
WORDSNET-4008 | Shape is improperly rendered | Bug |
WORDSNET-11161 | Hidden text should not be hyphenated | Bug |
WORDSNET-19910 | Footnotes are rendered wrong | Bug |
WORDSNET-21057 | Shapes are overlapped after DOCX to PDF conversion | Bug |
WORDSNET-21184 | Document.UpdateFields throws System.NullReferenceException | Bug |
Public API and Backward Incompatible Changes
This section lists public API changes that were introduced in Aspose.Words 20.11. 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 existing behavior is especially important and is documented here.
Added a new public properties Document.SpellingChecked and Document.GrammarChecked
Related issue: WORDSNET-13875
Added a new public property Document.SpellingChecked:
A new public property IgnorePrinterMetrics has been added to the LayoutOptions class.
/// <summary>
/// Returns <b>true</b> if the document has been checked for spelling.
/// </summary>
/// <remarks>
/// To recheck the spelling in the document, set this property to <b>false</b>.
/// </remarks>
public bool SpellingChecked
{
get;
set;
}
Added a new public property Document.GrammarChecked:
/// <summary>
/// Returns <b>true</b> if the document has been checked for grammar.
/// </summary>
/// <remarks>
/// To recheck the grammar in the document, set this property to <b>false</b>.
/// </remarks>
public bool GrammarChecked
{
get;
set;
}
Use Case:
Document doc = new Document(fileName);
// Verifying if this document has been checked for spelling or grammar.
if (doc.SpellingChecked || doc.GrammarChecked)
{
// The string with spelling errors.
doc.FirstSection.Body.FirstParagraph.FirstRun.Text = "The speeling in this documentz is all broked";
// Spelling check start.
doc.SpellingChecked = false;
// Grammar check start.
doc.GrammarChecked = false;
}
doc.Save(outFileName);
Changes in API of chart data points
The following changes in chart data points API have been implemented (WORDSNET-18874):
- The this property of the ChartDataPointCollection class has been changed to automatically create a data point if it does not exist yet. In the past, a point representing default data point properties was returned at this case.
- The Count property of the ChartDataPointCollection class has been changed to return a number of all data points of series, not just those that have non-default formatting, as it was in the previous versions of the software.
- The enumerator of the ChartDataPointCollection class has been changed to go through all data points of a series, not just those with non-default formatting.
- The ClearFormat method has been added to the ChartDataPointCollection class.
- The ClearFormat method has been added to the ChartDataPoint class.
- The Add, RemoveAt and Clear methods have been marked as obsolete. The collection contains all data points of series now and there is no need to add points to it. The RemoveAt and Clear methods actually reset the formatting of data point(s) to default values, so the ClearFormat methods can be used instead.
public class ChartDataPointCollection
{
/// <summary>
/// Adds new <see cref="ChartDataPoint"/> at the specified index.
/// </summary>
[Obsolete("All data points are available in this collection.")]
public ChartDataPoint Add(int index);
/// <summary>
/// Clears format of a <see cref="ChartDataPoint"/> at the specified index.
/// </summary>
[Obsolete("Use the ChartDataPoint.ClearFormat method instead.")]
public void RemoveAt(int index);
/// <summary>
/// Clears format of all <see cref="ChartDataPoint"/> in this collection.
/// </summary>
[Obsolete("Use the ClearFormat method instead.")]
public void Clear();
/// <summary>
/// Clears format of all <see cref="ChartDataPoint"/> in this collection.
/// </summary>
public void ClearFormat();
}
public class ChartDataPoint
{
/// <summary>
/// Clears format of this data point. The properties are set to the default values defined in the parent series.
/// </summary>
public void ClearFormat();
}
Use Case:
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
Shape shape = builder.InsertChart(ChartType.Line, 432, 252);
Chart chart = shape.Chart;
// Delete default generated series.
chart.Series.Clear();
ChartSeries series = chart.Series.Add("Series 1",
new string[] { "Category 1", "Category 2", "Category 3" },
new double[] { 1, 5, 4 });
series.Marker.Symbol = MarkerSymbol.Square;
series.Marker.Size = 10;
series.DataPoints[1].Marker.Symbol = MarkerSymbol.Circle;
series.DataPoints[1].Marker.Size = 15;
doc.Save(dir + "DataPoints.docx");
Aspose.Words now retains hyperlinks in the output PDF (breaking change)
Reference: WORDSNET-21281
In the past, we satisfied a customer’s request for removing HYPERLINK fields in TOC field result when the MailMergeCleanupOptions.RemoveStaticFields option is specified. However, MS Word retains them, and an ES customer asked us to change Aspose.Words' behaviour accordingly (WORDSNET-21281). We have implemented that in 20.11.
Here is the code snippet for backward compatibility:
foreach (FieldPageRef field in document.Range.Fields.OfType<FieldPageRef>())
field.Unlink();
foreach (FieldHyperlink field in document.Range.Fields.OfType<FieldHyperlink>())
{
HashSet<Inline> hyperlinkNodes = new HashSet<Inline>();
Node resultNode = field.Separator;
while (true)
{
if (resultNode is Inline inline && inline.Font.StyleIdentifier == StyleIdentifier.Hyperlink)
hyperlinkNodes.Add(inline);
if (resultNode == field.End)
break;
resultNode = resultNode.NextSibling;
}
// Unlink method clears Hyperlink style according to MS Word behaviour.
field.Unlink();
foreach (Inline inline in hyperlinkNodes)
inline.Font.StyleIdentifier = StyleIdentifier.Hyperlink;
}