summaryrefslogtreecommitdiff
path: root/src/main/java/com/amazon/carbonado/synthetic/SyntheticBuilder.java
blob: 057825c0f33b1685acbc0321f270660016f0072d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/*
 * Copyright 2006 Amazon Technologies, Inc. or its affiliates.
 * Amazon, Amazon.com and Carbonado are trademarks or registered trademarks
 * of Amazon Technologies, Inc. or its affiliates.  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.amazon.carbonado.synthetic;

import com.amazon.carbonado.Storable;
import com.amazon.carbonado.SupportException;

/**
 * A synthetic builder provides a mechanism for creating a user storable from scratch.
 * The client creates the builder, decorates with properties and indexes on those
 * properties, then builds.
 *
 * If additional, ad hoc decoration is desired, the partially constructed classfile
 * can be retrieved and operated on directly via the ClassFileBuilder
 * returned by {@link #prepare}.
 *
 * @author Don Schneider
 */
public interface SyntheticBuilder {


    /**
     * @return {@link ClassFileBuilder} ready for further decoration or building
     * @throws SupportException
     */
    public ClassFileBuilder prepare() throws SupportException;

    /**
     * @return the generated class file for this builder.  Note that
     * proper operation requires that {@link #prepare()} already have been called
     * prior to calling this method.
     * @throws IllegalStateException if build has not yet been called.
     */
    public Class<? extends Storable> getStorableClass() throws IllegalStateException;

    /**
     * Convenience method to generate the class.
     * Build will always call {@link #prepare()} and return the result of
     * generating the class from that classfile.  If the caller does not
     * wish to regenerate the class from scratch, use {@link #getStorableClass()} instead.
     */
    public Class<? extends Storable> build() throws SupportException;

    /**
     * Add a property to the set managed by this builder.
     * @param name of the property
     * @param type of the property
     * @return property specification which can be further refined
     */
    public SyntheticProperty addProperty(String name, Class type);

    /**
     * Add an externally defined synthetic property to the list
     * @param prop to add
     * @return original synthetic property as a convenience
     */
    public SyntheticProperty addProperty(SyntheticProperty prop);

    /**
     * Check to see if a particular property has already been added to the list of
     * properties to generate
     * @param name
     */
    public boolean hasProperty(String name);

    /**
     * Add a primary key to be built.
     * @return key to be decorated with property values defining the primary key
     */
    public SyntheticKey addPrimaryKey();

    /**
     * Add an index to the set managed by this builder.  All indexes added this
     * way will be in addition to the primary key index.
     * @return index to be decorated with property values defining the index
     */
    public SyntheticIndex addIndex();


    /**
     * Returns true if a property with the version attribute has been addded
     */
    public boolean isVersioned();

    /**
     * Interface used to get the name for the class to generate. This allows the
     * client to apply different rules for classname generation.
     */
    public interface ClassNameProvider {
        public String getName();

        /**
         * SyntheticBuilder may choose to alter the class name to prevent a
         * class name collision. When explicit is true, the class name must not
         * be altered.
         */
        public boolean isExplicit();
    }
}