2009-12-02 Rafael Avila de Espindola <espindola@google.com>
[deliverable/binutils-gdb.git] / gold / testsuite / debug_msg.cc
CommitLineData
f0323c2f
ILT
1// debug_msg.cc -- a test case for printing debug info for missing symbols.
2
ebdbb458 3// Copyright 2006, 2007, 2008 Free Software Foundation, Inc.
f0323c2f
ILT
4// Written by Ian Lance Taylor <iant@google.com>.
5
6// This file is part of gold.
7
8// This program is free software; you can redistribute it and/or modify
9// it under the terms of the GNU General Public License as published by
10// the Free Software Foundation; either version 3 of the License, or
11// (at your option) any later version.
12
13// This program is distributed in the hope that it will be useful,
14// but WITHOUT ANY WARRANTY; without even the implied warranty of
15// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16// GNU General Public License for more details.
17
18// You should have received a copy of the GNU General Public License
19// along with this program; if not, write to the Free Software
20// Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
21// MA 02110-1301, USA.
22
23// This file is constructed to have undefined references. In
24// debug_msg.sh, we will try to link this file, and analyze the
25// error messages that are produced.
26
27extern int undef_int;
28extern float undef_float;
29extern void undef_fn1();
30extern void undef_fn2();
31
32int* badref1 = &undef_int;
33static float* badref2 = &undef_float;
34void (*fn_array[])() =
35{
36 undef_fn1,
37 undef_fn2
38};
39
40template<class Foo>
41int testfn(Foo x)
42{
43 undef_fn1();
44 undef_fn2();
45 return undef_int;
46}
47
48class Base
49{
50 virtual void virtfn() { undef_fn1(); }
51};
52
53class Derived : public Base
54{
55 virtual void virtfn() { undef_fn2(); }
56};
57
a55ce7fe
ILT
58// This tests One Definition Rule (ODR) violations.
59void SortAscending(int array[], int size); // in odr_violation1.cc
60void SortDescending(int array[], int size); // in odr_violation2.cc
61
f0323c2f
ILT
62int main()
63{
64 testfn(5);
65 testfn(4.0);
66
67 Base b;
68 Derived d;
69
a55ce7fe
ILT
70 int kInput1[] = {1, 6, 9, 7, 3, 4, 2, 10, 5, 8};
71 int kSize1 = sizeof(kInput1) / sizeof(int);
72 SortAscending(kInput1, kSize1);
73
74 int kInput2[] = {1, 6, 9, 7, 3, 4, 2, 10, 5, 8};
75 int kSize2 = sizeof(kInput2) / sizeof(int);
76 SortDescending(kInput2, kSize2);
77
f0323c2f
ILT
78 return 0;
79}
This page took 0.100854 seconds and 4 git commands to generate.