* An array of objects that display the details about each Synthetics canary runtime version. *
*/ private java.util.List
     * A token that indicates that there is more data available. You can use this token in a subsequent
     * DescribeRuntimeVersions operation to retrieve the next set of results.
     * 
* An array of objects that display the details about each Synthetics canary runtime version. *
* * @return An array of objects that display the details about each Synthetics canary runtime version. */ public java.util.List* An array of objects that display the details about each Synthetics canary runtime version. *
* * @param runtimeVersions * An array of objects that display the details about each Synthetics canary runtime version. */ public void setRuntimeVersions(java.util.Collection* An array of objects that display the details about each Synthetics canary runtime version. *
** NOTE: This method appends the values to the existing list (if any). Use * {@link #setRuntimeVersions(java.util.Collection)} or {@link #withRuntimeVersions(java.util.Collection)} if you * want to override the existing values. *
* * @param runtimeVersions * An array of objects that display the details about each Synthetics canary runtime version. * @return Returns a reference to this object so that method calls can be chained together. */ public DescribeRuntimeVersionsResult withRuntimeVersions(RuntimeVersion... runtimeVersions) { if (this.runtimeVersions == null) { setRuntimeVersions(new java.util.ArrayList* An array of objects that display the details about each Synthetics canary runtime version. *
* * @param runtimeVersions * An array of objects that display the details about each Synthetics canary runtime version. * @return Returns a reference to this object so that method calls can be chained together. */ public DescribeRuntimeVersionsResult withRuntimeVersions(java.util.Collection
     * A token that indicates that there is more data available. You can use this token in a subsequent
     * DescribeRuntimeVersions operation to retrieve the next set of results.
     * 
DescribeRuntimeVersions operation to retrieve the next set of results.
     */
    public void setNextToken(String nextToken) {
        this.nextToken = nextToken;
    }
    /**
     * 
     * A token that indicates that there is more data available. You can use this token in a subsequent
     * DescribeRuntimeVersions operation to retrieve the next set of results.
     * 
DescribeRuntimeVersions operation to retrieve the next set of results.
     */
    public String getNextToken() {
        return this.nextToken;
    }
    /**
     * 
     * A token that indicates that there is more data available. You can use this token in a subsequent
     * DescribeRuntimeVersions operation to retrieve the next set of results.
     * 
DescribeRuntimeVersions operation to retrieve the next set of results.
     * @return Returns a reference to this object so that method calls can be chained together.
     */
    public DescribeRuntimeVersionsResult withNextToken(String nextToken) {
        setNextToken(nextToken);
        return this;
    }
    /**
     * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
     * redacted from this string using a placeholder value.
     *
     * @return A string representation of this object.
     *
     * @see java.lang.Object#toString()
     */
    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder();
        sb.append("{");
        if (getRuntimeVersions() != null)
            sb.append("RuntimeVersions: ").append(getRuntimeVersions()).append(",");
        if (getNextToken() != null)
            sb.append("NextToken: ").append(getNextToken());
        sb.append("}");
        return sb.toString();
    }
    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (obj instanceof DescribeRuntimeVersionsResult == false)
            return false;
        DescribeRuntimeVersionsResult other = (DescribeRuntimeVersionsResult) obj;
        if (other.getRuntimeVersions() == null ^ this.getRuntimeVersions() == null)
            return false;
        if (other.getRuntimeVersions() != null && other.getRuntimeVersions().equals(this.getRuntimeVersions()) == false)
            return false;
        if (other.getNextToken() == null ^ this.getNextToken() == null)
            return false;
        if (other.getNextToken() != null && other.getNextToken().equals(this.getNextToken()) == false)
            return false;
        return true;
    }
    @Override
    public int hashCode() {
        final int prime = 31;
        int hashCode = 1;
        hashCode = prime * hashCode + ((getRuntimeVersions() == null) ? 0 : getRuntimeVersions().hashCode());
        hashCode = prime * hashCode + ((getNextToken() == null) ? 0 : getNextToken().hashCode());
        return hashCode;
    }
    @Override
    public DescribeRuntimeVersionsResult clone() {
        try {
            return (DescribeRuntimeVersionsResult) super.clone();
        } catch (CloneNotSupportedException e) {
            throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
        }
    }
}