использование хешмарка в значении параметров программы (ini-файл) - PullRequest
1 голос
/ 05 июля 2011

У меня проблемы с чтением из INI-файла с использованием опций программы Boost.Проблема заключается в ключе, который содержит хеш-метки (простой пример):

[section]
key = "xxx # yyy"

При получении ключа возвращается «xxx», потому чтокажется, что хешмарк интерпретируется как начало комментария, поэтому остальная часть строки пропускается.К сожалению, я не могу заменить '#' каким-либо другим символом, потому что значение является регулярным выражением.Я не нашел способа процитировать хэшмарк и предпочел бы не делать этого, потому что это изменит мое регулярное выражение и сделает его еще более нечитаемым.

Есть ли способ решить эту проблему, не переписываяанализатор ini-файлов?Спасибо за любую помощь.

Мой код для получения ключа выглядит так:

std::string key;
boost::program_options::options_description opDesc("test");
opDesc.add_options()("section.key", po::value<string>(&key))
std::ifstream ifs("file.ini");
boost::program_options::parse_config_file(ifs, opDesc);

1 Ответ

1 голос
/ 05 июля 2011

Возможно, пришло время начать использовать Расширять дерево свойств , поскольку вы уже прошли точку «Параметры синтаксического анализа программы», действительно.

http://www.boost.org/doc/libs/1_46_1/doc/html/property_tree.html

В дереве свойств есть анализаторы / форматеры для форматов JSON, Xml, Ini (<-- you are here) и INFO.Связанная страница в нескольких строках указывает, какие именно обходы (в большинстве случаев это обход, кроме информации о типах JSON и иногда пробелах).

Полагаю, вам нужен формат INI (потому что он близок кчто вы используете) и параметр INFO (потому что он имеет более строковый синтаксис, в дополнение к иерархически вложенным разделам).


Из примеров:

#include <boost/property_tree/ptree.hpp>
#include <boost/property_tree/xml_parser.hpp>
#include <boost/foreach.hpp>
#include <string>
#include <set>
#include <exception>
#include <iostream>

struct debug_settings
{
    std::string m_file;               // log filename
    int m_level;                      // debug level
    std::set<std::string> m_modules;  // modules where logging is enabled
    void load(const std::string &filename);
    void save(const std::string &filename);
};

void debug_settings::load(const std::string &filename)
{
    using boost::property_tree::ptree;
    ptree pt;
    read_xml(filename, pt);
    m_file = pt.get<std::string>("debug.filename");
    m_level = pt.get("debug.level", 0);
    BOOST_FOREACH(ptree::value_type &v, pt.get_child("debug.modules"))
        m_modules.insert(v.second.data());
}

void debug_settings::save(const std::string &filename)
{
    using boost::property_tree::ptree;
    ptree pt;
    pt.put("debug.filename", m_file);
    pt.put("debug.level", m_level);
    BOOST_FOREACH(const std::string &name, m_modules)
        pt.add("debug.modules.module", name);
    write_xml(filename, pt);
}

int main()
{
    try
    {
        debug_settings ds;
        ds.load("debug_settings.xml");
        ds.save("debug_settings_out.xml");
        std::cout << "Success\n";
    }
    catch (std::exception &e)
    {
        std::cout << "Error: " << e.what() << "\n";
    }
    return 0;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...