Main Page   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Related Pages  

ACE_Naming_Context Class Reference

Maintaining accesses Name Server Databases. Allows to add NameBindings, change them, remove them and resolve NameBindings. More...

#include <Naming_Context.h>

Inheritance diagram for ACE_Naming_Context:

Inheritance graph
[legend]
Collaboration diagram for ACE_Naming_Context:

Collaboration graph
[legend]
List of all members.

Public Types

enum  Context_Scope_Type { PROC_LOCAL, NODE_LOCAL, NET_LOCAL }

Public Methods

 ACE_Naming_Context (void)
 "Do-nothing" constructor.

 ACE_Naming_Context (Context_Scope_Type scope_in, int light=0)
int open (Context_Scope_Type scope_in=ACE_Naming_Context::PROC_LOCAL, int light=0)
int close (void)
int close_down (void)
 Release all resources. Gets called by destructor and fini.

 ~ACE_Naming_Context (void)
virtual int init (int argc, ACE_TCHAR *argv[])
virtual int fini (void)
 Close down the test when dynamically unlinked.

virtual int info (ACE_TCHAR **strp, size_t length) const
 Returns information about this context.

ACE_Name_Optionsname_options (void)
 Returns the ACE_Name_Options associated with the Naming_Context.

int bind (const ACE_NS_WString &name_in, const ACE_NS_WString &value_in, const char *type_in="")
 Bind a new name to a naming context (Wide character strings).

int bind (const char *name_in, const char *value_in, const char *type_in="")
 Bind a new name to a naming context ( character strings).

int rebind (const ACE_NS_WString &name_in, const ACE_NS_WString &value_in, const char *type_in="")
int rebind (const char *name_in, const char *value_in, const char *type_in="")
int unbind (const ACE_NS_WString &name_in)
int unbind (const char *name_in)
int resolve (const ACE_NS_WString &name_in, ACE_NS_WString &value_out, char *&type_out)
int resolve (const char *name_in, ACE_NS_WString &value_out, char *&type_out)
int resolve (const char *name_in, char *&value_out, char *&type_out)
int list_names (ACE_PWSTRING_SET &set_out, const ACE_NS_WString &pattern_in)
int list_names (ACE_PWSTRING_SET &set_out, const char *pattern_in)
int list_values (ACE_PWSTRING_SET &set_out, const ACE_NS_WString &pattern_in)
int list_values (ACE_PWSTRING_SET &set_out, const char *pattern_in)
int list_types (ACE_PWSTRING_SET &set_out, const ACE_NS_WString &pattern_in)
int list_types (ACE_PWSTRING_SET &set_out, const char *pattern_in)
virtual int list_name_entries (ACE_BINDING_SET &set_out, const ACE_NS_WString &pattern_in)
virtual int list_name_entries (ACE_BINDING_SET &set_out, const char *pattern_in)
virtual int list_value_entries (ACE_BINDING_SET &set_out, const ACE_NS_WString &pattern_in)
virtual int list_value_entries (ACE_BINDING_SET &set_out, const char *pattern_in)
virtual int list_type_entries (ACE_BINDING_SET &set_out, const ACE_NS_WString &pattern_in)
virtual int list_type_entries (ACE_BINDING_SET &set_out, const char *pattern_in)
void dump (void)
 Dump the state of the object.


Private Methods

int local (void)
 1 if we're on the same local machine as the name server, else 0.


Private Attributes

ACE_Name_Optionsname_options_
 Keep track of the options such as database name etc per Naming Context.

ACE_Name_Spacename_space_
 Name space (can be either local or remote) dynamically bound.

ACE_TCHAR hostname_ [MAXHOSTNAMELEN+1]
 Holds the local hostname.

const ACE_TCHARnetnameserver_host_
 Holds name of net name server.

int netnameserver_port_
 Holds port number of the net name server.


Detailed Description

Maintaining accesses Name Server Databases. Allows to add NameBindings, change them, remove them and resolve NameBindings.

Manages a Naming Service . That represents a persistent string to string mapping for different scopes. The scope of a ACE_Naming_Context may be either local for the calling process (Note : A process is hereby not identified by it's pid, but by it's argv[0]. So different processes (in UNIX syntax) may access the same NameBindings), global for all processes running on one host or global for all processes on the net (that know the address of the net name server socket). Strings may be plain character strings or Wide character strings. A Name Binding consists of a name string (that's the key), a value string and an optional type string (no wide chars).


Member Enumeration Documentation

enum ACE_Naming_Context::Context_Scope_Type
 

Enumeration values:
PROC_LOCAL  Name lookup is local to the process.
NODE_LOCAL  Name lookup is local to the node (host).
NET_LOCAL  Name lookup is local to the (sub)network.


Constructor & Destructor Documentation

ACE_Naming_Context::ACE_Naming_Context void   
 

"Do-nothing" constructor.

ACE_Naming_Context::ACE_Naming_Context Context_Scope_Type    scope_in,
int    light = 0
 

Specifies the scope of this namespace, opens and memory-maps the associated file (if accessible) or contacts the dedicated name server process for NET_LOCAL namespace. Note that light specifies whether or not we want to use ACE_Lite_MMap_Memory_Pool. By default we use ACE_MMap_Memory_Pool.

ACE_Naming_Context::~ACE_Naming_Context void   
 

destructor, do some cleanup :TBD: last dtor should "compress" file


Member Function Documentation

int ACE_Naming_Context::bind const char *    name_in,
const char *    value_in,
const char *    type_in = ""
 

Bind a new name to a naming context ( character strings).

int ACE_Naming_Context::bind const ACE_NS_WString   name_in,
const ACE_NS_WString   value_in,
const char *    type_in = ""
 

Bind a new name to a naming context (Wide character strings).

int ACE_Naming_Context::close void   
 

Deletes the instance of Name Space. Must be called before switching name spaces.

int ACE_Naming_Context::close_down void   
 

Release all resources. Gets called by destructor and fini.

void ACE_Naming_Context::dump void   
 

Dump the state of the object.

int ACE_Naming_Context::fini void    [virtual]
 

Close down the test when dynamically unlinked.

Reimplemented from ACE_Shared_Object.

virtual int ACE_Naming_Context::info ACE_TCHAR **    strp,
size_t    length
const [virtual]
 

Returns information about this context.

Reimplemented from ACE_Shared_Object.

int ACE_Naming_Context::init int    argc,
ACE_TCHAR   argv[]
[virtual]
 

Initialize name options and naming context when dynamically linked.

Reimplemented from ACE_Shared_Object.

int ACE_Naming_Context::list_name_entries ACE_BINDING_SET   set_out,
const char *    pattern_in
[virtual]
 

Get a set of names matching a specified pattern (wchars). Matching means the names must begin with the pattern string. Returns the complete binding associated each pattern match.

int ACE_Naming_Context::list_name_entries ACE_BINDING_SET   set_out,
const ACE_NS_WString   pattern_in
[virtual]
 

Get a set of names matching a specified pattern (wchars). Matching means the names must begin with the pattern string. Returns the complete binding associated each pattern match.

int ACE_Naming_Context::list_names ACE_PWSTRING_SET   set_out,
const char *    pattern_in
 

Get a set of names matching a specified pattern (chars). Matching means the names must begin with the pattern string.

int ACE_Naming_Context::list_names ACE_PWSTRING_SET   set_out,
const ACE_NS_WString   pattern_in
 

Get a set of names matching a specified pattern (wchars). Matching means the names must begin with the pattern string.

int ACE_Naming_Context::list_type_entries ACE_BINDING_SET   set_out,
const char *    pattern_in
[virtual]
 

Get a set of types matching a specified pattern (wchars). Matching means the types must begin with the pattern string. Returns the complete binding associated each pattern match.

int ACE_Naming_Context::list_type_entries ACE_BINDING_SET   set_out,
const ACE_NS_WString   pattern_in
[virtual]
 

Get a set of types matching a specified pattern (wchars). Matching means the types must begin with the pattern string. Returns the complete binding associated each pattern match.

int ACE_Naming_Context::list_types ACE_PWSTRING_SET   set_out,
const char *    pattern_in
 

Get a set of types matching a specified pattern (chars). Matching means the types must begin with the pattern string.

int ACE_Naming_Context::list_types ACE_PWSTRING_SET   set_out,
const ACE_NS_WString   pattern_in
 

Get a set of types matching a specified pattern (wchars). Matching means the types must begin with the pattern string.

int ACE_Naming_Context::list_value_entries ACE_BINDING_SET   set_out,
const char *    pattern_in
[virtual]
 

Get a set of values matching a specified pattern (wchars). Matching means the values must begin with the pattern string. Returns the complete binding associated each pattern match.

int ACE_Naming_Context::list_value_entries ACE_BINDING_SET   set_out,
const ACE_NS_WString   pattern_in
[virtual]
 

Get a set of values matching a specified pattern (wchars). Matching means the values must begin with the pattern string. Returns the complete binding associated each pattern match.

int ACE_Naming_Context::list_values ACE_PWSTRING_SET   set_out,
const char *    pattern_in
 

Get a set of values matching a specified pattern (chars). Matching means the values must begin with the pattern string.

int ACE_Naming_Context::list_values ACE_PWSTRING_SET   set_out,
const ACE_NS_WString   pattern_in
 

Get a set of values matching a specified pattern (wchars). Matching means the values must begin with the pattern string.

int ACE_Naming_Context::local void    [private]
 

1 if we're on the same local machine as the name server, else 0.

ACE_Name_Options * ACE_Naming_Context::name_options void   
 

Returns the ACE_Name_Options associated with the Naming_Context.

int ACE_Naming_Context::open Context_Scope_Type    scope_in = ACE_Naming_Context::PROC_LOCAL,
int    light = 0
 

Specifies the scope of this namespace, opens and memory-maps the associated file (if accessible) or contacts the dedicated name server process for NET_LOCAL namespace. Note that light specifies whether or not we want to use ACE_Lite_MMap_Memory_Pool. By default we use ACE_MMap_Memory_Pool.

int ACE_Naming_Context::rebind const char *    name_in,
const char *    value_in,
const char *    type_in = ""
 

Overwrite the value or type of an existing name in a ACE_Naming_Context or bind a new name to the context, if it didn't exist yet. ( charcter strings interface)

int ACE_Naming_Context::rebind const ACE_NS_WString   name_in,
const ACE_NS_WString   value_in,
const char *    type_in = ""
 

Overwrite the value or type of an existing name in a ACE_Naming_Context or bind a new name to the context, if it didn't exist yet. (Wide charcter strings interface).

int ACE_Naming_Context::resolve const char *    name_in,
char *&    value_out,
char *&    type_out
 

Get value and type of a given name binding ( chars ). The caller is responsible for deleting both value_out and type_out!

int ACE_Naming_Context::resolve const char *    name_in,
ACE_NS_WString   value_out,
char *&    type_out
 

Get value and type of a given name binding (Wide chars output). The caller is responsible for deleting both value_out and type_out!

int ACE_Naming_Context::resolve const ACE_NS_WString   name_in,
ACE_NS_WString   value_out,
char *&    type_out
 

Get value and type of a given name binding (Wide chars). The caller is responsible for deleting both value_out> and type_out!

int ACE_Naming_Context::unbind const char *    name_in
 

Delete a name from a ACE_Naming_Context (character strings interface).

int ACE_Naming_Context::unbind const ACE_NS_WString   name_in
 

Delete a name from a ACE_Naming_Context (Wide charcter strings Interface).


Member Data Documentation

ACE_TCHAR ACE_Naming_Context::hostname_[MAXHOSTNAMELEN + 1] [private]
 

Holds the local hostname.

ACE_Name_Options* ACE_Naming_Context::name_options_ [private]
 

Keep track of the options such as database name etc per Naming Context.

ACE_Name_Space* ACE_Naming_Context::name_space_ [private]
 

Name space (can be either local or remote) dynamically bound.

const ACE_TCHAR* ACE_Naming_Context::netnameserver_host_ [private]
 

Holds name of net name server.

int ACE_Naming_Context::netnameserver_port_ [private]
 

Holds port number of the net name server.


The documentation for this class was generated from the following files:
Generated on Fri Apr 2 16:50:43 2004 for ACE by doxygen1.2.18