GCC Code Coverage Report


Directory: cvmfs/
File: cvmfs/path_filters/relaxed_path_filter.cc
Date: 2026-06-14 02:36:34
Exec Total Coverage
Lines: 45 46 97.8%
Branches: 33 46 71.7%

Line Branch Exec Source
1 /**
2 * This file is part of the CernVM File System.
3 */
4
5 #include "path_filters/relaxed_path_filter.h"
6
7 #include <cstdio>
8 #include <string>
9
10 using namespace catalog; // NOLINT
11
12 46 RelaxedPathFilter *RelaxedPathFilter::Create(const std::string &dirtab_path) {
13
1/2
✓ Branch 2 taken 46 times.
✗ Branch 3 not taken.
46 RelaxedPathFilter *dt = new RelaxedPathFilter();
14 46 dt->Open(dirtab_path);
15 46 return dt;
16 }
17
18
19 1196 bool RelaxedPathFilter::IsMatching(const std::string &path) const {
20 1196 bool has_positive_match = Dirtab::IsMatching(path);
21
2/2
✓ Branch 0 taken 736 times.
✓ Branch 1 taken 460 times.
1196 if (!has_positive_match) {
22
1/2
✓ Branch 1 taken 736 times.
✗ Branch 2 not taken.
736 std::string current_path = path;
23
2/2
✓ Branch 1 taken 1058 times.
✓ Branch 2 taken 276 times.
1334 while (current_path.length() > 0) {
24 1058 const size_t new_length = current_path.find_last_of("/");
25
1/2
✓ Branch 1 taken 1058 times.
✗ Branch 2 not taken.
1058 current_path = current_path.substr(0, new_length);
26
3/4
✓ Branch 1 taken 1058 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 460 times.
✓ Branch 4 taken 598 times.
1058 if (exact_dirtab_.IsMatching(current_path)) {
27 460 has_positive_match = true;
28 460 break;
29 }
30 } // walk through sub paths
31 736 }
32
33
4/4
✓ Branch 0 taken 920 times.
✓ Branch 1 taken 276 times.
✓ Branch 3 taken 690 times.
✓ Branch 4 taken 230 times.
1196 return has_positive_match && !IsOpposing(path);
34 }
35
36
37 1518 bool RelaxedPathFilter::IsOpposing(const std::string &path) const {
38
3/4
✓ Branch 1 taken 1518 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 184 times.
✓ Branch 4 taken 1334 times.
1518 if (Dirtab::IsOpposing(path))
39 184 return true;
40
41
1/2
✓ Branch 1 taken 1334 times.
✗ Branch 2 not taken.
1334 std::string current_path = path;
42
2/2
✓ Branch 1 taken 2944 times.
✓ Branch 2 taken 1242 times.
4186 while (current_path.length() > 0) {
43 2944 const size_t new_length = current_path.find_last_of("/");
44
1/2
✓ Branch 1 taken 2944 times.
✗ Branch 2 not taken.
2944 current_path = current_path.substr(0, new_length);
45
3/4
✓ Branch 1 taken 2944 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 92 times.
✓ Branch 4 taken 2852 times.
2944 if (Dirtab::IsOpposing(current_path)) {
46 92 return true;
47 }
48 }
49
50 1242 return false;
51 1334 }
52
53
54 138 bool RelaxedPathFilter::Parse(const std::string &dirtab) {
55 138 return Dirtab::Parse(dirtab) & exact_dirtab_.Parse(dirtab);
56 }
57
58 46 bool RelaxedPathFilter::Parse(FILE *dirtab_file) {
59 46 bool result = Dirtab::Parse(dirtab_file);
60 46 rewind(dirtab_file);
61 46 result &= exact_dirtab_.Parse(dirtab_file);
62 46 return result;
63 }
64
65
66 506 bool RelaxedPathFilter::ParsePathspec(const std::string &pathspec_str,
67 bool negation) {
68
2/2
✓ Branch 0 taken 230 times.
✓ Branch 1 taken 276 times.
506 if (negation) {
69
1/2
✓ Branch 1 taken 230 times.
✗ Branch 2 not taken.
230 return Dirtab::ParsePathspec(pathspec_str, true);
70 }
71 276 bool success = true;
72
1/2
✓ Branch 1 taken 276 times.
✗ Branch 2 not taken.
276 std::string current_pathspec_str(pathspec_str);
73
2/2
✓ Branch 1 taken 736 times.
✓ Branch 2 taken 276 times.
1012 while (current_pathspec_str.length() > 0) {
74
2/4
✓ Branch 1 taken 736 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 736 times.
736 if (!Dirtab::ParsePathspec(current_pathspec_str, false))
75 success = false;
76 736 const size_t new_length = current_pathspec_str.find_last_of("/");
77
1/2
✓ Branch 1 taken 736 times.
✗ Branch 2 not taken.
736 current_pathspec_str = current_pathspec_str.substr(0, new_length);
78 }
79
80 276 return success;
81 276 }
82