summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaAccess.cpp
diff options
context:
space:
mode:
authorZachary Turner <zturner@google.com>2018-07-26 22:13:39 +0000
committerZachary Turner <zturner@google.com>2018-07-26 22:13:39 +0000
commit23df1319ca76f867a83634d74ba78377569e29b1 (patch)
tree75441b96905f6734a47649d0f5545865dcacc4e3 /clang/lib/Sema/SemaAccess.cpp
parent60bdd09d10c6f758603907cbf0dfbf866dd12325 (diff)
downloadbcm5719-llvm-23df1319ca76f867a83634d74ba78377569e29b1.tar.gz
bcm5719-llvm-23df1319ca76f867a83634d74ba78377569e29b1.zip
[MS Demangler] Properly handle function parameter back-refs.
Properly demangle function parameter back-references. Previously we treated lists of function parameters and template parameters the same. There are some important differences with regards to back-references, and some less important differences regarding which characters can appear before or after the name. The important differences are that with a given type T, all instances of a function parameter list share the same global back-ref table. Specifically, if X and Y are function pointers, then there are 3 entities in the declaration X func(Y) which all affect and are affected by the master parameter back-ref table: 1) The parameter list of X's function type 2) the parameter list of func itself 3) The parameter list of Y's function type. The previous code would create a back-reference table that was local to a single parameter list, so it would not be shared across parameter lists. This was discovered when porting ms-back-references.test from clang's mangling tests. All of these tests should now pass with the new changes. In doing so, I split the function for parsing template and function parameters into two separate functions. This makes the template parameter list parsing code in particular very small and easy to understand now. Differential Revision: https://reviews.llvm.org/D49875 llvm-svn: 338075
Diffstat (limited to 'clang/lib/Sema/SemaAccess.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud