#include <coherence/net/ConfigurableAddressProviderFactory.hpp>
Inherits Object, AddressProviderFactory, and XmlConfigurable.
<!ELEMENT ... (socket-address+ | address-provider)> <!ELEMENT address-provider (class-name | (class-factory-name, method-name), init-params?> <!ELEMENT socket-address (address, port)>
Public Types | |
typedef spec::Handle | Handle |
ConfigurableAddressProviderFactory Handle definition. | |
typedef spec::View | View |
ConfigurableAddressProviderFactory View definition. | |
typedef spec::Holder | Holder |
ConfigurableAddressProviderFactory Holder definition. | |
Public Member Functions | |
virtual AddressProvider::Handle | createAddressProvider (ClassLoader::View vLoader=NULL) |
Instantiate an AddressProvider configured according to the specified XML. | |
virtual void | setConfig (XmlElement::View xml) |
virtual XmlElement::View | getConfig () const |
If this Object was previously configured using some XML configuration, the corresponding XmlElement is returned.
| |
virtual TypedHandle < const String > | toString () const |
Output a human-readable description of this Object to the given stream. Note that when overriding this method the return type must be TypedHandle<const String> rather then String::View. These two types are assignment compatible but not equivalent and declaring the override with String::View will not be a compatible override. coherence::lang::operator<<(std::ostream, Object::View) is defined and will call into the toString method, to output Objects. If a managed String object is desired, the COH_TO_STRING macro can be used to build up a String from streamable contents and is generally how toString() will be implemented.
Object::View vKey = ... Object::View vValue = ... std::cout << vKey << " = " << vValue << std::endl; String::View vs = COH_TO_STRING(vKey << " = " << vValue); The COH_TO_STRING macro is also the most common way to implement the toString method. For example:
virtual TypedHandle<const String> Person::toString() const { return COH_TO_STRING("Name: " << f_sName << " SSN: " << f_nSSN); }
| |
Protected Member Functions | |
ConfigurableAddressProviderFactory () | |
Create a new ConfigurableAddressProviderFactory instance. | |
Protected Attributes | |
FinalView< XmlElement > | f_vXmlConfig |
XML configuration for this ConfigurableAddressProviderFactory. |
virtual AddressProvider::Handle createAddressProvider | ( | ClassLoader::View | vLoader = NULL |
) | [virtual] |
Instantiate an AddressProvider configured according to the specified XML.
The passed XML has to conform to the following format:
<!ELEMENT ... (socket-address+ | address-provider)> <!ELEMENT address-provider (class-name | (class-factory-name, method-name), init-params?> <!ELEMENT socket-address (address, port)>
vLoader | the optional ClassLoader with which to configure the new AddressProvider. |
Implements AddressProviderFactory.