package com.amazonaws.a2s.model;
import java.util.ArrayList;
import java.util.List;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlType;
/**
* <p>Java class for CartCreateRequest complex type.
*
* <p>The following schema fragment specifies the expected content contained within this class.
*
* <pre>
* <complexType name="CartCreateRequest">
* <complexContent>
* <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
* <sequence>
* <element name="MergeCart" type="{http://www.w3.org/2001/XMLSchema}string" minOccurs="0"/>
* <element name="Items" type="{http://webservices.amazon.com/AWSECommerceService/2007-10-29}CartCreateItems" minOccurs="0"/>
* <element name="ResponseGroup" maxOccurs="unbounded" minOccurs="0">
* <simpleType>
* <restriction base="{http://www.w3.org/2001/XMLSchema}string">
* <enumeration value="Request"/>
* <enumeration value="Cart"/>
* <enumeration value="CartSimilarities"/>
* <enumeration value="CartTopSellers"/>
* <enumeration value="CartNewReleases"/>
* </restriction>
* </simpleType>
* </element>
* </sequence>
* </restriction>
* </complexContent>
* </complexType>
* </pre>
* Generated by AWS Code Generator
* <p/>
* Thu Jan 10 05:27:59 PST 2008
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "CartCreateRequest", propOrder = {
"mergeCart",
"items",
"responseGroup"
})
public class CartCreateRequest {
@XmlElement(name = "MergeCart")
protected String mergeCart;
@XmlElement(name = "Items")
protected CartCreateItems items;
@XmlElement(name = "ResponseGroup")
protected List<String> responseGroup;
/**
* Gets the value of the mergeCart property.
*
* @return
* possible object is
* {@link String }
*
*/
public String getMergeCart() {
return mergeCart;
}
/**
* Sets the value of the mergeCart property.
*
* @param value
* allowed object is
* {@link String }
*
*/
public void setMergeCart(String value) {
this.mergeCart = value;
}
public boolean isSetMergeCart() {
return (this.mergeCart!= null);
}
/**
* Gets the value of the items property.
*
* @return
* possible object is
* {@link CartCreateItems }
*
*/
public CartCreateItems getItems() {
return items;
}
/**
* Sets the value of the items property.
*
* @param value
* allowed object is
* {@link CartCreateItems }
*
*/
public void setItems(CartCreateItems value) {
this.items = value;
}
public boolean isSetItems() {
return (this.items!= null);
}
/**
* Gets the value of the responseGroup property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the responseGroup property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getResponseGroup().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link String }
*
*
*/
public List<String> getResponseGroup() {
if (responseGroup == null) {
responseGroup = new ArrayList<String>();
}
return this.responseGroup;
}
public boolean isSetResponseGroup() {
return ((this.responseGroup!= null)&&(!this.responseGroup.isEmpty()));
}
public void unsetResponseGroup() {
this.responseGroup = null;
}
/**
* Sets the value of the MergeCart property.
*
* @param value
* @return
* this instance
*/
public CartCreateRequest withMergeCart(String value) {
setMergeCart(value);
return this;
}
/**
* Sets the value of the Items property.
*
* @param value
* @return
* this instance
*/
public CartCreateRequest withItems(CartCreateItems value) {
setItems(value);
return this;
}
/**
* Sets the value of the ResponseGroup property.
*
* @param values
* @return
* this instance
*/
public CartCreateRequest withResponseGroup(String... values) {
for (String value: values) {
getResponseGroup().add(value);
}
return this;
}
/**
* Sets the value of the responseGroup property.
*
* @param responseGroup
* allowed object is
* {@link String }
*
*/
public void setResponseGroup(List<String> responseGroup) {
this.responseGroup = responseGroup;
}
/**
*
* XML fragment representation of this object
*
* @return XML fragment for this object. Name for outer
* tag expected to be set by calling method. This fragment
* returns inner properties representation only
*/
protected String toXMLFragment() {
StringBuffer xml = new StringBuffer();
if (isSetMergeCart()) {
xml.append("<MergeCart>");
xml.append(escapeXML(getMergeCart()));
xml.append("</MergeCart>");
}
if (isSetItems()) {
CartCreateItems items = getItems();
xml.append("<Items>");
xml.append(items.toXMLFragment());
xml.append("</Items>");
}
java.util.List<String> responseGroupList = getResponseGroup();
for (String responseGroup : responseGroupList) {
xml.append("<ResponseGroup>");
xml.append(responseGroup + "");
xml.append("</ResponseGroup>");
}
return xml.toString();
}
/**
*
* Escape XML special characters
*/
private String escapeXML(String string) {
StringBuffer sb = new StringBuffer();
int length = string.length();
for (int i = 0; i < length; ++i) {
char c = string.charAt(i);
switch (c) {
case '&':
sb.append("&");
break;
case '<':
sb.append("<");
break;
case '>':
sb.append(">");
break;
case '\'':
sb.append("'");
break;
case '"':
sb.append(""");
break;
default:
sb.append(c);
}
}
return sb.toString();
}
}
|