Files
qt-creator/tests/auto/cplusplus/cppselectionchanger/testCppFile.cpp
Alexandru Croitor bed88818ce C++: Implement context-aware expand / shrink selection actions.
Implement selection expanding / shrinking, that is aware of C++
semantics, thus giving smart selection changing.

Change-Id: I1386a20597fa6bb85c3aa0d8ddfb87cdb3fd7c38
Reviewed-by: Nikolai Kosjar <nikolai.kosjar@theqtcompany.com>
2016-02-29 08:15:03 +00:00

125 lines
3.0 KiB
C++

/****************************************************************************
**
** Copyright (C) 2016 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of Qt Creator.
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 as published by the Free Software
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
****************************************************************************/
#include <string>
#include <iostream>
#include <map>
#include <vector>
struct TestClass {
int a;
char b;
char x;
char y;
char z;
std::string c;
double d;
std::map<int, int> e;
};
int add(int a, int b) {
return a + b;
}
template <class T>
int subtract(T a, T b) {
return a - b;
}
namespace CustomNamespace {
extern int insideNamespace;
int foo() {
insideNamespace = 2;
return insideNamespace;
}
}
class CustomClass {
bool customClassMethod(const int &parameter) const volatile;
};
class SecondCustomClass {
public:
SecondCustomClass(int argc, char *argv[]);
void secondCustomClassFunction();
};
bool CustomClass::customClassMethod(const int &parameter) const volatile {
int secondParameter = parameter;
++secondParameter;
return secondParameter;
}
int main(int argc, char *argv[])
{
std::map<int,TestClass> a;
SecondCustomClass secondCustomClass(argc, argv);
secondCustomClass.secondCustomClassFunction();
TestClass bla;
bla.a = 1;
bla.b = 65;
bla.c = "Hello";
bla.d = 3.14f;
bla.e[3] = 3;
a[3] = bla;
std::vector<int> v;
v.push_back(1);
v.push_back(2);
if (5 == 5) {
std::cout << "Hello" << 'c' << 54545 << u8"utf8string" << U"unicodeString";
for (int i = 0; i < 3; ++i) {
std::cout << i;
}
for (auto val :v) {
std::cout << val;
}
}
std::cout << "\n After exec";
std::cout << argc << argv;
std::cout << add(1, add(2, add(10, 20)));
auto res = std::find(v.begin(), v.end(), 1);
if (res != v.end())
std::cout << *res;
std::cout << static_cast<int>(3);
auto aLambda = [=, &a](int lambdaArgument) -> int {
return lambdaArgument + 1;
};
aLambda(1);
std::cout << R"(
Raw literal
)";
}