blob: ed7114d4c65f108118d0cdd889a1e72196b6ac4d [file] [log] [blame]
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_BOOKMARKS_BROWSER_TITLED_URL_MATCH_H_
#define COMPONENTS_BOOKMARKS_BROWSER_TITLED_URL_MATCH_H_
#include <stddef.h>
#include <utility>
#include <vector>
#include "base/memory/raw_ptr.h"
namespace bookmarks {
class TitledUrlNode;
struct TitledUrlMatch {
// Each MatchPosition is the [begin, end) positions of a match within a
// string.
using MatchPosition = std::pair<size_t, size_t>;
using MatchPositions = std::vector<MatchPosition>;
TitledUrlMatch();
TitledUrlMatch(const TitledUrlMatch& other);
~TitledUrlMatch();
// Extracts and returns the offsets from `match_positions`.
static std::vector<size_t> OffsetsFromMatchPositions(
const MatchPositions& match_positions);
// Replaces the offsets in `match_positions` with those given in `offsets`,
// deleting any which are npos, and returns the updated list of match
// positions.
static MatchPositions ReplaceOffsetsInMatchPositions(
const MatchPositions& match_positions,
const std::vector<size_t>& offsets);
// The matching node of a query.
raw_ptr<const TitledUrlNode> node;
// Location of the matching words in the title of the node.
MatchPositions title_match_positions;
// Location of the matching words in the URL of the node.
MatchPositions url_match_positions;
// Whether there was at least 1 match in the titles of ancestors of the node.
bool has_ancestor_match;
};
} // namespace bookmarks
#endif // COMPONENTS_BOOKMARKS_BROWSER_TITLED_URL_MATCH_H_