Aspose.Words for Java 21.9 Release Notes

Major Features

There are 87 improvements and fixes in this regular monthly release. The most notable are:

  • License checking is updated to tolerate “suspicious” complex environments.
  • Added an ability to get CustomNumberStyleFormat of ListLevel.
  • Make it possible to get the string representation of the ListLevel object for the specified index.
  • Implemented export of triangular gradients into PDF in native (vector) form.
  • Implemented logical structure for comments rendering to PDF.

Full List of Issues Covering all Changes in this Release (Reported by Java Users)

Key Summary Category
WORDSNET-22525 NumberStyle CUSTOM for LEADING_ZERO formats New Feature
WORDSJAVA-2543 Aspose.Words 21.3: java.lang.UnsatisfiedLinkError prints to console, when using the library after jarjar repackager. Bug
WORDSJAVA-2585 java.lang.UnsatisfiedLinkError error occurs in the obfuscated assembly Bug
WORDSJAVA-2596 Aspose.Words 21.5: java.lang.IllegalArgumentException: bytes cannot be null error occurs in the obfuscated assembly Bug
WORDSJAVA-2604 Aspose.Words 21.6: Invalid license signature of JarJar-ed jar under Java 1.7 Bug
WORDSJAVA-2612 Invalid license signature error occurs even without setting license Bug
WORDSJAVA-2617 JavaFX - java.lang.IllegalStateException: Invalid license signature Bug
WORDSJAVA-2621 java.lang.ExceptionInInitializerError is thrown Confluence server plugin Bug
WORDSJAVA-2622 Exception thrown when using maven shade plugin Bug
WORDSJAVA-2626 java.lang.IllegalStateException: Invalid license signature is thrown on MAC Bug
WORDSJAVA-2627 java.lang.IllegalStateException: Invalid license signature is thrown on Linux Bug
WORDSJAVA-2628 java.lang.IllegalStateException: Invalid license signature. when loading a file in Spring boot application Bug
WORDSJAVA-2630 Quarkus application using Java 11 throws “Invalid license signature” exception Bug
WORDSJAVA-2637 Regression: WAR application shows: Invalid license signature. Please make sure the license file was not modified. Bug
WORDSJAVA-2639 java.lang.IllegalStateException is thrown while generating a report from JSON Bug
WORDSJAVA-2640 Exception Initializing Document Class Bug
WORDSJAVA-2642 “Invalid license signature” exception is thrown at Linux using Java 11 Bug
WORDSJAVA-2644 “Invalid license signature” exception is thrown while setting license at Windows10 and centos7 Bug
WORDSJAVA-2645 java.lang.IllegalStateException: Invalid license signature Bug
WORDSJAVA-2652 Regression: exception when instantiating Document object Bug
WORDSNET-22642 Wrong Replacement of Text Content if Bookmarks in Word DOCM Document are enclosing each other Bug
WORDSNET-21726 Comments do not survive two consecutive Document.compare calls Bug
WORDSNET-22026 Blank page is created after DOCX to PDF conversion Bug
WORDSNET-22587 Run.Font returns unexpected font family Bug
WORDSNET-22553 Document comparison: incorrect revision values for content control differences Bug
WORDSNET-22478 Page Number is rendered as English Number instead of Thai in output PDF Bug
WORDSNET-22442 System.IndexOutOfRangeException is thrown when DOC is saved to fixed file format Bug
WORDSNET-22604 System.ArgumentException is thrown while re-saving DOCM Bug
WORDSNET-21178 Part of equation text gets subscripted and misaligned  in output PDF Bug
WORDSNET-21718 Incorrect processing of Comment after comparing doucments Bug
WORDSNET-19443 A diagonal line in Chart deviates from its original position when rendering to JPG Bug
WORDSNET-22599 FindReplaceOptions.ApplyFont does not change the font size of text Bug

Full List of Issues Covering all Changes in this Release (Reported by .NET Users)

Key Summary Category
WORDSNET-17101 Optimize the PDF output size for document with multiple gradient filled shapes New Feature
WORDSNET-22577 Add feature to read custom properties from PDF New Feature
WORDSNET-22603 Add the ability to apply 3D effects to the image New Feature
WORDSNET-21742 Add feature to export language in Tag tab of object properties (ExportDocumentStructure) New Feature
WORDSNET-17842 Set Language in PDF Tag Properties New Feature
WORDSNET-18006 Widow/orphan rule not respected in the PDF output New Feature
WORDSNET-22576 Unable to SetLicense on Xamarin.iOS when using SDK Linking Enhancement
WORDSNET-15320 Document’s comment is lost after comparing documents Bug
WORDSNET-22614 The indentation of the equation changed after converting a Docx to PDF Bug
WORDSNET-22632 Find and Replace does not work with delete revisions Bug
WORDSNET-22558 Missed numbering revision when compare paragraphs with equal nsids in list definitions Bug
WORDSNET-22463 Performance issue with XML to PDF Conversion Bug
WORDSNET-22572 Shapes (Images) are lost after RTF to HTML conversion Bug
WORDSNET-18623 Incorrect keep with next rule handling for a tall table row on converting to pdf Bug
WORDSNET-22566 Image is lost when document is saved to DOCX with Iso29500_2008_Strict Bug
WORDSNET-22574 Bullet symbol is lost after Inserting HTML to DOCX Bug
WORDSNET-22542 A Table moves to previous Page during DOCX to PDF conversion Bug
WORDSNET-22516 Text/row moved to the previous page in converted PDF Bug
WORDSNET-22466 Insert Image Exif orientation ignored Bug
WORDSNET-22613 Empty page returns when split document on pages using ExtractPages Bug
WORDSNET-13652 InsertDocument splits one content control into multiple when document have section break Bug
WORDSNET-22547 VbaModuleCollection.Remove does not remove VBA module from document Bug
WORDSNET-22560 VBA Code is lost after modifying source code Bug
WORDSNET-22541 VbaProject  is removed after copying modules to existing VbaProject Bug
WORDSNET-22514 Incorrect expression evaluation for headers and footers in multi-section data bands for LINQ Reporting Engine Bug
WORDSNET-22636 Odd square characters are rendered in PDF Bug
WORDSNET-22601 fldrslt most recent calculated result of the field is empty after DOCX to RTF Conversion Bug
WORDSNET-22512 Text wrapping does not take place in PDF Bug
WORDSNET-22611 DOCX to PDF converting and displaying certain International Characters Bug
WORDSNET-21272 DataTable of chart is rendered incorrectly in output PDF Bug
WORDSNET-22568 Distance to the series labels is calculated incorrectly Bug
WORDSNET-22536 Document.UpdatePageLayout throws System.NullReferenceException Bug
WORDSNET-22459 NUMPAGES in Textbox is not updated after Joining documents Bug
WORDSNET-22464 Frame position in the footer is wrong Bug
WORDSNET-22570 Fix failed performance tests Bug
WORDSNET-22544 Update Benchmark to use DotNetBenchmark 0.13 Bug
WORDSNET-22435 Default ContinuosSectionRestart Enum Value & Associated MS Word Versions Bug
WORDSNET-22551 Reflection is shifted down if DmlEffectsRenderingModeCore is “Fine” Bug
WORDSNET-22399 Comments graphics is not tagged Bug
WORDSNET-21700 NullReferenceException is thrown when call UpdatePageLayout Bug
WORDSNET-19045 DOCX to PDF conversion issue with chart rendering Bug
WORDSNET-18088 DOC to PDF issue with chart rendering Bug
WORDSNET-22668 System.InvalidCastException occurs upon comparing DOC files Bug
WORDSNET-21976 Document Comparison-Redlining is not accurate Bug
WORDSNET-22489 Document.Compare discards formatting changes Bug
WORDSNET-22646 Aspose.Words.FileCorruptedException is thrown while loading DOC Bug
WORDSNET-21525 Run.Text does not insert line break for “\r” in table cell Bug
WORDSNET-22308 Range.Fields.Count returns zero for Word document Bug
WORDSNET-22622 Document.ExtractPages does not extract the last character of page using .NET 5.0 Bug
WORDSNET-22561 Table cell background color is changed in output PDF Bug
WORDSNET-22634 Calculation error in total number of pages Bug
WORDSNET-22151 Extra Page is created after DOCX to PDF conversion Bug
WORDSNET-22142 Multiple fonts in equations not aligned in PDF Bug
WORDSNET-17985 Document.Compare generates the incorrect output for comments Bug
WORDSNET-22363 LegendPosition.None does not hide the legend for Column3D chart Bug

Public API and Backward Incompatible Changes

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

Added a new public property ListLevel.CustomNumberStyleFormat

Related issue: WORDSNET-22525

A new public property ‘CustomNumberStyleFormat’ has been added to the ‘ListLevel’ class:

/// <summary>
/// Gets the custom number style format for this list level. For example: "a, ç, ĝ, ...".
/// </summary>
public string CustomNumberStyleFormat

Use Case: Explains how to get the custom number style format for the list level.

Document doc = new Document("in.docx");
ListLevel listLevel = doc.FirstSection.Body.Paragraphs[0].ListFormat.ListLevel;
string customNumberStyleFormat = string.Empty;
if (listLevel.NumberStyle == NumberStyle.Custom)
    customNumberStyleFormat = listLevel.CustomNumberStyleFormat;

Added a new public static method ListLevel.GetEffectiveValue()

Related issue: WORDSNET-22525

A new public static method ‘GetEffectiveValue()’ has been added to the ‘ListLevel’ class:

/// <summary>
/// Reports the string representation of the <see cref="ListLevel"/> object for the specified index
/// of the list item. Parameters specify the <see cref="Words.NumberStyle"/> and an optional format string
/// used when <see cref="NumberStyle.Custom"/> is specified.
/// </summary>
/// <param name="index">The index of the list item (must be in the range from 1 to 32767).</param>
/// <param name="numberStyle">
/// The <see cref="Words.NumberStyle"/> of the <see cref="ListLevel"/> object.
/// </param>
/// <param name="customNumberStyleFormat">
/// The optional format string used when <see cref="NumberStyle.Custom"/> is specified (e.g. "a, ç, ĝ, ...").
/// In other cases, this parameter must be null or empty.
/// </param>
/// <returns>
/// The string representation of the <see cref="ListLevel"/> object, described by the numberStyle parameter and
/// the customNumberStyleFormat parameter, in the list item at the position determined by the index parameter.
/// </returns>
/// <exception cref="ArgumentException">
/// customNumberStyleFormat is null or empty when the numberStyle is custom.-or-
/// customNumberStyleFormat is not null or empty when the numberStyle is non-custom.-or-
/// customNumberStyleFormat is invalid.
/// </exception>
/// <exception cref="ArgumentOutOfRangeException">index is out of range.</exception>
public static string GetEffectiveValue(int index, NumberStyle numberStyle, string customNumberStyleFormat);

Use Case: Explains how to get the string representation of the ListLevel object for the specified index of the list item.

Assert.AreEqual("iv", ListLevel.GetEffectiveValue(4, NumberStyle.LowercaseRoman, null));
Assert.AreEqual("005", ListLevel.GetEffectiveValue(5, NumberStyle.Custom, "001, 002, 003, ..."));