From 346295449270eea993334b6f4a677f0287f2b0d3 Mon Sep 17 00:00:00 2001 From: Stephan Herrmann Date: Thu, 15 Feb 2024 14:57:11 +0100 Subject: [PATCH] IrritantSet needs unsigned right shift for GROUP4 and higher fixes #2006 --- .../internal/compiler/impl/IrritantSet.java | 8 ++-- .../core/tests/compiler/IrritantSetTest.java | 44 +++++++++++++++++++ .../tests/compiler/regression/TestAll.java | 2 + 3 files changed, 50 insertions(+), 4 deletions(-) create mode 100644 org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/IrritantSetTest.java diff --git a/org.eclipse.jdt.core.compiler.batch/src/org/eclipse/jdt/internal/compiler/impl/IrritantSet.java b/org.eclipse.jdt.core.compiler.batch/src/org/eclipse/jdt/internal/compiler/impl/IrritantSet.java index 340f45926f7..c07532688dd 100644 --- a/org.eclipse.jdt.core.compiler.batch/src/org/eclipse/jdt/internal/compiler/impl/IrritantSet.java +++ b/org.eclipse.jdt.core.compiler.batch/src/org/eclipse/jdt/internal/compiler/impl/IrritantSet.java @@ -224,7 +224,7 @@ public boolean areAllSet() { } public IrritantSet clear(int singleGroupIrritants) { - int group = (singleGroupIrritants & GROUP_MASK) >> GROUP_SHIFT; + int group = (singleGroupIrritants & GROUP_MASK) >>> GROUP_SHIFT; this.bits[group] &= ~singleGroupIrritants; return this; } @@ -242,7 +242,7 @@ public IrritantSet clearAll() { public void initialize(int singleGroupIrritants) { if (singleGroupIrritants == 0) return; - int group = (singleGroupIrritants & GROUP_MASK) >> GROUP_SHIFT; + int group = (singleGroupIrritants & GROUP_MASK) >>> GROUP_SHIFT; this.bits[group] = singleGroupIrritants & ~GROUP_MASK; // erase group information } @@ -280,14 +280,14 @@ public boolean hasSameIrritants(IrritantSet irritantSet) { } public boolean isSet(int singleGroupIrritants) { - int group = (singleGroupIrritants & GROUP_MASK) >> GROUP_SHIFT; + int group = (singleGroupIrritants & GROUP_MASK) >>> GROUP_SHIFT; return (this.bits[group] & singleGroupIrritants) != 0; } public int[] getBits() { return this.bits; } public IrritantSet set(int singleGroupIrritants) { - int group = (singleGroupIrritants & GROUP_MASK) >> GROUP_SHIFT; + int group = (singleGroupIrritants & GROUP_MASK) >>> GROUP_SHIFT; this.bits[group] |= (singleGroupIrritants & ~GROUP_MASK); // erase the group bits return this; } diff --git a/org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/IrritantSetTest.java b/org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/IrritantSetTest.java new file mode 100644 index 00000000000..89168c741db --- /dev/null +++ b/org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/IrritantSetTest.java @@ -0,0 +1,44 @@ +/******************************************************************************* + * Copyright (c) 2024 GK Software SE and others. + * + * This program and the accompanying materials + * are made available under the terms of the Eclipse Public License 2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/legal/epl-2.0/ + * + * SPDX-License-Identifier: EPL-2.0 + * + * Contributors: + * Stephan Herrmann - Initial API and implementation + *******************************************************************************/ +package org.eclipse.jdt.core.tests.compiler; + +import org.eclipse.jdt.core.tests.junit.extension.TestCase; +import org.eclipse.jdt.internal.compiler.impl.IrritantSet; + +import junit.framework.Test; +import junit.framework.TestSuite; + +public class IrritantSetTest extends TestCase { + + public IrritantSetTest(String name) { + super(name); + } + + public static Test suite() { + TestSuite suite = new TestSuite(IrritantSetTest.class.getPackageName()); + suite.addTest(new TestSuite(IrritantSetTest.class)); + return suite; + } + + public void testGroup4() { + if (IrritantSet.GROUP_MAX <= 4) { + System.out.println("IrritantSetTest.testGroup4 will trigger once IrritantSet.GROUP_MAX exceeds 4."); + return; + } + @SuppressWarnings("unused") // dead code as of now + int singleIrritant = ( 4 << IrritantSet.GROUP_SHIFT /* group4 */) + 42; + IrritantSet irritantSet = new IrritantSet(singleIrritant); + assertTrue(irritantSet.isSet(singleIrritant)); + } +} diff --git a/org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/regression/TestAll.java b/org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/regression/TestAll.java index 9538665de8d..08a9953583b 100644 --- a/org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/regression/TestAll.java +++ b/org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/regression/TestAll.java @@ -25,6 +25,7 @@ import java.util.ArrayList; +import org.eclipse.jdt.core.tests.compiler.IrritantSetTest; import org.eclipse.jdt.core.tests.compiler.util.HashtableOfObjectTest; import org.eclipse.jdt.core.tests.compiler.util.JrtUtilTest; import org.eclipse.jdt.core.tests.dom.StandAloneASTParserTest; @@ -94,6 +95,7 @@ public static Test suite() { standardTests.add(ResourceLeakTests.class); standardTests.add(ResourceLeakAnnotatedTests.class); standardTests.add(PackageBindingTest.class); + standardTests.add(IrritantSetTest.class); // add all javadoc tests for (int i=0, l=JavadocTest.ALL_CLASSES.size(); i