blob: 74391cd1ee98a34266ad4438e86ec39d4b0597a4 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
// file : butl/string-parser -*- C++ -*-
// copyright : Copyright (c) 2014-2017 Code Synthesis Ltd
// license : MIT; see accompanying LICENSE file
#ifndef BUTL_STRING_PARSER
#define BUTL_STRING_PARSER
#include <string>
#include <vector>
#include <cstddef> // size_t
#include <utility> // pair
#include <stdexcept> // invalid_argument
#include <butl/export>
namespace butl
{
class LIBBUTL_EXPORT invalid_string: public std::invalid_argument
{
public:
invalid_string (std::size_t p, const std::string& d)
: invalid_argument (d), position (p) {}
std::size_t position; // Zero-based.
};
class LIBBUTL_EXPORT string_parser
{
public:
// Parse a whitespace-separated list of strings. Can contain single or
// double quoted substrings. No escaping is supported. If unquote is true,
// return one-level unquoted values. Throw invalid_string in case of
// invalid quoting.
//
static std::vector<std::string>
parse_quoted (const std::string&, bool unquote);
// As above but return a list of string and zero-based position pairs.
// Position is useful for issuing diagnostics about an invalid string
// during second-level parsing.
//
static std::vector<std::pair<std::string, std::size_t>>
parse_quoted_position (const std::string&, bool unquote);
// Remove a single level of quotes. Note that the format or the
// correctness of the quotation is not validated.
//
static std::string
unquote (const std::string&);
static std::vector<std::string>
unquote (const std::vector<std::string>&);
};
}
#endif // BUTL_STRING_PARSER
|