From: jhugunin Date: Mon, 30 Dec 2002 20:30:48 +0000 (+0000) Subject: better errors for circularities X-Git-Tag: V_1_1_b5~203 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=580d0ccb31b25769510283e93174915f76b06d09;p=aspectj.git better errors for circularities --- diff --git a/weaver/src/org/aspectj/weaver/patterns/DeclareDominates.java b/weaver/src/org/aspectj/weaver/patterns/DeclareDominates.java index 23b0a45f2..87eed741d 100644 --- a/weaver/src/org/aspectj/weaver/patterns/DeclareDominates.java +++ b/weaver/src/org/aspectj/weaver/patterns/DeclareDominates.java @@ -16,6 +16,7 @@ package org.aspectj.weaver.patterns; import java.io.*; import java.util.List; +import org.aspectj.bridge.IMessage; import org.aspectj.weaver.*; import org.aspectj.weaver.ResolvedTypeX; @@ -77,9 +78,12 @@ public class DeclareDominates extends Declare { TypePattern p = patterns.get(i); if (p.isStar()) { starMatch = i; - } else if (p.matchesExactly(a)) { + } else if (p.matchesStatically(a)) { if (knownMatch != -1) { - throw new BCException("multiple matches: " + this + " with " + a); + a.getWorld().showMessage(IMessage.ERROR, "multiple matches for " + a + + ", matches both " + patterns.get(knownMatch) + " and " + p, + patterns.get(knownMatch).getSourceLocation(), p.getSourceLocation()); + return -1; } else { knownMatch = i; }