Skip to content

Commit

Permalink
IrritantSet needs unsigned right shift for GROUP4 and higher
Browse files Browse the repository at this point in the history
fixes #2006
  • Loading branch information
stephan-herrmann committed Feb 15, 2024
1 parent b05494a commit 3462954
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -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;
}
Expand All @@ -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
}

Expand Down Expand Up @@ -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;
}
Expand Down
Original file line number Diff line number Diff line change
@@ -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));
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -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;
Expand Down Expand Up @@ -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<l; i++) {
Expand Down

0 comments on commit 3462954

Please sign in to comment.