/* Copyright (c) 2008 Google 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 com.google.gdata.data.extensions;
import com.google.gdata.util.common.xml.XmlWriter;
import com.google.gdata.data.BaseEntry;
import com.google.gdata.data.Extension;
import com.google.gdata.data.ExtensionDescription;
import com.google.gdata.data.ExtensionPoint;
import com.google.gdata.data.ExtensionProfile;
import com.google.gdata.data.ExtensionVisitor;
import com.google.gdata.data.ExtensionVisitor.StoppedException;
import com.google.gdata.util.Namespaces;
import com.google.gdata.util.ParseException;
import com.google.gdata.util.XmlParser;
import org.xml.sax.Attributes;
import java.io.IOException;
import java.util.ArrayList;
/**
* GData schema extension describing a place (not necessarily a specific
* geographical location).
*
*
*/
public class Where extends ExtensionPoint implements Extension {
/** Relation type. Describes the meaning of this location. */
public static final class Rel {
/** Place where the enclosing event occurs. */
public static final String EVENT = null;
/** Secondary location. */
public static final String EVENT_ALTERNATE = Namespaces.gPrefix + "event.alternate";
/** Nearby parking lot. */
public static final String EVENT_PARKING = Namespaces.gPrefix + "event.parking";
}
/** Constructs an empty Where instance. */
public Where() {}
/** Constructs a new Where instance using the specified parameters. */
public Where(String rel, String label, String valueString) {
this.rel = rel;
this.label = label;
this.valueString = valueString;
}
/** Describes the meaning of this location. */
protected String rel;
public String getRel() { return rel; }
public void setRel(String v) { rel = v; }
/**
* User-readable label that identifies this location in case multiple
* locations may be present.
*/
protected String label;
public String getLabel() { return label; }
public void setLabel(String v) { label = v; }
/** Text description of the place. */
protected String valueString;
public String getValueString() { return valueString; }
public void setValueString(String v) { valueString = v; }
/** Nested person or venue (Contact) entry. */
protected EntryLink<?> entryLink;
public EntryLink<?> getEntryLink() { return entryLink; }
public void setEntryLink(EntryLink<?> v) { entryLink = v; }
/** Returns the suggested extension description. */
public static ExtensionDescription getDefaultDescription() {
ExtensionDescription desc = new ExtensionDescription();
desc.setExtensionClass(Where.class);
desc.setNamespace(Namespaces.gNs);
desc.setLocalName("where");
desc.setRepeatable(true);
return desc;
}
@Override
protected void visitChildren(ExtensionVisitor ev) throws StoppedException {
if (entryLink != null) {
visitChild(ev, entryLink);
}
super.visitChildren(ev);
}
@Override
public void generate(XmlWriter w, ExtensionProfile extProfile)
throws IOException {
ArrayList<XmlWriter.Attribute> attrs = new ArrayList<XmlWriter.Attribute>();
if (rel != null) {
attrs.add(new XmlWriter.Attribute("rel", rel));
}
if (label != null) {
attrs.add(new XmlWriter.Attribute("label", label));
}
if (valueString != null) {
attrs.add(new XmlWriter.Attribute("valueString", valueString));
}
generateStartElement(w, Namespaces.gNs, "where", attrs, null);
if (entryLink != null) {
entryLink.generate(w, extProfile);
}
// Invoke ExtensionPoint.
generateExtensions(w, extProfile);
w.endElement(Namespaces.gNs, "where");
}
@Override
public XmlParser.ElementHandler getHandler(ExtensionProfile extProfile,
String namespace, String localName, Attributes attrs) {
return new Handler(extProfile);
}
/** <g:where> parser. */
private class Handler extends ExtensionPoint.ExtensionHandler {
public Handler(ExtensionProfile extProfile) {
super(extProfile, Where.class);
}
@Override
public void processAttribute(String namespace,
String localName,
String value) {
if (namespace.equals("")) {
if (localName.equals("rel")) {
rel = value;
} else if (localName.equals("label")) {
label = value;
} else if (localName.equals("valueString")) {
valueString = value;
}
}
}
@Override
public XmlParser.ElementHandler getChildHandler(String namespace,
String localName,
Attributes attrs)
throws ParseException, IOException {
if (namespace.equals(Namespaces.g)) {
if (localName.equals("entryLink")) {
entryLink = new EntryLink<BaseEntry<?>>();
return entryLink.getHandler(extProfile, namespace, localName, attrs);
}
}
return super.getChildHandler(namespace, localName, attrs);
}
}
}