teak-llvm/lldb/packages/Python/lldbsuite/test/lang/cpp/inlines/inlines.cpp
Adrian McCarthy 536183275d Fix TestInlines.py on Windows
The inlining semantics for C and C++ are different, which affects the test's expectation of the number of times the function should appear in the binary.  In the case of this test, C semantics means there should be three instances of inner_inline, while C++ semantics means there should be only two.

On Windows, clang uses C++ inline semantics even for C code, and there doesn't seem to be a combination of compiler flags to avoid this.

So, for consistency, I've recast the test to use C++ everywhere.  Since the test resided under lang/c, it seemed appropriate to move it to lang/cpp.

This does not address the other XFAIL for this test on Linux/gcc.  See https://llvm.org/bugs/show_bug.cgi?id=26710

Differential Revision: http://reviews.llvm.org/D17650

llvm-svn: 262255
2016-02-29 21:13:29 +00:00

54 lines
913 B
C++

#include <stdio.h>
#include "inlines.h"
#define INLINE_ME __inline__ __attribute__((always_inline))
int
not_inlined_2 (int input)
{
printf ("Called in not_inlined_2 with : %d.\n", input);
return input;
}
int
not_inlined_1 (int input)
{
printf ("Called in not_inlined_1 with %d.\n", input);
return not_inlined_2(input);
}
INLINE_ME int
inner_inline (int inner_input, int mod_value)
{
int inner_result;
inner_result = inner_input % mod_value;
printf ("Returning: %d.\n", inner_result);
return not_inlined_1 (inner_result); // Set break point at this line.
}
INLINE_ME int
outer_inline (int outer_input)
{
int outer_result;
outer_result = inner_inline (outer_input, outer_input % 3);
return outer_result;
}
int
main (int argc, char **argv)
{
printf ("Starting...\n");
int (*func_ptr) (int);
func_ptr = outer_inline;
outer_inline (argc);
func_ptr (argc);
return 0;
}