Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

C# 13: params modifier on collection types. #18329

Merged
merged 7 commits into from
Jan 3, 2025

Conversation

michaelnebel
Copy link
Contributor

@michaelnebel michaelnebel commented Dec 19, 2024

In this PR we make the relevant updates to the CodeQL library to support collection like types for params parameters. The extractor worked out of the box for extracting these types.
The feature is described here: https://learn.microsoft.com/en-us/dotnet/csharp/whats-new/csharp-13#params-collections

@github-actions github-actions bot added the C# label Dec 19, 2024
@michaelnebel michaelnebel force-pushed the csharp/params branch 2 times, most recently from ecced67 to f4539f7 Compare December 20, 2024 10:29
@michaelnebel michaelnebel marked this pull request as ready for review December 20, 2024 13:26
@Copilot Copilot bot review requested due to automatic review settings December 20, 2024 13:26
@michaelnebel michaelnebel requested a review from a team as a code owner December 20, 2024 13:26
Copy link
Contributor

@Copilot Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copilot reviewed 13 out of 30 changed files in this pull request and generated 2 comments.

Files not reviewed (17)
  • csharp/ql/lib/semmle/code/csharp/Callable.qll: Language not supported
  • csharp/ql/lib/semmle/code/csharp/Variable.qll: Language not supported
  • csharp/ql/lib/semmle/code/csharp/commons/Collections.qll: Language not supported
  • csharp/ql/lib/semmle/code/csharp/dataflow/internal/DataFlowPrivate.qll: Language not supported
  • csharp/ql/lib/semmle/code/csharp/dispatch/Dispatch.qll: Language not supported
  • csharp/ql/lib/semmle/code/csharp/frameworks/Format.qll: Language not supported
  • csharp/ql/lib/semmle/code/csharp/frameworks/System.qll: Language not supported
  • csharp/ql/lib/semmle/code/csharp/frameworks/system/collections/Generic.qll: Language not supported
  • csharp/ql/test/library-tests/arguments/argumentByName.expected: Language not supported
  • csharp/ql/test/library-tests/arguments/argumentByParameter.expected: Language not supported
  • csharp/ql/test/library-tests/arguments/argumentByParameter.ql: Language not supported
  • csharp/ql/test/library-tests/arguments/argumentName.expected: Language not supported
  • csharp/ql/test/library-tests/arguments/argumentType.expected: Language not supported
  • csharp/ql/test/library-tests/arguments/parameterGetArguments.expected: Language not supported
  • csharp/ql/test/library-tests/arguments/parameterGetArguments.ql: Language not supported
  • csharp/ql/test/library-tests/dispatch/CallContext.expected: Language not supported
  • csharp/ql/test/library-tests/dispatch/GetADynamicTarget.expected: Language not supported

Tip: Leave feedback on Copilot's review comments with the 👎 and 👍 buttons to help improve review quality. Learn more

{
f10(0, 1, 2);
f10(0, [1, 2]);
f10(args: 1, o: 0);
Copy link
Preview

Copilot AI Dec 20, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The params modifier expects a List, but 1 is an int. It should be f10(args: new List { 1 }, o: 0);

Suggested change
f10(args: 1, o: 0);
f10(args: new List<int> { 1 }, o: 0);

Copilot is powered by AI, so mistakes are possible. Review output carefully before use.

Positive Feedback
Negative Feedback

Provide additional feedback

Please help us improve GitHub Copilot by sharing more details about this comment.

Please select one or more of the options
SinkCollectionParams(new A()); // flow
SinkCollectionParams(null, new A()); // flow
SinkCollectionParams(null, new A(), null); // flow
SinkCollectionParams([new A()]); // flow
Copy link
Preview

Copilot AI Dec 20, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The use of square brackets '[]' for collection initialization is incorrect in C#. It should be replaced with curly braces '{}'.

Suggested change
SinkCollectionParams([new A()]); // flow
SinkCollectionParams(new A[] { new A() }); // flow

Copilot is powered by AI, so mistakes are possible. Review output carefully before use.

Positive Feedback
Negative Feedback

Provide additional feedback

Please help us improve GitHub Copilot by sharing more details about this comment.

Please select one or more of the options
tamasvajk
tamasvajk previously approved these changes Dec 30, 2024
Copy link
Contributor

@tamasvajk tamasvajk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, added two minor comments.

abstract Type getElementType();
}

private class AddArrayType extends ParamsCollectionTypeImpl instanceof ArrayType {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why is this class named AddArrayType? An alternative would be ParamsArrayType.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have used the prefix Add in other places for private classes, which only purpose is to populate (or add) elements to an abstract class. In any case, I don't have any strong preference :-)

override Type getElementType() { result = ArrayType.super.getElementType() }
}

private class AddCollectionTypes extends ParamsCollectionTypeImpl {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

An alternative name could be ParamsConstructedCollectionTypes?

@michaelnebel
Copy link
Contributor Author

DCA looks good.

@michaelnebel michaelnebel requested a review from tamasvajk January 2, 2025 10:26
@michaelnebel michaelnebel changed the title C#: params modifier on collection types. C# 13: params modifier on collection types. Jan 2, 2025
Copy link
Contributor

@tamasvajk tamasvajk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@michaelnebel michaelnebel merged commit 7cdaa79 into github:main Jan 3, 2025
20 checks passed
@michaelnebel michaelnebel deleted the csharp/params branch January 3, 2025 14:07
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants