Skip to content
Snippets Groups Projects
Select Git revision
  • 38306eaec58c046d787eaee7f36373c2130f27d3
  • master default
  • windows_ci_static
  • c_link
  • cpack
  • windows_ci
  • cert_pk_id
  • proxy_push_result
  • cnode_put_id
  • update-windows-build
  • proxy
  • resubscribe_on_token_change
  • actions
  • client_mode
  • llhttp
  • search_node_add
  • crypto_aes_gcm_argon2
  • ios_notifications
  • log_fmt
  • v2asio
  • fix-msvc
  • v3.4.0
  • v3.3.1
  • v3.3.1rc1
  • v3.3.1rc2
  • v3.3.0
  • v3.2.0
  • v3.1.11
  • v3.1.10
  • v3.1.9
  • v3.1.8.2
  • v3.1.8.1
  • v3.1.8
  • v3.1.7
  • v3.1.6
  • v3.1.5
  • v3.1.4
  • v3.1.3
  • v3.1.2
  • v3.1
  • v3.0.1
41 results

benchmark.py

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    string_utils.cpp 4.44 KiB
    /*
     *  Copyright (C) 2004-2020 Savoir-faire Linux Inc.
     *
     *  Author: Tristan Matthews <tristan.matthews@savoirfairelinux.com>
     *  Author: Adrien Béraud <adrien.beraud@savoirfairelinux.com>
     *
     *  This program is free software; you can redistribute it and/or modify
     *  it under the terms of the GNU General Public License as published by
     *  the Free Software Foundation; either version 3 of the License, or
     *  (at your option) any later version.
     *
     *  This program is distributed in the hope that it will be useful,
     *  but WITHOUT ANY WARRANTY; without even the implied warranty of
     *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     *  GNU General Public License for more details.
     *
     *  You should have received a copy of the GNU General Public License
     *  along with this program; if not, write to the Free Software
     *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301 USA.
     */
    
    #include "string_utils.h"
    
    #include <sstream>
    #include <cctype>
    #include <algorithm>
    #include <ostream>
    #include <iomanip>
    #include <stdexcept>
    #include <ios>
    #include <charconv>
    #include <string_view>
    #ifdef _WIN32
    #include <windows.h>
    #include <oleauto.h>
    #endif
    
    #include <ciso646> // fix windows compiler bug
    
    namespace jami {
    
    #ifdef _WIN32
    std::wstring
    to_wstring(const std::string& str, int codePage)
    {
        int srcLength = (int) str.length();
        int requiredSize = MultiByteToWideChar(codePage, 0, str.c_str(), srcLength, nullptr, 0);
        if (!requiredSize) {
            throw std::runtime_error("Can't convert string to wstring");
        }
        std::wstring result((size_t) requiredSize, 0);
        if (!MultiByteToWideChar(codePage, 0, str.c_str(), srcLength, &(*result.begin()), requiredSize)) {
            throw std::runtime_error("Can't convert string to wstring");
        }
        return result;
    }
    
    std::string
    to_string(const std::wstring& wstr, int codePage)
    {
        int srcLength = (int) wstr.length();
        int requiredSize = WideCharToMultiByte(codePage, 0, wstr.c_str(), srcLength, nullptr, 0, 0, 0);
        if (!requiredSize) {
            throw std::runtime_error("Can't convert wstring to string");
        }
        std::string result((size_t) requiredSize, 0);
        if (!WideCharToMultiByte(
                codePage, 0, wstr.c_str(), srcLength, &(*result.begin()), requiredSize, 0, 0)) {
            throw std::runtime_error("Can't convert wstring to string");
        }
        return result;
    }
    #endif
    
    std::string
    to_string(double value)
    {
        char buf[64];
        int len = snprintf(buf, sizeof(buf), "%-.*G", 16, value);
        if (len <= 0)
            throw std::invalid_argument {"can't parse double"};
        return {buf, (size_t) len};
    }
    
    std::string
    to_hex_string(uint64_t id)
    {
        std::ostringstream ss;
        ss << std::hex << std::setfill('0') << std::setw(16) << id;
        return ss.str();
    }
    
    uint64_t
    from_hex_string(const std::string& str)
    {
        std::istringstream ss(str);
        ss >> std::hex;
        uint64_t id;
        if (!(ss >> id))
            throw std::invalid_argument("Can't parse id: " + str);
        return id;
    }
    
    std::string_view
    trim(std::string_view s)
    {
        auto wsfront = std::find_if_not(s.cbegin(), s.cend(), [](int c) { return std::isspace(c); });
        return std::string_view(&*wsfront, std::find_if_not(s.rbegin(),
                                            std::string_view::const_reverse_iterator(wsfront),
                                            [](int c) { return std::isspace(c); })
                               .base() - wsfront);
    }
    
    std::vector<unsigned>
    split_string_to_unsigned(const std::string& str, char delim)
    {
        std::vector<unsigned> output;
        for (auto first = str.data(), second = str.data(), last = first + str.size(); second != last && first != last; first = second + 1) {
            second = std::find(first, last, delim);
            if (first != second) {
                unsigned result;
                auto [p, ec] = std::from_chars(first, second, result);
                if (ec ==  std::errc())
                    output.emplace_back(result);
            }
        }
        return output;
    }
    
    void
    string_replace(std::string& str, const std::string& from, const std::string& to)
    {
        size_t start_pos = 0;
        while ((start_pos = str.find(from, start_pos)) != std::string::npos) {
            str.replace(start_pos, from.length(), to);
            start_pos += to.length(); // Handles case where 'to' is a substring of 'from'
        }
    }
    
    std::string_view
    string_remove_suffix(std::string_view str, char separator)
    {
        auto it = str.find(separator);
        if (it != std::string_view::npos)
            str = str.substr(0, it);
        return str;
    }
    
    } // namespace jami