diff --git a/Control/AthenaIPCTools/src/AthenaSharedMemoryTool.cxx b/Control/AthenaIPCTools/src/AthenaSharedMemoryTool.cxx index 5c46484f21e9407f51ba01b1eaaa1fbe604191de..224f48fc98c60d64449ee76773da90efb7d9004e 100644 --- a/Control/AthenaIPCTools/src/AthenaSharedMemoryTool.cxx +++ b/Control/AthenaIPCTools/src/AthenaSharedMemoryTool.cxx @@ -356,7 +356,7 @@ StatusCode AthenaSharedMemoryTool::getObject(void** target, size_t& nbytes, int } //___________________________________________________________________________ -StatusCode AthenaSharedMemoryTool::clearObject(char** tokenString, int& num) const { +StatusCode AthenaSharedMemoryTool::clearObject(const char** tokenString, int& num) const { if (m_isClient) { ShareEventHeader* evtH = static_cast<ShareEventHeader*>(m_status->get_address()); if (evtH->evtProcessStatus != ShareEventHeader::CLEARED) { diff --git a/Control/AthenaIPCTools/src/AthenaSharedMemoryTool.h b/Control/AthenaIPCTools/src/AthenaSharedMemoryTool.h index 182cda61b452b7affcef16bf1f6f541006038354..d629361ff115c0cfd26edabcd2d59ef8918d8222 100644 --- a/Control/AthenaIPCTools/src/AthenaSharedMemoryTool.h +++ b/Control/AthenaIPCTools/src/AthenaSharedMemoryTool.h @@ -53,7 +53,7 @@ public: StatusCode putObject(const void* source, size_t nbytes, int num = 0) const; StatusCode getObject(void** target, size_t& nbytes, int num = 0) const; - StatusCode clearObject(char** tokenString, int& num) const; + StatusCode clearObject(const char** tokenString, int& num) const; StatusCode lockObject(const char* tokenString, int num = 0) const; private: diff --git a/Control/AthenaIPCTools/src/AthenaYamplTool.cxx b/Control/AthenaIPCTools/src/AthenaYamplTool.cxx index fea75d358e3007c68fe3c72c7cb70e967efd0f76..7ed8fc9a153bb372d0bd416eb8ed3bb4b31927a4 100644 --- a/Control/AthenaIPCTools/src/AthenaYamplTool.cxx +++ b/Control/AthenaIPCTools/src/AthenaYamplTool.cxx @@ -235,7 +235,7 @@ StatusCode AthenaYamplTool::getObject(void**, size_t&, int) const { } //___________________________________________________________________________ -StatusCode AthenaYamplTool::clearObject(char**, int&) const { +StatusCode AthenaYamplTool::clearObject(const char**, int&) const { return(StatusCode::FAILURE); } diff --git a/Control/AthenaIPCTools/src/AthenaYamplTool.h b/Control/AthenaIPCTools/src/AthenaYamplTool.h index 51e91ed2c88ce2295a8eb58b74da59db03f3fd3d..440b47f6a8c2f0095d9a37125fdd896fe1936413 100644 --- a/Control/AthenaIPCTools/src/AthenaYamplTool.h +++ b/Control/AthenaIPCTools/src/AthenaYamplTool.h @@ -43,7 +43,7 @@ public: StatusCode putObject(const void* source, size_t nbytes, int num = 0) const; StatusCode getObject(void** target, size_t& nbytes, int num = 0) const; - StatusCode clearObject(char** tokenString, int& num) const; + StatusCode clearObject(const char** tokenString, int& num) const; StatusCode lockObject(const char* tokenString, int num = 0) const; private: diff --git a/Control/AthenaKernel/AthenaKernel/IAthenaIPCTool.h b/Control/AthenaKernel/AthenaKernel/IAthenaIPCTool.h index b734fa1bc6251ebdc2b2aa9c601a0ec435070b1c..12e3353e39837e61fb4d4b8036f665329c713eb2 100644 --- a/Control/AthenaKernel/AthenaKernel/IAthenaIPCTool.h +++ b/Control/AthenaKernel/AthenaKernel/IAthenaIPCTool.h @@ -24,7 +24,7 @@ public: virtual StatusCode putObject(const void* source, size_t nbytes, int num = 0) const = 0; virtual StatusCode getObject(void** target, size_t& nbytes, int num = 0) const = 0; - virtual StatusCode clearObject(char** tokenString, int& num) const = 0; + virtual StatusCode clearObject(const char** tokenString, int& num) const = 0; virtual StatusCode lockObject(const char* tokenString, int num = 0) const = 0; }; diff --git a/Database/AthenaPOOL/AthenaPoolCnvSvc/src/AthenaPoolCnvSvc.cxx b/Database/AthenaPOOL/AthenaPoolCnvSvc/src/AthenaPoolCnvSvc.cxx index 51518beb0b8e2e606c9035ca0ac1d3604c3f71a9..2134f4c0206d5143858950e51956791ec7b9a0c7 100644 --- a/Database/AthenaPOOL/AthenaPoolCnvSvc/src/AthenaPoolCnvSvc.cxx +++ b/Database/AthenaPOOL/AthenaPoolCnvSvc/src/AthenaPoolCnvSvc.cxx @@ -424,7 +424,7 @@ StatusCode AthenaPoolCnvSvc::commitOutput(const std::string& outputConnectionSpe && m_outputStreamingTool[m_streamServer]->isServer()) { auto& streamingTool = m_outputStreamingTool[m_streamServer]; // Clear object to get Placements for all objects in a Stream - char* placementStr = nullptr; + const char* placementStr = nullptr; int num = -1; StatusCode sc = streamingTool->clearObject(&placementStr, num); if (sc.isSuccess() && placementStr != nullptr && strlen(placementStr) > 6 && num > 0) { @@ -778,7 +778,7 @@ Token* AthenaPoolCnvSvc::registerForWrite(Placement* placement, const void* obj, return(nullptr); } // Get Token back from Server - char* tokenStr = nullptr; + const char* tokenStr = nullptr; int num = -1; sc = m_outputStreamingTool[streamClient]->clearObject(&tokenStr, num); while (sc.isRecoverable()) { @@ -893,7 +893,7 @@ void AthenaPoolCnvSvc::setObjPtr(void*& obj, const Token* token) { } } if (!m_inputStreamingTool.empty() && m_inputStreamingTool->isClient()) { - ATH_MSG_VERBOSE("Requesting object for: " << token->toString()); + ATH_MSG_VERBOSE("Requesting remote object for: " << token->toString()); if (!m_inputStreamingTool->lockObject(token->toString().c_str()).isSuccess()) { ATH_MSG_ERROR("Failed to lock Data for " << token->toString()); obj = nullptr; @@ -979,7 +979,7 @@ StatusCode AthenaPoolCnvSvc::createAddress(long svcType, return(StatusCode::FAILURE); } token = new Token(); - token->fromString(static_cast<char*>(buffer)); buffer = nullptr; + token->fromString(static_cast<const char*>(buffer)); buffer = nullptr; if (token->classID() == Guid::null()) { delete token; token = nullptr; } @@ -1118,7 +1118,7 @@ StatusCode AthenaPoolCnvSvc::readData() { if (m_inputStreamingTool.empty()) { return(StatusCode::FAILURE); } - char* tokenStr = nullptr; + const char* tokenStr = nullptr; int num = -1; StatusCode sc = m_inputStreamingTool->clearObject(&tokenStr, num); if (sc.isSuccess() && tokenStr != nullptr && strlen(tokenStr) > 0 && num > 0) { @@ -1200,7 +1200,7 @@ StatusCode AthenaPoolCnvSvc::abortSharedWrClients(int client_n) if (client_n >= 0) { sc = streamingTool->lockObject("ABORT", client_n); } - char* dummy; + const char* dummy; sc = streamingTool->clearObject(&dummy, client_n); while (sc.isRecoverable()) { sc = streamingTool->clearObject(&dummy, client_n); diff --git a/Database/AthenaPOOL/AthenaPoolCnvSvc/src/AuxDiscoverySvc.cxx b/Database/AthenaPOOL/AthenaPoolCnvSvc/src/AuxDiscoverySvc.cxx index a45a0580a3a83c880eaf70f54706fe686a1c5bde..643354ddd27f40fb52ed5b972b63035a4e3c39b0 100644 --- a/Database/AthenaPOOL/AthenaPoolCnvSvc/src/AuxDiscoverySvc.cxx +++ b/Database/AthenaPOOL/AthenaPoolCnvSvc/src/AuxDiscoverySvc.cxx @@ -166,25 +166,25 @@ StatusCode AuxDiscoverySvc::receiveStore(const IAthenaSerializeSvc* serSvc, cons return(StatusCode::SUCCESS); } Guid classId; - classId.fromString(static_cast<char*>(buffer)); + classId.fromString(static_cast<const char*>(buffer)); if (!ipcTool->getObject(&buffer, nbytes, num).isSuccess() || nbytes == 0) { return(StatusCode::FAILURE); } - const std::string contName = std::string(static_cast<char*>(buffer)); + const std::string contName = std::string(static_cast<const char*>(buffer)); if (classId != Guid::null() && this->getAuxStore(obj, classId, contName)) { - void* attrName = nullptr; - void* typeName = nullptr; - void* elemName = nullptr; + void* nameData = nullptr; // StreamingTool owns buffer, will stay around until last dynamic attribute is copied - while (ipcTool->getObject(&attrName, nbytes, num).isSuccess() && nbytes > 0 && - ipcTool->getObject(&typeName, nbytes, num).isSuccess() && nbytes > 0 && - ipcTool->getObject(&elemName, nbytes, num).isSuccess() && nbytes > 0) { + while (ipcTool->getObject(&nameData, nbytes, num).isSuccess() && nbytes > 0) { + const char* del1 = static_cast<const char*>(memchr(nameData, '\n', nbytes)); + const char* del2 = static_cast<const char*>(memchr(del1 + 1, '\n', nbytes - (del1 - static_cast<const char*>(nameData) - 1))); + const std::string dataStr(static_cast<const char*>(nameData)); + const std::string& attrName = dataStr.substr(0, del1 - static_cast<const char*>(nameData)); + const std::string& typeName = dataStr.substr(del1 - static_cast<const char*>(nameData) + 1, del2 - del1 - 1); + const std::string& elemName = dataStr.substr(del2 - static_cast<const char*>(nameData) + 1); if (ipcTool->getObject(&buffer, nbytes, num).isSuccess()) { - SG::auxid_t auxid = this->getAuxID(static_cast<char*>(attrName), - static_cast<char*>(elemName), - static_cast<char*>(typeName)); + SG::auxid_t auxid = this->getAuxID(attrName, elemName, typeName); if (auxid != SG::null_auxid) { - const RootType type(std::string(static_cast<char*>(typeName))); + const RootType type(typeName); void* dynAttr = nullptr; if (type.IsFundamental()) { dynAttr = new char[nbytes]; @@ -218,12 +218,8 @@ StatusCode AuxDiscoverySvc::sendStore(const IAthenaSerializeSvc* serSvc, } } for (SG::auxid_set_t::const_iterator iter = auxIDs.begin(), last = auxIDs.end(); iter != last; iter++) { - const std::string& attrName = this->getAttrName(*iter); - const std::string& typeName = this->getTypeName(*iter); - const std::string& elemName = this->getElemName(*iter); - if (!ipcTool->putObject(attrName.c_str(), attrName.size() + 1, num).isSuccess() || - !ipcTool->putObject(typeName.c_str(), typeName.size() + 1, num).isSuccess() || - !ipcTool->putObject(elemName.c_str(), elemName.size() + 1, num).isSuccess()) { + const std::string& dataStr = this->getAttrName(*iter) + "\n" + this->getTypeName(*iter) + "\n" + this->getElemName(*iter); + if (!ipcTool->putObject(dataStr.c_str(), dataStr.size() + 1, num).isSuccess()) { return(StatusCode::FAILURE); } const std::type_info* tip = this->getType(*iter);