Skip to content
Snippets Groups Projects
Data.cpp 20.7 KiB
Newer Older
Philip Müller's avatar
Philip Müller committed
/*
 *  This file is part of the mhwd - Manjaro Hardware Detection project
 *  
dec's avatar
dec committed
 *  mhwd - Manjaro Hardware Detection
 *  Roland Singer <roland@manjaro.org>
 *  Łukasz Matysiak <december0123@gmail.com>
Philip Müller's avatar
Philip Müller committed
 *  Filipe Marques <eagle.software3@gmail.com>
Philip Müller's avatar
Philip Müller committed
 *
dec's avatar
dec committed
 *  Copyright (C) 2007 Free Software Foundation, Inc.
 *
 *  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, see <http://www.gnu.org/licenses/>.
Philip Müller's avatar
Philip Müller committed
 */

#include <dirent.h>
december0123's avatar
december0123 committed
#include <algorithm>
Philip Müller's avatar
Philip Müller committed
#include <fstream>
#include <iomanip>
#include <sstream>
december0123's avatar
december0123 committed
#include <string>
#include <vector>

#include "Data.hpp"

Philip Müller's avatar
Philip Müller committed
Data::Data()
{
december0123's avatar
december0123 committed
    fillDevices("PCI");
    fillDevices("USB");
Philip Müller's avatar
Philip Müller committed

december0123's avatar
december0123 committed
    updateConfigData();
Philip Müller's avatar
Philip Müller committed
}

Data::~Data()
{
}

void Data::updateInstalledConfigData()
{
december0123's avatar
december0123 committed
    // Clear config vectors in each device element
    for (auto&& PCIDevice = PCIDevices.begin();
            PCIDevice != PCIDevices.end(); ++PCIDevice)
december0123's avatar
december0123 committed
    {
december0123's avatar
december0123 committed
        (*PCIDevice)->installedConfigs_.clear();
    for (auto&& USBDevice = USBDevices.begin();
            USBDevice != USBDevices.end(); ++USBDevice)
december0123's avatar
december0123 committed
    {
december0123's avatar
december0123 committed
        (*USBDevice)->installedConfigs_.clear();
december0123's avatar
december0123 committed
    }

    installedPCIConfigs.clear();
    installedUSBConfigs.clear();

    // Refill data
    fillInstalledConfigs("PCI");
    fillInstalledConfigs("USB");

    setMatchingConfigs(PCIDevices, installedPCIConfigs, true);
    setMatchingConfigs(USBDevices, installedUSBConfigs, true);
Philip Müller's avatar
Philip Müller committed
}

void Data::fillInstalledConfigs(std::string type)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    std::vector<std::string> configPaths;
december0123's avatar
december0123 committed
    std::vector<std::shared_ptr<Config>>* configs;
december0123's avatar
december0123 committed

    if ("USB" == type)
december0123's avatar
december0123 committed
    {
        configs = &installedUSBConfigs;
        configPaths = getRecursiveDirectoryFileList(MHWD_USB_DATABASE_DIR, MHWD_CONFIG_NAME);
    }
    else
    {
        configs = &installedPCIConfigs;
        configPaths = getRecursiveDirectoryFileList(MHWD_PCI_DATABASE_DIR, MHWD_CONFIG_NAME);
    }

    for (auto&& configPath = configPaths.begin();
december0123's avatar
december0123 committed
            configPath != configPaths.end(); ++configPath)
    {
        Config *config = new Config((*configPath), type);

        if (config->readConfigFile((*configPath)))
        {
december0123's avatar
december0123 committed
            configs->push_back(std::shared_ptr<Config>{config});
december0123's avatar
december0123 committed
        }
        else
        {
december0123's avatar
december0123 committed
            invalidConfigs.push_back(std::shared_ptr<Config>{config});
Philip Müller's avatar
Philip Müller committed
}

december0123's avatar
december0123 committed
void Data::getAllDevicesOfConfig(std::shared_ptr<Config> config, std::vector<std::shared_ptr<Device>>& foundDevices)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    std::vector<std::shared_ptr<Device>> devices;
    if ("USB" == config->type_)
december0123's avatar
december0123 committed
    {
        devices = USBDevices;
    }
    else
    {
        devices = PCIDevices;
    }

    getAllDevicesOfConfig(devices, config, foundDevices);
Philip Müller's avatar
Philip Müller committed
}

december0123's avatar
december0123 committed
void Data::getAllDevicesOfConfig(const std::vector<std::shared_ptr<Device>>& devices,
        std::shared_ptr<Config> config,
        std::vector<std::shared_ptr<Device>>& foundDevices)
Philip Müller's avatar
Philip Müller committed
{
    foundDevices.clear();
    for (auto&& hwdID = config->hwdIDs_.begin();
december0123's avatar
december0123 committed
            hwdID != config->hwdIDs_.end(); ++hwdID)
    {
        bool foundDevice = false;
        // Check all devices
        for (auto&& i_device = devices.begin(); i_device != devices.end();
december0123's avatar
december0123 committed
                ++i_device)
        {
            // Check class ids
            bool found = std::find_if(hwdID->classIDs.begin(), hwdID->classIDs.end(), [i_device](const std::string& classID){
            					return (("*" == classID) || (classID == (*i_device)->classID_));
            				}) != hwdID->classIDs.end();
december0123's avatar
december0123 committed

            if (!found)
            {
                continue;
            }
            else
            {
                // Check blacklisted class ids
                found = std::find_if(hwdID->blacklistedClassIDs.begin(), hwdID->blacklistedClassIDs.end(), [i_device](const std::string& blacklistedClassID){
                				return (blacklistedClassID == (*i_device)->classID_);
                			}) != hwdID->blacklistedClassIDs.end();
december0123's avatar
december0123 committed

                if (found)
                {
                    continue;
                }
                else
                {
                    // Check vendor ids
                	found = std::find_if(hwdID->vendorIDs.begin(), hwdID->vendorIDs.end(), [i_device](const std::string& vendorID){
                	            	return (("*" == vendorID) || (vendorID == (*i_device)->vendorID_));
                	            }) != hwdID->vendorIDs.end();
december0123's avatar
december0123 committed

                    if (!found)
                    {
                        continue;
                    }
                    else
                    {
                        // Check blacklisted vendor ids
                        found = std::find_if(hwdID->blacklistedVendorIDs.begin(), hwdID->blacklistedVendorIDs.end(), [i_device](const std::string& blacklistedVendorID){
                        				return (blacklistedVendorID == (*i_device)->vendorID_);
                        			}) != hwdID->blacklistedVendorIDs.end();
december0123's avatar
december0123 committed

                        if (found)
                        {
                            continue;
                        }
                        else
                        {
                            // Check device ids
                        	found = std::find_if(hwdID->deviceIDs.begin(), hwdID->deviceIDs.end(), [i_device](const std::string& deviceID){
                        	        		return (("*" == deviceID) || (deviceID == (*i_device)->deviceID_));
                        	            }) != hwdID->deviceIDs.end();
december0123's avatar
december0123 committed

                            if (!found)
                            {
                                continue;
                            }
                            else
                            {
                                // Check blacklisted device ids
                                found = std::find_if(hwdID->blacklistedDeviceIDs.begin(), hwdID->blacklistedDeviceIDs.end(), [i_device](const std::string& blacklistedDeviceID){
                                				return (blacklistedDeviceID == (*i_device)->deviceID_);
                                			}) != hwdID->blacklistedDeviceIDs.end();
december0123's avatar
december0123 committed
                                if (found)
                                {
                                    continue;
                                }
                                else
                                {
                                    foundDevice = true;
                                    foundDevices.push_back(*i_device);
            foundDevices.clear();
december0123's avatar
december0123 committed
            return;
        }
    }
Philip Müller's avatar
Philip Müller committed
}

december0123's avatar
december0123 committed
std::vector<std::shared_ptr<Config>> Data::getAllDependenciesToInstall(
        std::shared_ptr<Config> config)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    std::vector<std::shared_ptr<Config>> depends;
    std::vector<std::shared_ptr<Config>> installedConfigs;
december0123's avatar
december0123 committed

    // Get the right configs
    if ("USB" == config->type_)
december0123's avatar
december0123 committed
    {
        installedConfigs = installedUSBConfigs;
    }
    else
    {
        installedConfigs = installedPCIConfigs;
    }

    // Get all depends
    getAllDependenciesToInstall(config, installedConfigs, &depends);
december0123's avatar
december0123 committed

    return depends;
Philip Müller's avatar
Philip Müller committed
}

december0123's avatar
december0123 committed
void Data::getAllDependenciesToInstall(std::shared_ptr<Config> config,
        std::vector<std::shared_ptr<Config>>& installedConfigs,
        std::vector<std::shared_ptr<Config>> *dependencies)
Philip Müller's avatar
Philip Müller committed
{
    for (auto&& configDependency = config->dependencies_.begin();
            configDependency != config->dependencies_.end(); ++configDependency)
december0123's avatar
december0123 committed
    {
        auto found = std::find_if(installedConfigs.begin(), installedConfigs.end(),
dec's avatar
dec committed
                [configDependency](const std::shared_ptr<Config>& rhs) -> bool {
                    return (rhs->name_ == *configDependency);
december0123's avatar
december0123 committed
                });
        if (found != installedConfigs.end())
december0123's avatar
december0123 committed
        {
            continue;
        }
        else
        {
december0123's avatar
december0123 committed
            found = std::find_if(dependencies->begin(), dependencies->end(),
dec's avatar
dec committed
                    [configDependency](const std::shared_ptr<Config>& rhs) -> bool {
                        return (rhs->name_ == *configDependency);
december0123's avatar
december0123 committed
                    });

            if (found != dependencies->end())
december0123's avatar
december0123 committed
            {
                continue;
            }
            else
            {
december0123's avatar
december0123 committed
                // Add to vector and check for further subdepends...
                std::shared_ptr<Config> dependconfig {
                	getDatabaseConfig((*configDependency), config->type_)};
                if (nullptr == dependconfig)
december0123's avatar
december0123 committed
                {
                    continue;
                }
                else
                {
dec's avatar
dec committed
                    dependencies->emplace_back(dependconfig);
december0123's avatar
december0123 committed
                    getAllDependenciesToInstall(dependconfig, installedConfigs, dependencies);
                }
Philip Müller's avatar
Philip Müller committed
}

december0123's avatar
december0123 committed
std::shared_ptr<Config> Data::getDatabaseConfig(const std::string configName,
december0123's avatar
december0123 committed
        const std::string configType)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    std::vector<std::shared_ptr<Config>> allConfigs;
december0123's avatar
december0123 committed

    // Get the right configs
    if ("USB" == configType)
december0123's avatar
december0123 committed
    {
        allConfigs = allUSBConfigs;
    }
    else
    {
        allConfigs = allPCIConfigs;
    }

    for (auto&& config = allConfigs.begin(); config != allConfigs.end();
december0123's avatar
december0123 committed
    {
        if (configName == (*config)->name_)
        {
            return (*config);
        }
    }

    return nullptr;
Philip Müller's avatar
Philip Müller committed
}

december0123's avatar
december0123 committed
std::vector<std::shared_ptr<Config>> Data::getAllLocalConflicts(std::shared_ptr<Config> config)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    std::vector<std::shared_ptr<Config>> conflicts;
    std::vector<std::shared_ptr<Config>> dependencies = getAllDependenciesToInstall(config);
    std::vector<std::shared_ptr<Config>> installedConfigs;
december0123's avatar
december0123 committed

    // Get the right configs
    if ("USB" == config->type_)
december0123's avatar
december0123 committed
    {
        installedConfigs = installedUSBConfigs;
    }
    else
    {
        installedConfigs = installedPCIConfigs;
    }

dec's avatar
dec committed
    dependencies.emplace_back(config);
    for (auto&& dependency = dependencies.begin();
            dependency != dependencies.end(); ++dependency)
december0123's avatar
december0123 committed
    {
        for (auto&& dependencyConflict = (*dependency)->conflicts_.begin();
                dependencyConflict != (*dependency)->conflicts_.end(); ++dependencyConflict)
december0123's avatar
december0123 committed
        {
            for (auto&& installedConfig = installedConfigs.begin();
                    installedConfig != installedConfigs.end(); ++installedConfig)
december0123's avatar
december0123 committed
            {
                if ((*dependencyConflict) != (*installedConfig)->name_)
                {
                    continue;
                }
                else
                {
                    // Check if already in vector
                    bool found = false;
                    for (auto&& conflict = conflicts.begin();
                            conflict != conflicts.end(); ++conflict)
december0123's avatar
december0123 committed
                    {
                        if ((*conflict)->name_ == (*dependencyConflict))
                        {
                            found = true;
                            break;
                        }
                    }

                    if (found)
                    {
                        continue;
                    }
                    else
                    {
dec's avatar
dec committed
                        conflicts.emplace_back(*installedConfig);
december0123's avatar
december0123 committed
                        break;
                    }
                }
            }
        }
    }

    return conflicts;
Philip Müller's avatar
Philip Müller committed
}

december0123's avatar
december0123 committed
std::vector<std::shared_ptr<Config>> Data::getAllLocalRequirements(std::shared_ptr<Config> config)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    std::vector<std::shared_ptr<Config>> requirements;
    std::vector<std::shared_ptr<Config>> installedConfigs;
december0123's avatar
december0123 committed

    // Get the right configs
    if ("USB" == config->type_)
december0123's avatar
december0123 committed
    {
        installedConfigs = installedUSBConfigs;
    }
    else
    {
        installedConfigs = installedPCIConfigs;
    }

    // Check if this config is required by another installed config
    for (auto&& installedConfig = installedConfigs.begin();
            installedConfig != installedConfigs.end(); ++installedConfig)
december0123's avatar
december0123 committed
    {
        for (auto&& dependency = (*installedConfig)->dependencies_.begin();
december0123's avatar
december0123 committed
                dependency != (*installedConfig)->dependencies_.end(); dependency++)
        {
            if ((*dependency) != config->name_)
            {
                continue;
            }
            else
            {
                // Check if already in vector
                bool found = false;
                for (auto&& requirement = requirements.begin();
                        requirement != requirements.end(); ++requirement)
december0123's avatar
december0123 committed
                {
                    if ((*requirement)->name_ == (*installedConfig)->name_)
                    {
                        found = true;
                        break;
                    }
                }

                if (!found)
                {
dec's avatar
dec committed
                    requirements.emplace_back(*installedConfig);
december0123's avatar
december0123 committed
                    break;
                }
            }
        }
    }

    return requirements;
Philip Müller's avatar
Philip Müller committed
}

void Data::fillDevices(std::string type)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    hw_item hw;
december0123's avatar
december0123 committed
    std::vector<std::shared_ptr<Device>>* devices;
    if ("USB" == type)
december0123's avatar
december0123 committed
    {
        hw = hw_usb;
        devices = &USBDevices;
    }
    else
    {
        hw = hw_pci;
        devices = &PCIDevices;
    }

    // Get the hardware devices
dec's avatar
dec committed
    std::unique_ptr<hd_data_t> hd_data{new hd_data_t()};
    hd_t *hd = hd_list(hd_data.get(), hw, 1, nullptr);
dec's avatar
dec committed
    std::unique_ptr<Device> device;
dec's avatar
dec committed
    for (hd_t *hdIter = hd; hdIter; hdIter = hdIter->next)
december0123's avatar
december0123 committed
    {
dec's avatar
dec committed
        device.reset(new Device());
december0123's avatar
december0123 committed
        device->type_ = type;
dec's avatar
dec committed
        device->classID_ = from_Hex(hdIter->base_class.id, 2) + from_Hex(hdIter->sub_class.id, 2).toLower();
        device->vendorID_ = from_Hex(hdIter->vendor.id, 4).toLower();
        device->deviceID_ = from_Hex(hdIter->device.id, 4).toLower();
        device->className_ = from_CharArray(hdIter->base_class.name);
        device->vendorName_ = from_CharArray(hdIter->vendor.name);
        device->deviceName_ = from_CharArray(hdIter->device.name);
        device->sysfsBusID_ = from_CharArray(hdIter->sysfs_bus_id);
        device->sysfsID_ = from_CharArray(hdIter->sysfs_id);
dec's avatar
dec committed
        devices->emplace_back(device.release());
dec's avatar
dec committed
    hd_free_hd_list(hd);
dec's avatar
dec committed
    hd_free_hd_data(hd_data.get());
Philip Müller's avatar
Philip Müller committed
}

void Data::fillAllConfigs(std::string type)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    std::vector<std::string> configPaths;
december0123's avatar
december0123 committed
    std::vector<std::shared_ptr<Config>>* configs;
    if ("USB" == type)
december0123's avatar
december0123 committed
    {
        configs = &allUSBConfigs;
        configPaths = getRecursiveDirectoryFileList(MHWD_USB_CONFIG_DIR, MHWD_CONFIG_NAME);
    }
    else
    {
        configs = &allPCIConfigs;
        configPaths = getRecursiveDirectoryFileList(MHWD_PCI_CONFIG_DIR, MHWD_CONFIG_NAME);
    }

    for (auto&& configPath = configPaths.begin();
december0123's avatar
december0123 committed
            configPath != configPaths.end(); ++configPath)
    {
dec's avatar
dec committed
        std::unique_ptr<Config> config{new Config((*configPath), type)};
december0123's avatar
december0123 committed

        if (config->readConfigFile((*configPath)))
        {
dec's avatar
dec committed
            configs->emplace_back(config.release());
dec's avatar
dec committed
            invalidConfigs.emplace_back(config.release());
Philip Müller's avatar
Philip Müller committed
}

december0123's avatar
december0123 committed
bool Data::fillConfig(std::shared_ptr<Config> config, std::string configPath, std::string type)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    config->type_ = type;
    config->priority_ = 0;
    config->freedriver_ = true;
    config->basePath_ = configPath.substr(0, configPath.find_last_of('/'));
    config->configPath_ = configPath;

    // Add new HardwareIDs group to vector if vector is empty
    if (config->hwdIDs_.empty())
    {
dec's avatar
dec committed
        config->hwdIDs_.emplace_back();
    return config->readConfigFile(config->configPath_);
Philip Müller's avatar
Philip Müller committed
}

std::vector<std::string> Data::getRecursiveDirectoryFileList(const std::string& directoryPath,
december0123's avatar
december0123 committed
        std::string onlyFilename)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    std::vector<std::string> list;
december0123's avatar
december0123 committed
    struct dirent *dir = nullptr;
dec's avatar
dec committed
    DIR* d = opendir(directoryPath.c_str());
december0123's avatar
december0123 committed
    if (d)
    {
        while (nullptr != (dir = readdir(d)))
december0123's avatar
december0123 committed
        {
            std::string filename = dir->d_name;
december0123's avatar
december0123 committed
            std::string filepath = directoryPath + "/" + filename;

            if (("." == filename) || (".." == filename) || ("" == filename))
december0123's avatar
december0123 committed
            {
                continue;
            }
            else
            {
                struct stat filestatus;
                lstat(filepath.c_str(), &filestatus);

december0123's avatar
december0123 committed
                if (S_ISREG(filestatus.st_mode) &&
                        (onlyFilename.empty() || (onlyFilename == filename)))
december0123's avatar
december0123 committed
                {
                    list.push_back(filepath);
                }
                else if (S_ISDIR(filestatus.st_mode))
                {
                    std::vector<std::string> templist = getRecursiveDirectoryFileList(filepath,
                            onlyFilename);

                    for (auto&& iterator = templist.begin();
december0123's avatar
december0123 committed
                            iterator != templist.end(); iterator++)
                    {
                        list.push_back((*iterator));
                    }
                }
            }
        }

        closedir(d);
    }
december0123's avatar
december0123 committed
    delete dir;
december0123's avatar
december0123 committed
    return list;
Philip Müller's avatar
Philip Müller committed
}

Vita::string Data::getRightConfigPath(Vita::string str, Vita::string baseConfigPath)
{
december0123's avatar
december0123 committed
    str = str.trim();
    if ((str.size() <= 0) || (str.substr(0, 1) == "/"))
december0123's avatar
december0123 committed
    {
        return str;
    }
    return baseConfigPath + "/" + str;
Philip Müller's avatar
Philip Müller committed
}

std::vector<std::string> Data::splitValue(Vita::string str, Vita::string onlyEnding)
{
december0123's avatar
december0123 committed
    std::vector<Vita::string> work = str.toLower().explode(" ");
    std::vector<std::string> final;

    for (auto&& iterator = work.begin(); iterator != work.end();
december0123's avatar
december0123 committed
            iterator++)
    {
        if (("" != *iterator) && onlyEnding.empty())
december0123's avatar
december0123 committed
        {
            final.push_back(*iterator);
        }
        else if (("" != *iterator) && (Vita::string(*iterator).explode(".").back() == onlyEnding)
                && ((*iterator).size() > 5))
december0123's avatar
december0123 committed
        {
            final.push_back(Vita::string(*iterator).substr(0, (*iterator).size() - 5));
        }
    }

    return final;
Philip Müller's avatar
Philip Müller committed
}

void Data::updateConfigData()
{
december0123's avatar
december0123 committed
    // Clear config vectors in each device element
    for (auto&& PCIDevice = PCIDevices.begin();
december0123's avatar
december0123 committed
            PCIDevice != PCIDevices.end(); PCIDevice++)
    {
december0123's avatar
december0123 committed
        (*PCIDevice)->availableConfigs_.clear();
    for (auto&& USBDevice = USBDevices.begin();
december0123's avatar
december0123 committed
            USBDevice != USBDevices.end(); USBDevice++)
    {
december0123's avatar
december0123 committed
        (*USBDevice)->availableConfigs_.clear();
december0123's avatar
december0123 committed
    }
    allPCIConfigs.clear();
    allUSBConfigs.clear();

    // Refill data
    fillAllConfigs("PCI");
    fillAllConfigs("USB");

    setMatchingConfigs(PCIDevices, allPCIConfigs, false);
    setMatchingConfigs(USBDevices, allUSBConfigs, false);
december0123's avatar
december0123 committed

    // Update also installed config data
    updateInstalledConfigData();
Philip Müller's avatar
Philip Müller committed
}

december0123's avatar
december0123 committed
void Data::setMatchingConfigs(const std::vector<std::shared_ptr<Device>>& devices,
        std::vector<std::shared_ptr<Config>>& configs, bool setAsInstalled)
Philip Müller's avatar
Philip Müller committed
{
    for (auto&& config = configs.begin(); config != configs.end();
december0123's avatar
december0123 committed
            ++config)
    {
        setMatchingConfig((*config), devices, setAsInstalled);
    }
Philip Müller's avatar
Philip Müller committed
}

void Data::setMatchingConfig(std::shared_ptr<Config> config,
		const std::vector<std::shared_ptr<Device>>& devices, bool setAsInstalled)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    std::vector<std::shared_ptr<Device>> foundDevices;
    getAllDevicesOfConfig(devices, config, foundDevices);
december0123's avatar
december0123 committed

    // Set config to all matching devices
    for (auto&& foundDevice = foundDevices.begin();
december0123's avatar
december0123 committed
            foundDevice != foundDevices.end(); ++foundDevice)
    {
        if (setAsInstalled)
        {
            addConfigSorted((*foundDevice)->installedConfigs_, config);
            addConfigSorted((*foundDevice)->availableConfigs_, config);
Philip Müller's avatar
Philip Müller committed
}

void Data::addConfigSorted(std::vector<std::shared_ptr<Config>>& configs,
		std::shared_ptr<Config> config)
Philip Müller's avatar
Philip Müller committed
{
    for (auto&& iterator = configs.begin();
            iterator != configs.end(); iterator++)
december0123's avatar
december0123 committed
    {
        if (config->name_ == (*iterator)->name_)
        {
            return;
        }
    }

    for (auto&& iterator = configs.begin(); iterator != configs.end();
december0123's avatar
december0123 committed
            iterator++)
    {
        if (config->priority_ > (*iterator)->priority_)
        {
december0123's avatar
december0123 committed
            configs.insert(iterator, std::shared_ptr<Config>(config));
dec's avatar
dec committed
    configs.emplace_back(config);
Philip Müller's avatar
Philip Müller committed
}

Vita::string Data::from_Hex(std::uint16_t hexnum, int fill)
Philip Müller's avatar
Philip Müller committed
{
december0123's avatar
december0123 committed
    std::stringstream stream;
    stream << std::hex << std::setfill('0') << std::setw(fill) << hexnum;
    return stream.str();
Philip Müller's avatar
Philip Müller committed
}

std::string Data::from_CharArray(char* c)
Philip Müller's avatar
Philip Müller committed
{
    if (nullptr == c)
december0123's avatar
december0123 committed
    {
        return "";
    }
Philip Müller's avatar
Philip Müller committed

    return std::string(c);
Philip Müller's avatar
Philip Müller committed
}