/******************************************************************************* * Copyright (c) 2015 Bruno Medeiros and other Contributors. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * Bruno Medeiros - initial API and implementation *******************************************************************************/ package melnorme.lang.tooling.engine.resolver; import static melnorme.utilbox.core.Assert.AssertNamespace.assertTrue; import melnorme.lang.tooling.engine.ElementSemantics; import melnorme.lang.tooling.engine.ErrorElement; import melnorme.lang.tooling.engine.ErrorElement.Invalid_TypeErrorElement; import melnorme.lang.tooling.engine.PickedElement; public abstract class ExpSemantics extends ElementSemantics<TypeReferenceResult> { protected final IResolvable resolvable; public ExpSemantics(IResolvable resolvable, PickedElement<?> pickedElement) { super(pickedElement); assertTrue(pickedElement.element == resolvable); this.resolvable = resolvable; } /** @return non-null. */ public final TypeReferenceResult resolveTypeOfUnderlyingValue() { return getElementResolution(); } @Override protected final TypeReferenceResult createLoopResolution() { // TODO: test this path return new TypeReferenceResult(ErrorElement.newLoopError(resolvable, null)); } @Override protected final TypeReferenceResult createResolution() { TypeReferenceResult result = doCreateExpResolution(); if(result == null) { return new TypeReferenceResult(new Invalid_TypeErrorElement("#InvalidExp", resolvable, null, null)); } return result; } public abstract TypeReferenceResult doCreateExpResolution(); /* ----------------- ----------------- */ public TypeReferenceResult resolveTypeReference(IReference reference) { return ResolvableUtil.resolveTypeReference2(reference, context); } }