diff options
author | Marc Laukien <marc@zeroc.com> | 2001-10-01 17:02:38 +0000 |
---|---|---|
committer | Marc Laukien <marc@zeroc.com> | 2001-10-01 17:02:38 +0000 |
commit | cf6d7ca679baa07b64bea6dce9dbc40b8bce14e9 (patch) | |
tree | f169a8b42a735aa12155b12b12833127437aa15e /cpp/src/Ice/Incoming.cpp | |
parent | servant factory/locator management changes (diff) | |
download | ice-cf6d7ca679baa07b64bea6dce9dbc40b8bce14e9.tar.bz2 ice-cf6d7ca679baa07b64bea6dce9dbc40b8bce14e9.tar.xz ice-cf6d7ca679baa07b64bea6dce9dbc40b8bce14e9.zip |
Servant lookup fixes
Diffstat (limited to 'cpp/src/Ice/Incoming.cpp')
-rw-r--r-- | cpp/src/Ice/Incoming.cpp | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/cpp/src/Ice/Incoming.cpp b/cpp/src/Ice/Incoming.cpp index f9a74512494..828948cc817 100644 --- a/cpp/src/Ice/Incoming.cpp +++ b/cpp/src/Ice/Incoming.cpp @@ -39,24 +39,30 @@ IceInternal::Incoming::invoke(Stream& is) Stream::Container::size_type statusPos = _os.b.size(); - ObjectPtr servant = _adapter->identityToServant(identity); + ObjectPtr servant; ServantLocatorPtr locator; LocalObjectPtr cookie; try { + servant = _adapter->identityToServant(identity); + if (!servant) { string::size_type pos = identity.find('#'); if (pos != string::npos) { locator = _adapter->findServantLocator(identity.substr(0, pos)); + if (locator) + { + servant = locator->locate(_adapter, identity, operation, cookie); + } } - else - { - locator = _adapter->findServantLocator(""); - } + } + if (!servant) + { + locator = _adapter->findServantLocator(""); if (locator) { servant = locator->locate(_adapter, identity, operation, cookie); |