Aspose.Words for C++ 20.12 Release Notes

Major Features

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

  • Added an ability to allow embedding of PostScript Fonts upon save documents.
  • Implemented condition evaluation extension point.

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
WORDSNET-16895 Add feature to insert style separator using DOM New Feature
WORDSNET-18827 Add option to perform memory optimization while loading document New Feature
WORDSNET-21432 Check Aspose.Words for .NET Standard works with .NET 5.0 New Feature
WORDSNET-21102 Add feature to export inserted SVG as SVG in media folder New Feature
WORDSNET-21441 Provide access to common StructuredDocumentRangeStart properties New Feature
WORDSNET-11665 Macros better support including read/add/delete/import/edit New Feature
WORDSNET-18804 ManualLayout settings in dataLabel extLst should be taken into account Enhancement
WORDSNET-3863 Consider exposing FontAttr.SpecialHidden property Enhancement
WORDSNET-12430 Word spell checker not activated in converted DOCX Enhancement
WORDSNET-14063 ODT to PDF conversion issue with table’s rendering Enhancement
WORDSNET-21251 Contents of document are lost after DOCX to PDF Bug
WORDSNET-17941 Text in table’s cell is rendered on next line in output PDF Bug
WORDSNET-21467 “Unrecognized operand value in the formula.” exception when open document DOCX file Bug
WORDSNET-20722 Aspose.Words.FileCorruptedException occurs upon loading a DOCX Bug
WORDSNET-21485 List numbering updates when KeepSourceNumbering is true Bug
WORDSNET-21331 Incomplete rendering of barcode in TIFF Bug
WORDSNET-21337 Loading as RTF format: System.NotSupportedException: ‘Memory stream is not expandable.’ Bug
WORDSNET-21346 Hidden text in Word is shown on Aspose rendered PDF Bug
WORDSNET-21349 The w14:docId has been removed after re-saving Bug
WORDSNET-21017 Comments structure is not correct after generating document by LINQ Reporting Bug
WORDSNET-21371 Fixed layout HTML from Word does not print correctly Bug
WORDSNET-20711 Reporting engine does not populate all data when JSON data source is used Bug
WORDSNET-21373 Root resource is not found in a multipart structure exception when opening MHT file Bug
WORDSNET-21347 Document Comparison-Redlining is not accurate Bug
WORDSNET-20816 Text language is changed from Hebrew to Arabic after DOCX>HTML>DOCX Bug
WORDSNET-21378 System.NullReferenceException is thrown while saving RTF to PDF Bug
WORDSNET-21380 UpdateFields causes Process to hang after optimizing for Word 2016 Bug
WORDSNET-17565 Saving a word document as PDF cuts off some footer text Bug
WORDSNET-18375 Property PageCount returns more pages than exist in document Bug
WORDSNET-21385 System.ArgumentOutOfRangeException is thrown while saving DOCX to TXT Bug
WORDSNET-20997 Document.Compare produces revisions for unchanged images Bug
WORDSNET-21402 Process hangs during DOCX to PDF conversion Bug
WORDSNET-19255 Debug.Assert failure in the layout code when a DOCX document is converted to PDF Bug
WORDSNET-20364 Table aligment and font issue after DOCX - HTML - DOCX conversion Bug
WORDSNET-19042 Different Non Visual Properties for images (nvPicPr) in the same document Bug
WORDSNET-20704 Tab Stops of style are incorrect after copying style Bug
WORDSNET-18646 Small ellipses are deformed on rendering Bug
WORDSNET-20404 Chart Title should Render in Three Lines when Converting to Image Bug
WORDSNET-16702 Provide RenderToSize and RenderToScale methods through SkiaSharp.SKCanvas Bug
WORDSNET-20007 Parent node of Run node returns null after replacing text of Run node Bug
WORDSNET-20267 insertHTML - Big image containing math equations not visible in Word Bug
WORDSNET-21218 Left Indent lost after Appending Document Bug
WORDSNET-21411 Incorrect rendering of charts that contains series without Y-values (only X-valyes) Bug
WORDSNET-21413 Character spacing problem for Wingdings, Symbol upon RTF to PDF Conversion Bug
WORDSNET-19312 System.InvalidOperationException - too many styles in the document Bug
WORDSNET-19787 Document.Save does not save MHTML to PDF Bug
WORDSNET-21230 Table border size is increased after joining documents Bug
WORDSNET-20709 Unable to Extract Content from Bookmarks Bug
WORDSNET-21232 Long hand format lost if value over a billion Bug
WORDSNET-20752 MHTML to PDF fails to complete Bug
WORDSNET-21236 Calling UpdateFields before Rendering causes many Error! Reference source not found Bug
WORDSNET-20767 Table row is pushed in MW and not pushed in AW Bug
WORDSNET-20773 Incorrect comparison of Words Bug
WORDSNET-20776 Document can’t be loaded Bug
WORDSNET-20160 Document comparison result is different comparing to MS Word result Bug
WORDSNET-20173 MHTML to PDF conversion lasts for too long Bug
WORDSNET-20553 BookmarkEnd is created in another node DOCX is saved to HTML Bug
WORDSNET-21428 Extra missing line text cut off in PDF converted from the latest Aspose.Words Bug
WORDSNET-21242 System.ArgumentException is thrown while saving DOCX to HTML Bug
WORDSNET-21430 JsonDataSource throws System.Data.DuplicateNameException Bug
WORDSNET-21100 DOCX to HTML conversion issue with text shifting in tables cell using C# Bug
WORDSNET-21302 System.Text.DecoderFallbackException and System.Xml.XmlException Bug
WORDSNET-21248 Duplicate message content in converted PDF for SMIME Outlook Message conversion to PDF Bug
WORDSNET-20874 DOCX to PDF conversion issue with list item rendering Bug
WORDSNET-21436 w14:paraId and w14:textId removed after re-saving the document Bug
WORDSNET-21254 InvalidCastException while load document in .netcore Bug
WORDSNET-21405 Image is inserted incorrectly into textbox after mail merge Bug
WORDSNET-21255 System.ArgumentOutOfRangeException: ‘Index was out of range.’ is shown during UpdatePageLayout() Bug
WORDSNET-20897 HtmlSaveOptions.ScaleImageToShapeSize has no effect Bug
WORDSNET-20515 Spell Check Disabled after Aspose.Words' Find and Replace Operation Bug
WORDSNET-20910 A long paragraph with shape near the bottom occupies many pages Bug
WORDSNET-19275 Numbering chapters disappear during appending documents Bug
WORDSNET-21119 Incorrect rendering of series data label of PieChart. Bug
WORDSNET-20937 System.InvalidCastException is thrown while saving DOCX to HTML Bug
WORDSNET-21132 The root element “Document” is missing in document structure of PDF Bug
WORDSNET-20947 DOCX to PDF conversion issue with rectangle shape rendering Bug
WORDSNET-20948 DOCX to PDF conversion issue with shape Bug
WORDSNET-20951 Fill in Document.CompatibilityOptions according to LoadOptions.MswVersion when loading HTML Bug
WORDSNET-21139 HtmlFixedSave mirror hebrew inside shapes Bug
WORDSNET-21393 Unexpected page break in table issue - RTF to PDF Bug
WORDSNET-16606 DOCX to PDF conversion error: java.lang.IllegalStateException: Infinite loop detected Bug
WORDSNET-20737 DOCX to PDF conversion issue with comment rendering Bug
WORDSNET-21146 Table rows are rendered on the next page after DOCX to PDF conversion Bug
WORDSNET-21463 An exception was thrown while activating Kzb -> bec -> ?:_adB upon PDF import on .NET 5.0 Bug
WORDSNET-21276 Misaligned text and extra wrap in inserted SVG Bug
WORDSNET-21278 Document.Compare generates the incorrect revisions Bug
WORDSNET-21468 FileLoadException while opening PDF document. Bug
WORDSNET-20658 Conversion time issue while converting PDF to DOCX Bug
WORDSNET-21296 Paragraphs are changed to number list after joining document Bug
WORDSNET-21308 Empty extracted page Bug
WORDSNET-21303 Text from chevron list  (SmartArt Shape) rendered upside down in Html Fixed Bug
WORDSNET-20760 Issue rendering quote characters that appear inside of p, div or blockquote tags Bug
WORDSNET-9499 A DrawingML in Cell is pushed a few inches to the right in PDF Bug
WORDSNET-9833 Document.PageCount returns wrong value Bug
WORDSNET-10251 Text renders outside the right page edge in PDF Bug
WORDSNET-10180 DOCX to PDF conversion issue with content position Bug
WORDSNET-16093 Text overlapping in rendered PDF Bug
WORDSNET-20822 DOCX to PDF conversion issue with image quality Bug
WORDSNET-21287 Image is lost after conversion from HTML to DOCX Bug
WORDSNET-11193 Footnote and text position is changed after conversion from DOCX to PDF/PNG Bug
WORDSNET-10046 A DrawingML overlaps the content of Table Bug
WORDSNET-16693 TestDefect3702 image has incorrect dimensions Bug
WORDSNET-20971 Page Count issue Bug
WORDSNET-12923 DOCX to PDF conversion issue with shape’s position Bug
WORDSNET-9834 PAGE field value is calculated incorrectly Bug
WORDSNET-16094 Incorrect text rendering order in resultant PDF Bug

Public API and Backward Incompatible Changes

This section lists public API changes that were introduced in Aspose.Words 20.12. 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 property SaveOptions::AllowEmbeddingPostScriptFonts

Related issue: WORDSNET-21120

Added a new public property SaveOptions::AllowEmbeddingPostScriptFonts:

/// Gets a boolean value indicating whether to allow embedding fonts with PostScript outlines
/// when embedding TrueType fonts in a document upon it is saved.
/// The default value is <b>false</b>.
/// 
/// Note, Word does not embed PostScript fonts, but can open documents with embedded fonts of this type.
/// 
/// This option only works when <see cref="Aspose::Words::Fonts::FontInfoCollection::get_EmbedTrueTypeFonts">EmbedTrueTypeFonts</see> of the
/// <see cref="Aspose::Words::DocumentBase::get_FontInfos">FontInfos</see> property is set to <c>true</c>.
bool get_AllowEmbeddingPostScriptFonts() const;

/// Setter for Aspose::Words::Saving::SaveOptions::get_AllowEmbeddingPostScriptFonts
void set_AllowEmbeddingPostScriptFonts(bool value);

Use Case:

String testDir = u"\\TestDir\\";
auto doc = MakeObject<Document>();
auto builder = MakeObject<DocumentBuilder>(doc);
 
// Create some content that will use PostScript font.
builder->get_Font()->set_Name(u"PostScriptFont");
builder->Writeln(u"Some text with PostScript font.");
 
// Load the font with PostScript to use in the document.
auto otf = MakeObject<MemoryFontSource>(File::ReadAllBytes(testDir + u"PostScriptFont.otf")).dynamic_pointer_cast<FontSourceBase>();
auto sources = MakeArray<SharedPtr<FontSourceBase>>(otf);
doc->set_FontSettings(MakeObject<FontSettings>());
doc->get_FontSettings()->SetFontsSources(sources);
 
// Embed TrueType fonts.
doc->get_FontInfos->set_EmbedTrueTypeFonts(true);
// Allow embedding PostScript fonts while embedding TrueType fonts.
auto saveOptions = SaveOptions::CreateSaveOptions(SaveFormat::Docx);
saveOptions->set_AllowEmbeddingPostScriptFonts(true);
 
// Save document with embedded PostScript font.
doc->Save(testDir + u"out.docx", saveOptions);

Changed DocumentBuilder::InsertImage behavior when insert SVG images

We changed DocumentBuilder::InsertImage behavior when insert SVG. Earlier Aspose.Words inserted SVG as EMF metafile to keep the inserted image in vector representation. Now AW inserts SVG as PNG with svgBlip extension that contain the original SVG image, just like MS Word does.

Use Case 1:

auto doc = MakeObject<Document>();
auto builder = MakeObject<DocumentBuilder>(doc);
builder->InsertImage(u"test.svg");
doc->Save(u"out.docx");

SVG image is inserted into the document as PNG with svgBlip extension that contains the original vector SVG image representation.

Use Case 2 - Document is saved in old MS Word format:

auto doc = MakeObject<Document>();
auto builder = MakeObject<DocumentBuilder>(doc);
builder->InsertImage(u"test.svg");
doc->Save(u"out.doc");

SVG image is saved to output document as PNG, just like MS Word does.

Use Case 3 - Document is optimized for old versions of MS Word using OptimizeFor method:

auto doc = MakeObject<Document>();
doc->get_CompatibilityOptions->OptimizeFor(Settings::MsWordVersion::Word2003);
auto builder = MakeObject<DocumentBuilder>(doc);
builder->InsertImage(u"test.svg");
doc->Save(u"out.doc");

SVG is inserted into the document as EMF metafile to keep the image in vector representation (old Aspose.Word behavior).

Changed version of MS Word during import Html

Related issue: WORDSNET-20364

Previously, the LoadOptions::MswVersion property had no effect when loading documents from HTML and HTML-based formats (for example, MHTML). All documents were loaded as if no MswVersion were specified. This has been changed and now the HTML reader may load documents differently depending on the value of MswVersion. Since the default value of MswVersion is MsWordVersion.Word2019, by default HTML documents are loaded as if they are opened by MS Word 2019.

Customer may change this behavior by specifying the required version of MS Word in LoadOptions. For example:

auto loadOptions = MakeObject<LoadOptions>();
loadOptions->set_MswVersion(Settings::MsWordVersion::Word2010);
auto doc = MakeObject<Document>(u"in.html", loadOptions);

Implemented condition evaluation extension point

Related issue: WORDSNET-20913

We have implemented extension point for condition evaluation. This allows users to implement custom evaluation for the IF and COMPARE fields.

/// The comparison expression.
class ComparisonExpression final : public Object
{
public:
    /// Gets the left expression.
    String get_LeftExpression() const;

    /// Gets the comparison operator.
    String get_ComparisonOperator() const;

    /// Gets the right expression.
    String get_RightExpression() const;
};

/// The comparison evaluation result.
class ComparisonEvaluationResult final : public Object
{
public:
    /// Gets the comparison evaluation result.
    bool get_Result() const;

    /// Gets the failed comparison evaluation result's error message.
    String get_ErrorMessage() const;

    /// Creates a comparison evaluation result.
    ComparisonEvaluationResult(bool result);

    /// Creates a failed comparison evaluation result with the corresponding error message.
    ComparisonEvaluationResult(System::String errorMessage);
};


/// \interface IComparisonExpressionEvaluator
/// When implemented, allows to override default comparison expressions evaluation for the <see cref="Aspose::Words::Fields::FieldIf">FieldIf</see> and <see cref="Aspose::Words::Fields::FieldCompare">FieldCompare</see> fields.
/// 
/// @sa Aspose::Words::Fields::FieldOptions::get_ComparisonExpressionEvaluator
class IComparisonExpressionEvaluator : public Object
{
public:
    /// Evaluates comparison expression.
	/// <remarks>
	/// The implementation should return <b>null</b> to indicate that the default evaluation should be performed.
	/// </remarks>
    virtual SharedPtr<ComparisonEvaluationResult> Evaluate(SharedPtr<Field> field, SharedPtr<ComparisonExpression> expression) = 0; 
};

class FieldOptions final : public Object
{
public:
	/// Gets or sets the field comparison expressions evaluator.
	/// <seealso cref="IComparisonExpressionEvaluator"/>
	SharedPtr<IComparisonExpressionEvaluator> get_ComparisonExpressionEvaluator();
	void set_ComparisonExpressionEvaluator(SharedPtr<IComparisonExpressionEvaluator> value);
}

Use Case:

class ComparisonExpressionEvaluator : public IComparisonExpressionEvaluator
{
    using ThisType = ComparisonExpressionEvaluator;
    using BaseType = IComparisonExpressionEvaluator;
    using ThisTypeBaseTypesInfo = ::System::BaseTypesInfo<BaseType>;
    RTTI_INFO(ThisType, ThisTypeBaseTypesInfo);
public:
	ComparisonExpressionEvaluator(SharedPtr<ComparisonEvaluationResult> const& result)
    : mResult(result) { }
 
	SharedPtr<ComparisonEvaluationResult> Evaluate(SharedPtr<Field> field, SharedPtr<ComparisonExpression> expresion) override
	{
		return mResult;
	}
private:
	SharedPtr<ComparisonEvaluationResult> mResult;
};

auto result = MakeObject<ComparisonEvaluationResult>(true);
auto evaluator = MakeObject<ComparisonExpressionEvaluator>(result);
 
document->get_FieldOptions()->set_ComparisonExpressionEvaluator(evaluator);