Skip to content

Commit

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

Differential Revision: https://reviews.llvm.org/D157814
  • Loading branch information
serge-sans-paille committed Aug 15, 2023
1 parent f2dd62f commit cda3198
Show file tree
Hide file tree
Showing 3 changed files with 54 additions and 0 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 @@ -214,6 +214,7 @@ class JSONNodeDumper
void VisitUnavailableAttr(const UnavailableAttr *UA);
void VisitSectionAttr(const SectionAttr *SA);
void VisitVisibilityAttr(const VisibilityAttr *VA);
void VisitTLSModelAttr(const TLSModelAttr *TA);

void VisitTypedefType(const TypedefType *TT);
void VisitUsingType(const UsingType *TT);
Expand Down
4 changes: 4 additions & 0 deletions clang/lib/AST/JSONNodeDumper.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -559,6 +559,10 @@ void JSONNodeDumper::VisitVisibilityAttr(const VisibilityAttr *VA) {
VA->getVisibility()));
}

void JSONNodeDumper::VisitTLSModelAttr(const TLSModelAttr *TA) {
JOS.attribute("tls_model", TA->getModel());
}

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

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

__thread __attribute__ ((tls_model ("local-exec"))) int tls_model_var;

// NOTE: CHECK lines have been autogenerated by gen_ast_dump_json_test.py
// using --filters=VarDecl
Expand Down Expand Up @@ -479,3 +480,51 @@ __attribute__ ((visibility ("hidden"))) int visibility_var;
// CHECK-NEXT: }
// CHECK-NEXT: ]
// CHECK-NEXT: }


// CHECK-NOT: {{^}}Dumping
// CHECK: "kind": "VarDecl",
// CHECK-NEXT: "loc": {
// CHECK-NEXT: "offset": 748,
// CHECK-NEXT: "line": 22,
// CHECK-NEXT: "col": 57,
// CHECK-NEXT: "tokLen": 13
// CHECK-NEXT: },
// CHECK-NEXT: "range": {
// CHECK-NEXT: "begin": {
// CHECK-NEXT: "offset": 692,
// CHECK-NEXT: "col": 1,
// CHECK-NEXT: "tokLen": 8
// CHECK-NEXT: },
// CHECK-NEXT: "end": {
// CHECK-NEXT: "offset": 748,
// CHECK-NEXT: "col": 57,
// CHECK-NEXT: "tokLen": 13
// CHECK-NEXT: }
// CHECK-NEXT: },
// CHECK-NEXT: "name": "tls_model_var",
// CHECK-NEXT: "mangledName": "tls_model_var",
// CHECK-NEXT: "type": {
// CHECK-NEXT: "qualType": "int"
// CHECK-NEXT: },
// CHECK-NEXT: "tls": "static",
// CHECK-NEXT: "inner": [
// CHECK-NEXT: {
// CHECK-NEXT: "id": "0x{{.*}}",
// CHECK-NEXT: "kind": "TLSModelAttr",
// CHECK-NEXT: "range": {
// CHECK-NEXT: "begin": {
// CHECK-NEXT: "offset": 717,
// CHECK-NEXT: "col": 26,
// CHECK-NEXT: "tokLen": 9
// CHECK-NEXT: },
// CHECK-NEXT: "end": {
// CHECK-NEXT: "offset": 740,
// CHECK-NEXT: "col": 49,
// CHECK-NEXT: "tokLen": 1
// CHECK-NEXT: }
// CHECK-NEXT: },
// CHECK-NEXT: "tls_model": "local-exec"
// CHECK-NEXT: }
// CHECK-NEXT: ]
// CHECK-NEXT: }

0 comments on commit cda3198

Please sign in to comment.