View Javadoc
1   /*
2    * (c) Copyright 2006-2020 by rapiddweller GmbH & Volker Bergmann. All rights reserved.
3    *
4    * Redistribution and use in source and binary forms, with or without
5    * modification, is permitted under the terms of the
6    * GNU General Public License.
7    *
8    * For redistributing this software or a derivative work under a license other
9    * than the GPL-compatible Free Software License as defined by the Free
10   * Software Foundation or approved by OSI, you must first obtain a commercial
11   * license to this software product from rapiddweller GmbH & Volker Bergmann.
12   *
13   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
14   * WITHOUT A WARRANTY OF ANY KIND. ALL EXPRESS OR IMPLIED CONDITIONS,
15   * REPRESENTATIONS AND WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF
16   * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE
17   * HEREBY EXCLUDED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
18   * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
19   * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
20   * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
21   * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
22   * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
23   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
24   * POSSIBILITY OF SUCH DAMAGE.
25   */
26  
27  package com.rapiddweller.benerator.engine.parser.xml;
28  
29  import com.rapiddweller.benerator.Generator;
30  import com.rapiddweller.benerator.distribution.Distribution;
31  import com.rapiddweller.benerator.engine.Statement;
32  import com.rapiddweller.benerator.engine.statement.WaitStatement;
33  import com.rapiddweller.benerator.factory.FactoryUtil;
34  import com.rapiddweller.benerator.primitive.DynamicLongGenerator;
35  import com.rapiddweller.benerator.util.ExpressionBasedGenerator;
36  import com.rapiddweller.benerator.wrapper.WrapperFactory;
37  import com.rapiddweller.common.CollectionUtil;
38  import com.rapiddweller.model.data.Uniqueness;
39  import com.rapiddweller.script.Expression;
40  import com.rapiddweller.script.expression.ExpressionUtil;
41  import org.w3c.dom.Element;
42  
43  import static com.rapiddweller.benerator.engine.DescriptorConstants.ATT_DISTRIBUTION;
44  import static com.rapiddweller.benerator.engine.DescriptorConstants.ATT_DURATION;
45  import static com.rapiddweller.benerator.engine.DescriptorConstants.ATT_GRANULARITY;
46  import static com.rapiddweller.benerator.engine.DescriptorConstants.ATT_MAX;
47  import static com.rapiddweller.benerator.engine.DescriptorConstants.ATT_MIN;
48  import static com.rapiddweller.benerator.engine.DescriptorConstants.EL_WAIT;
49  import static com.rapiddweller.benerator.engine.parser.xml.DescriptorParserUtil.getAttribute;
50  import static com.rapiddweller.benerator.engine.parser.xml.DescriptorParserUtil.parseLongAttribute;
51  
52  /**
53   * Parses a 'wait' element.<br/><br/>
54   * Created: 21.02.2010 08:07:59
55   *
56   * @author Volker Bergmann
57   * @since 0.6.0
58   */
59  public class WaitParser extends AbstractBeneratorDescriptorParser {
60  
61    /**
62     * Instantiates a new Wait parser.
63     */
64    public WaitParser() {
65      super(EL_WAIT, null, CollectionUtil.toSet(ATT_DURATION, ATT_MIN, ATT_MAX, ATT_GRANULARITY, ATT_DISTRIBUTION));
66    }
67  
68    @Override
69    public Statementcom/rapiddweller/benerator/engine/Statement.html#Statement">Statement doParse(Element element, Statement[] parentPath, BeneratorParseContext context) {
70  
71      // check attribute combinations
72      assertAtLeastOneAttributeIsSet(element, ATT_DURATION, ATT_MIN, ATT_MAX);
73      excludeAttributes(element, ATT_DURATION, ATT_MIN);
74      excludeAttributes(element, ATT_DURATION, ATT_MAX);
75  
76      // check for constant value
77      Expression<Long> duration = parseLongAttribute(ATT_DURATION, element, null);
78      if (duration != null) {
79        ExpressionBasedGenerator<Long> base = new ExpressionBasedGenerator<>(duration, Long.class);
80        return new WaitStatement(WrapperFactory.asNonNullGenerator(base));
81      }
82  
83      // check for distribution
84      Expression<Long> min = parseLongAttribute(ATT_MIN, element, null);
85      Expression<Long> max = parseLongAttribute(ATT_MAX, element, null);
86      Expression<Long> granularity = parseLongAttribute(ATT_GRANULARITY, element, null);
87      String distSpec = getAttribute(ATT_DISTRIBUTION, element);
88      Expression<Distribution> distribution
89          = FactoryUtil.getDistributionExpression(distSpec, Uniqueness.NONE, false);
90      Generator<Long> durationGenerator = new DynamicLongGenerator(min, max, granularity,
91          distribution, ExpressionUtil.constant(false));
92      return new WaitStatement(WrapperFactory.asNonNullGenerator(durationGenerator));
93    }
94  
95  }