Update the test now that lookupFuncProto does overload resolution. Explicitly test paramter that are reference to object. Test case where we request only the non defaulted argument.

git-svn-id: http://root.cern.ch/svn/root/trunk@46455 27541ba8-7e3a-0410-8455-c3a389f83636
This commit is contained in:
Philippe Canal 2012-10-11 00:07:55 +00:00
parent bb8ebacdba
commit 0701fb4621

View File

@ -107,6 +107,9 @@ public:
void operator delete(void* vp, void* arena) {} void operator delete(void* vp, void* arena) {}
void operator delete[](void* vp) { ::operator delete[](vp); } void operator delete[](void* vp) { ::operator delete[](vp); }
void operator delete[](void* vp, void* arena) {} void operator delete[](void* vp, void* arena) {}
void A_n(B& b) { b.B_f(); }
void A_n(const char *msg, int ndim = 0) { if (ndim) ++msg; }
}; };
// Note: In CINT, looking up a class template specialization causes // Note: In CINT, looking up a class template specialization causes
// instantiation, but looking up a function template specialization // instantiation, but looking up a function template specialization
@ -635,6 +638,47 @@ func_A_m_proto->print(llvm::outs());
//CHECK-NEXT: int y = v; //CHECK-NEXT: int y = v;
//CHECK-NEXT: } //CHECK-NEXT: }
//
// Test finding a member function taking an obj reference arg.
//
const clang::FunctionDecl* func_A_n_args = lookup.findFunctionArgs(class_A, "A_n", "*(new B()");
const clang::FunctionDecl* func_A_n_proto = lookup.findFunctionProto(class_A, "A_n", "B&");
printf("func_A_n_args: 0x%lx\n", (unsigned long) func_A_n_args);
//CHECK: func_A_n_args: 0x{{[1-9a-f][0-9a-f]*$}}
func_A_n_args->print(llvm::outs());
//CHECK-NEXT: void A_n(B &b) {
//CHECK-NEXT: b.B_f();
//CHECK-NEXT: }
printf("func_A_n_proto: 0x%lx\n", (unsigned long) func_A_n_proto);
//CHECK: func_A_n_proto: 0x{{[1-9a-f][0-9a-f]*$}}
func_A_n_proto->print(llvm::outs());
//CHECK-NEXT: void A_n(B &b) {
//CHECK-NEXT: b.B_f();
//CHECK-NEXT: }
//
// Test finding a member function taking with a default argument.
//
const clang::FunctionDecl* func_A_n2_args = lookup.findFunctionArgs(class_A, "A_n", "\"\"");
const clang::FunctionDecl* func_A_n2_proto = lookup.findFunctionProto(class_A, "A_n", "const char *");
printf("func_A_n2_args: 0x%lx\n", (unsigned long) func_A_n2_args);
//CHECK: func_A_n2_args: 0x{{[1-9a-f][0-9a-f]*$}}
func_A_n2_args->print(llvm::outs());
//CHECK-NEXT: void A_n(const char *msg, int ndim = 0) {
//CHECK-NEXT: if (ndim)
//CHECK-NEXT: ++msg;
//CHECK-NEXT: }
printf("func_A_n2_proto: 0x%lx\n", (unsigned long) func_A_n2_proto);
//CHECK: func_A_n2_proto: 0x{{[1-9a-f][0-9a-f]*$}}
func_A_n2_proto->print(llvm::outs());
//CHECK-NEXT: void A_n(const char *msg, int ndim = 0) {
//CHECK-NEXT: if (ndim)
//CHECK-NEXT: ++msg;
//CHECK-NEXT: }
// //
@ -905,21 +949,18 @@ func_B_ctr4_args->print(llvm::outs());
printf("func_B_ctr4_proto: 0x%lx\n", (unsigned long) func_B_ctr4_proto); printf("func_B_ctr4_proto: 0x%lx\n", (unsigned long) func_B_ctr4_proto);
//CHECK: func_B_ctr4_proto: 0x{{[1-9a-f][0-9a-f]*$}} //CHECK: func_B_ctr4_proto: 0x{{[1-9a-f][0-9a-f]*$}}
// Note: The lookupFunctionArgs() routine does not do overload resolution,
// so the template constructor taking T and not T* is selected.
buf.clear(); buf.clear();
cast<clang::NamedDecl>(func_B_ctr4_proto)->getNameForDiagnostic(buf, Policy, /*Qualified=*/true); cast<clang::NamedDecl>(func_B_ctr4_proto)->getNameForDiagnostic(buf, Policy, /*Qualified=*/true);
printf("func_B_ctr4_proto name: %s\n", buf.c_str()); printf("func_B_ctr4_proto name: %s\n", buf.c_str());
//CHECK-NEXT: func_B_ctr4_proto name: B::B<char *> //CHECK-NEXT: func_B_ctr4_proto name: B::B<char>
// Note: The lookupFunctionArgs() routine does not do overload resolution,
// so the uninstantiated constructor template was chosen, there is no body.
printf("func_B_ctr4_proto has body: %d\n", func_B_ctr4_proto->hasBody()); printf("func_B_ctr4_proto has body: %d\n", func_B_ctr4_proto->hasBody());
//CHECK-NEXT: func_B_ctr4_proto has body: 0 //CHECK-NEXT: func_B_ctr4_proto has body: 1
func_B_ctr4_proto->print(llvm::outs()); func_B_ctr4_proto->print(llvm::outs());
// Note: The test framework does not let us check for the absence of output here. //CHECK-NEXT: B(char *v) : m_B_i(0), m_B_d(0.), m_B_ip(0) {
//CHECK-NEXT: this->m_B_i = (long)(char *)v;
//CHECK-NEXT: this->m_B_d = 1.;
//CHECK-NEXT: }
// //
// Test finding destructors. // Test finding destructors.
@ -929,7 +970,7 @@ const clang::FunctionDecl* func_B_dtr_args = lookup.findFunctionArgs(class_B, "~
const clang::FunctionDecl* func_B_dtr_proto = lookup.findFunctionProto(class_B, "~B", ""); const clang::FunctionDecl* func_B_dtr_proto = lookup.findFunctionProto(class_B, "~B", "");
printf("func_B_dtr_args: 0x%lx\n", (unsigned long) func_B_dtr_args); printf("func_B_dtr_args: 0x%lx\n", (unsigned long) func_B_dtr_args);
//CHECK-NEXT: func_B_dtr_args: 0x{{[1-9a-f][0-9a-f]*$}} //CHECK: func_B_dtr_args: 0x{{[1-9a-f][0-9a-f]*$}}
buf.clear(); buf.clear();
cast<clang::NamedDecl>(func_B_dtr_args)->getNameForDiagnostic(buf, Policy, /*Qualified=*/true); cast<clang::NamedDecl>(func_B_dtr_args)->getNameForDiagnostic(buf, Policy, /*Qualified=*/true);