File: IdentifierDatabase.h

package info (click to toggle)
ycmd 0%2B20230103%2Bgitf53e7ac%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 5,904 kB
  • sloc: python: 41,740; cpp: 6,055; java: 295; sh: 271; cs: 194; javascript: 150; ansic: 82; makefile: 46; xml: 18; objc: 10
file content (117 lines) | stat: -rw-r--r-- 3,617 bytes parent folder | download | duplicates (3)
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
// Copyright (C) 2013-2018 ycmd contributors
//
// This file is part of ycmd.
//
// ycmd is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// ycmd is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with ycmd.  If not, see <http://www.gnu.org/licenses/>.

#ifndef IDENTIFIERDATABASE_H_ZESX3CVR
#define IDENTIFIERDATABASE_H_ZESX3CVR

#ifdef YCM_ABSEIL_SUPPORTED
#include <absl/container/flat_hash_map.h>
namespace YouCompleteMe {
template< typename K, typename V >
using HashMap = absl::flat_hash_map< K, V >;
} // namespace YouCompleteMe
#else
#include <unordered_map>
namespace YouCompleteMe {
template< typename K, typename V >
using HashMap = std::unordered_map< K, V >;
} // namespace YouCompleteMe
#endif
#include <memory>
#include <shared_mutex>
#include <string>
#include <vector>

namespace YouCompleteMe {

class Candidate;
class Result;
template< typename Candidate >
class Repository;


// filepath -> identifiers
using FilepathToIdentifiers = HashMap< std::string, std::vector< std::string > >;

// filetype -> (filepath -> identifiers)
using FiletypeIdentifierMap = HashMap< std::string, FilepathToIdentifiers >;


// This class stores the database of identifiers the identifier completer has
// seen. It stores them in a data structure that makes it easy to tell which
// identifier came from which file and what files have which filetypes.
//
// The main point of this class is to isolate the parts of the code that need
// access to this internal data structure so that it's easier to confirm that
// mutexes are used correctly to protect concurrent access.
//
// This class is thread-safe.
class IdentifierDatabase {
public:
  YCM_EXPORT IdentifierDatabase();
  IdentifierDatabase( const IdentifierDatabase& ) = delete;
  IdentifierDatabase& operator=( const IdentifierDatabase& ) = delete;

  void AddSingleIdentifier(
    std::string&& new_candidate,
    std::string&& filetype,
    std::string&& filepath );

  void RecreateIdentifiers( FiletypeIdentifierMap&& filetype_identifier_map );

  void RecreateIdentifiers(
    std::vector< std::string >&& new_candidates,
    std::string&& filetype,
    std::string&& filepath );

  void ClearCandidatesStoredForFile( std::string&& filetype,
                                     std::string&& filepath );

  std::vector< Result > ResultsForQueryAndType(
    std::string&& query,
    const std::string &filetype,
    const size_t max_results ) const;

private:
  std::vector< Candidate > &GetCandidateSet(
    std::string&& filetype,
    std::string&& filepath );

  void RecreateIdentifiersNoLock(
    std::vector< std::string >&& new_candidates,
    std::string&& filetype,
    std::string&& filepath );


  // filepath -> ( candidate )
  using FilepathToCandidates = HashMap< std::string, std::vector< Candidate > >;

  // filetype -> ( filepath -> ( candidate ) )
  using FiletypeCandidateMap = HashMap< std::string, FilepathToCandidates >;


  Repository< Candidate > &candidate_repository_;

  FiletypeCandidateMap filetype_candidate_map_;
  mutable std::shared_mutex filetype_candidate_map_mutex_;
};

} // namespace YouCompleteMe


#endif /* end of include guard: IDENTIFIERDATABASE_H_ZESX3CVR */