Package org.omg.CosNaming
Provides a naming service for Java IDL.
See: Description
| Interface | Description |
|---|---|
| BindingIterator | The BindingIterator interface allows a client to iterate through the bindings using the next_one or next_n operations. |
| BindingIteratorOperations | The BindingIterator interface allows a client to iterate through the bindings using the next_one or next_n operations. |
| NamingContext | A naming context is an object that contains a set of name bindings in which each name is unique. |
| NamingContextExt |
|
| NamingContextExtOperations |
|
| NamingContextOperations | A naming context is an object that contains a set of name bindings in which each name is unique. |
| Class | Description |
|---|---|
| _BindingIteratorImplBase | |
| _BindingIteratorStub | The BindingIterator interface allows a client to iterate through the bindings using the next_one or next_n operations. |
| _NamingContextExtStub |
|
| _NamingContextImplBase | |
| _NamingContextStub | A naming context is an object that contains a set of name bindings in which each name is unique. |
| Binding | org/omg/CosNaming/Binding.java . |
| BindingHelper | org/omg/CosNaming/BindingHelper.java . |
| BindingHolder | org/omg/CosNaming/BindingHolder.java . |
| BindingIteratorHelper | The BindingIterator interface allows a client to iterate through the bindings using the next_one or next_n operations. |
| BindingIteratorHolder | The BindingIterator interface allows a client to iterate through the bindings using the next_one or next_n operations. |
| BindingIteratorPOA | The BindingIterator interface allows a client to iterate through the bindings using the next_one or next_n operations. |
| BindingListHelper | List of Bindings. |
| BindingListHolder | List of Bindings. |
| BindingType | Specifies whether the given binding is for a object (that is not a naming context) or for a naming context. |
| BindingTypeHelper | Specifies whether the given binding is for a object (that is not a naming context) or for a naming context. |
| BindingTypeHolder | Specifies whether the given binding is for a object (that is not a naming context) or for a naming context. |
| IstringHelper | org/omg/CosNaming/IstringHelper.java . |
| NameComponent | org/omg/CosNaming/NameComponent.java . |
| NameComponentHelper | org/omg/CosNaming/NameComponentHelper.java . |
| NameComponentHolder | org/omg/CosNaming/NameComponentHolder.java . |
| NameHelper | A name is a sequence of name components. |
| NameHolder | A name is a sequence of name components. |
| NamingContextExtHelper |
|
| NamingContextExtHolder |
|
| NamingContextExtPOA |
|
| NamingContextHelper | A naming context is an object that contains a set of name bindings in which each name is unique. |
| NamingContextHolder | A naming context is an object that contains a set of name bindings in which each name is unique. |
| NamingContextPOA | A naming context is an object that contains a set of name bindings in which each name is unique. |
Package org.omg.CosNaming Description
Provides a naming service for Java IDL. The Object Request Broker Daemon (ORBD) also includes both a transient and persistent naming service.
The package and all its classes and interfaces were generated by running the tool idlj on the file nameservice.idl, which is a module written in OMG IDL.
Package Specification
For a precise list of supported sections of official specifications with which the Java[tm] Platform, Standard Edition 6, ORB complies, see Official Specifications for CORBA support in Java[tm] SE 6.
Interfaces
The packageorg.omg.CosNaming contains two public interfaces and several auxiliary classes. The interfaces are:
-
NamingContext -
BindingIterator
These two interfaces provide the means to bind/unbind names and object references, to retrieve bound object references, and to iterate through a list of bindings. The NamingContext interface supplies the main functionality for the naming service, and BindingIterator provides a means of iterating through a list of name/object reference bindings.
Auxiliary Classes
In order to map an OMG IDL interface to the Java programming language, the idlj compiler creates Java classes that can be thought of as auxiliary classes. Comments for the generated auxiliary classes used by the interfacesNamingContext and BindingIterator are included here.
Classes Used by NamingContext and BindingIterator
The following are classes used by the naming service. (Helper and holder classes, which are generated for each of the classes listed here, are discussed below.) -
public final class NameComponent-- a building block for names. (Names are bound to object references in a naming context.)A name is an array of one or more
NameComponentobjects. A name with a singleNameComponentis called a simple name; a name with multipleNameComponentobjects is called a compound name.A
NameComponentobject consists of two fields:-
id-- aStringused as an identifier -
kind-- aStringthat can be used for any descriptive purpose. Its importance is that it can be used to describe an object without affecting syntax. The C programming language, for example, uses the the syntactic convention of appending the extension ".c" to a file name to indicate that it is a source code file. In aNameComponentobject, thekindfield can be used to describe the type of object rather than a file extension or some other syntactic convention. Examples of the value of thekindfield include the strings"c_source","object_code","executable","postscript", and"". It is not unusual for thekindfield to be the empty string.
In a name, each
NameComponentobject except the last denotes aNamingContextobject; the lastNameComponentobject denotes the bound object reference. This is similar to a path name, in which the last name is the file name, and all names before it are directory names. -
-
public final class Binding-- an object that associates a name with an object reference or a naming context. ABindingobject has two fields:-
binding_name- an array of one or moreNameComponentobjects that represents the bound name -
binding_type- aBindingTypeobject indicating whether the binding is between a name and an object reference or between a name and a naming context
The interface
NamingContexthas methods for binding/unbinding names with object references or naming contexts, for listing bindings, and for resolving bindings (given a name, the methodresolvereturns the object reference bound to it). -
-
public final class BindingType-- an object that specifies whether the givenBindingobject is a binding between a name and an object reference (that is, not a naming context) or between a name and a naming context.The class
BindingTypeconsists of two methods and four constants. Two of these constants areBindingTypeobjects, and two areints.The
BindingTypeobjects can be passed to the constructor for the classBindingor used as parameters or return values. TheseBindingTypeobjects are:-
public static final BindingType nobject-- to indicate that the binding is with an object reference -
public static final BindingType ncontext-- to indicate that the binding is with a naming context
The
intconstants can be supplied to the methodfrom_intto createBindingTypeobjects, or they can be return values for the methodvalue. These constants are:-
public static final int _nobject -
public static final int _ncontext
from_intis supplied with anything other than_nobjector_ncontext, it will throw the exceptionorg.omg.CORBA.BAD_PARAM.Usage is as follows:
BindingType btObject = from_int(_nobject); BindingType btContext = from_int(_ncontext);The variablebtObjectrefers to aBindingTypeobject initialized to represent a binding with an object reference. The variablebtContextrefers to aBindingTypeobject initialized to represent a binding with aNamingContexobject.The method
valuereturns either_nobjector_ncontext, so in the following line of code, the variablebtwill contain_nobjector_ncontext:int bt = BindingType.value();
-
Holder Classes
OMG IDL uses OUT and INOUT parameters for returning values from operations. The mapping to the Java programming language, which does not have OUT and INOUT parameters, creates a special class for each type, called a holder class. An instance of a holder class can be passed to a Java method as a parameter, and a value can be assigned to itsvalue field. This allows it to perform the function of an OUT or INOUT parameter. The following holder classes are generated for the package org.omg.CosNaming:
-
NamingContextHolder -
BindingIteratorHolder -
BindingHolder -
BindingListHolder -
BindingTypeHolder -
NameComponentHolder -
NameHolder
Note that in the org.omg.CORBA package, there is a holder class for each of the basic Java types: IntHolder, ShortHolder, StringHolder, and so on.
Note also that there is a NameHolder class even though there is no Name class; similarly, there is a BindingListHolder class even though there is no BindingList class. This is true because in the OMG IDL interface, Name and BindingList are typedefs. There is no mapping from an IDL typedef to a Java construct, but holder classes are generated if the typedef is for a sequence or an array. As mapped to the Java programming language, Name is an array of NameComponent objects, and a BindingList is an array of Binding objects. All holder classes have at least two constructors and one field:
-
valuefield -- an instance of the type being used as an OUT or INOUT parameter. For example, thevaluefield of aNamingContextHolderwill be aNamingContextobject. - default constructor -- a constructor that creates a new holder object initialized with the default value for the type. For example, a new
BindingHolderobject created with the default constructor will have itsvaluefield set tonullbecause that is the default value for an object. Other defaults arefalseforboolean,0for numeric and char types, andnullfor object references. - constructor from an instance -- a constructor that creates a new holder object whose
valuefield is initialized with the instance supplied
A holder class for a user-defined type (a Java class) has three more methods, but application developers do not use them directly.
Helper Classes
Helper classes, which are generated for all user-defined types in an OMG IDL interface, supply static methods needed to manipulate those types. There is only one method in a helper class that an application programmer uses: the method narrow. Only Java interfaces mapped from IDL interfaces will have a helper class that includes a narrow method, so in the CosNaming package, only the classes NamingContextHelper and BindingIteratorHelper have a narrow method.
-
public static NamingContext narrow(org.omg.CORBA.Object obj)-- converts the given CORBA object to aNamingContextobject -
public static BindingIterator narrow(org.omg.CORBA.Object obj)-- converts the given CORBA object to aBindingIteratorobject
Package org.omg.CosNaming.NamingContextPackage
This package supplies Helper and Holder classes for the exceptions used in the package org.omg.CosNaming and also for the class NotFoundReason, which supplies a reason for the exception NotFound. There are Helper and Holder classes for the following exceptions:
-
AlreadyBound -
CannotProceed -
InvalidName -
NotEmpty -
NotFound
Naming Service Compatibility
Sun's implementation of theCosNaming package complies with the OMG COSNaming specification. In other words, the APIs in Sun's naming service are implemented according to the guidelines for a naming service provided by OMG. Therefore, if a third-party vendor has implemented a naming service that is OMG compliant, it is possible to switch between Sun's implementation of CosNaming and the third-party vendor's implementation. However, it is important to understand that there can be minor variations in the way different vendors implement the naming service, such as differences in the exception strings. Instructions for Using a Third Party's Naming Service
Although we encourage using an ORB and ORB services that are both from one vendor, it is possible to plug in a third party'sCOSNaming implementation with Sun's RMI-IIOP ORB. Here are the steps to follow: - Create a properties file for the Bootstrap server and give it two entries. For example, you could call this properties file
/tmp/servicesand put the following in it:NameService, <Stringified IOR of the Root Naming Context>.This associates
NameServicewith the Root Naming Context of theCosNamingimplementation that you want to use. - Start the standalone Bootstrap server using the following command:
java -classpath $(CLASSPATH) com.sun.corba.ee.internal.CosNaming.BootstrapServer -InitialServicesFile "/tmp/services" [-ORBInitialPort port]Note that the square brackets at the end of the command indicate that specifying a port number is optional.
Now when an application calls the method org.omg.CORBA.ORB.resolve_initial_references, CORBA processes will contact the Bootstrap Server to get the Root Naming Context.
- Since:
- JDK1.3
© 1993, 2020, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/javase/8/docs/api/org/omg/CosNaming/package-summary.html