/*
* Copyright 2006-2017 ICEsoft Technologies Canada Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an "AS
* IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language
* governing permissions and limitations under the License.
*/
package org.icepdf.core.util.content;
import org.icepdf.core.pobjects.Resources;
import org.icepdf.core.util.Library;
import java.lang.reflect.Constructor;
import java.util.logging.Level;
import java.util.logging.Logger;
/**
* ContentParserFactory will reflectively load the PRO parsing engine
* if found on the class path.
*
* @since 5.0
*/
public class ContentParserFactory {
private static final Logger logger =
Logger.getLogger(ContentParserFactory.class.toString());
private static ContentParserFactory contentParserFactory;
private static final String N_CONTENT_PARSER =
"org.icepdf.core.util.content.NContentParser";
private static boolean foundPro;
static {
// check class bath for NFont library, and declare results.
try {
Class.forName(N_CONTENT_PARSER);
foundPro = true;
} catch (ClassNotFoundException e) {
logger.log(Level.FINE, "ICEpdf PRO was not found on the class path");
}
}
private ContentParserFactory() {
}
/**
* <p>Returns a static instance of the ContentParserclass.</p>
*
* @return instance of the ContentParser.
*/
public static ContentParserFactory getInstance() {
// make sure we have initialized the manager
if (contentParserFactory == null) {
contentParserFactory = new ContentParserFactory();
}
return contentParserFactory;
}
/**
* Factory call to return the content parser associated with the given
* product version.
*
* @param library document library
* @param resources page's parent resource object.
* @return implementation of the ContentParser interface.
*/
public ContentParser getContentParser(Library library, Resources resources) {
if (foundPro) {
// load each know file type reflectively.
try {
Class<?> contentParserClass = Class.forName(N_CONTENT_PARSER);
Class[] parserArgs = {Library.class, Resources.class};
Constructor fontClassConstructor =
contentParserClass.getDeclaredConstructor(parserArgs);
Object[] args = {library, resources};
return (ContentParser) fontClassConstructor.newInstance(args);
} catch (Throwable e) {
logger.log(Level.FINE, "Could not load font dictionary class", e);
}
}
return new OContentParser(library, resources);
}
}