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
base / substring_set_matcher / matcher_string_pattern.h [blame]
// Copyright 2013 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef BASE_SUBSTRING_SET_MATCHER_MATCHER_STRING_PATTERN_H_
#define BASE_SUBSTRING_SET_MATCHER_MATCHER_STRING_PATTERN_H_
#include <string>
#include "base/base_export.h"
#include "base/compiler_specific.h"
namespace base {
// An individual pattern of a substring or regex matcher. A pattern consists of
// a string (interpreted as individual bytes, no character encoding) and an
// identifier.
// IDs are returned to the caller of SubstringSetMatcher::Match() or
// RegexMatcher::MatchURL() to help the caller to figure out what
// patterns matched a string. All patterns registered to a matcher
// need to contain unique IDs.
class BASE_EXPORT MatcherStringPattern {
public:
using ID = size_t;
// An invalid ID value. Clients must not use this as the id.
static constexpr ID kInvalidId = static_cast<ID>(-1);
MatcherStringPattern(std::string pattern, ID id);
MatcherStringPattern(const MatcherStringPattern&) = delete;
MatcherStringPattern& operator=(const MatcherStringPattern&) = delete;
~MatcherStringPattern();
MatcherStringPattern(MatcherStringPattern&&);
MatcherStringPattern& operator=(MatcherStringPattern&&);
const std::string& pattern() const LIFETIME_BOUND { return pattern_; }
ID id() const { return id_; }
bool operator<(const MatcherStringPattern& rhs) const;
private:
std::string pattern_;
ID id_;
};
} // namespace base
#endif // BASE_SUBSTRING_SET_MATCHER_MATCHER_STRING_PATTERN_H_