From: trippels Date: Wed, 2 Dec 2015 19:57:55 +0000 (+0000) Subject: Fix c++/67337 (segfault in mangle.c) X-Git-Tag: upstream/6.1~2542 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=c57ab0e84926bd55f6f4837abad2cdec58b51cdd;p=platform%2Fupstream%2Flinaro-gcc.git Fix c++/67337 (segfault in mangle.c) PR c++/67337 * mangle.c (write_template_prefix): Guard against context==NULL. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@231203 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 6d344ff..ce26e5d 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2015-12-02 Markus Trippelsdorf + + PR c++/67337 + * mangle.c (write_template_prefix): Guard against context==NULL. + 2015-12-02 Jason Merrill * call.c (build_new_op_1): Don't fold arguments to diff --git a/gcc/cp/mangle.c b/gcc/cp/mangle.c index 6f8bf68..3ff3066 100644 --- a/gcc/cp/mangle.c +++ b/gcc/cp/mangle.c @@ -1145,7 +1145,7 @@ write_template_prefix (const tree node) So, for the example above, `Outer::Inner' is represented as a substitution candidate by a TREE_LIST whose purpose is `Outer' and whose value is `Outer::Inner'. */ - if (TYPE_P (context)) + if (context && TYPE_P (context)) substitution = build_tree_list (context, templ); else substitution = templ; diff --git a/gcc/testsuite/g++.dg/template/pr67337.C b/gcc/testsuite/g++.dg/template/pr67337.C new file mode 100644 index 0000000..df2651b --- /dev/null +++ b/gcc/testsuite/g++.dg/template/pr67337.C @@ -0,0 +1,25 @@ +template class A +{ + void m_fn1 (int *, int); +}; + +template class B +{ +public: + typedef int Type; +}; + +template class C +{ +public: + C (int); + template