/******************************************************************************* * Copyright (c) 2013, 2015 Oracle and/or its affiliates. All rights reserved. * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 * which accompanies this distribution. * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html * and the Eclipse Distribution License is available at * http://www.eclipse.org/org/documents/edl-v10.php. * * Contributors: * Guy Pelletier - initial API and implementation ******************************************************************************/ package org.eclipse.persistence.internal.jpa.config.partitioning; import java.util.ArrayList; import org.eclipse.persistence.internal.jpa.config.MetadataImpl; import org.eclipse.persistence.internal.jpa.config.columns.ColumnImpl; import org.eclipse.persistence.internal.jpa.metadata.partitioning.RangePartitionMetadata; import org.eclipse.persistence.internal.jpa.metadata.partitioning.RangePartitioningMetadata; import org.eclipse.persistence.jpa.config.Column; import org.eclipse.persistence.jpa.config.RangePartition; import org.eclipse.persistence.jpa.config.RangePartitioning; /** * JPA scripting API implementation. * * @author Guy Pelletier * @since EclipseLink 2.5.1 */ public class RangePartitioningImpl extends MetadataImpl<RangePartitioningMetadata> implements RangePartitioning { public RangePartitioningImpl() { super(new RangePartitioningMetadata()); getMetadata().setPartitions(new ArrayList<RangePartitionMetadata>()); } public RangePartition addPartition() { RangePartitionImpl rangePartition = new RangePartitionImpl(); getMetadata().getPartitions().add(rangePartition.getMetadata()); return rangePartition; } public RangePartitioning setName(String name) { getMetadata().setName(name); return this; } public Column setPartitionColumn() { ColumnImpl column = new ColumnImpl(); getMetadata().setPartitionColumn(column.getMetadata()); return column; } public RangePartitioning setPartitionValueType(String partitionValueType) { getMetadata().setPartitionValueTypeName(partitionValueType); return this; } public RangePartitioning setUnionUnpartitionableQueries(Boolean unionUnpartitionableQueries) { getMetadata().setUnionUnpartitionableQueries(unionUnpartitionableQueries); return this; } }