List of usage examples for javax.xml.stream.events XMLEvent isEndElement
public boolean isEndElement();
From source file:org.apache.olingo.client.core.serialization.AtomGeoValueDeserializer.java
private MultiLineString multiLineString(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final SRID srid) throws XMLStreamException { final List<LineString> lineStrings = new ArrayList<LineString>(); boolean foundEndProperty = false; while (reader.hasNext() && !foundEndProperty) { final XMLEvent event = reader.nextEvent(); if (event.isStartElement() && event.asStartElement().getName().equals(Constants.QNAME_LINESTRING)) { lineStrings.add(lineString(reader, event.asStartElement(), type, null)); }//from w w w . j a v a 2s. c o m if (event.isEndElement() && start.getName().equals(event.asEndElement().getName())) { foundEndProperty = true; } } return new MultiLineString(GeoUtils.getDimension(type), srid, lineStrings); }
From source file:org.apache.olingo.client.core.serialization.AtomGeoValueDeserializer.java
private MultiPolygon multiPolygon(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final SRID srid) throws XMLStreamException { final List<Polygon> polygons = new ArrayList<Polygon>(); boolean foundEndProperty = false; while (reader.hasNext() && !foundEndProperty) { final XMLEvent event = reader.nextEvent(); if (event.isStartElement() && event.asStartElement().getName().equals(Constants.QNAME_POLYGON)) { polygons.add(polygon(reader, event.asStartElement(), type, null)); }/*from w w w .j a v a 2 s .co m*/ if (event.isEndElement() && start.getName().equals(event.asEndElement().getName())) { foundEndProperty = true; } } return new MultiPolygon(GeoUtils.getDimension(type), srid, polygons); }
From source file:org.apache.olingo.client.core.serialization.AtomGeoValueDeserializer.java
private GeospatialCollection collection(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final SRID srid) throws XMLStreamException { final List<Geospatial> geospatials = new ArrayList<Geospatial>(); boolean foundEndCollection = false; while (reader.hasNext() && !foundEndCollection) { final XMLEvent event = reader.nextEvent(); if (event.isStartElement() && event.asStartElement().getName().equals(Constants.QNAME_GEOMEMBERS)) { boolean foundEndMembers = false; while (reader.hasNext() && !foundEndMembers) { final XMLEvent subevent = reader.nextEvent(); if (subevent.isStartElement()) { geospatials.add(deserialize(reader, subevent.asStartElement(), GeoUtils.getType( GeoUtils.getDimension(type), subevent.asStartElement().getName().getLocalPart()))); }//from ww w. j av a 2 s . c o m if (subevent.isEndElement() && Constants.QNAME_GEOMEMBERS.equals(subevent.asEndElement().getName())) { foundEndMembers = true; } } } if (event.isEndElement() && start.getName().equals(event.asEndElement().getName())) { foundEndCollection = true; } } return new GeospatialCollection(GeoUtils.getDimension(type), srid, geospatials); }
From source file:org.apache.olingo.commons.core.data.AtomGeoValueDeserializer.java
private List<Point> points(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final String crs) throws XMLStreamException { final List<Point> result = new ArrayList<Point>(); boolean foundEndProperty = false; while (reader.hasNext() && !foundEndProperty) { final XMLEvent event = reader.nextEvent(); if (event.isCharacters() && !event.asCharacters().isWhiteSpace()) { final String[] pointInfo = event.asCharacters().getData().split(" "); final Point point = new Point(GeoUtils.getDimension(type), crs); try { point.setX(EdmDouble.getInstance().valueOfString(pointInfo[0], null, null, Constants.DEFAULT_PRECISION, Constants.DEFAULT_SCALE, null, Double.class)); point.setY(EdmDouble.getInstance().valueOfString(pointInfo[1], null, null, Constants.DEFAULT_PRECISION, Constants.DEFAULT_SCALE, null, Double.class)); } catch (EdmPrimitiveTypeException e) { throw new XMLStreamException("While deserializing point coordinates as double", e); }/* w w w .j a v a 2 s .co m*/ result.add(point); } if (event.isEndElement() && start.getName().equals(event.asEndElement().getName())) { foundEndProperty = true; } } return result; }
From source file:org.apache.olingo.commons.core.data.AtomGeoValueDeserializer.java
private MultiPoint multipoint(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final String crs) throws XMLStreamException { List<Point> points = Collections.<Point>emptyList(); boolean foundEndProperty = false; while (reader.hasNext() && !foundEndProperty) { final XMLEvent event = reader.nextEvent(); if (event.isStartElement() && event.asStartElement().getName().equals(Constants.QNAME_POINTMEMBERS)) { points = points(reader, event.asStartElement(), type, null); }/*from w ww . ja v a 2s.c om*/ if (event.isEndElement() && start.getName().equals(event.asEndElement().getName())) { foundEndProperty = true; } } return new MultiPoint(GeoUtils.getDimension(type), crs, points); }
From source file:org.apache.olingo.commons.core.data.AtomGeoValueDeserializer.java
private Polygon polygon(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final String crs) throws XMLStreamException { List<Point> extPoints = null; List<Point> intPoints = null; boolean foundEndProperty = false; while (reader.hasNext() && !foundEndProperty) { final XMLEvent event = reader.nextEvent(); if (event.isStartElement()) { if (event.asStartElement().getName().equals(Constants.QNAME_POLYGON_EXTERIOR)) { extPoints = points(reader, event.asStartElement(), type, null); }//from w ww. j ava 2s .c om if (event.asStartElement().getName().equals(Constants.QNAME_POLYGON_INTERIOR)) { intPoints = points(reader, event.asStartElement(), type, null); } } if (event.isEndElement() && start.getName().equals(event.asEndElement().getName())) { foundEndProperty = true; } } return new Polygon(GeoUtils.getDimension(type), crs, intPoints, extPoints); }
From source file:org.apache.olingo.commons.core.data.AtomGeoValueDeserializer.java
private MultiLineString multiLineString(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final String crs) throws XMLStreamException { final List<LineString> lineStrings = new ArrayList<LineString>(); boolean foundEndProperty = false; while (reader.hasNext() && !foundEndProperty) { final XMLEvent event = reader.nextEvent(); if (event.isStartElement() && event.asStartElement().getName().equals(Constants.QNAME_LINESTRING)) { lineStrings.add(lineString(reader, event.asStartElement(), type, null)); }//from w w w. ja va 2 s . co m if (event.isEndElement() && start.getName().equals(event.asEndElement().getName())) { foundEndProperty = true; } } return new MultiLineString(GeoUtils.getDimension(type), crs, lineStrings); }
From source file:org.apache.olingo.commons.core.data.AtomGeoValueDeserializer.java
private MultiPolygon multiPolygon(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final String crs) throws XMLStreamException { final List<Polygon> polygons = new ArrayList<Polygon>(); boolean foundEndProperty = false; while (reader.hasNext() && !foundEndProperty) { final XMLEvent event = reader.nextEvent(); if (event.isStartElement() && event.asStartElement().getName().equals(Constants.QNAME_POLYGON)) { polygons.add(polygon(reader, event.asStartElement(), type, null)); }//ww w. j av a 2 s.co m if (event.isEndElement() && start.getName().equals(event.asEndElement().getName())) { foundEndProperty = true; } } return new MultiPolygon(GeoUtils.getDimension(type), crs, polygons); }
From source file:org.apache.olingo.commons.core.data.AtomGeoValueDeserializer.java
private GeospatialCollection collection(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final String crs) throws XMLStreamException { final List<Geospatial> geospatials = new ArrayList<Geospatial>(); boolean foundEndCollection = false; while (reader.hasNext() && !foundEndCollection) { final XMLEvent event = reader.nextEvent(); if (event.isStartElement() && event.asStartElement().getName().equals(Constants.QNAME_GEOMEMBERS)) { boolean foundEndMembers = false; while (reader.hasNext() && !foundEndMembers) { final XMLEvent subevent = reader.nextEvent(); if (subevent.isStartElement()) { geospatials.add(deserialize(reader, subevent.asStartElement(), GeoUtils.getType( GeoUtils.getDimension(type), subevent.asStartElement().getName().getLocalPart()))); }/*from ww w . ja v a2 s.c o m*/ if (subevent.isEndElement() && Constants.QNAME_GEOMEMBERS.equals(subevent.asEndElement().getName())) { foundEndMembers = true; } } } if (event.isEndElement() && start.getName().equals(event.asEndElement().getName())) { foundEndCollection = true; } } return new GeospatialCollection(GeoUtils.getDimension(type), crs, geospatials); }
From source file:org.apache.olingo.commons.core.data.AtomPropertyDeserializer.java
private Value fromPrimitive(final XMLEventReader reader, final StartElement start, final EdmTypeInfo typeInfo) throws XMLStreamException { Value value = null;//from ww w. j a va2s. co m boolean foundEndProperty = false; while (reader.hasNext() && !foundEndProperty) { final XMLEvent event = reader.nextEvent(); if (event.isStartElement() && typeInfo != null && typeInfo.getPrimitiveTypeKind().isGeospatial()) { final EdmPrimitiveTypeKind geoType = EdmPrimitiveTypeKind.valueOfFQN(version, typeInfo.getFullQualifiedName().toString()); value = new GeospatialValueImpl( this.geoDeserializer.deserialize(reader, event.asStartElement(), geoType)); } if (event.isCharacters() && !event.asCharacters().isWhiteSpace() && (typeInfo == null || !typeInfo.getPrimitiveTypeKind().isGeospatial())) { value = new PrimitiveValueImpl(event.asCharacters().getData()); } if (event.isEndElement() && start.getName().equals(event.asEndElement().getName())) { foundEndProperty = true; } } return value; }