Skip to content

Commit

Permalink
Loosen a type test for constants corresponding to their expressions.
Browse files Browse the repository at this point in the history
PiperOrigin-RevId: 575618753
  • Loading branch information
lukesandberg authored and copybara-github committed Oct 22, 2023
1 parent 1878227 commit 7aad784
Showing 1 changed file with 5 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -418,8 +418,8 @@ protected Expression(
this.constantValue = checkNotNull(constantValue);
if (Flags.DEBUG && constantValue.isPresent()) {
checkState(
resultType.equals(constantValue.get().type),
"Type mismatch. Expected constant value of type %s to have type %s",
BytecodeUtils.isPossiblyAssignableFrom(resultType, constantValue.get().type),
"Type mismatch. Expected constant value of type %s to to be assignable to %s",
constantValue.get().type,
resultType);
}
Expand Down Expand Up @@ -583,7 +583,10 @@ public Expression asSoyNullish() {
if (!isNonSoyNullish()) {
return this;
}
checkAssignableTo(BytecodeUtils.SOY_VALUE_TYPE);
return new DelegatingExpression(
// The only type that is a super type of a NullData,UndefinedData and any other SoyValue is
// SoyValue itself.
this, BytecodeUtils.SOY_VALUE_TYPE, features.minus(Feature.NON_SOY_NULLISH));
}

Expand Down

0 comments on commit 7aad784

Please sign in to comment.