aboutsummaryrefslogtreecommitdiff
path: root/absl/debugging/internal/demangle_test.cc
diff options
context:
space:
mode:
authorChris Mihelich <cmihelic@google.com>2024-05-29 15:23:58 -0700
committerCopybara-Service <copybara-worker@google.com>2024-05-29 15:24:50 -0700
commit36c2a14c5966d06f4f8c3bd02e3ef9d517ead081 (patch)
tree582412afe6bfece2e84cb048529d446784118888 /absl/debugging/internal/demangle_test.cc
parent65a55c2ba891f6d2492477707f4a2e327a0b40dc (diff)
downloadabseil-36c2a14c5966d06f4f8c3bd02e3ef9d517ead081.tar.gz
abseil-36c2a14c5966d06f4f8c3bd02e3ef9d517ead081.tar.bz2
abseil-36c2a14c5966d06f4f8c3bd02e3ef9d517ead081.zip
Demangle unofficial <unresolved-qualifier-level> encodings like S0_IT_E.
PiperOrigin-RevId: 638430573 Change-Id: Ifc4d93bc4ea30951404546436f5397c8fb1bda57
Diffstat (limited to 'absl/debugging/internal/demangle_test.cc')
-rw-r--r--absl/debugging/internal/demangle_test.cc15
1 files changed, 15 insertions, 0 deletions
diff --git a/absl/debugging/internal/demangle_test.cc b/absl/debugging/internal/demangle_test.cc
index d559d8ca..7705b0fd 100644
--- a/absl/debugging/internal/demangle_test.cc
+++ b/absl/debugging/internal/demangle_test.cc
@@ -372,6 +372,21 @@ TEST(Demangle, SubstpackNotationForTroublesomeTemplatePack) {
EXPECT_STREQ(tmp, "A<>::f<>()");
}
+TEST(Demangle, TemplateTemplateParamAppearingAsBackrefFollowedByTemplateArgs) {
+ char tmp[100];
+
+ // Source:
+ //
+ // template <template <class> class C> struct W {
+ // template <class T> static decltype(C<T>::m()) f() { return {}; }
+ // };
+ //
+ // template <class T> struct S { static int m() { return 0; } };
+ // template decltype(S<int>::m()) W<S>::f<int>();
+ ASSERT_TRUE(Demangle("_ZN1WI1SE1fIiEEDTclsrS0_IT_EE1mEEv", tmp, sizeof(tmp)));
+ EXPECT_STREQ(tmp, "W<>::f<>()");
+}
+
// Test corner cases of boundary conditions.
TEST(Demangle, CornerCases) {
char tmp[10];