mirror of
https://github.com/UglyToad/PdfPig.git
synced 2025-04-05 20:55:01 +08:00
#483 make skip missing fonts even more resilient to nonsense files
This commit is contained in:
parent
2aed996319
commit
c8874c5984
34
src/UglyToad.PdfPig.Fonts/CorruptCompressedDataException.cs
Normal file
34
src/UglyToad.PdfPig.Fonts/CorruptCompressedDataException.cs
Normal file
@ -0,0 +1,34 @@
|
||||
namespace UglyToad.PdfPig.Fonts
|
||||
{
|
||||
using System;
|
||||
using System.Runtime.Serialization;
|
||||
|
||||
/// <summary>
|
||||
/// Thrown when a PDF contains an invalid compressed data stream.
|
||||
/// </summary>
|
||||
[Serializable]
|
||||
public class CorruptCompressedDataException : Exception
|
||||
{
|
||||
/// <inheritdoc />
|
||||
public CorruptCompressedDataException()
|
||||
{
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
public CorruptCompressedDataException(string message) : base(message)
|
||||
{
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
public CorruptCompressedDataException(string message, Exception inner) : base(message, inner)
|
||||
{
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
protected CorruptCompressedDataException(
|
||||
SerializationInfo info,
|
||||
StreamingContext context) : base(info, context)
|
||||
{
|
||||
}
|
||||
}
|
||||
}
|
@ -6,7 +6,7 @@
|
||||
|
||||
internal interface IResourceStore
|
||||
{
|
||||
void LoadResourceDictionary(DictionaryToken resourceDictionary);
|
||||
void LoadResourceDictionary(DictionaryToken resourceDictionary, InternalParsingOptions parsingOptions);
|
||||
|
||||
/// <summary>
|
||||
/// Remove any named resources and associated state for the last resource dictionary loaded.
|
||||
|
@ -33,7 +33,7 @@
|
||||
this.fontFactory = fontFactory;
|
||||
}
|
||||
|
||||
public void LoadResourceDictionary(DictionaryToken resourceDictionary)
|
||||
public void LoadResourceDictionary(DictionaryToken resourceDictionary, InternalParsingOptions parsingOptions)
|
||||
{
|
||||
lastLoadedFont = (null, null);
|
||||
|
||||
@ -43,7 +43,7 @@
|
||||
{
|
||||
var fontDictionary = DirectObjectFinder.Get<DictionaryToken>(fontBase, scanner);
|
||||
|
||||
LoadFontDictionary(fontDictionary);
|
||||
LoadFontDictionary(fontDictionary, parsingOptions);
|
||||
}
|
||||
|
||||
if (resourceDictionary.TryGet(NameToken.Xobject, out var xobjectBase))
|
||||
@ -132,7 +132,7 @@
|
||||
currentResourceState.Pop();
|
||||
}
|
||||
|
||||
private void LoadFontDictionary(DictionaryToken fontDictionary)
|
||||
private void LoadFontDictionary(DictionaryToken fontDictionary, InternalParsingOptions parsingOptions)
|
||||
{
|
||||
lastLoadedFont = (null, null);
|
||||
|
||||
@ -157,7 +157,18 @@
|
||||
continue;
|
||||
}
|
||||
|
||||
loadedFonts[reference] = fontFactory.Get(fontObject);
|
||||
try
|
||||
{
|
||||
loadedFonts[reference] = fontFactory.Get(fontObject);
|
||||
}
|
||||
catch
|
||||
{
|
||||
if (!parsingOptions.SkipMissingFonts)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
else if (pair.Value is DictionaryToken fd)
|
||||
{
|
||||
|
@ -1,5 +1,6 @@
|
||||
namespace UglyToad.PdfPig.Filters
|
||||
{
|
||||
using Fonts;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
@ -79,10 +80,17 @@
|
||||
memoryStream.ReadByte();
|
||||
memoryStream.ReadByte();
|
||||
|
||||
using (var deflate = new DeflateStream(memoryStream, CompressionMode.Decompress))
|
||||
try
|
||||
{
|
||||
deflate.CopyTo(output);
|
||||
return output.ToArray();
|
||||
using (var deflate = new DeflateStream(memoryStream, CompressionMode.Decompress))
|
||||
{
|
||||
deflate.CopyTo(output);
|
||||
return output.ToArray();
|
||||
}
|
||||
}
|
||||
catch (InvalidDataException ex)
|
||||
{
|
||||
throw new CorruptCompressedDataException("Invalid Flate compressed stream encountered", ex);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -479,7 +479,7 @@
|
||||
var hasResources = formStream.StreamDictionary.TryGet<DictionaryToken>(NameToken.Resources, pdfScanner, out var formResources);
|
||||
if (hasResources)
|
||||
{
|
||||
resourceStore.LoadResourceDictionary(formResources);
|
||||
resourceStore.LoadResourceDictionary(formResources, parsingOptions);
|
||||
}
|
||||
|
||||
// 1. Save current state.
|
||||
|
@ -63,13 +63,13 @@
|
||||
{
|
||||
var resource = pageTreeMembers.ParentResources.Dequeue();
|
||||
|
||||
resourceStore.LoadResourceDictionary(resource);
|
||||
resourceStore.LoadResourceDictionary(resource, parsingOptions);
|
||||
stackDepth++;
|
||||
}
|
||||
|
||||
if (dictionary.TryGet(NameToken.Resources, pdfScanner, out DictionaryToken resources))
|
||||
{
|
||||
resourceStore.LoadResourceDictionary(resources);
|
||||
resourceStore.LoadResourceDictionary(resources, parsingOptions);
|
||||
stackDepth++;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user