Source for org.omg.CORBA.portable.ObjectImpl

   1: /* ObjectImpl.java --
   2:    Copyright (C) 2005, 2006 Free Software Foundation, Inc.
   3: 
   4: This file is part of GNU Classpath.
   5: 
   6: GNU Classpath is free software; you can redistribute it and/or modify
   7: it under the terms of the GNU General Public License as published by
   8: the Free Software Foundation; either version 2, or (at your option)
   9: any later version.
  10: 
  11: GNU Classpath is distributed in the hope that it will be useful, but
  12: WITHOUT ANY WARRANTY; without even the implied warranty of
  13: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  14: General Public License for more details.
  15: 
  16: You should have received a copy of the GNU General Public License
  17: along with GNU Classpath; see the file COPYING.  If not, write to the
  18: Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
  19: 02110-1301 USA.
  20: 
  21: Linking this library statically or dynamically with other modules is
  22: making a combined work based on this library.  Thus, the terms and
  23: conditions of the GNU General Public License cover the whole
  24: combination.
  25: 
  26: As a special exception, the copyright holders of this library give you
  27: permission to link this library with independent modules to produce an
  28: executable, regardless of the license terms of these independent
  29: modules, and to copy and distribute the resulting executable under
  30: terms of your choice, provided that you also meet, for each linked
  31: independent module, the terms and conditions of the license of that
  32: module.  An independent module is a module which is not derived from
  33: or based on this library.  If you modify this library, you may extend
  34: this exception to your version of the library, but you are not
  35: obligated to do so.  If you do not wish to do so, delete this
  36: exception statement from your version. */
  37: 
  38: 
  39: package org.omg.CORBA.portable;
  40: 
  41: import org.omg.CORBA.BAD_PARAM;
  42: import org.omg.CORBA.Context;
  43: import org.omg.CORBA.ContextList;
  44: import org.omg.CORBA.DomainManager;
  45: import org.omg.CORBA.ExceptionList;
  46: import org.omg.CORBA.NVList;
  47: import org.omg.CORBA.NamedValue;
  48: import org.omg.CORBA.ORB;
  49: import org.omg.CORBA.Policy;
  50: import org.omg.CORBA.Request;
  51: import org.omg.CORBA.SetOverrideType;
  52: 
  53: /**
  54:  * The basic implementation of the CORBA Object. The most of the methods
  55:  * delegate the functionality to the {@link Delegate} that can be replaced
  56:  * by {@link #_set_delegate(Delegate)}.
  57:  *
  58:  * @author Audrius Meskauskas (AudriusA@Bioinformatics.org)
  59:  */
  60: public abstract class ObjectImpl
  61:   implements org.omg.CORBA.Object
  62: {
  63:   /**
  64:    * The delegate, responsible for the method implementations.
  65:    */
  66:   transient Delegate delegate;
  67: 
  68:   /**
  69:     * Create a request to invoke the method of this object, specifying
  70:     * context list and the list of the expected exception.
  71:     *
  72:     * @param context a list of additional properties.
  73:     * @param operation the name of method to be invoked.
  74:     * @param parameters the method parameters.
  75:     * @param returns the container for tge method returned value.
  76:     * @param exceptions the list of the possible exceptions that the method
  77:     * can throw.
  78:     * @param ctx_list the list of the context strings that need to be
  79:     * resolved and send as a context instance.
  80:     *
  81:     * @return the created reaquest.
  82:     */
  83:   public Request _create_request(Context context, String operation,
  84:                                  NVList parameters, NamedValue returns,
  85:                                  ExceptionList exceptions, ContextList ctx_list
  86:                                 )
  87:   {
  88:     return delegate.create_request(this, context, operation, parameters,
  89:                                    returns, exceptions, ctx_list
  90:                                   );
  91:   }
  92: 
  93:   /**
  94:    * Create a request to invoke the method of this object.
  95:    *
  96:    * @param context a list of additional properties.
  97:    * @param operation the name of method to be invoked.
  98:    * @param parameters the method parameters.
  99:    * @param returns the container for tge method returned value.
 100:    *
 101:    * @return the created reaquest.
 102:    */
 103:   public Request _create_request(Context context, String operation,
 104:                                  NVList parameters, NamedValue returns
 105:                                 )
 106:   {
 107:     return delegate.create_request(this, context, operation, parameters, returns);
 108:   }
 109: 
 110:   /**
 111:    * Duplicate the object reference. This does not make much sense for
 112:    * java platform and is just included for the sake of compliance with
 113:    * CORBA APIs.
 114:    *
 115:    * The method may return the object reference itself.
 116:    *
 117:    * @return as a rule, <code>this</code>.
 118:    */
 119:   public org.omg.CORBA.Object _duplicate()
 120:   {
 121:     return delegate.duplicate(this);
 122:   }
 123: 
 124:   /**
 125:    * Get vendor specific delegate, responsible for the implemented
 126:    * functionality.
 127:    */
 128:   public Delegate _get_delegate()
 129:   {
 130:     return delegate;
 131:   }
 132: 
 133:   /**
 134:    * Retrieve the domain managers for this object.
 135:    *
 136:    * @return the domain managers.
 137:    */
 138:   public DomainManager[] _get_domain_managers()
 139:   {
 140:     return delegate.get_domain_managers(this);
 141:   }
 142: 
 143:   /**
 144:    * Get the <code>InterfaceDef</code> for this Object.
 145:    */
 146:   public org.omg.CORBA.Object _get_interface_def()
 147:   {
 148:     return delegate.get_interface_def(this);
 149:   }
 150: 
 151:   /**
 152:    * Returns the {@link Policy}, applying to this object.
 153:    *
 154:    * @param a_policy_type a type of policy to be obtained.
 155:    * @return a corresponding Policy object.
 156:    *
 157:    * @throws BAD_PARAM if the policy of the given type is not
 158:    * associated with this object, or if it is not supported by this ORB.
 159:    */
 160:   public Policy _get_policy(int a_policy_type)
 161:   {
 162:     return delegate.get_policy(this, a_policy_type);
 163:   }
 164: 
 165:   /**
 166:    * Get the array of interface repository ids, defining this object.
 167:    */
 168:   public abstract String[] _ids();
 169: 
 170:   /**
 171:    * Get the hashcode this object reference. The same hashcode still
 172:    * does not means that the references are the same. From the other
 173:    * side, two different references may still refer to the same CORBA
 174:    * object. The returned value must not change during the object
 175:    * lifetime.
 176:    *
 177:    * @param max the maximal value to return.
 178:    *
 179:    * @return the hashcode.
 180:    */
 181:   public int _hash(int max)
 182:   {
 183:     return delegate.hash(this, max);
 184:   }
 185: 
 186:   /**
 187:    * Invoke the operation.
 188:    *
 189:    * @param output the stream, containing the written arguments.
 190:    *
 191:    * @return the stream, from where the input parameters could be read.
 192:    *
 193:    * @throws ApplicationException if the application throws an exception,
 194:    * defined as a part of its remote method definition.
 195:    *
 196:    * @throws RemarshalException if reading(remarshalling) fails.
 197:    */
 198:   public InputStream _invoke(OutputStream output)
 199:                       throws org.omg.CORBA.portable.ApplicationException,
 200:                              org.omg.CORBA.portable.RemarshalException
 201:   {
 202:     return delegate.invoke(this, output);
 203:   }
 204: 
 205:   /**
 206:    * Check if this object can be referenced by the given repository id.
 207:    *
 208:    * @param idl_id the repository id.
 209:    *
 210:    * @return true if the passed parameter is a repository id of this
 211:    * CORBA object.
 212:    */
 213:   public boolean _is_a(String idl_id)
 214:   {
 215:     return delegate.is_a(this, idl_id);
 216:   }
 217: 
 218:   /**
 219:    * Return true if the other object references are equivalent, so far as
 220:    * it is possible to determine this easily.
 221:    *
 222:    * @param other the other object reference.
 223:    *
 224:    * @return true if both references refer the same object, false
 225:    * if they probably can refer different objects. Uses direct
 226:    * comparison if the delegate has not been set.
 227:    */
 228:   public boolean _is_equivalent(org.omg.CORBA.Object other)
 229:   {
 230:     return (delegate == null) ? this == other
 231:            : delegate.is_equivalent(this, other);
 232:   }
 233: 
 234:   /**
 235:    * Returns true if the object is local.
 236:    *
 237:    * @return false, always (following 1.4 specs). Override to get
 238:    * functionality.
 239:    */
 240:   public boolean _is_local()
 241:   {
 242:     return delegate.is_local(this);
 243:   }
 244: 
 245:   /**
 246:   * Determines if the server object for this reference has already
 247:   * been destroyed.
 248:   *
 249:   * @return true if the object has been destroyed, false otherwise.
 250:   */
 251:   public boolean _non_existent()
 252:   {
 253:     return delegate.non_existent(this);
 254:   }
 255: 
 256:   /**
 257:    * Provides the reference to ORB.
 258:    *
 259:    * @return the associated ORB.
 260:    */
 261:   public ORB _orb()
 262:   {
 263:     return delegate.orb(this);
 264:   }
 265: 
 266:   /**
 267:    * Free resoureces, occupied by this reference. The object implementation
 268:    * is not notified, and the other references to the same object are not
 269:    * affected.
 270:    */
 271:   public void _release()
 272:   {
 273:     delegate.release(this);
 274:   }
 275: 
 276:   /**
 277:    * Release the reply stream back to ORB after finishing reading the data
 278:    * from it.
 279:    *
 280:    * @param stream the stream, normally returned by {@link #_invoke} or
 281:    * {@link ApplicationException#getInputStream()}, can be null.
 282:    */
 283:   public void _releaseReply(InputStream stream)
 284:   {
 285:     if (delegate != null)
 286:       delegate.releaseReply(this, stream);
 287:   }
 288: 
 289:   /**
 290:    * Create a request to invoke the method of this CORBA object.
 291:    *
 292:    * @param method the name of the method to invoke.
 293:    *
 294:    * @return the request.
 295:    */
 296:   public Request _request(String method)
 297:   {
 298:     return delegate.request(this, method);
 299:   }
 300: 
 301:   /**
 302:    * Create a request to invoke the method of this CORBA object.
 303:    *
 304:    * @param method the name of the method to invoke.
 305:    * @param response_expected specifies if this is one way message or the
 306:    * response to the message is expected.
 307:    *
 308:    * @return the stream where the method arguments should be written.
 309:    */
 310:   public org.omg.CORBA.portable.OutputStream _request(String method,
 311:                                                       boolean response_expected
 312:                                                      )
 313:   {
 314:     return delegate.request(this, method, response_expected);
 315:   }
 316: 
 317:   /**
 318:    * This method is always called after invoking the operation on the
 319:    * local servant.
 320:    *
 321:    * The default method returns without action.
 322:    *
 323:    * @param servant the servant.
 324:    */
 325:   public void _servant_postinvoke(ServantObject servant)
 326:   {
 327:     delegate.servant_postinvoke(this, servant);
 328:   }
 329: 
 330:   /**
 331:    * Returns a servant that should be used for this request.
 332:    * The servant can also be casted to the expected type, calling the
 333:    * required method directly.
 334:    *
 335:    * @param method the operation
 336:    * @param expected_type the expected type of the servant.
 337:    *
 338:    * This implementation always returns null; override for different
 339:    * behavior.
 340:    *
 341:    * @return the servant or null if the servant is not an expected type
 342:    * of the method is not supported, for example, due security reasons.
 343:    */
 344:   @SuppressWarnings("rawtypes") // Needed for API compatibility
 345:   public ServantObject _servant_preinvoke(String method, Class expected_type)
 346:   {
 347:     return delegate.servant_preinvoke(this, method, expected_type);
 348:   }
 349: 
 350:   /**
 351:    * Set the delegate, responsible for the implemented functionality.
 352:    *
 353:    * @param a_delegate a delegate, responsible for the implemented
 354:    * functionality.
 355:    */
 356:   public void _set_delegate(Delegate a_delegate)
 357:   {
 358:     delegate = a_delegate;
 359:   }
 360: 
 361:   /**
 362:    * Returns a new object with the new policies either replacing or
 363:    * extending the current policies, depending on the second parameter.
 364:    *
 365:    * @param policies the policy additions or replacements.
 366:    * @param how either {@link SetOverrideType#SET_OVERRIDE} to override the
 367:    * current policies of {@link SetOverrideType#ADD_OVERRIDE} to replace
 368:    * them.
 369:    */
 370:   public org.omg.CORBA.Object _set_policy_override(Policy[] policies,
 371:                                                    SetOverrideType how
 372:                                                   )
 373:   {
 374:     return delegate.set_policy_override(this, policies, how);
 375:   }
 376: 
 377:   /**
 378:    * Check if this object is equal to another object.
 379:    *
 380:    * @param other the other object to compare.
 381:    *
 382:    * @return true if the objects are equal.
 383:    */
 384:   public boolean equals(java.lang.Object other)
 385:   {
 386:     if (delegate == null)
 387:       return this == other;
 388:     else
 389:       return delegate.equals(this, other);
 390:   }
 391: 
 392:   /**
 393:    * Return the string representation of the passed object.
 394:    *
 395:    * @return the string representation.
 396:    */
 397:   public String toString()
 398:   {
 399:     return delegate.toString(this);
 400:   }
 401: }