diff options
author | Tarun Gupta <tarun1995gupta@gmail.com> | 2015-06-10 18:32:35 (GMT) |
---|---|---|
committer | Tarun Gupta <tarun1995gupta@gmail.com> | 2015-06-16 19:11:04 (GMT) |
commit | b2a8ac9a0387a9a5e75e31f7704e62ac077faba4 (patch) | |
tree | 633f0aa33043bef9db2f677d6b0874552562db75 /src/com/isode/stroke/parser | |
parent | 2180f81bd45045021d98c3a2e0649f10680596f9 (diff) | |
download | stroke-b2a8ac9a0387a9a5e75e31f7704e62ac077faba4.zip stroke-b2a8ac9a0387a9a5e75e31f7704e62ac077faba4.tar.bz2 |
Add the UserTune Element.
Adds UserTune Element, its parser and Serializer.
License:
This patch is BSD-licensed, see Documentation/Licenses/BSD-simplified.txt for details.
Test-Information:
Tests added for UserTune Parser and UserTune Serializer.
Change-Id: I3330d8493c79c2305de426827b5018b68d5b8e1b
Diffstat (limited to 'src/com/isode/stroke/parser')
-rw-r--r-- | src/com/isode/stroke/parser/payloadparsers/FullPayloadParserFactoryCollection.java | 2 | ||||
-rw-r--r-- | src/com/isode/stroke/parser/payloadparsers/UserTuneParser.java | 87 |
2 files changed, 88 insertions, 1 deletions
diff --git a/src/com/isode/stroke/parser/payloadparsers/FullPayloadParserFactoryCollection.java b/src/com/isode/stroke/parser/payloadparsers/FullPayloadParserFactoryCollection.java index 7c9679b..ef491dd 100644 --- a/src/com/isode/stroke/parser/payloadparsers/FullPayloadParserFactoryCollection.java +++ b/src/com/isode/stroke/parser/payloadparsers/FullPayloadParserFactoryCollection.java @@ -71,7 +71,7 @@ public class FullPayloadParserFactoryCollection extends PayloadParserFactoryColl addFactory(new GenericPayloadParserFactory2<MAMResultParser>("result", "urn:xmpp:mam:0", this, MAMResultParser.class)); addFactory(new GenericPayloadParserFactory<MAMQueryParser>("query", "urn:xmpp:mam:0", MAMQueryParser.class)); addFactory(new GenericPayloadParserFactory<MAMFinParser>("fin", "urn:xmpp:mam:0", MAMFinParser.class)); - + addFactory(new GenericPayloadParserFactory<UserTuneParser>("tune", "http://jabber.org/protocol/tune", UserTuneParser.class)); //addFactory(new NicknameParserFactory()); PayloadParserFactory defaultFactory = new RawXMLPayloadParserFactory(); diff --git a/src/com/isode/stroke/parser/payloadparsers/UserTuneParser.java b/src/com/isode/stroke/parser/payloadparsers/UserTuneParser.java new file mode 100644 index 0000000..3526150 --- /dev/null +++ b/src/com/isode/stroke/parser/payloadparsers/UserTuneParser.java @@ -0,0 +1,87 @@ +/* + * Copyright (c) 2014 Isode Limited. + * All rights reserved. + * See the COPYING file for more information. + */ +/* + * Copyright (c) 2015 Tarun Gupta. + * Licensed under the simplified BSD license. + * See Documentation/Licenses/BSD-simplified.txt for more information. + */ + +package com.isode.stroke.parser.payloadparsers; + +import com.isode.stroke.parser.GenericPayloadParser; +import com.isode.stroke.parser.AttributeMap; +import com.isode.stroke.elements.UserTune; +import com.isode.stroke.base.NotNull; + +public class UserTuneParser extends GenericPayloadParser<UserTune> { + + private int level = 0; + private String currentText; + + public UserTuneParser() { + super(new UserTune()); + } + + /** + * @param element, NotNull. + * @param ns. + * @param attributes. + */ + @Override + public void handleStartElement(String element, String ns, AttributeMap attributes) { + if (level == 1) { + currentText = ""; + } + ++level; + } + + /** + * @param element, NotNull. + * @param ns. + */ + @Override + public void handleEndElement(String element, String ns) { + NotNull.exceptIfNull(element, "element"); + --level; + if (level == 1) { + try { + if (element.equals("artist")) { + getPayloadInternal().setArtist(currentText); + } + else if (element.equals("length")) { + getPayloadInternal().setLength(Integer.parseInt(currentText)); + } + else if (element.equals("rating")) { + getPayloadInternal().setRating(Integer.parseInt(currentText)); + } + else if (element.equals("source")) { + getPayloadInternal().setSource(currentText); + } + else if (element.equals("title")) { + getPayloadInternal().setTitle(currentText); + } + else if (element.equals("track")) { + getPayloadInternal().setTrack(currentText); + } + else if (element.equals("URI")) { + getPayloadInternal().setURI(currentText); + } + } + catch (NumberFormatException e) { + + } + } + } + + /** + * @param data, NotNull. + */ + @Override + public void handleCharacterData(String data) { + NotNull.exceptIfNull(data, "data"); + currentText += data; + } +}
\ No newline at end of file |