View Javadoc

1   package org.apache.ojb.odmg;
2   
3   /* Copyright 2002-2005 The Apache Software Foundation
4    *
5    * Licensed under the Apache License, Version 2.0 (the "License");
6    * you may not use this file except in compliance with the License.
7    * You may obtain a copy of the License at
8    *
9    *     http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  
18  import org.odmg.Implementation;
19  
20  /**
21   * Offers useful none odmg-standard methods of the odmg {@link org.odmg.Implementation} interface.
22   * <p>
23   * Note: All listed methods are <strong>not</strong> part of the standard ODMG-api -
24   * they are special (proprietary) OJB extensions.
25   * </p>
26   *
27   * @version $Id: ImplementationExt.java,v 1.1 2007-08-24 22:17:37 ewestfal Exp $
28   */
29  public interface ImplementationExt extends Implementation
30  {
31      /**
32       * The used collection type class returned by OQL queries.
33       *
34       * @see org.apache.ojb.odmg.oql.EnhancedOQLQuery#execute()
35       * @see org.odmg.OQLQuery#execute()
36       * @return The collection class type
37       */
38      public Class getOqlCollectionClass();
39  
40      /**
41       * Set the used collection type class returned by OQL queries.
42       * <p/>
43       * NOTE: Each specified class must implement interface {@link org.apache.ojb.broker.ManageableCollection}
44       * to work proper with OJB.
45       *
46       * @param oqlCollectionClass The collection class used in OQL queries.
47       */
48      public void setOqlCollectionClass(Class oqlCollectionClass);
49  
50      /**
51       * If the OJB implicit locking feature (see {@link TransactionExt#setImplicitLocking(boolean)}) is
52       * enabled, this define the lock type of all implicit locked objects.
53       * <p/>
54       * If set to <em>true</em>, acquiring a write-lock on a given object x implies write locks on all
55       * implicit locked objects.
56       * <br/>
57       * If set to <em>false</em>, in any case implicit read-locks are acquired.
58       * Acquiring a read- or write lock on x thus allways results in implicit read-locks
59       * on all associated objects.
60       *
61       * @param impliciteWriteLocks If <em>true</em> implicit write locks will enabled.
62       */
63      public void setImpliciteWriteLocks(boolean impliciteWriteLocks);
64  
65      /**
66       * Is <em>true</em> when implicite write locks are enabled.
67       *
68       * @return <em>true</em> when implicit write locks are enabled.
69       * @see #setImpliciteWriteLocks(boolean)
70       */
71      public boolean isImpliciteWriteLocks();
72  
73      /**
74       * Set the global property <em>implicit locking</em>. This method can be used
75       * to activate or deactivate the global implicit
76       * locking mechanism.
77       * <br/>
78       * If set <em>true</em> OJB implicitly locks objects to ODMG transactions
79       * after performing OQL queries. Also if implicit locking is used
80       * locking objects is recursive, that is associated objects are also
81       * locked. If ImplicitLocking is set to 'false', no locks are obtained
82       * in OQL queries, lookup objects and there is also no recursive locking.
83       * <p/>
84       * However it's possible to set this value only for the current used {@link org.odmg.Transaction}
85       * using {@link TransactionExt#setImplicitLocking(boolean)} and to detect the implicit locking
86       * state of the used transaction instance call {@link TransactionExt#isImplicitLocking()}.
87       * <br/>
88       * Turning off implicit locking may improve performance but requires
89       * additional care to make sure that all changed objects are properly
90       * registered to the transaction.
91       *
92       * @param impliciteLocking If set <em>true</em> implicit locking is enabled,
93       *        if <em>false</em>, implicit locking is disabled.
94       */
95      public void setImplicitLocking(boolean impliciteLocking);
96  
97      /**
98       * Returns <em>true</em> if the global implicit locking is enabled
99       * for this {@link org.odmg.Implementation} instance, else <em>false</em>.
100      * <br/>
101      * <strong>Important:</strong> The returned value is the global used setting for all
102      * {@link org.odmg.Transaction#lock(Object, int)} calls.
103      * <br/>
104      * However it's possible to set this value only for the current used {@link org.odmg.Transaction}
105      * using {@link TransactionExt#setImplicitLocking(boolean)} and to detect the implicit locking
106      * state of the used transaction instance call {@link TransactionExt#isImplicitLocking()}.
107      *
108      * @return <em>true</em> if the global property <em>implicit locking</em><em>true</em> is enabled.
109      * @see #setImplicitLocking(boolean)
110      */
111     public boolean isImplicitLocking();
112 
113     /**
114      * Returns <em>true</em> if OJB's ordering algorithm is enabled.
115      *
116      * @see #setOrdering(boolean)
117      */
118     public boolean isOrdering();
119 
120     /**
121      * Disable/enable OJB's ordering algorithm when insert, update, delete a
122      * bunch of objects within a transaction. The ordering algorithm try to
123      * calculate the correct order of the modified/new persistent objects to
124      * prevent problems on commit of the transaction.
125      * <br/>
126      * If the used databases support 'deferred checks' it's recommended to
127      * use this feature and to disable OJB's object ordering.
128      * <p/>
129      * However it's possible to set this value only for the current
130      * used {@link org.odmg.Transaction} using {@link TransactionExt#setOrdering(boolean)}
131      *
132      * @param ordering If <em>true</em> OJB's ordering algorithm is used.
133      */
134     public void setOrdering(boolean ordering);
135 
136 //    /**
137 //     * Returns whether or not the persistent method calls determine
138 //     * the persistent object order on commit.
139 //     *
140 //     * @see #setNoteUserOrder(boolean)
141 //     */
142 //    public boolean isNoteUserOrder();
143 //
144 //    /**
145 //     * If <em>true</em> the order of persisting method calls like
146 //     * <br/> - {@link org.odmg.Transaction#lock(Object, int)}).
147 //     * <br/> - {@link org.odmg.Database#deletePersistent(Object)}).
148 //     * <br/> - {@link org.odmg.Database#makePersistent(Object)})
149 //     * determine the order of objects before commit.
150 //     * <br/>
151 //     * If <em>false</em> the ordering was determined by OJB's internal
152 //     * method calls and user calls.
153 //     * <br/>
154 //     * However it's possible to set this value only for the current
155 //     * used {@link org.odmg.Transaction} using {@link TransactionExt#setNoteUserOrder(boolean)}
156 //     * <p/>
157 //     * <strong>NOTE:</strong> If OJB's ordering algorithm (see
158 //     * {@link #setOrdering(boolean)}) is enabled, the
159 //     * order of objects may change on commit.
160 //     *
161 //     * @param noteUserOrder If <em>true</em> the order of persisting
162 //     * method calls determine the order of objects.
163 //     */
164 //    public void setNoteUserOrder(boolean noteUserOrder);
165 
166 
167 //    /**
168 //     * Get object by OJB's {@link org.apache.ojb.broker.Identity}.
169 //     *
170 //     * @param id The identity of the object to look for.
171 //     * @return The matching object or <em>null</em>.
172 //     */
173 //    public Object getObjectByIdentity(Identity id);
174 
175 //    /**
176 //     * If set <em>true</em> the odmg implementation do it's best to find out the user intension, if set
177 //     * <em>false</em> OJB use an optimized mode and the user has to adhere strictly the odmg-api:
178 //     * <ul>
179 //     * <li>
180 //     * New objects can only be made persistent by using {@link org.odmg.Database#makePersistent(Object)}
181 //     * </li>
182 //     * <li>
183 //     * Only persistent objects can be locked with {@link org.odmg.Transaction#lock(Object, int)}.
184 //     * </li>
185 //     * <li>
186 //     * When deleting an object with {@link org.odmg.Database#deletePersistent(Object)} to reuse it
187 //     * within a transaction a call to {@link org.odmg.Database#makePersistent(Object)} is needed and
188 //     * field changes on objects marked as "deleted" are not allowed.
189 //     * </li>
190 //     * </ul>
191 //     * When running odmg in <em>safe-mode</em> these restrictions are "softened" and it's e.g. possible
192 //     * to persist new objects with {@link org.odmg.Transaction#lock(Object, int)}.
193 //     * <p/>
194 //     * The <em>optimized-mode</em> show a significant better performance, but needs strictness in using the API.
195 //     *
196 //     * @param safeMode Set <em>true</em> to enable the <em>safe-mode</em>, use <em>false</em> to enable
197 //     *                 the <em>optimized-mode</em>.
198 //     */
199 //    void setSafeMode(boolean safeMode);
200 //
201 //    /**
202 //     * Returns <em>true</em> if this class use the safe-mode for
203 //     * user interaction, else the optimized-mode is used.
204 //     */
205 //    boolean isSafeMode();
206 }