Browse our Products

Aspose.Words for C++ 21.3 Release Notes

Major Features

We have added the following features from Aspose.Words for .NET on this regular monthly release:

  • ClearQuickStyleGallery method of StyleCollection class was introduced.
  • Extended font API to set Fill properties of text.
  • Added an ability to work with child nodes of StructuredDocumentTag range.
  • Fixed issue with nested PDF bookmarks due to merged hidden paragraphs.

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 advanced typography based on HarfBuzz shaper.
  • 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

KeySummaryCategory
WORDSCPP-1007Page Splitter produces one extra pageBug
WORDSCPP-1035Memory leak (Linux package) - Memory Release Interface not available
WORDSNET-7788Support Font.Fill property and provide public members in APINew Feature
WORDSNET-18173Implement full functionality of MERGESEQ fieldNew Feature
WORDSNET-12810Provide bool FontSettings.SetFontsFolder overloadNew Feature
WORDSNET-20554Support dynamic cell merging in both directions simultaneously for LINQ Reporting EngineNew Feature
WORDSNET-21189Add feature to get the content of StructuredDocumentTagRangeStartNew Feature
WORDSNET-21785Remove styles from Style GalleryNew Feature
WORDSNET-9676Incorrect result of Node.NextSiblingEnhancement
WORDSNET-16692Improve path gradient rendering in .NET StandardBug
WORDSNET-12371Date field value is changed after re-saving ODTBug
WORDSNET-21788Memory consumption issueBug
WORDSNET-21539Very long backward conversion time HTML-to-DOCXBug
WORDSNET-21790Text from INCLUDETEXT field no longer appearing in mailmerge using Aspose WordsBug
WORDSNET-16714TestSaveToImageHorizaontalVerticalResolution is rendered improperlyBug
WORDSNET-18067UpdateFields does not update REF field with FieldRef.IncludeNoteOrComment attribute properlyBug
WORDSNET-18083TOC field with designated bookmark picks up SEQ entries from outside of it, until it is manually updatedBug
WORDSNET-21196Even/Odd numbered pages use wrong header/footer definitions upon RTF to PDF conversionBug
WORDSNET-10033Field.Type return incorrect value for SaveDate field when it is hiddenBug
WORDSNET-21511Two borders displayed instead of One in converted documentsBug
WORDSNET-21806DOCX to PDF: System.NullReferenceException thrownBug
WORDSNET-21681Part of text is lost during DOCX-to-Markdown conversionBug
WORDSNET-21777Shapes collection grows on each creation of LayoutCollectorBug
WORDSNET-16695TestPathGradientFill metafile is rendered improperlyBug
WORDSNET-21666Analyse Aspose.Words.Net NuGet Used By packagesBug
WORDSNET-18100Chart’s series do not render correctly in output PDFBug
WORDSNET-21667Turkish characters in the headings are corruptedBug
WORDSNET-21668Analyze LoadOptions inheritance treeBug
WORDSNET-19580Incorrect scaling of the horizontal date axis after conversion to PDFBug
WORDSNET-21820Incorrect Page Number Appears in Extracted DocumentBug
WORDSNET-21817Benchmark fails on .NetStandard projectsBug
WORDSNET-21502Document.PageCount throws System.DivideByZeroExceptionBug
WORDSNET-21861Text with “Berlin Sans FB Demi” is rendered incorrectly when converting to PNGBug
WORDSNET-21674Investigate and fix XXE vulnerabilities in Aspose.Words.NetBug
WORDSNET-20097Conversion to PDF displays hidden contentBug
WORDSNET-21678Text and Image are overlapped in output PDFBug
WORDSNET-19844A Table Repeats on all Pages of Rendered DocumentBug
WORDSNET-21682Base URL collisionBug
WORDSNET-198454 Pages DOC turned into a 86 Pages PDFBug
WORDSNET-18900Rounded corners are converted differently in HTMLBug
WORDSNET-21870Aspose.Words.FileCorruptedException occurs upon loading a DOCBug
WORDSNET-21687Bookmarks wrongly nested when hidden headingsBug
WORDSNET-21874Unexpected results produced when comparing Documents with ImagesBug
WORDSNET-21690System.NullReferenceException is thrown when call UpdatePageLayoutBug
WORDSNET-18817Low performance for Document.UpdatePageLayout() methodBug
WORDSNET-19614Value of attribute “id” of navPoint element is invalid for an XML nameBug
WORDSNET-21414Some Lines move to Next Pages in PDFBug
WORDSNET-21559Table moves and touches the left page edge in rendered documentBug
WORDSNET-21869System.IO.FileLoadException upon PDF to ODT conversionBug
WORDSNET-21403Wrong header & footer definitions used for odd and even numbered pages in PDF?sBug
WORDSNET-19911Even numbered pages use header/footer definition for odd numbered pageBug
WORDSNET-19138Header contents are lost in output PDF when FieldToc.UpdatePageNumbers is calledBug
WORDSNET-21710ArgumentException when save document to pngBug
WORDSNET-21708InvalidCastException  is thrown when call UpdatePageLayoutBug
WORDSNET-21408Missing textboxes during conversion from HTML to DOCXBug
WORDSNET-21712DOCX is corrupted after calling Document.UpdateFieldsBug
WORDSNET-21591Random content copied to the output after converting the DOCX file with Content ControlsBug
WORDSNET-21889FileCorruptedException occurs for a DOC | EndOfStreamException: Unable to read beyond the end of the streamBug
WORDSNET-21498Remove and modify rels - Shape.HRef does not workBug
WORDSNET-21723Reconfigure recipients list on JenkinsBug
WORDSNET-21729RTF content is not converted to PDF correctlyBug
WORDSNET-21734PDF output does not pass accessibility check for alt text for header imageBug
WORDSNET-20944Frozen application on Document.UpdatePageLayout()Bug
WORDSNET-21747The text labels for the bubble chart should not be drawn for zero valueBug
WORDSNET-21909Aspose.Words.FileCorruptedException occurs upon loading a DOCBug
WORDSNET-21749The document isn’t opened by APIBug
WORDSNET-21298ArgumentOutOfRangeException while extract pagesBug
WORDSNET-21483Image scaling is incorrect when custom resolution is specified.Bug
WORDSNET-21618Aspose.Words.FileCorruptedException error when converting HTML to DOCBug
WORDSNET-21619Japanese font is incorrectly rendered in output PDFBug
WORDSNET-21611Document.Compare throws System.NullReferenceExceptionBug
WORDSNET-21627Aspose.Words generates PDF document with incorrect compliance levelBug
WORDSNET-21641System.ArgumentOutOfRangeException occurs upon Word to PDF conversionBug
WORDSNET-21194Consider ignoring certain hyperlinks with special URI schemas when loading CHM documentsBug
WORDSNET-18968Inserting HTML lists causes empty list entryBug
WORDSNET-21769File Corrupted Exception occurs upon loading a Word DocumentBug
WORDSNET-21768Document.Compare throws ArgumentOutOfRangeExceptionBug
WORDSNET-21770StoreItemChecksum removed after re-saving documentBug
WORDSNET-21771Document.ExtractPages adds extra Table BordersBug
WORDSNET-21775Diagonal border appears in table after RTF to PDF conversionBug
WORDSNET-16681UnifiedTestSteveQuarles TIFF is has incorrect height.Bug
WORDSNET-21367Internal Aspose nuget server hangs sometimesBug
WORDSNET-21660Double border around image appears during HTML to Word conversionBug
WORDSNET-21326AW hangs with tha test document on Linux when Tahoma font is absentBug
WORDSNET-21743DOCX to PDF conversion issue with Arabic text renderingBug
WORDSNET-21507Specific Mhtml file can’t ne opened - Aspose.Words.FileCorruptedExceptionBug
WORDSNET-21714Arabic Text shifted up & few Arabic Words get cut post transformationBug
WORDSNET-21827Adding HtmlFragment does not fit to A4 pageBug

Public API and Backward Incompatible Changes

This section lists public API changes that were introduced in Aspose.Words 21.3. 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.

Aspose::Words::DigitalSignatures namespace was introduced

Due to refactoring work on Aspose::Words namespaces, DigitalSignature, DigitalSignatureCollection, DigitalSignatureUtil, DigitalSignatureType, CertificateHolder, SignOptions classes were moved to new separate namespace Aspose::Words::DigitalSignatures. In case of compilation error – please add using namespace Aspose::Words::DigitalSignatures and fix corresponding include directives.

Aspose::Words::Vba namespace was introduced

Due to refactoring work on Aspose::Words namespaces, VbaModule, VbaModuleCollection, VbaProject, VbaReference, VbaReferenceCollection, VbaModuleType, VbaReferenceType classes were moved to new separate namespace Aspose::Words::Vba. In case of compilation error – please add using namespace Aspose::Words::Vba and fix corresponding include directives.

ListFormat class was moved to Aspose::Words::Lists namespace

Due to refactoring work on Aspose::Words namespaces, ListFormat class was moved to the Aspose::Words::Lists namespace. In case of compilation error – please add using namespace Aspose::Words::Lists and fix corresponding include directives.

Added a new public method ClearQuickStyleGallery()

Related issue: WORDSNET-21785

Added a new public method ClearQuickStyleGallery() to StyleCollection class:

/// <summary>
/// Removes all styles from the Quick Style Gallery panel.
/// </summary>
void ClearQuickStyleGallery();

Use Case:

auto doc = MakeObject<Document>(docPath);
doc->get_Styles()->ClearQuickStyleGallery();
doc->Save(dsrPath, saveOptions);

Added warning callback property for font sources

Related issue: WORDSNET-12810

The following public property have been added to the FontSourceBase class:

/// <summary>
/// Called during processing of font source when an issue is detected that might result in formatting fidelity loss.
/// </summary>
System::SharedPtr<IWarningCallback> get_WarningCallback();
void set_WarningCallback(System::SharedPtr<IWarningCallback>);

Use Case:

auto settings = MakeObject<FontSettings>();
settings->SetFontsFolder(u"bad folder?", false);

auto source = settings->GetFontsSources()->idx_get(0);
auto wc = MakeObject<CustomWarningCallback>();
source->set_WarningCallback(wc);

auto fontInfos = source->GetAvailableFonts();

std::cout << wc->idx_gex(0)->get_Description() << '\n';

The output will be:

Error loading font from the folder "bad folder?": Illegal characters in path.

Extended font API to set Fill properties of text

Related issue: WORDSNET-7788

The Fill property can be accessed not only from ShapeBase, but also from Font object now:

/// <summary>
/// Represents fill formatting for an object.
/// </summary>
/// <remarks>
/// <p>Use the <see cref="ShapeBase.Fill"/> or <see cref="Font.Fill"/> property
/// to access fill properties of an object.
/// You do not create instances of the <see cref="Fill"/> class directly.</p>
///
/// <p>Although the <see cref="Fill"/> class provides properties to specify solid color fill only,
/// all of the more complex fill types, including as gradient, pattern and texture are fully preserved
/// during document open-save cycles.</p>
/// </remarks>
class Fill

Also, the following new public properties were added into the Fill class:

/// <summary>
/// Gets or sets a Color object that represents the foreground color for the fill.
/// </summary>
public Color ForeColor

/// <summary>
/// Gets or sets a Color object that represents the background color for the fill.
/// </summary>
public Color BackColor

/// <summary>
/// Gets or sets value that is <c>true</c> if the formatting applied to this instance, is visible.
/// </summary>
public bool Visible

/// <summary>
/// Gets or sets the degree of transparency of the specified fill as a value between 0.0 (opaque) and 1.0 (clear).
/// </summary>
/// <remarks>This property is the opposite of property <see cref="Opacity"/>.</remarks>
public double Transparency

/// <summary>
/// Gets or sets whether the fill rotates with the specified object.
/// </summary>
public bool RotateWithObject

/// <summary>
/// Gets a fill type.
/// </summary>
public FillType FillType

In addition, the following new public enumeration is added into Aspose.Words.Drawing namespace:

/// <summary>
/// Specifies fill type for a fillable object.
/// </summary>
public enum FillType
{
    /// <summary>
    /// Solid fill.
    /// </summary>
    Solid = 1,

    /// <summary>
    /// Patterned fill.
    /// </summary>
    Patterned = 2,
     
    /// <summary>
    /// Gradient fill.
    /// </summary>
    Gradient = 3,
     
    /// <summary>
    /// Textured fill.
    /// </summary>
    Textured = 4,
     
    /// <summary>
    /// Fill is the same as the background.
    /// </summary>
    Background = 5,
     
    /// <summary>
    /// Picture fill.
    /// </summary>
    Picture = 6
}

Use Case: Explains how to use Fill object for the Font.

// Open some document with text effects.
String myDir = u"example\\";
auto doc = MakeObject<Document>(myDir + u"TextTwoColorGradient.docx");

// Get Fill object for Font of the first Run.
auto fill = doc->get_FirstSection()->get_Body()->get_FirstParagraph()->get_Runs()->idx_get(0)->get_Font()->get_Fill();

// Check Fill properties of the Font.
std::cout << "The type of the fill is:" << System::ObjectExt::ToString(fill->get_FillType()).ToUtf8String() << '\n';
std::cout << "It is" << (fill->get_Visible() ? "" : " not") << " visible.\n";
std::cout << "The foreground color of the fill is: " << System::ObjectExt::ToString(fill->get_ForeColor()).ToUtf8String() << '\n';
std::cout << "The background color of the fill is: " << System::ObjectExt::ToString(fill->get_BackColor()).ToUtf8String() << '\n';
std::cout << "The fill is transparent at " << fill->get_Transparency()*100 << "%\n";
std::cout << "Note the opacity is opposite to transparency and has value: " << fill->get_Opacity() * 100 << "%\n";

// You can change, for example, the foreground color.
fill->set_ForeColor(Color::get_Yellow());
// Or even make it invisible.
fill->set_Visible(false);
// But let's make it visible again with foreground color Red.
fill->set_ForeColor(Color::get_Green());
// Note, it now has Solid type with 100% opacity.
std::cout << "\nThe fill is changed:\n";
std::cout << "The type of the fill is:" << System::ObjectExt::ToString(fill->get_FillType()).ToUtf8String() << '\n';
std::cout << "The foreground color of the fill is: " << System::ObjectExt::ToString(fill->get_ForeColor()).ToUtf8String() << '\n';
std::cout << "The fill opacity is " << fill->get_Opacity() * 100 << "%\n";

// Let's also change the transparency.
fill->set_Transparency(0.25);
std::cout << "\nThe fill is changed once again:\n";
std::cout << "The fill transparency is " << fill->get_Transparency() * 100 "%\n";

doc.Save(myDir + u"TextTwoColorGradient Out.docx");
/*
This code example produces the following results:

The type of the fill is: Gradient
It is visible.
The foreground color of the fill is: Color [A=255, R=128, G=0, B=0]
The background color of the fill is: Color [A=255, R=0, G=0, B=0]
The fill is transparent at 16%
Note the opacity is opposite to transparency and has value: 84%

The fill is changed:
The type of the fill is: Solid
The foreground color of the fill is: Color [A=255, R=0, G=128, B=0]
The fill opacity is 100%

The fill is changed once again:
The fill transparency is 25%
*/

Added an ability to work with child nodes of StructuredDocumentTagRangeStart

Related issue: WORDSNET-21189

The following public property have been added to the StructuredDocumentTagRangeStart class:

/// <summary>
/// Gets all nodes between this range start node and the range end node.
/// </summary>
System::SharedPtr<NodeCollection> get_ChildNodes();

The following public method have been added to the StructuredDocumentTagRangeStart class:

/// <summary>
/// Returns a live collection of child nodes that match the specified types.
/// </summary>
System::SharedPtr<NodeCollection> GetChildNodes(NodeType nodeType, bool isDeep)

These changes allows to enumerate child nodes of ranged structured document tag. For customer convenience feature follows CompositeNode pattern and returns live collection.

Use Case: Explains how to work with child nodes of StructuredDocumentTagRangeStart

auto doc = MakeObject<Document>(u"document-containing-ranged-structured-document-tag");
auto tag = System::DinamicCast<StructuredDocumentTagRangeStart>(doc->get_FirstSection()->get_Body()->get_FirstChild());

std::cout << tag->get_ChildNodes()->get_Count();

for (auto node : System::IterateOver(tag->get_ChildNodes()))
{
    std::cout << System::ObjectExt::ToString(node->get_NodeType()).ToUtf8String() << '\n';
}

fore(auto node : System::IterateOver(tag->GetChildNodes(NodeType::Run, true)))
{
    std::cout << node->GetText().ToUtf8String() << '\n';
}