#region MigraDoc - Creating Documents on the Fly
//
// Authors:
// Stefan Lange
// Klaus Potzesny
// David Stephensen
//
// Copyright (c) 2001-2017 empira Software GmbH, Cologne Area (Germany)
//
// http://www.pdfsharp.com
// http://www.migradoc.com
// http://sourceforge.net/projects/pdfsharp
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
#endregion
using System;
using System.Collections.Generic;
namespace MigraDoc.DocumentObjectModel
{
///
/// Deals with image file names, searches along the image path, checks if images exist etc.
///
public class ImageHelper
{
///
/// Gets the first existing image from the subfolders.
///
public static string GetImageName(string root, string filename, string imagePath)
{
List subfolders = new List(imagePath.Split(new [] { ';' }, StringSplitOptions.RemoveEmptyEntries));
subfolders.Add("");
foreach (string subfolder in subfolders)
{
string fullname = System.IO.Path.Combine(System.IO.Path.Combine(root, subfolder), filename);
int pageNumber;
string realFile = ExtractPageNumber(fullname, out pageNumber);
#if !NETFX_CORE
if (System.IO.File.Exists(realFile))
return fullname;
#else
throw new NotImplementedException();
//if (System.IO.File.Exists(realFile))
// return fullname;
#endif
}
return null;
}
///
/// Gets a value indicating whether the filename given in the referenceFilename exists in the subfolders.
///
public static bool InSubfolder(string root, string filename, string imagePath, string referenceFilename)
{
List subfolders = new List(imagePath.Split(new char[] { ';' }, StringSplitOptions.RemoveEmptyEntries));
subfolders.Add("");
foreach (string subfolder in subfolders)
{
string fullname = System.IO.Path.Combine(System.IO.Path.Combine(root, subfolder), filename);
int pageNumber;
string realFile = ExtractPageNumber(fullname, out pageNumber);
#if !NETFX_CORE
if (System.IO.File.Exists(realFile))
{
if (fullname == referenceFilename)
return true;
}
#else
throw new NotImplementedException();
#endif
}
return false;
}
///
/// Extracts the page number if the path has the form 'MyFile.pdf#123' and returns
/// the actual path without the number sign and the following digits.
///
public static string ExtractPageNumber(string path, out int pageNumber)
{
// Note: duplicated from class XPdfForm
if (path == null)
throw new ArgumentNullException("path");
pageNumber = 0;
int length = path.Length;
if (length != 0)
{
length--;
if (Char.IsDigit(path, length))
{
while (Char.IsDigit(path, length) && length >= 0)
length--;
if (length > 0 && path[length] == '#')
{
// must have at least one dot left of colon to distinguish from e.g. '#123'
if (path.IndexOf('.') != -1)
{
pageNumber = Int32.Parse(path.Substring(length + 1));
path = path.Substring(0, length);
}
}
}
}
return path;
}
}
}