Files
clang-p2996/lldb/test/API/lang/cpp/namespace/ns2.cpp
Jordan Rupprecht 99451b4453 [lldb][test] Remove symlink for API tests.
Summary: Moves lldbsuite tests to lldb/test/API.

This is a largely mechanical change, moved with the following steps:

```
rm lldb/test/API/testcases
mkdir -p lldb/test/API/{test_runner/test,tools/lldb-{server,vscode}}
mv lldb/packages/Python/lldbsuite/test/test_runner/test lldb/test/API/test_runner
for d in $(find lldb/packages/Python/lldbsuite/test/* -maxdepth 0 -type d | egrep -v "make|plugins|test_runner|tools"); do mv $d lldb/test/API; done
for d in $(find lldb/packages/Python/lldbsuite/test/tools/lldb-vscode -maxdepth 1 -mindepth 1 | grep -v ".py"); do mv $d lldb/test/API/tools/lldb-vscode; done
for d in $(find lldb/packages/Python/lldbsuite/test/tools/lldb-server -maxdepth 1 -mindepth 1 | egrep -v "gdbremote_testcase.py|lldbgdbserverutils.py|socket_packet_pump.py"); do mv $d lldb/test/API/tools/lldb-server; done
```

lldb/packages/Python/lldbsuite/__init__.py and lldb/test/API/lit.cfg.py were also updated with the new directory structure.

Reviewers: labath, JDevlieghere

Tags: #lldb

Differential Revision: https://reviews.llvm.org/D71151
2020-02-11 10:03:53 -08:00

65 lines
2.0 KiB
C++

//===-- ns2.cpp ------------------------------------------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#include "ns.h"
static int func()
{
std::printf("static m2.cpp func()\n");
return 2;
}
void test_lookup_at_file_scope()
{
// BP_file_scope
std::printf("at file scope: func() = %d\n", func()); // eval func(), exp: 2
std::printf("at file scope: func(10) = %d\n", func(10)); // eval func(10), exp: 11
}
namespace A {
namespace B {
int func()
{
std::printf("A::B::func()\n");
return 4;
}
void test_lookup_at_nested_ns_scope()
{
// BP_nested_ns_scope
std::printf("at nested ns scope: func() = %d\n", func()); // eval func(), exp: 4
//printf("func(10) = %d\n", func(10)); // eval func(10), exp: 13
// NOTE: Under the rules of C++, this test would normally get an error
// because A::B::func() hides A::func(), but lldb intentionally
// disobeys these rules so that the intended overload can be found
// by only removing duplicates if they have the same type.
}
void test_lookup_at_nested_ns_scope_after_using()
{
// BP_nested_ns_scope_after_using
using A::func;
std::printf("at nested ns scope after using: func() = %d\n", func()); // eval func(), exp: 3
}
}
}
int A::foo()
{
std::printf("A::foo()\n");
return 42;
}
int A::func(int a)
{
std::printf("A::func(int)\n");
return a + 3;
}
void A::test_lookup_at_ns_scope()
{
// BP_ns_scope
std::printf("at nested ns scope: func() = %d\n", func()); // eval func(), exp: 3
std::printf("at nested ns scope: func(10) = %d\n", func(10)); // eval func(10), exp: 13
std::printf("at nested ns scope: foo() = %d\n", foo()); // eval foo(), exp: 42
}