1
0
Fork 0
mirror of https://github.com/eclipse-cdt/cdt synced 2025-07-01 06:05:24 +02:00
Commit graph

14474 commits

Author SHA1 Message Date
Igor V. Kovalenko
40e3314e53 Fix typo in testTemplateIDAmbiguity_341747a testing 3rd expression 2023-02-23 13:13:40 -05:00
Igor V. Kovalenko
8f2342e842 Add more C++ builtins
Add __has_unique_object_representations
    __is_aggregate
    __is_assignable
    __is_nothrow_assignable
    __is_nothrow_constructible
2023-02-23 10:44:02 -05:00
Igor V. Kovalenko
58ab28dfd1 c++17 simplify fold expression parser and fix cast-expression on sides
Simplify parser by deferring fold-expression op token check until complete
expression can be examined.

Binary expression builder already produces a chain of BInaryOperator with
cast-expression objects. Use that to restrict valid fold-expression sequence
to the one containing only cast-expression on sides.
2023-02-14 09:53:26 -05:00
Igor V. Kovalenko
04c2da4678 More tests for c++17 fold expression 2023-02-14 09:53:26 -05:00
Igor V. Kovalenko
dc8313b304 Add another integer conversion test for issue 265
Bug: https://github.com/eclipse-cdt/cdt/issues/265
2023-02-13 10:35:57 -05:00
Igor V. Kovalenko
c0220469ad Fix type conversion in unary and binary expression evaluations. 2023-02-13 10:35:57 -05:00
Igor V. Kovalenko
09ab420f17 Actually apply type conversion in CPPEvaluation maybeApplyConversion()
Currently type of parameters of instantiated template function is ignored while
preparing activation record, which makes constexpr evaluation of instantiated
body use types of arguments in function call expression instead:

    template<typename T> bool f(T t) { return t > 0; }
    t<unsigned int>(-1); // CDT returns false because conversion is not done

Fix this by applying EvalTypeId to argument if cost of standard conversions is
Rank.CONVERSION to make sure createActivationRecord() would populate activation
record with argument values matching template parameter types.
2023-02-13 10:35:57 -05:00
Igor V. Kovalenko
beb201e082 Apply truncation and sign-extension to result of initializer evaluation 2023-02-13 10:35:57 -05:00
Jonah Graham
8dd97763a3 Fix incorrect since tags 2023-02-08 21:54:37 -05:00
Jonah Graham
f8625ef447 Fix rebase error for pr #234 - C++ Fold Expressions
PR #234 had a compilation error once it was rebased which
wasn't identified until after it was rebased and merged
to main causing build to fail.

This PR is to fix that rebase error.
2023-02-07 21:49:02 -05:00
Igor V. Kovalenko
f2f862351e Add c++17 fold expression 2023-02-07 21:06:24 -05:00
Igor V. Kovalenko
c973dd5e80 Make sure AST is available to C getExpressionType too
C++ parser methods already store current lookup point which makes AST available
via thread-local variable. Do the same for C parser to enable SizeofCalculator
accessing type size macros via AST while processing C code.
2023-02-04 09:55:07 -05:00
Igor V. Kovalenko
b84b0f62eb Test arithmetic conversion from larger unsigned operand type 2023-02-04 09:55:07 -05:00
Igor V. Kovalenko
57008babd8 Fix arithmetic conversion from larger unsigned operand type
Fixes: 16944a0de7 ("Arithmetic conversions for unary and binary expressions, bug 231859.")
Closes: https://github.com/eclipse-cdt/cdt/issues/265
2023-02-04 09:55:07 -05:00
Philipp Wendler
cf834dd838 Add definitions for integer overflow builtins from GCC
Closes #271
2023-02-04 09:51:34 -05:00
Jonah Graham
a4ba7173e8 Mark DocCommentHighlightingTest as flaky
This test regularly fails on CI builds, but the test passes ok.

Fixes #259
2023-01-30 14:55:55 -05:00
Jonah Graham
ff858fee08 Convert test to JUnit5
This is a pre-requisite to be able to use flaky test tag
2023-01-30 14:55:55 -05:00
Jonah Graham
cbbbe44553 Provide a base UI test case for JUnit5
This is the analogous class to BaseUITestCase, but for JUnit5.
2023-01-30 14:55:55 -05:00
Jonah Graham
8ff58a5262 Remove field in test
The field implies that the fSourceViewer has a longer life
than it does. But reality is that the viewer is only
valid until the editor gets reopened while the test is
running.
2023-01-30 14:55:55 -05:00
Dominic Scharfe
22ee440b88 Issue #254: Constructors of inner classes not resolved properly
- add test case to reproduce #254
- add special case to detect constructors which were declared in the
index file set of the tu
2023-01-28 11:01:08 -05:00
Igor V. Kovalenko
fe7a9d7856
Do not allow structured binding initializer referencing introduced name (#241)
If name lookup ends up with a variable, additionally check if node being
resolved is part of the structured binding initializer introducing found
variable. If this is the case, produce problem binding and report structured
binding declaration error via codan.

This change also prevents infinite recursion trying to resolve auto type of
introduced variable while evaluating such problematic initializer.
2023-01-28 10:54:09 -05:00
Igor V. Kovalenko
2776d17014 Drop three-way comparison from C parser, this is C++ only. 2023-01-28 10:52:07 -05:00
Igor V. Kovalenko
a90cbe1736 Add simple evaluation for c++20 three-way comparison 2023-01-28 10:52:07 -05:00
Jonah Graham
a0f91038e0 Add and correct since tags for new API in 8.1.0
o.e.cdt.core 8.0.0 was released as part of CDT 11, so this new
non-breaking API needs a version bump to 8.1.0.
2023-01-28 10:52:07 -05:00
Igor V. Kovalenko
97dccc2c1e Fix precedence for c++20 three-way comparison operator 2023-01-28 10:52:07 -05:00
Igor V. Kovalenko
f13157720e Add operator name test for c++20 three-way comparison 2023-01-28 10:52:07 -05:00
Igor V. Kovalenko
ae8da7ef88 Add variable read/write flag test for c++20 three-way comparison 2023-01-28 10:52:07 -05:00
Igor V. Kovalenko
a8b3401a47 Add rewriter test for c++20 three-way comparison expression 2023-01-28 10:52:07 -05:00
Igor V. Kovalenko
5eb89637b2 Add test for c++20 three-way comparison expression 2023-01-28 10:52:07 -05:00
Igor V. Kovalenko
5622e59e5f Replace useGNUExtensions flag in test code with scanner configuration id
Add STD and GNU scanner configuration ids and pass these as needed instead of
boolean flag useGNUExtensions. This will be used later by C++20 scanner tests.
2023-01-28 10:52:07 -05:00
Igor V. Kovalenko
ff8ac10f6e Add basic support for c++20 three-way comparison operator 2023-01-28 10:52:07 -05:00
Igor V. Kovalenko
ccf8053680 Fix copyright header typo 2023-01-26 14:18:41 -05:00
Igor V. Kovalenko
8fc812ee27 Fix pack expansion for array elements
When parameter pack contains array type the EvalCompositeAccess.getType() will
attempt to return type of array element.

Fix this by providing EvalPackAccess which returns pack elements as is.
2023-01-26 12:15:40 -05:00
Erwin Waterlander
7911ac8a2b Bug 552070 - Build not configured correctly error while building a project
https://bugs.eclipse.org/bugs/show_bug.cgi?id=552070

After closing and opening a Core Build project (Make, CMake,
Autotools, and Meson), the project could not be built for Debug
anymore. Error: "Build not configured correctly".

Restoration of the debug build configurations failed, because the
settings had been removed during closure of the project.
CBuildConfiguration(IBuildConfiguration config, String name)
failed with a CoreException. The CBuildConfigurationManager
silently catched the exception and put the IBuildConfiguration for
debug in the noConfigs list.
2023-01-25 14:23:14 -05:00
Jonah Graham
7bcef26f65 Make Select Configurations Dialog resizable
Fixes #240
2023-01-18 15:50:45 -05:00
John Dallaway
1c7aa967a0 Add support for DW_FORM_line_strp 2023-01-16 20:47:09 +00:00
Jonah Graham
781646e0ef Account for new header layout in DWARF v5
Fixes #198
2023-01-16 20:47:09 +00:00
John Dallaway
a949830dd3
Support multiple MSYS2 64-bit registry names (#243) 2023-01-15 16:52:20 +00:00
TheShermanTanker
c98aae4c6a Update comment because #warning is no longer an extension in C23 2023-01-01 13:51:32 -05:00
Jonah Graham
503ca0af58 Bump version of cdt.core in preparation for 11.1.0 dev 2023-01-01 13:51:32 -05:00
Jonah Graham
48c5abfcb3 [releng] Update to latest maven-compiler-plugin version 2022-12-09 12:24:55 -05:00
Jonah Graham
b87a45520a [releng] Prepare repo for CDT 11.1.0 development 2022-12-09 12:24:55 -05:00
Jonah Graham
fcf2a16614 [releng] Bump versions of bundles modified since 11.0 release 2022-12-09 12:24:55 -05:00
徐持恒 Xu Chiheng
352630b8ea
ProcessFactory.java : envpToEnvMap() consider null envp (#195) 2022-12-06 16:05:28 -05:00
徐持恒 Xu Chiheng
ac64d4aedc
refactor ProcessFactory to help debugging (#191) 2022-12-06 13:20:38 -05:00
徐持恒 Xu Chiheng
9114ac3ff2
refactor ProcessFactory.java to put all process creations in one function. (#188)
* refactor ProcessFactory.java to put all process creations in one function.

Prerequisite of #187

* add missing $NON-NLS$ tags
2022-12-03 12:06:28 -05:00
Jonah Graham
1087dc5f22 [releng] Require target platform bundles as minimum version
Without setting dependent plug-ins to minimum version to match the
target platform we are aiming for we can imply (and therefore let install)
CDT into older versions of Eclipse where CDT does not actually work.

This can be exposed in very odd ways, such as IllegalAccessError, when
platform has allowed API changes.

However, rather than update every single bundle in CDT, only the
o.e.cdt.core/ui bundles are being updated as this should achieve the
desired result without every other bundle needing to be touched.

See Bug 536448
Part of #77
2022-11-29 16:20:31 -05:00
Jonah Graham
1d0550a9f1 Cosmetics. 2022-11-21 18:57:10 -05:00
Jonah Graham
73fae6d6c1 Add missing @since 2022-11-21 18:57:10 -05:00
Jonah Graham
60f668f259 Resolve deadlock in Jobmanager related code
Because of
[changes](https://www.eclipse.org/eclipse/news/4.26/platform_isv.php#JobManager_Implementation)
in Eclipse Platform where the jobmanager's behaviour changes (within
the API), the consumers of the jobmanager can deadlock due to incorrect
assumptions.

In particular, where we call job.schedule(), the callback can happen
in different threads to the IJobChangeListener's. As CDT was holding
a lock while calling schedule that is also required in those
listeners, we need to no longer lock when calling schedule.

As the code already dealt with the case of when there was a delay
between the job.schedule() and where & when it was run, we can
move the schedule call out of the synchronized block.

Fixes #81
2022-11-21 18:00:03 -05:00