Skip to content

Commit

Permalink
WIP
Browse files Browse the repository at this point in the history
  • Loading branch information
srikanth-sankaran committed Feb 13, 2024
1 parent 8398f6c commit 3dc896d
Show file tree
Hide file tree
Showing 11 changed files with 73 additions and 75 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -1825,11 +1825,6 @@ public StringBuilder printExpressionNoParenthesis(int indent, StringBuilder outp
return this.right.printExpression(0, output);
}

@Override
public void addPatternVariables(BlockScope scope, CodeStream codeStream) {
this.left.addPatternVariables(scope, codeStream); // Srikanth
this.right.addPatternVariables(scope, codeStream);
}
@Override
public boolean containsPatternVariable() {
return this.left.containsPatternVariable() || this.right.containsPatternVariable();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -462,13 +462,6 @@ public StringBuilder printExpressionNoParenthesis(int indent, StringBuilder outp
return this.valueIfFalse.printExpression(0, output);
}

@Override
public void addPatternVariables(BlockScope scope, CodeStream codeStream) {
this.condition.addPatternVariables(scope, codeStream);
this.valueIfTrue.addPatternVariables(scope, codeStream);
this.valueIfFalse.addPatternVariables(scope, codeStream);
}

@Override
public TypeBinding resolveType(BlockScope scope) {
// JLS3 15.25
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -782,9 +782,7 @@ public void generateCode(BlockScope currentScope, CodeStream codeStream, boolean
throw new ShouldNotImplement(Messages.ast_missingCode);
}
}
public void addPatternVariables(BlockScope scope, CodeStream codeStream) {
// Nothing by default
}

public LocalDeclaration getPatternVariable() {
return null;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -270,9 +270,6 @@ public void generateCode(BlockScope currentScope, CodeStream codeStream) {
this.initializations[i].generateCode(this.scope, codeStream);
}
}
if (containsPatternVariable()) {
this.condition.addPatternVariables(currentScope, codeStream);
}
Constant cst = this.condition == null ? null : this.condition.optimizedBooleanConstant();
boolean isConditionOptimizedFalse = cst != null && (cst != Constant.NotAConstant && cst.booleanValue() == false);
if (isConditionOptimizedFalse) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -97,11 +97,13 @@ public boolean visit(RecordPattern recordPattern, BlockScope scope1) {
PatternsCollector patCollector = new PatternsCollector(guardedElseTarget);
this.condition.traverse(patCollector, currentScope);
}

@Override
public boolean isAlwaysTrue() {
Constant cst = this.condition.optimizedBooleanConstant();
return cst != Constant.NotAConstant && cst.booleanValue() == true;
}

@Override
public boolean coversType(TypeBinding type) {
return this.primaryPattern.coversType(type) && isAlwaysTrue();
Expand Down Expand Up @@ -167,18 +169,21 @@ public void traverse(ASTVisitor visitor, BlockScope scope) {
}
visitor.endVisit(this, scope);
}

@Override
public void suspendVariables(CodeStream codeStream, BlockScope scope) {
codeStream.removeNotDefinitelyAssignedVariables(scope, this.thenInitStateIndex1);
this.primaryPattern.suspendVariables(codeStream, scope);
}

@Override
public void resumeVariables(CodeStream codeStream, BlockScope scope) {
codeStream.addDefinitelyAssignedVariables(scope, this.thenInitStateIndex2);
this.primaryPattern.resumeVariables(codeStream, scope);
}

@Override
protected boolean isPatternTypeCompatible(TypeBinding other, BlockScope scope) {
return this.primaryPattern.isPatternTypeCompatible(other, scope);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,6 @@ public void generateCode(BlockScope currentScope, CodeStream codeStream, boolean
if (this.elementVariable != null && this.elementVariable.binding != null) {
this.elementVariable.binding.modifiers &= ~ExtraCompilerModifiers.AccOutOfFlowScope;
}
addPatternVariables(currentScope, codeStream);

int pc = codeStream.position;

Expand Down Expand Up @@ -145,12 +144,6 @@ public void generateOptimizedBoolean(BlockScope currentScope, CodeStream codeStr
// a label valued to nil means: by default we fall through the case...
// both nil means we leave the value on the stack

if (this.elementVariable == null && this.pattern == null) {
super.generateOptimizedBoolean(currentScope, codeStream, trueLabel, falseLabel, valueRequired);
return;
}
addPatternVariables(currentScope, codeStream);

int pc = codeStream.position;

this.expression.generateCode(currentScope, codeStream, true);
Expand All @@ -169,12 +162,7 @@ public void generateOptimizedBoolean(BlockScope currentScope, CodeStream codeStr
this.expression.generateCode(currentScope, codeStream, true);
}

if (this.pattern instanceof RecordPattern) {
this.pattern.generateOptimizedBoolean(currentScope, codeStream, trueLabel, nextSibling);
} else {
codeStream.checkcast(this.type, this.type.resolvedType, codeStream.position);
codeStream.store(this.elementVariable.binding, false);
}
this.pattern.generateOptimizedBoolean(currentScope, codeStream, trueLabel, nextSibling);

if (valueRequired) {
codeStream.generateImplicitConversion(this.implicitConversion);
Expand Down Expand Up @@ -209,13 +197,6 @@ public StringBuilder printExpressionNoParenthesis(int indent, StringBuilder outp
this.expression.printExpression(indent, output).append(" instanceof "); //$NON-NLS-1$
return this.pattern == null ? this.type.print(0, output) : this.pattern.printExpression(0, output);
}

@Override
public void addPatternVariables(BlockScope currentScope, CodeStream codeStream) {
for (LocalVariableBinding local: bindingsWhenTrue()) {
codeStream.addVisibleLocalVariable(local);
}
}
@Override
public LocalVariableBinding[] bindingsWhenTrue() {
return this.pattern != null ? this.pattern.bindingsWhenTrue() : NO_VARIABLES;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,8 @@ public FlowInfo analyseCode(BlockScope currentScope, FlowContext flowContext, Fl
this.bits |= ASTNode.IsLocalDeclarationReachable; // only set if actually reached
}
if (this.initialization == null) {
if (this.binding != null && this.binding.isPatternVariable())
this.bits |= FirstAssignmentToLocal;
return flowInfo;
}
this.initialization.checkNPEbyUnboxing(currentScope, flowContext, flowInfo);
Expand Down Expand Up @@ -162,22 +164,24 @@ public void generateCode(BlockScope currentScope, CodeStream codeStream) {

// something to initialize?
generateInit: {
if (this.initialization == null)
if (this.initialization == null && !this.binding.isPatternVariable())
break generateInit;
// forget initializing unused or final locals set to constant value (final ones are inlined)
if (this.binding.resolvedPosition < 0) {
if (this.initialization.constant != Constant.NotAConstant)
if (this.initialization != null) {
// forget initializing unused or final locals set to constant value (final ones are inlined)
if (this.binding.resolvedPosition < 0) {
if (this.initialization.constant != Constant.NotAConstant)
break generateInit;
// if binding unused generate then discard the value
this.initialization.generateCode(currentScope, codeStream, false);
break generateInit;
// if binding unused generate then discard the value
this.initialization.generateCode(currentScope, codeStream, false);
break generateInit;
}
this.initialization.generateCode(currentScope, codeStream, true);
// 26903, need extra cast to store null in array local var
if (this.binding.type.isArrayType()
&& ((this.initialization instanceof CastExpression) // arrayLoc = (type[])null
&& (((CastExpression)this.initialization).innermostCastedExpression().resolvedType == TypeBinding.NULL))){
codeStream.checkcast(this.binding.type);
}
this.initialization.generateCode(currentScope, codeStream, true);
// 26903, need extra cast to store null in array local var
if (this.binding.type.isArrayType()
&& ((this.initialization instanceof CastExpression) // arrayLoc = (type[])null
&& (((CastExpression)this.initialization).innermostCastedExpression().resolvedType == TypeBinding.NULL))){
codeStream.checkcast(this.binding.type);
}
}
codeStream.store(this.binding, false);
if ((this.bits & ASTNode.FirstAssignmentToLocal) != 0) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,7 @@ public Pattern getEnclosingPattern() {
public void setEnclosingPattern(RecordPattern enclosingPattern) {
this.enclosingPattern = enclosingPattern;
}

/**
* Implement the rules in the spec under 14.11.1.1 Exhaustive Switch Blocks
*
Expand All @@ -71,9 +72,11 @@ public void setEnclosingPattern(RecordPattern enclosingPattern) {
public boolean coversType(TypeBinding type) {
return false;
}

public boolean isAlwaysTrue() {
return true;
}

@Override
public void generateCode(BlockScope currentScope, CodeStream codeStream) {
setTargets(codeStream);
Expand All @@ -85,12 +88,15 @@ public void generateCode(BlockScope currentScope, CodeStream codeStream) {
if (this.thenTarget == null)
this.thenTarget = new BranchLabel(codeStream);
}

public void suspendVariables(CodeStream codeStream, BlockScope scope) {
// nothing by default
}

public void resumeVariables(CodeStream codeStream, BlockScope scope) {
// nothing by default
}

public abstract void generateOptimizedBoolean(BlockScope currentScope, CodeStream codeStream, BranchLabel trueLabel, BranchLabel falseLabel);

public TypeReference getType() {
Expand All @@ -105,4 +111,4 @@ public TypeReference getType() {
public StringBuilder print(int indent, StringBuilder output) {
return this.printExpression(indent, output);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -43,21 +43,25 @@ public class RecordPattern extends TypePattern {
private TypeBinding expectedType; // for record pattern type inference

public RecordPattern(TypeReference type, int sourceStart, int sourceEnd) {
super(null); // no local declaration with record patterns
this.type = type;
this.sourceStart = sourceStart;
this.sourceEnd = sourceEnd;
}

@Override
public TypeReference getType() {
return this.type;
}

@Override
public boolean checkUnsafeCast(Scope scope, TypeBinding castType, TypeBinding expressionType, TypeBinding match, boolean isNarrowing) {
if (!castType.isReifiable())
return CastExpression.checkUnsafeCast(this, scope, castType, expressionType, match, isNarrowing);
else
return super.checkUnsafeCast(scope, castType, expressionType, match, isNarrowing);
}

@Override
public LocalVariableBinding[] bindingsWhenTrue() {
LocalVariableBinding [] variables = NO_VARIABLES;
Expand All @@ -66,6 +70,7 @@ public LocalVariableBinding[] bindingsWhenTrue() {
}
return variables;
}

@Override
public FlowInfo analyseCode(BlockScope currentScope, FlowContext flowContext, FlowInfo flowInfo) {
this.thenInitStateIndex1 = currentScope.methodScope().recordInitializationStates(flowInfo);
Expand All @@ -76,6 +81,7 @@ public FlowInfo analyseCode(BlockScope currentScope, FlowContext flowContext, Fl
this.thenInitStateIndex2 = currentScope.methodScope().recordInitializationStates(flowInfo);
return flowInfo;
}

@Override
public boolean coversType(TypeBinding t) {
if (TypeBinding.equalsEquals(t, this.resolvedType)) {
Expand Down Expand Up @@ -173,6 +179,7 @@ public TypeBinding resolveType(BlockScope scope) {
}
return this.resolvedType;
}

private ReferenceBinding inferRecordParameterization(BlockScope scope, ReferenceBinding proposedMatchingType) {
InferenceContext18 freshInferenceContext = new InferenceContext18(scope);
try {
Expand All @@ -181,10 +188,12 @@ private ReferenceBinding inferRecordParameterization(BlockScope scope, Reference
freshInferenceContext.cleanUp();
}
}

@Override
public boolean isAlwaysTrue() {
return false;
}

@Override
public boolean dominates(Pattern p) {
if (!this.resolvedType.isValidBinding())
Expand Down Expand Up @@ -282,10 +291,12 @@ original record instance as receiver - leaving the stack drained.
public void suspendVariables(CodeStream codeStream, BlockScope scope) {
codeStream.removeNotDefinitelyAssignedVariables(scope, this.thenInitStateIndex1);
}

@Override
public void resumeVariables(CodeStream codeStream, BlockScope scope) {
codeStream.addDefinitelyAssignedVariables(scope, this.thenInitStateIndex2);
}

@Override
public void traverse(ASTVisitor visitor, BlockScope scope) {
if (visitor.visit(this, scope)) {
Expand All @@ -311,4 +322,4 @@ public StringBuilder printExpression(int indent, StringBuilder output) {
output.append(')');
return output;
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -39,17 +39,18 @@ public class TypePattern extends Pattern {
public TypePattern(LocalDeclaration local) {
this.local = local;
}
protected TypePattern() {
}

@Override
public TypeReference getType() {
return this.local.type;
}

@Override
public LocalVariableBinding[] bindingsWhenTrue() {
return (this.local.binding == null || this.local.isUnnamed(this.local.binding.declaringScope)) ?
NO_VARIABLES : new LocalVariableBinding[] { this.local.binding };
}

@Override
public boolean checkUnsafeCast(Scope scope, TypeBinding castType, TypeBinding expressionType, TypeBinding match, boolean isNarrowing) {
if (!castType.isReifiable())
Expand Down Expand Up @@ -78,16 +79,15 @@ public FlowInfo analyseCode(BlockScope currentScope, FlowContext flowContext, Fl
}
return patternInfo;
}

@Override
public void generateOptimizedBoolean(BlockScope currentScope, CodeStream codeStream, BranchLabel trueLabel, BranchLabel falseLabel) {
LocalVariableBinding localBinding = this.local.binding;
if (!this.isTotalTypeNode) {
codeStream.checkcast(localBinding.type);
codeStream.checkcast(this.local.binding.type);
}
this.local.generateCode(currentScope, codeStream);
codeStream.store(localBinding, false);
localBinding.recordInitializationStartPC(codeStream.position);
}

@Override
public LocalDeclaration getPatternVariable() {
return this.local;
Expand All @@ -99,6 +99,7 @@ public boolean coversType(TypeBinding type) {
return false;
return (type.isSubtypeOf(this.resolvedType, false));
}

@Override
protected boolean isPatternTypeCompatible(TypeBinding other, BlockScope scope) {
TypeBinding patternType = this.resolvedType;
Expand All @@ -115,6 +116,7 @@ protected boolean isPatternTypeCompatible(TypeBinding other, BlockScope scope) {
}
return true;
}

@Override
public boolean dominates(Pattern p) {
if (p.resolvedType == null || this.resolvedType == null)
Expand Down Expand Up @@ -168,6 +170,7 @@ public TypeBinding resolveType(BlockScope scope) {

return this.resolvedType;
}

// Synthetics? Ref 4.10.5 also watch out for spec changes in rec pattern..
private TypeVariableBinding[] findSyntheticTypeVariables(TypeBinding typeBinding) {
final Set<TypeVariableBinding> mentioned = new HashSet<>();
Expand Down Expand Up @@ -195,4 +198,4 @@ public void traverse(ASTVisitor visitor, BlockScope scope) {
public StringBuilder printExpression(int indent, StringBuilder output) {
return this.local.printAsExpression(indent, output);
}
}
}
Loading

0 comments on commit 3dc896d

Please sign in to comment.