Skip to content

Commit

Permalink
fixup! fixup! SILKIT-1612 log: add participant name to file names
Browse files Browse the repository at this point in the history
  • Loading branch information
MariusBgm committed Oct 11, 2024
1 parent b2ee5ae commit 95986b1
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 22 deletions.
24 changes: 2 additions & 22 deletions SilKit/source/core/vasio/VAsioConnection.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
#include "Uri.hpp"
#include "Assert.hpp"
#include "TransformAcceptorUris.hpp"
#include "StringHelpers.hpp"

#include "ConnectPeer.hpp"
#include "util/TracingMacros.hpp"
Expand All @@ -63,27 +64,6 @@ namespace fs = SilKit::Filesystem;

namespace {

auto printableName(const std::string& participantName) -> std::string
{
std::string safeName;
for (const auto& ch : participantName)
{
// do not use std::isalnum, as it may sensitive to the current locale
const bool isAlphaNumeric{('a' <= ch && ch <= 'z') || ('A' <= ch && ch <= 'Z') || ('0' <= ch && ch <= '9')
|| (ch == '_' || ch == '-' || ch == '.' || ch == '~')};

if (isAlphaNumeric)
{
safeName.push_back(ch);
}
else
{
safeName += fmt::format("{:02X}", static_cast<unsigned char>(ch));
}
}
return safeName;
}

//Debug print of given peer infos

auto printUris(const std::vector<std::string>& uris)
Expand All @@ -99,7 +79,7 @@ auto makeLocalEndpoint(const std::string& participantName, const SilKit::Core::P
{
asio::local::stream_protocol::endpoint result;
// Ensure the participantName is in a useful encoding
const auto safe_name = printableName(participantName);
const auto safe_name = SilKit::Util::PrintableString(participantName);
const auto bounded_name = safe_name.substr(0, std::min<size_t>(safe_name.size(), 10));

// We hash the participant name, ID and the current working directory
Expand Down
20 changes: 20 additions & 0 deletions SilKit/source/util/StringHelpers.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -119,6 +119,26 @@ auto LowerCase(std::string input) -> std::string
return input;
}

auto PrintableString(const std::string& participantName) -> std::string
{
std::string safeName;
for (const auto& ch : participantName)
{
// do not use std::isalnum, as it may sensitive to the current locale
const bool isAlphaNumeric{('a' <= ch && ch <= 'z') || ('A' <= ch && ch <= 'Z') || ('0' <= ch && ch <= '9')
|| (ch == '_' || ch == '-' || ch == '.' || ch == '~')};

if (isAlphaNumeric)
{
safeName.push_back(ch);
}
else
{
safeName += fmt::format("{:02X}", static_cast<unsigned char>(ch));
}
}
return safeName;
}

} // namespace Util
} // namespace SilKit
2 changes: 2 additions & 0 deletions SilKit/source/util/StringHelpers.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,8 @@ auto CurrentTimestampString() -> std::string;

auto LowerCase(std::string input) -> std::string;

auto PrintableString(const std::string& input) -> std::string;


} // namespace Util
} // namespace SilKit

0 comments on commit 95986b1

Please sign in to comment.