[M94 Dev][Tizen] Fix for errors for generating ninja files
[platform/framework/web/chromium-efl.git] / base / callback_unittest.nc
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 // This is a "No Compile Test" suite.
6 // http://dev.chromium.org/developers/testing/no-compile-tests
7
8 #include "base/callback.h"
9
10 namespace base {
11
12 class Parent {
13 };
14
15 class Child : Parent {
16 };
17
18 #if defined(NCTEST_EQUALS_REQUIRES_SAMETYPE)  // [r"fatal error: invalid operands to binary expression \('RepeatingCallback<void \(\)>' and 'RepeatingCallback<int \(\)>'\)"]
19
20 // Attempting to call comparison function on two callbacks of different type.
21 //
22 // This should be a compile time failure because each callback type should be
23 // considered distinct.
24 void WontCompile() {
25   RepeatingCallback<void()> c1;
26   RepeatingCallback<int()> c2;
27   c1 == c2;
28 }
29
30 #elif defined(NCTEST_CONSTRUCTION_FROM_SUBTYPE)  // [r"fatal error: no viable conversion from 'RepeatingCallback<base::Parent \(\)>' to 'RepeatingCallback<base::Child \(\)>'"]
31
32 // Construction of RepeatingCallback<A> from RepeatingCallback<B> if A is
33 // supertype of B.
34 //
35 // While this is technically safe, most people aren't used to it when coding
36 // C++ so if this is happening, it is almost certainly an error.
37 void WontCompile() {
38   RepeatingCallback<Parent()> cb_a;
39   RepeatingCallback<Child()> cb_b = cb_a;
40 }
41
42 #elif defined(NCTEST_ASSIGNMENT_FROM_SUBTYPE)  // [r"fatal error: no viable overloaded '='"]
43
44 // Assignment of RepeatingCallback<A> from RepeatingCallback<B> if A is
45 // supertype of B. See explanation for NCTEST_CONSTRUCTION_FROM_SUBTYPE.
46 void WontCompile() {
47   RepeatingCallback<Parent()> cb_a;
48   RepeatingCallback<Child()> cb_b;
49   cb_a = cb_b;
50 }
51
52 #elif defined(NCTEST_ONCE_THEN_MISMATCH)  // [r"static_assert failed due to requirement '.+' \"\|then\| callback's parameter must be constructible from return type of \|this\|\.\""]
53
54 // Calling Then() with a callback that can't receive the original
55 // callback's return type. Here we would pass `int*` to `float*`.
56 void WontCompile() {
57   OnceCallback<int*()> original;
58   OnceCallback<void(float*)> then;
59   std::move(original).Then(std::move(then));
60 }
61
62 #elif defined(NCTEST_ONCE_THEN_MISMATCH_VOID_RESULT)  // [r"fatal error: static_assert failed due to requirement '.+' \"\|then\| callback cannot accept parameters if \|this\| has a void return type\.\""]
63
64 // Calling Then() with a callback that can't receive the original
65 // callback's return type. Here we would pass `void` to `float`.
66 void WontCompile() {
67   OnceCallback<void()> original;
68   OnceCallback<void(float)> then;
69   std::move(original).Then(std::move(then));
70 }
71
72 #elif defined(NCTEST_ONCE_THEN_MISMATCH_VOID_PARAM)  // [r"fatal error: static_assert failed due to requirement '.+' \"\|then\| callback must accept exactly one parameter if \|this\| has a non-void return type\.\""]
73
74 // Calling Then() with a callback that can't receive the original
75 // callback's return type. Here we would pass `int` to `void`.
76 void WontCompile() {
77   OnceCallback<int()> original;
78   OnceCallback<void()> then;
79   std::move(original).Then(std::move(then));
80 }
81
82 #elif defined(NCTEST_REPEATINGRVALUE_THEN_MISMATCH)  // [r"static_assert failed due to requirement '.+' \"\|then\| callback's parameter must be constructible from return type of \|this\|\.\""]
83
84 // Calling Then() with a callback that can't receive the original
85 // callback's return type.  Here we would pass `int*` to `float*`.
86 void WontCompile() {
87   RepeatingCallback<int*()> original;
88   RepeatingCallback<void(float*)> then;
89   std::move(original).Then(std::move(then));
90 }
91
92 #elif defined(NCTEST_REPEATINGRVALUE_THEN_MISMATCH_VOID_RESULT)  // [r"fatal error: static_assert failed due to requirement '.+' \"\|then\| callback cannot accept parameters if \|this\| has a void return type\.\""]
93
94 // Calling Then() with a callback that can't receive the original
95 // callback's return type. Here we would pass `void` to `float`.
96 void WontCompile() {
97   RepeatingCallback<void()> original;
98   RepeatingCallback<void(float)> then;
99   std::move(original).Then(std::move(then));
100 }
101
102 #elif defined(NCTEST_REPEATINGRVALUE_THEN_MISMATCH_VOID_PARAM)  // [r"fatal error: static_assert failed due to requirement '.+' \"\|then\| callback must accept exactly one parameter if \|this\| has a non-void return type\.\""]
103
104 // Calling Then() with a callback that can't receive the original
105 // callback's return type. Here we would pass `int` to `void`.
106 void WontCompile() {
107   RepeatingCallback<int()> original;
108   RepeatingCallback<void()> then;
109   std::move(original).Then(std::move(then));
110 }
111
112 #elif defined(NCTEST_REPEATINGLVALUE_THEN_MISMATCH)  // [r"static_assert failed due to requirement '.+' \"\|then\| callback's parameter must be constructible from return type of \|this\|\.\""]
113
114 // Calling Then() with a callback that can't receive the original
115 // callback's return type.  Here we would pass `int*` to `float*`.
116 void WontCompile() {
117   RepeatingCallback<int*()> original;
118   RepeatingCallback<void(float*)> then;
119   original.Then(then);
120 }
121
122 #elif defined(NCTEST_REPEATINGLVALUE_THEN_MISMATCH_VOID_RESULT)  // [r"fatal error: static_assert failed due to requirement '.+' \"\|then\| callback cannot accept parameters if \|this\| has a void return type\.\""]
123
124 // Calling Then() with a callback that can't receive the original
125 // callback's return type. Here we would pass `void` to `float`.
126 void WontCompile() {
127   RepeatingCallback<void()> original;
128   RepeatingCallback<void(float)> then;
129   original.Then(then);
130 }
131
132 #elif defined(NCTEST_REPEATINGLVALUE_THEN_MISMATCH_VOID_PARAM)  // [r"fatal error: static_assert failed due to requirement '.+' \"\|then\| callback must accept exactly one parameter if \|this\| has a non-void return type\.\""]
133
134 // Calling Then() with a callback that can't receive the original
135 // callback's return type. Here we would pass `int` to `void`.
136 void WontCompile() {
137   RepeatingCallback<int()> original;
138   RepeatingCallback<void()> then;
139   original.Then(then);
140 }
141
142 #endif
143
144 }  // namespace base