• This repository has been archived on 18/Nov/2021
  • Stars
    star
    200
  • Rank 195,325 (Top 4 %)
  • Language
    Java
  • License
    Apache License 2.0
  • Created about 12 years ago
  • Updated about 3 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Java library for XML deserialization

GsonXml

GsonXml is a small library that allows using [Google Gson library] (https://code.google.com/p/google-gson/) for XML deserialization. The main idea is to convert a stream of XML pull parser events to a stream of JSON tokens. It's implemented by passing a custom JsonReader (that wraps XmlPullParsers) to Gson.

Though currently this library is not pretending to be the most efficient one for XML deserialization, it can be very useful.

Build Status

Compatible Gson versions: 2.1, 2.2.

Usage

/** Very simple model. */
public static class SimpleModel {
  private String name;
  private String description;

  public String getName() { return name; }
  public String getDescription() { return description; }
}


public void simpleTest() {
  
  XmlParserCreator parserCreator = new XmlParserCreator() {
    @Override
    public XmlPullParser createParser() {
      try {
        return XmlPullParserFactory.newInstance().newPullParser();
      } catch (Exception e) {
        throw new RuntimeException(e);
      }
    }
  };

  GsonXml gsonXml = new GsonXmlBuilder()
     .setXmlParserCreator(parserCreator)
     .create();

  String xml = "<model><name>my name</name><description>my description</description></model>";
  SimpleModel model = gsonXml.fromXml(xml, SimpleModel.class);
  
  assertEquals("my name", model.getName());
  assertEquals("my description", model.getDescription());
}

Use @SerializedName annotation to handle tag attributes and text nodes.

To illustrate, this XML

<person dob="01.01.1973" gender="male">
  <name>John</name>
  Likes traveling.
</person>

can be mapped to a POJO

public class Person {

  @SerializedName("@dob")
  private String dob;

  @SerializedName("@gender")
  private String gender;

  private String name;

  @SerializedName("$")
  private String description;

  // ...
}

You may also take a look at SimpleXmlReaderTest to see other samples.

Deserializing lists

Since there is no direct analogy of JSON arrays in XML, some ambiguity appears when you are trying to deserialize lists. GsonXmlBuilder has method setSameNameLists(boolean) in order to resolve this issue.

Considering the following Java class

class Container {
  List<Person> persons;
}

Call setSameNameLists(false) in order to deserialize such an object from the following XML:

<container>
  <persons>
    <any-tag-name id="1">
      <name>John</name>
    </any-tag-name>
    <any-tag-name id="2">
      <name>Mark</name>
    </any-tag-name>
  </persons>
</container>

Note that tag names of persons tag children nodes are ignored.

And call setSameNameLists(true) in order to deserialize such an object from another piece of XML:

<container>
  <person id="1">
    <name>John</name>
  </person>
  <person id="2">
    <name>Mark</name>
  </person>
</container>

Don't forget to put SerializedName('person') annotation on persons field.

Note that at the moment it's impossible to deserialize more than one list in the same container with option setSameNameLists(true).

Also be aware that currently it's impossible to deserialize XML structure where both types of lists exist.

Download

In a Maven project include the dependency:

<dependency>
  <groupId>com.stanfy</groupId>
  <artifactId>gson-xml-java</artifactId>
  <version>(insert latest version)</version>
</dependency>

Gradle example:

compile 'com.stanfy:gson-xml-java:0.1.+'

Android Notes

In order to use this library in Android project, copy only gson-xml and gson jars to the project libraries folder. kxml2 and xmlpull jars are not required since XmlPullParser is a part of Android SDK. To exclude them in your Gradle project use the following lines:

compile('com.stanfy:gson-xml-java:0.1.+') {
  exclude group: 'xmlpull', module: 'xmlpull'
}

Also be aware that Android SDK up to 'Ice Cream Sandwich' returns instance of ExpatPullParser when you call Xml.newPullParser(). And this parser does not support namespaces.

Read also this blog post about issues with Android XML parsers.

License

Copyright 2013 Stanfy 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.

More Repositories

1

spoon-gradle-plugin

Gradle plugin for Spoon.
Groovy
353
star
2

enroscar

A set of Android tools that facilitate apps development
Java
182
star
3

SwiftyMock

This repository contains helpers that make mocking in Swift much easier
Swift
77
star
4

goro

Android library for organizing your asynchronous tasks in queues
Java
63
star
5

helium

DSL for REST API specification, verification, and code generation.
Groovy
47
star
6

submit-to-appstore-objc

Checklist for iOS developer before submitting app to AppStore
41
star
7

ios-components-bikeshedding

often we create same components again and again. read this before estimation!
27
star
8

gradle-android-apt

Makes sources generated by annotation processors visible in Android Studio
Groovy
26
star
9

behave-rest

BDD-style Rest API testing tool
Python
20
star
10

parse-server-ansible

Create Parse Server backend based on MongoRocks and Parse Dashboard.
Shell
19
star
11

enroscar-async

Makes it easy to put your asynchronous operations behind Android's Loader
Java
12
star
12

cintegration

Scripts for iOS Continious Integration
Shell
10
star
13

xcode-templates

8
star
14

SFObjectMapping

Object mapping for JSON <-> PONSO transformations
Objective-C
5
star
15

SFCoreUtils

Number of useful beans: DateFormatter, UIView macroses, non-retaining arrays etc
Objective-C
5
star
16

hotandroid

Set of samples and tasks for HotCode conference.
Java
4
star
17

SFTransitionManager

Objective-C
3
star
18

ironman-bulb

Ironman bulb project based on ESP8266
Arduino
2
star
19

icfpc2014

Our rep for icfpc2014
Java
2
star
20

java-code-style

Stanfy checkstyle rules and IDE configuration for Java developers
Shell
2
star
21

mattock

JUnit4 tests runner for Android
Groovy
2
star
22

git-pulse

JavaScript
1
star