blob: 669b73a5956392b48c283f89558f8fe39b9aefe6 [file] [log] [blame]
/* TaggedProfile.java --
Copyright (C) 2005, 2006 Free Software Foundation, Inc.
This file is part of GNU Classpath.
GNU Classpath is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
GNU Classpath is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with GNU Classpath; see the file COPYING. If not, write to the
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA.
Linking this library statically or dynamically with other modules is
making a combined work based on this library. Thus, the terms and
conditions of the GNU General Public License cover the whole
combination.
As a special exception, the copyright holders of this library give you
permission to link this library with independent modules to produce an
executable, regardless of the license terms of these independent
modules, and to copy and distribute the resulting executable under
terms of your choice, provided that you also meet, for each linked
independent module, the terms and conditions of the license of that
module. An independent module is a module which is not derived from
or based on this library. If you modify this library, you may extend
this exception to your version of the library, but you are not
obligated to do so. If you do not wish to do so, delete this
exception statement from your version. */
package org.omg.IOP;
import org.omg.CORBA.portable.IDLEntity;
import java.io.Serializable;
/**
* The TaggedProfile if part of the {@link IOR}, defining a single specific
* aspect of the object related information. The content of profile depends
* on this information. It is represented here just as an array of
* bytes. The OMG currently defines three types of the tagged profile:
* <ul>
* <li>The Internet profile, identified by {@link TAG_INTERNET_IOP},
* supports the Internet Inter-ORB Protocol.
* </li>
* <li>The Multiple Components profile, identified by
* {@link TAG_MULTIPLE_COMPONENTS}, may be used to carry various IOR
* tagged components.
* <li>
* </li>
* <li>The SCCP IOP profile (described in OMG CORBA/IN Interworking
* specification).</li>
* </ul>
*
* The tagged profile may have its internal tagged components. The examples
* of the possible components inside the tag are {@link TAG_CODE_SETS},
* {@link TAG_ALTERNATE_IIOP_ADDRESS}, {@link TAG_JAVA_CODEBASE},
* {@link TAG_ORB_TYPE} and {@link TAG_POLICIES}. The complete list can only
* be found in OMG specification. Some of them occur only once
* (in the same TaggedProfile), others can be repeated.
*
* @see TaggedProfileHolder
* @see TaggedProfileHelper
*
* @author Audrius Meskauskas, Lithuania (AudriusA@Bioinformatics.org)
*/
public final class TaggedProfile
implements IDLEntity, Serializable
{
/**
* Use serialVersionUID (v1.4) for interoperability.
*/
private static final long serialVersionUID = -461232684387903343L;
/**
* The integer tag identifier, typically one of TAG_INTERNET_IOP.value or
* TAG_MULTIPLE_COMPONENTS.value.
*/
public int tag;
/**
* The profile_data, represented here in the form of the array of bytes.
*/
public byte[] profile_data;
/**
* Create the unitialised instance, assigning to
* the all fields java default values.
*/
public TaggedProfile()
{
}
/**
* Create the instance, initialising the fields to the given values.
*/
public TaggedProfile(int a_tag, byte[] a_profile_data)
{
tag = a_tag;
profile_data = a_profile_data;
}
}