blob: 353e1873aaf4cc67549b32fd0fdf99fd4110dc2a [file] [log] [blame]
// Copyright 2017 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef SRC_MODULAR_LIB_STRING_ESCAPE_STRING_ESCAPE_H_
#define SRC_MODULAR_LIB_STRING_ESCAPE_STRING_ESCAPE_H_
#include <string_view>
#include <vector>
namespace modular {
constexpr char kDefaultEscapeChar = '\\';
// Escape the set of chars in |chars_to_escape| in |input||. Use |escape_char|
// to escape. All params are expected to be in ASCII.
std::string StringEscape(std::string_view input, std::string_view chars_to_escape,
char escape_char = kDefaultEscapeChar);
// Unescape all escape sequences in |input|, where the escape sequence begins
// with |escape_char|. All input params are expected to be in ASCII. In debug
// mode, crashes if |input| cannot be unescaped.
std::string StringUnescape(std::string_view input, char escape_char = kDefaultEscapeChar);
// Splits an escaped string |input| by |split_char|; this splitter skips over
// any characters escaped using |escape_char|s. All params are expected to be in
// ASCII.
//
// Example:
// SplitEscapedString("a_b\\_c_d", '_', '\\')
// => std::vector<std::string_view>{"a", "b\\_c", "d"}
std::vector<std::string_view> SplitEscapedString(std::string_view input, char split_char,
char escape_char = kDefaultEscapeChar);
} // namespace modular
#endif // SRC_MODULAR_LIB_STRING_ESCAPE_STRING_ESCAPE_H_