forked from OpenFeign/feign
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSAXDecoder.java
More file actions
74 lines (67 loc) · 2.48 KB
/
SAXDecoder.java
File metadata and controls
74 lines (67 loc) · 2.48 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
/*
* Copyright 2013 Netflix, Inc.
*
* 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 feign.codec;
import org.xml.sax.ContentHandler;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xml.sax.XMLReader;
import org.xml.sax.helpers.XMLReaderFactory;
import javax.inject.Provider;
import java.io.IOException;
import java.io.Reader;
import java.lang.reflect.Type;
import static feign.Util.checkNotNull;
import static feign.Util.checkState;
public class SAXDecoder<T> implements Decoder.TextStream<T> {
/* Implementations are not intended to be shared across requests. */
public interface ContentHandlerWithResult<T> extends ContentHandler {
/*
* expected to be set following a call to {@link
* XMLReader#parse(InputSource)}
*/
T result();
}
private final Provider<? extends ContentHandlerWithResult<T>> handlers;
/**
* You must subclass this, in order to prevent type erasure on {@code T}. In
* addition to making a concrete type, you can also use the following form.
* <p/>
* <br>
* <p/>
* <pre>
* new SaxDecoder<Foo>(fooHandlers) {
* }; // note the curly braces ensures no type erasure!
* </pre>
*/
protected SAXDecoder(Provider<? extends ContentHandlerWithResult<T>> handlers) {
this.handlers = checkNotNull(handlers, "handlers");
}
@Override
public T decode(Reader reader, Type type) throws IOException, DecodeException {
ContentHandlerWithResult<T> handler = handlers.get();
checkState(handler != null, "%s returned null for type %s", this, type);
try {
XMLReader xmlReader = XMLReaderFactory.createXMLReader();
xmlReader.setFeature("http://xml.org/sax/features/namespaces", false);
xmlReader.setFeature("http://xml.org/sax/features/validation", false);
xmlReader.setContentHandler(handler);
xmlReader.parse(new InputSource(reader));
return handler.result();
} catch (SAXException e) {
throw new DecodeException(e.getMessage(), e);
}
}
}