// Copyright 2016 Google Inc. All Rights Reserved. // // 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.api.ads.adwords.jaxws.v201607.cm; 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.XmlType; /** * * Scope of products. Contains a set of product dimensions, all of which a product has to match to * be included in the campaign. These product dimensions must have a value; the "everything else" * case without a value is not allowed. * * <p>If there is no {@code ProductScope}, all products are included in the campaign. If a campaign * has more than one {@code ProductScope}, products are included as long as they match any. * Campaigns of {@link AdvertisingChannelType#SHOPPING} can have at most one {@code ProductScope}. * <span class="constraint AdxEnabled">This is disabled for AdX when it is contained within Operators: ADD, SET.</span> * * * <p>Java class for ProductScope complex type. * * <p>The following schema fragment specifies the expected content contained within this class. * * <pre> * <complexType name="ProductScope"> * <complexContent> * <extension base="{https://adwords.google.com/api/adwords/cm/v201607}Criterion"> * <sequence> * <element name="dimensions" type="{https://adwords.google.com/api/adwords/cm/v201607}ProductDimension" maxOccurs="unbounded" minOccurs="0"/> * </sequence> * </extension> * </complexContent> * </complexType> * </pre> * * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "ProductScope", propOrder = { "dimensions" }) public class ProductScope extends Criterion { protected List<ProductDimension> dimensions; /** * Gets the value of the dimensions 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 dimensions property. * * <p> * For example, to add a new item, do as follows: * <pre> * getDimensions().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list * {@link ProductDimension } * * */ public List<ProductDimension> getDimensions() { if (dimensions == null) { dimensions = new ArrayList<ProductDimension>(); } return this.dimensions; } }