From 34e225a30bcb010bc46846eb3ea6ad9e1321034d Mon Sep 17 00:00:00 2001 From: Nathan Sidwell Date: Thu, 11 Jan 2001 11:45:03 +0000 Subject: [PATCH] pt.c (unify): Check array has a domain, before checking whether it is variable sized. cp: * pt.c (unify): Check array has a domain, before checking whether it is variable sized. testsuite: * g++.old-deja/g++.pt/crash64.C: New test. From-SVN: r38902 --- gcc/cp/ChangeLog | 5 +++++ gcc/cp/pt.c | 1 + gcc/testsuite/g++.old-deja/g++.pt/crash64.C | 24 +++++++++++++++++++++ 3 files changed, 30 insertions(+) create mode 100644 gcc/testsuite/g++.old-deja/g++.pt/crash64.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 526424fd77a..d72b8b0d56e 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2001-01-11 Nathan Sidwell + + * pt.c (unify): Check array has a domain, before checking + whether it is variable sized. + 2001-01-11 Nathan Sidwell * decl.c (grokparms): Unobfuscate and get correct diagnostic for diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 13f9d203bfe..b0f2b560afc 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -8605,6 +8605,7 @@ unify (tparms, targs, parm, arg, strict) here. */ if (TREE_CODE (arg) == ARRAY_TYPE && !uses_template_parms (arg) + && TYPE_DOMAIN (arg) && (TREE_CODE (TYPE_MAX_VALUE (TYPE_DOMAIN (arg))) != INTEGER_CST)) return 1; diff --git a/gcc/testsuite/g++.old-deja/g++.pt/crash64.C b/gcc/testsuite/g++.old-deja/g++.pt/crash64.C new file mode 100644 index 00000000000..89494116493 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.pt/crash64.C @@ -0,0 +1,24 @@ +// Build don't link: + +// Copyright (C) 2000 Free Software Foundation, Inc. +// Contributed by Nathan Sidwell 10 Jan 2001 + +// Bug 1546. We ICE'd trying to unify an array of unknown bound, +// checking to see if it was a variable sized array. + +template class allocator {}; + +template +struct _Alloc_traits +{ + static const bool _S_instanceless = false; +}; + +template +struct _Alloc_traits<_Tp, allocator<_Tp1> > +{ + static const bool _S_instanceless = true; +}; + +typedef char state []; +bool y = _Alloc_traits >::_S_instanceless; -- 2.30.2