blob: ef9a86282cd780ef5490c85b8944b5184e492243 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
class Key;
class Value;
class SortAlgorithm;
class DefaultSort;
class T;
class X;
class Y;
class Bar;
class Foo {
template<class Bar> void fum(int i);
};
// TEMPLATE_STRUCT
template<class Key, class Value, class SortAlgorithm = DefaultSort>
struct Map {
Key* keys;
Value* values;
SortAlgorithm* sortAlgorithm;
Map();
};
// TEMPLATE_CLASS
template<class T> class nonVector {
private:
T* head;
public:
nonVector() {
head = new T();
}
int length() {
return 1;
}
const T& first() const;
};
// TEMPLATE_UNION
template<class X, class Y, int size = 16>
union ArrayOverlay {
public:
X x[size];
Y y[size];
static int numArrays;
};
// TEMPLATE_METHODS
class TemplateContainer {
// these are in an enclosing class
template<class Bar> void fum(int i);
template<int>
void scrum(void) {
}
;
};
// TEMPLATE_FUNCTION
template<class T> const T& nonVector<T>::first() const {
return *head;
}
template<class X> bool IsGreaterThan(X, X);
template<class Bar> void Foo::fum(int i) {
}
// TEMPLATE_VARIABLES
template<bool threads, int inst> char* default_alloc_template<threads, inst>::S_start_free =
0;
// an instantiation, not a template:
complex<float> cf(0, 0);
//template<class Language, class CharacterSet, class SortAlgorithm<CharacterSet> >
//Dictionary* TheSpellCheckDictionary;
int success;
|