浏览代码

Fix Addressing_OptionalOk selector expression rules for struct field variables

gingerBill 5 年之前
父节点
当前提交
cb52f6986a
共有 1 个文件被更改,包括 9 次插入6 次删除
  1. 9 6
      src/check_expr.cpp

+ 9 - 6
src/check_expr.cpp

@@ -3665,16 +3665,19 @@ Entity *check_selector(CheckerContext *c, Operand *operand, Ast *node, Type *typ
 		}
 		break;
 	case Entity_Variable:
-		// TODO(bill): Is this the rule I need?
-		if (operand->mode == Addressing_Context) {
-			if (sel.indirect) {
-				operand->mode = Addressing_Variable;
-			}
+		if (sel.indirect) {
+			operand->mode = Addressing_Variable;
+		} else if (operand->mode == Addressing_Context) {
+			// Do nothing
 		} else if (operand->mode == Addressing_MapIndex) {
 			operand->mode = Addressing_Value;
 		} else if (entity->flags & EntityFlag_SoaPtrField) {
 			operand->mode = Addressing_SoaVariable;
-		} else if (sel.indirect || operand->mode != Addressing_Value || operand->mode == Addressing_SoaVariable) {
+		} else if (operand->mode == Addressing_OptionalOk) {
+			operand->mode = Addressing_Value;
+		} else if (operand->mode == Addressing_SoaVariable) {
+			operand->mode = Addressing_Variable;
+		} else if (operand->mode != Addressing_Value) {
 			operand->mode = Addressing_Variable;
 		} else {
 			operand->mode = Addressing_Value;