Skip to content

Commit

Permalink
Merge branch 'main' into 570-semantic-info-empty-constraint-list
Browse files Browse the repository at this point in the history
# Conflicts:
#	src/language/validation/safe-ds-validator.ts
  • Loading branch information
lars-reimann committed Sep 21, 2023
2 parents f26da6e + cba3abf commit 1bfcc32
Show file tree
Hide file tree
Showing 3 changed files with 94 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
import { isSdsDeclaration, SdsTypeParameterConstraint } from '../../../generated/ast.js';
import { getContainerOfType, ValidationAcceptor } from 'langium';

export const CODE_TYPE_PARAMETER_CONSTRAINT_LEFT_OPERAND = 'type-parameter-constraint/left-operand';

export const typeParameterConstraintLeftOperandMustBeOwnTypeParameter = (
node: SdsTypeParameterConstraint,
accept: ValidationAcceptor,
) => {
const typeParameter = node.leftOperand.ref;
if (!typeParameter) {
return;
}

const declarationWithConstraint = getContainerOfType(node.$container, isSdsDeclaration);
const declarationWithTypeParameters = getContainerOfType(typeParameter.$container, isSdsDeclaration);

if (declarationWithConstraint !== declarationWithTypeParameters) {
accept('error', 'The left operand must refer to a type parameter of the declaration with the constraint.', {
node,
property: 'leftOperand',
code: CODE_TYPE_PARAMETER_CONSTRAINT_LEFT_OPERAND,
});
}
};
2 changes: 2 additions & 0 deletions src/language/validation/safe-ds-validator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import { templateStringMustHaveExpressionBetweenTwoStringParts } from './other/e
import { yieldMustNotBeUsedInPipeline } from './other/statements/assignments.js';
import { attributeMustHaveTypeHint, parameterMustHaveTypeHint, resultMustHaveTypeHint } from './types.js';
import { moduleDeclarationsMustMatchFileKind, moduleWithDeclarationsMustStatePackage } from './other/modules.js';
import { typeParameterConstraintLeftOperandMustBeOwnTypeParameter } from './other/declarations/typeParameterConstraints.js';

/**
* Register custom validation checks.
Expand All @@ -38,6 +39,7 @@ export const registerValidationChecks = function (services: SafeDsServices) {
SdsResult: [resultMustHaveTypeHint],
SdsSegment: [segmentResultListShouldNotBeEmpty],
SdsTemplateString: [templateStringMustHaveExpressionBetweenTwoStringParts],
SdsTypeParameterConstraint: [typeParameterConstraintLeftOperandMustBeOwnTypeParameter],
SdsTypeParameterList: [typeParameterListShouldNotBeEmpty],
SdsUnionType: [unionTypeShouldNotHaveASingularTypeArgument],
SdsYield: [yieldMustNotBeUsedInPipeline],
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
package tests.validation.other.declarations.typeParameterConstraints.typeParameterOnContainer

annotation MyAnnotation where {
// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»Unresolved« sub MyGlobalClass,
}

class MyGlobalClass<T1> where {
// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»T1« sub MyGlobalClass,

// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»Unresolved« sub MyGlobalClass
} {
class MyNestedClass<T2> where {
// $TEST$ error "The left operand must refer to a type parameter of the declaration with the constraint."
»T1« sub MyGlobalClass,

// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»T2« sub MyGlobalClass,

// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»Unresolved« sub MyGlobalClass,
}

enum MyNestedEnum {
MyEnumVariant<T2> where {
// $TEST$ error "The left operand must refer to a type parameter of the declaration with the constraint."
»T1« sub MyGlobalClass,

// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»T2« sub MyGlobalClass,

// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»Unresolved« sub MyGlobalClass,
}
}

fun myMethod<T2>() where {
// $TEST$ error "The left operand must refer to a type parameter of the declaration with the constraint."
»T1« sub MyGlobalClass,

// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»T2« sub MyGlobalClass,

// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»Unresolved« sub MyGlobalClass,
}
}

enum MyGlobalEnum {
MyEnumVariant<T1> where {
// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»T1« sub MyGlobalClass,

// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»Unresolved« sub MyGlobalClass,
}
}

fun myGlobalFunction<T1>() where {
// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»T1« sub MyGlobalClass,

// $TEST$ no error "The left operand must refer to a type parameter of the declaration with the constraint."
»Unresolved« sub MyGlobalClass,
}

0 comments on commit 1bfcc32

Please sign in to comment.