blob: caecde7ea67fd170b87de56c6dbde9bca7304150 (
plain) (
blame)
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
|
package com.juick.rss.extension;
import com.rometools.rome.feed.module.Module;
import com.rometools.rome.io.ModuleGenerator;
import org.jdom2.Element;
import org.jdom2.Namespace;
import java.util.Collections;
import java.util.HashSet;
import java.util.Set;
/**
* Created by vt on 13/12/2016.
*/
public class JuickModuleGenerator implements ModuleGenerator {
private static final Namespace JUICK_NS = Namespace.getNamespace("juick", JuickModule.URI);
@Override
public String getNamespaceUri() {
return JuickModule.URI;
}
private static final Set NAMESPACES;
static {
Set nss = new HashSet();
nss.add(JUICK_NS);
NAMESPACES = Collections.unmodifiableSet(nss);
}
@Override
public Set getNamespaces() {
return NAMESPACES;
}
@Override
public void generate(Module module, Element element) {
// this is not necessary, it is done to avoid the namespace definition in every item.
Element root = element;
while (root.getParent()!=null && root.getParent() instanceof Element) {
root = (Element) element.getParent();
}
root.addNamespaceDeclaration(JUICK_NS);
JuickModule juickModule = (JuickModule) module;
if (juickModule.getUid() > 0) {
Element user = new Element("user", JUICK_NS);
user.setAttribute("uid", String.valueOf(juickModule.getUid()), JUICK_NS);
element.addContent(user);
}
}
}
|