clang 22.0.0git
NoSanitizeList.cpp
Go to the documentation of this file.
1//===--- NoSanitizeList.cpp - Ignored list for sanitizers ----------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// User-provided ignore-list used to disable/alter instrumentation done in
10// sanitizers.
11//
12//===----------------------------------------------------------------------===//
13
19
20using namespace clang;
21
22NoSanitizeList::NoSanitizeList(const std::vector<std::string> &NoSanitizePaths,
23 SourceManager &SM)
24 : SSCL(SanitizerSpecialCaseList::createOrDie(
25 NoSanitizePaths, SM.getFileManager().getVirtualFileSystem())),
26 SM(SM) {}
27
29
30bool NoSanitizeList::containsPrefix(SanitizerMask Mask, StringRef Prefix,
31 StringRef Name, StringRef Category) const {
32 std::pair<unsigned, unsigned> NoSan =
33 SSCL->inSectionBlame(Mask, Prefix, Name, Category);
34 if (NoSan == llvm::SpecialCaseList::NotFound)
35 return false;
36 std::pair<unsigned, unsigned> San =
37 SSCL->inSectionBlame(Mask, Prefix, Name, "sanitize");
38 // The statement evaluates to true under the following conditions:
39 // 1. The string "prefix:*=sanitize" is absent.
40 // 2. If "prefix:*=sanitize" is present, its (File Index, Line Number) is less
41 // than that of "prefix:*".
42 return San == llvm::SpecialCaseList::NotFound || NoSan > San;
43}
44
45bool NoSanitizeList::containsGlobal(SanitizerMask Mask, StringRef GlobalName,
46 StringRef Category) const {
47 return containsPrefix(Mask, "global", GlobalName, Category);
48}
49
50bool NoSanitizeList::containsType(SanitizerMask Mask, StringRef MangledTypeName,
51 StringRef Category) const {
52 return containsPrefix(Mask, "type", MangledTypeName, Category);
53}
54
56 StringRef FunctionName) const {
57 return containsPrefix(Mask, "fun", FunctionName, {});
58}
59
61 StringRef Category) const {
62 return containsPrefix(Mask, "src", FileName, Category);
63}
64
66 StringRef Category) const {
67 return containsPrefix(Mask, "mainfile", FileName, Category);
68}
69
71 StringRef Category) const {
72 return Loc.isValid() &&
73 containsFile(Mask, SM.getFilename(SM.getFileLoc(Loc)), Category);
74}
Defines the clang::FileManager interface and associated types.
Defines the clang::SanitizerKind enum.
Defines the SourceManager interface.
NoSanitizeList(const std::vector< std::string > &NoSanitizeListPaths, SourceManager &SM)
bool containsType(SanitizerMask Mask, StringRef MangledTypeName, StringRef Category=StringRef()) const
bool containsGlobal(SanitizerMask Mask, StringRef GlobalName, StringRef Category=StringRef()) const
bool containsFile(SanitizerMask Mask, StringRef FileName, StringRef Category=StringRef()) const
bool containsLocation(SanitizerMask Mask, SourceLocation Loc, StringRef Category=StringRef()) const
bool containsMainFile(SanitizerMask Mask, StringRef FileName, StringRef Category=StringRef()) const
bool containsFunction(SanitizerMask Mask, StringRef FunctionName) const
Encodes a location in the source.
bool isValid() const
Return true if this is a valid SourceLocation object.
This class handles loading and caching of source files into memory.
The JSON file list parser is used to communicate input to InstallAPI.