naiveproxy/tools/gn/string_utils.h

54 lines
1.8 KiB
C
Raw Normal View History

2018-02-02 13:49:39 +03:00
// Copyright (c) 2013 The Chromium 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 TOOLS_GN_STRING_UTILS_H_
#define TOOLS_GN_STRING_UTILS_H_
#include <vector>
#include "base/strings/string_piece.h"
class Err;
class Scope;
class Token;
class Value;
inline std::string operator+(const std::string& a, const base::StringPiece& b) {
std::string ret;
ret.reserve(a.size() + b.size());
ret.assign(a);
ret.append(b.data(), b.size());
return ret;
}
inline std::string operator+(const base::StringPiece& a, const std::string& b) {
std::string ret;
ret.reserve(a.size() + b.size());
ret.assign(a.data(), a.size());
ret.append(b);
return ret;
}
// Unescapes and expands variables in the given literal, writing the result
// to the given value. On error, sets |err| and returns false.
bool ExpandStringLiteral(Scope* scope,
const Token& literal,
Value* result,
Err* err);
// Returns the minimum number of inserts, deleted, and replacements of
// characters needed to transform s1 to s2, or max_edit_distance + 1 if
// transforming s1 into s2 isn't possible in at most max_edit_distance steps.
size_t EditDistance(const base::StringPiece& s1,
const base::StringPiece& s2,
size_t max_edit_distance);
// Given a string |text| and a vector of correctly-spelled strings |words|,
// returns the first string in |words| closest to |text|, or an empty
// StringPiece if none of the strings in |words| is close.
base::StringPiece SpellcheckString(const base::StringPiece& text,
const std::vector<base::StringPiece>& words);
#endif // TOOLS_GN_STRING_UTILS_H_