![JAR search and dependency download from the Maven repository](/logo.png)
org.apache.abdera.util.AbstractParser Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aem-sdk-api Show documentation
Show all versions of aem-sdk-api Show documentation
The Adobe Experience Manager SDK
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. 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. For additional information regarding
* copyright in this work, please see the NOTICE file in the top level
* directory of this distribution.
*/
package org.apache.abdera.util;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.Reader;
import java.nio.channels.Channels;
import java.nio.channels.ReadableByteChannel;
import javax.xml.stream.XMLStreamReader;
import org.apache.abdera.Abdera;
import org.apache.abdera.factory.Factory;
import org.apache.abdera.model.Document;
import org.apache.abdera.model.Element;
import org.apache.abdera.parser.ParseException;
import org.apache.abdera.parser.Parser;
import org.apache.abdera.parser.ParserOptions;
/**
* Abstract base implementation of Abdera Parser.
*
* @deprecated This API is deprecated as Apache Abdera is a retired project since 2017.
*/
@Deprecated(since = "2021-07-29")
public abstract class AbstractParser implements Parser {
protected Abdera abdera;
protected ParserOptions options;
protected AbstractParser() {
this(new Abdera());
}
protected AbstractParser(Abdera abdera) {
this.abdera = abdera;
}
public Abdera getAbdera() {
return abdera;
}
public void setAbdera(Abdera abdera) {
this.abdera = abdera;
}
public Factory getFactory() {
return getAbdera().getFactory();
}
public Document parse(InputStream in) throws ParseException {
return parse(in, null, getDefaultParserOptions());
}
public Document parse(XMLStreamReader reader) throws ParseException {
return parse(reader, null, getDefaultParserOptions());
}
public Document parse(InputStream in, String base) throws ParseException {
return parse(in, base, getDefaultParserOptions());
}
public Document parse(InputStream in, ParserOptions options) throws ParseException {
return parse(in, null, options);
}
public Document parse(InputStream in, String base, ParserOptions options) throws ParseException {
return parse(new InputStreamReader(in), base, options);
}
public Document parse(Reader in) throws ParseException {
return parse(in, null, getDefaultParserOptions());
}
public Document parse(Reader in, String base) throws ParseException {
return parse(in, base, getDefaultParserOptions());
}
public Document parse(Reader in, ParserOptions options) throws ParseException {
return parse(in, null, options);
}
public Document parse(ReadableByteChannel buf, ParserOptions options) throws ParseException {
return parse(buf, null, options);
}
public Document parse(ReadableByteChannel buf, String base, ParserOptions options) throws ParseException {
String charset = options.getCharset();
return parse(Channels.newReader(buf, charset != null ? charset : "utf-8"), base, options);
}
public Document parse(ReadableByteChannel buf, String base) throws ParseException {
return parse(buf, base, getDefaultParserOptions());
}
public Document parse(ReadableByteChannel buf) throws ParseException {
return parse(buf, null, getDefaultParserOptions());
}
public synchronized ParserOptions getDefaultParserOptions() {
if (options == null)
options = initDefaultParserOptions();
// Make a copy of the options, so that changes to it don't result in
// changes to the Parser's defaults. Also, this allows us to remain
// thread safe without having to make ParseOptions implementations
// synchronized.
try {
return (ParserOptions) options.clone();
} catch (CloneNotSupportedException cnse) {
// This shouldn't actually happen
throw new RuntimeException(cnse);
}
}
protected abstract ParserOptions initDefaultParserOptions();
public synchronized Parser setDefaultParserOptions(ParserOptions options) {
// Ok, we need to make a defensive copy of the options, since otherwise
// the caller still has access to the object, which means our access to
// it isn't certain to be thread safe.
try {
this.options = (options != null) ? (ParserOptions) options.clone() : initDefaultParserOptions();
return this;
} catch (CloneNotSupportedException cnse) {
// This shouldn't actually happen
throw new RuntimeException(cnse);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy