Added test for filter backend_test.
[metaproxy-moved-to-github.git] / src / filter_virt_db.cpp
index 4c34f00..9b61465 100644 (file)
@@ -1,4 +1,4 @@
-/* $Id: filter_virt_db.cpp,v 1.4 2005-10-25 15:19:39 adam Exp $
+/* $Id: filter_virt_db.cpp,v 1.6 2005-10-25 21:32:01 adam Exp $
    Copyright (c) 2005, Index Data.
 
 %LICENSE%
@@ -117,10 +117,7 @@ void yf::Virt_db::Rep::release_session(Package &package)
 {
     boost::mutex::scoped_lock lock(m_sessions_mutex);
     
-    Ses_it it = m_sessions.find(package.session());
-    
-    if (it != m_sessions.end())
-        m_sessions.erase(it);
+    m_sessions.erase(package.session());
 }
 
 void yf::Virt_db::Rep::present(Package &package, Z_APDU *apdu, bool &move_later){
@@ -169,7 +166,7 @@ void yf::Virt_db::Rep::present(Package &package, Z_APDU *apdu, bool &move_later)
             odr_destroy(odr);
             return;
         }
-        id = new yp2::Session(it->second.m_session);
+        id = new yp2::Session(sets_it->second.m_session);
     }
     ODR odr = odr_createmem(ODR_ENCODE);
     
@@ -206,6 +203,8 @@ void yf::Virt_db::Rep::search(Package &package, Z_APDU *apdu, bool &move_later)
             Z_APDU *apdu = zget_APDU(odr, Z_APDU_close);
             
             *apdu->u.close->closeReason = Z_Close_protocolError;
+            apdu->u.close->diagnosticInformation =
+                odr_strdup(odr, "no session for search request");
             
             package.response() = apdu;
             package.session().close();