Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.myfaces.trinidadinternal.share.xml;
import java.io.InputStream;
import java.io.IOException;
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xml.sax.SAXParseException;
import org.apache.myfaces.trinidad.logging.TrinidadLogger;
import org.apache.myfaces.trinidad.share.io.InputStreamProvider;
import org.apache.myfaces.trinidad.share.io.NameResolver;
import org.apache.myfaces.trinidadinternal.share.config.Configuration;
import org.apache.myfaces.trinidadinternal.share.config.ConfigurationImpl;
import org.apache.myfaces.trinidadinternal.share.io.CachingInputStreamProvider;
import org.apache.myfaces.trinidadinternal.share.io.DefaultNameResolver;
import org.apache.myfaces.trinidadinternal.share.expl.JavaMethod;
/**
* Utility class for XML parsing.
*
* @version $Name: $ ($Revision: adfrt/faces/adf-faces-impl/src/main/java/oracle/adfinternal/view/faces/share/xml/XMLUtils.java#0 $) $Date: 10-nov-2005.18:59:17 $
*/
public class XMLUtils
{
/**
* Parses an XML file, like the skinning .xss file. For includes, see parseInclude().
* @param context the current ParseContext, which will be cloned
* @param xmlProvider an XML provider
* @param manager a ParserManager
* @param resolver a NameResolver to locate the target
* @param sourceName the name of the target, relative to the current file
* @param expectedType the expected Java type of the target.
*/
static public Object parseSource(
ParseContext context,
XMLProvider xmlProvider,
ParserManager manager,
NameResolver resolver,
String sourceName,
Class> expectedType) throws IOException, SAXException
{
if (manager == null)
throw new NullPointerException();
if (expectedType == null)
throw new NullPointerException();
if (resolver == null)
throw new NullPointerException();
if (sourceName == null)
throw new NullPointerException();
if (context == null)
throw new NullPointerException();
if (xmlProvider == null)
xmlProvider = new JaxpXMLProvider();
InputStreamProvider provider = resolver.getProvider(sourceName);
Object cached = provider.getCachedResult();
if ((cached != null) && expectedType.isInstance(cached))
return cached;
TreeBuilder builder = new TreeBuilder(manager, expectedType);
InputStream stream = provider.openInputStream();
try
{
InputSource source = new InputSource(stream);
source.setSystemId(sourceName);
// Store a resolver relative to the file we're about to parse
setResolver(context, resolver.getResolver(sourceName));
setInputStreamProvider(context, provider);
// Step 6. Parse!
Object value = builder.parse(xmlProvider, source, context);
// Step 7. Store the cached result (if successful)
if (value != null)
provider.setCachedResult(value);
return value;
}
finally
{
stream.close();
}
}
/**
* Parses an include of an XML file. The include will be located using
* an already-stored NameResolver object.
*
* @see #getResolver
* @see #setResolver
* @param context the current ParseContext, which will be cloned
* @param sourceName the name of the target, relative to the current file
* @param expectedType the expected Java type of the target.
*/
@SuppressWarnings("unchecked")
static public Object parseInclude(
ParseContext context,
String sourceName,
Class> expectedType) throws IOException, SAXException
{
// Step 1. Find the name resolver.
NameResolver resolver = getResolver(context);
if (resolver == null)
{
_log(context, "Internal error: couldn't find NameResolver");
return null;
}
// Step 2. Find an InputStreamProvider. Mark a dependency on the base
// provider (if necessary)
InputStreamProvider provider = resolver.getProvider(sourceName);
InputStreamProvider baseProvider = getInputStreamProvider(context);
if (baseProvider instanceof CachingInputStreamProvider)
{
((CachingInputStreamProvider) baseProvider).addCacheDependency(provider);
}
// Step 3. Detect if this will be a circular include.
ArrayList