Skip to content

Commit

Permalink
[clang] Add missing field to VisibilityAttr json AST dump
Browse files Browse the repository at this point in the history
Recommit with test file updated.

Differential Revision: https://reviews.llvm.org/D157808
  • Loading branch information
serge-sans-paille committed Aug 15, 2023
1 parent d50b18d commit f2dd62f
Show file tree
Hide file tree
Showing 4 changed files with 649 additions and 585 deletions.
1 change: 1 addition & 0 deletions clang/include/clang/AST/JSONNodeDumper.h
Original file line number Diff line number Diff line change
Expand Up @@ -213,6 +213,7 @@ class JSONNodeDumper
void VisitDeprecatedAttr(const DeprecatedAttr *DA);
void VisitUnavailableAttr(const UnavailableAttr *UA);
void VisitSectionAttr(const SectionAttr *SA);
void VisitVisibilityAttr(const VisibilityAttr *VA);

void VisitTypedefType(const TypedefType *TT);
void VisitUsingType(const UsingType *TT);
Expand Down
5 changes: 5 additions & 0 deletions clang/lib/AST/JSONNodeDumper.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -554,6 +554,11 @@ void JSONNodeDumper::VisitSectionAttr(const SectionAttr *SA) {
JOS.attribute("section_name", SA->getName());
}

void JSONNodeDumper::VisitVisibilityAttr(const VisibilityAttr *VA) {
JOS.attribute("visibility", VisibilityAttr::ConvertVisibilityTypeToStr(
VA->getVisibility()));
}

void JSONNodeDumper::VisitTypedefType(const TypedefType *TT) {
JOS.attribute("decl", createBareDeclRef(TT->getDecl()));
if (!TT->typeMatchesDecl())
Expand Down
50 changes: 50 additions & 0 deletions clang/test/AST/ast-dump-attr-json.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,9 @@ __attribute__((unavailable("reason"))) int unavailable_var1;

__attribute__ ((section ("SECTION_NAME"))) int section_var;

__attribute__ ((visibility ("hidden"))) int visibility_var;


// NOTE: CHECK lines have been autogenerated by gen_ast_dump_json_test.py
// using --filters=VarDecl

Expand Down Expand Up @@ -429,3 +432,50 @@ __attribute__ ((section ("SECTION_NAME"))) int section_var;
// CHECK-NEXT: }
// CHECK-NEXT: ]
// CHECK-NEXT: }


// CHECK-NOT: {{^}}Dumping
// CHECK: "kind": "VarDecl",
// CHECK-NEXT: "loc": {
// CHECK-NEXT: "offset": 675,
// CHECK-NEXT: "line": 20,
// CHECK-NEXT: "col": 45,
// CHECK-NEXT: "tokLen": 14
// CHECK-NEXT: },
// CHECK-NEXT: "range": {
// CHECK-NEXT: "begin": {
// CHECK-NEXT: "offset": 631,
// CHECK-NEXT: "col": 1,
// CHECK-NEXT: "tokLen": 13
// CHECK-NEXT: },
// CHECK-NEXT: "end": {
// CHECK-NEXT: "offset": 675,
// CHECK-NEXT: "col": 45,
// CHECK-NEXT: "tokLen": 14
// CHECK-NEXT: }
// CHECK-NEXT: },
// CHECK-NEXT: "name": "visibility_var",
// CHECK-NEXT: "mangledName": "visibility_var",
// CHECK-NEXT: "type": {
// CHECK-NEXT: "qualType": "int"
// CHECK-NEXT: },
// CHECK-NEXT: "inner": [
// CHECK-NEXT: {
// CHECK-NEXT: "id": "0x{{.*}}",
// CHECK-NEXT: "kind": "VisibilityAttr",
// CHECK-NEXT: "range": {
// CHECK-NEXT: "begin": {
// CHECK-NEXT: "offset": 647,
// CHECK-NEXT: "col": 17,
// CHECK-NEXT: "tokLen": 10
// CHECK-NEXT: },
// CHECK-NEXT: "end": {
// CHECK-NEXT: "offset": 667,
// CHECK-NEXT: "col": 37,
// CHECK-NEXT: "tokLen": 1
// CHECK-NEXT: }
// CHECK-NEXT: },
// CHECK-NEXT: "visibility": "hidden"
// CHECK-NEXT: }
// CHECK-NEXT: ]
// CHECK-NEXT: }

0 comments on commit f2dd62f

Please sign in to comment.