File: gen-overlapping-test.cc

package info (click to toggle)
chromium 139.0.7258.138-1
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 6,120,676 kB
  • sloc: cpp: 35,100,869; ansic: 7,163,530; javascript: 4,103,002; python: 1,436,920; asm: 946,517; xml: 746,709; pascal: 187,653; perl: 88,691; sh: 88,436; objc: 79,953; sql: 51,488; cs: 44,583; fortran: 24,137; makefile: 22,147; tcl: 15,277; php: 13,980; yacc: 8,984; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (57 lines) | stat: -rw-r--r-- 2,326 bytes parent folder | download | duplicates (9)
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
// Copyright 2020 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

// This file (and other gen-*-test.cc files) tests generation of output for
// --field-filter-file and therefore the expectations file
// (gen-overlapping-expected.txt) needs to be compared against the raw output of
// the rewriter (rather than against the actual edits result).  This makes the
// test incompatible with other tests, which require passing --apply-edits
// switch to test_tool.py and so to disable the test it is named *-test.cc
// rather than *-original.cc.
//
// To run the test use tools/clang/rewrite_raw_ptr_fields/tests/run_all_tests.py

namespace my_namespace {

class SomeClass {
  int x;
};

struct MyStruct {
  // The fields below have an overlapping |replacement_range| and therefore
  // should be emitted as candidates for --field-filter-file.
  SomeClass *overlapping_ptr_1a, *overlapping_ptr_1b;

  // It is sufficient to emit pointer fields (e.g. no need to emit
  // overlapping_ptr_2b or overlapping_ptr_3a).
  SomeClass *overlapping_ptr_2a, overlapping_ptr_2b;
  SomeClass overlapping_ptr_3a, *overlapping_ptr_3b;

  // The fields below have an overlapping |replacement_range| and therefore
  // should be emitted as candidates for --field-filter-file.
  SomeClass &overlapping_ref_1a, &overlapping_ref_1b;

  // It is sufficient to emit pointer fields (e.g. no need to emit
  // overlapping_ref_2b or overlapping_ref_3a).
  SomeClass &overlapping_ref_2a, overlapping_ref_2b;
  SomeClass overlapping_ref_3a, &overlapping_ref_3b;

  // Definition of the struct overlaps with the |replacement_range| of the
  // |ptr_to_non_free_standing_struct|.  Therefore the field should be emitted
  // as a candidate for --field-filter-file.
  struct NonFreeStandingStruct {
    int non_ptr;
  } * ptr_to_non_free_standing_struct;

  // Similarly to the above, definition of the struct overlaps with the
  // |replacement_range| of |ptr_to_non_free_standing_struct2|.  OTOH, it is
  // okay to proceed with rewriting |inner_ptr| - it should not be emitted as a
  // candidate for --field-filter-file.
  struct NonFreeStandingStruct2 {
    SomeClass* inner_ptr;
    SomeClass& inner_ref;
  } * ptr_to_non_free_standing_struct2;
};

}  // namespace my_namespace