mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-17 09:20:27 +08:00
* g++.old-deja/g++.other/cast5.C: New test.
From-SVN: r31850
This commit is contained in:
parent
2c55cdde2e
commit
1d3f28d4de
@ -1,3 +1,7 @@
|
||||
2000-02-08 Nathan Sidwell <nathan@acm.org>
|
||||
|
||||
* g++.old-deja/g++.other/cast5.C: New test.
|
||||
|
||||
2000-02-05 Alan Modra <alan@SPRI.Levels.UniSA.Edu.Au>
|
||||
|
||||
* gcc.c-torture/execute/20000205-1.c: New.
|
||||
|
38
gcc/testsuite/g++.old-deja/g++.other/cast5.C
Normal file
38
gcc/testsuite/g++.old-deja/g++.other/cast5.C
Normal file
@ -0,0 +1,38 @@
|
||||
// Build don't link:
|
||||
|
||||
// Copyright (C) 2000 Free Software Foundation, Inc.
|
||||
// Contributed by Nathan Sidwell 4 Feb 2000 <nathan@acm.org>
|
||||
|
||||
// Array of cv T decays to pointer to cv T, and pointer to array of cv T can
|
||||
// be converted to pointer to cv T. We need to make sure the `cv's don't
|
||||
// confuse us.
|
||||
|
||||
typedef char const *ary_t[2];
|
||||
|
||||
void f0 (ary_t const *const &ary)
|
||||
{
|
||||
static_cast <void const *> (ary);
|
||||
static_cast <void *> (ary); // ERROR - casts away const
|
||||
(void const *) (ary);
|
||||
}
|
||||
|
||||
void f1 (ary_t *const &ary)
|
||||
{
|
||||
static_cast <void *> (ary);
|
||||
static_cast <void const *> (ary);
|
||||
(void const *) (ary);
|
||||
}
|
||||
|
||||
void f2 (ary_t const *&ary)
|
||||
{
|
||||
static_cast <void const *> (ary);
|
||||
static_cast <void *> (ary); // ERROR - casts away const
|
||||
(void const *) (ary);
|
||||
}
|
||||
|
||||
void f3 (ary_t *&ary)
|
||||
{
|
||||
static_cast <void *> (ary);
|
||||
static_cast <void const *> (ary);
|
||||
(void const *) (ary);
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user