Merge "Fix 'Potential heap pollution via vargs parameter' warnings"

This commit is contained in:
Edwin Kempin 2013-11-29 19:45:52 +00:00 committed by Gerrit Code Review
commit bbc4fa77b0
9 changed files with 30 additions and 31 deletions

View File

@ -30,7 +30,7 @@ import java.util.Map;
/** Secondary index schemas for changes. */ /** Secondary index schemas for changes. */
public class ChangeSchemas { public class ChangeSchemas {
@SuppressWarnings({"unchecked", "deprecation"}) @SuppressWarnings("deprecation")
static final Schema<ChangeData> V1 = release( static final Schema<ChangeData> V1 = release(
ChangeField.LEGACY_ID, ChangeField.LEGACY_ID,
ChangeField.ID, ChangeField.ID,
@ -50,7 +50,7 @@ public class ChangeSchemas {
ChangeField.COMMIT_MESSAGE, ChangeField.COMMIT_MESSAGE,
ChangeField.COMMENT); ChangeField.COMMENT);
@SuppressWarnings({"unchecked", "deprecation"}) @SuppressWarnings("deprecation")
static final Schema<ChangeData> V2 = release( static final Schema<ChangeData> V2 = release(
ChangeField.LEGACY_ID, ChangeField.LEGACY_ID,
ChangeField.ID, ChangeField.ID,
@ -72,7 +72,6 @@ public class ChangeSchemas {
ChangeField.CHANGE, ChangeField.CHANGE,
ChangeField.APPROVAL); ChangeField.APPROVAL);
@SuppressWarnings("unchecked")
static final Schema<ChangeData> V3 = release( static final Schema<ChangeData> V3 = release(
ChangeField.LEGACY_ID, ChangeField.LEGACY_ID,
ChangeField.ID, ChangeField.ID,
@ -97,7 +96,6 @@ public class ChangeSchemas {
// For upgrade to Lucene 4.4.0 index format only. // For upgrade to Lucene 4.4.0 index format only.
static final Schema<ChangeData> V4 = release(V3.getFields().values()); static final Schema<ChangeData> V4 = release(V3.getFields().values());
@SuppressWarnings("unchecked")
static final Schema<ChangeData> V5 = release( static final Schema<ChangeData> V5 = release(
ChangeField.LEGACY_ID, ChangeField.LEGACY_ID,
ChangeField.ID, ChangeField.ID,
@ -124,10 +122,12 @@ public class ChangeSchemas {
return new Schema<ChangeData>(true, fields); return new Schema<ChangeData>(true, fields);
} }
@SafeVarargs
private static Schema<ChangeData> release(FieldDef<ChangeData, ?>... fields) { private static Schema<ChangeData> release(FieldDef<ChangeData, ?>... fields) {
return release(Arrays.asList(fields)); return release(Arrays.asList(fields));
} }
@SafeVarargs
@SuppressWarnings("unused") @SuppressWarnings("unused")
private static Schema<ChangeData> developer(FieldDef<ChangeData, ?>... fields) { private static Schema<ChangeData> developer(FieldDef<ChangeData, ?>... fields) {
return new Schema<ChangeData>(false, Arrays.asList(fields)); return new Schema<ChangeData>(false, Arrays.asList(fields));

View File

@ -27,6 +27,7 @@ public class AndPredicate<T> extends Predicate<T> {
private final List<Predicate<T>> children; private final List<Predicate<T>> children;
private final int cost; private final int cost;
@SafeVarargs
protected AndPredicate(final Predicate<T>... that) { protected AndPredicate(final Predicate<T>... that) {
this(Arrays.asList(that)); this(Arrays.asList(that));
} }

View File

@ -27,6 +27,7 @@ public class OrPredicate<T> extends Predicate<T> {
private final List<Predicate<T>> children; private final List<Predicate<T>> children;
private final int cost; private final int cost;
@SafeVarargs
protected OrPredicate(final Predicate<T>... that) { protected OrPredicate(final Predicate<T>... that) {
this(Arrays.asList(that)); this(Arrays.asList(that));
} }

View File

@ -50,6 +50,7 @@ public abstract class Predicate<T> {
} }
/** Combine the passed predicates into a single AND node. */ /** Combine the passed predicates into a single AND node. */
@SafeVarargs
public static <T> Predicate<T> and(final Predicate<T>... that) { public static <T> Predicate<T> and(final Predicate<T>... that) {
if (that.length == 1) { if (that.length == 1) {
return that[0]; return that[0];
@ -67,6 +68,7 @@ public abstract class Predicate<T> {
} }
/** Combine the passed predicates into a single OR node. */ /** Combine the passed predicates into a single OR node. */
@SafeVarargs
public static <T> Predicate<T> or(final Predicate<T>... that) { public static <T> Predicate<T> or(final Predicate<T>... that) {
if (that.length == 1) { if (that.length == 1) {
return that[0]; return that[0];

View File

@ -97,7 +97,7 @@ public abstract class QueryRewriter<T> {
} }
/** Combine the passed predicates into a single AND node. */ /** Combine the passed predicates into a single AND node. */
public Predicate<T> and(Predicate<T>... that) { public Predicate<T> and(@SuppressWarnings("unchecked") Predicate<T>... that) {
return and(Arrays.asList(that)); return and(Arrays.asList(that));
} }
@ -107,7 +107,7 @@ public abstract class QueryRewriter<T> {
} }
/** Combine the passed predicates into a single OR node. */ /** Combine the passed predicates into a single OR node. */
public Predicate<T> or(Predicate<T>... that) { public Predicate<T> or(@SuppressWarnings("unchecked") Predicate<T>... that) {
return or(Arrays.asList(that)); return or(Arrays.asList(that));
} }

View File

@ -14,7 +14,8 @@
package com.google.gerrit.server.query; package com.google.gerrit.server.query;
import java.util.Arrays; import com.google.common.collect.ImmutableList;
import java.util.Collection; import java.util.Collection;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
@ -24,10 +25,10 @@ public abstract class RewritePredicate<T> extends Predicate<T> {
private String name = getClass().getSimpleName(); private String name = getClass().getSimpleName();
private List<Predicate<T>> children = Collections.emptyList(); private List<Predicate<T>> children = Collections.emptyList();
protected void init(String name, Predicate<T>... args) { protected void init(String name, @SuppressWarnings("unchecked") Predicate<T>... args) {
this.init = true; this.init = true;
this.name = name; this.name = name;
this.children = Arrays.asList(args); this.children = ImmutableList.copyOf(args);
} }
@Override @Override

View File

@ -14,6 +14,7 @@
package com.google.gerrit.server.query; package com.google.gerrit.server.query;
import static com.google.common.collect.ImmutableList.of;
import static com.google.gerrit.server.query.Predicate.and; import static com.google.gerrit.server.query.Predicate.and;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertFalse;
@ -23,7 +24,6 @@ import static org.junit.Assert.assertTrue;
import org.junit.Test; import org.junit.Test;
import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
@ -70,23 +70,23 @@ public class AndPredicateTest {
n.getChildren().clear(); n.getChildren().clear();
} catch (RuntimeException e) { } catch (RuntimeException e) {
} }
assertChildren("clear", n, list(a, b)); assertChildren("clear", n, of(a, b));
try { try {
n.getChildren().remove(0); n.getChildren().remove(0);
} catch (RuntimeException e) { } catch (RuntimeException e) {
} }
assertChildren("remove(0)", n, list(a, b)); assertChildren("remove(0)", n, of(a, b));
try { try {
n.getChildren().iterator().remove(); n.getChildren().iterator().remove();
} catch (RuntimeException e) { } catch (RuntimeException e) {
} }
assertChildren("remove(0)", n, list(a, b)); assertChildren("remove(0)", n, of(a, b));
} }
private static void assertChildren(String o, Predicate<String> p, private static void assertChildren(String o, Predicate<String> p,
final List<Predicate<String>> l) { List<? extends Predicate<String>> l) {
assertEquals(o + " did not affect child", l, p.getChildren()); assertEquals(o + " did not affect child", l, p.getChildren());
} }
@ -134,8 +134,8 @@ public class AndPredicateTest {
final TestPredicate a = f("author", "alice"); final TestPredicate a = f("author", "alice");
final TestPredicate b = f("author", "bob"); final TestPredicate b = f("author", "bob");
final TestPredicate c = f("author", "charlie"); final TestPredicate c = f("author", "charlie");
final List<Predicate<String>> s2 = list(a, b); final List<TestPredicate> s2 = of(a, b);
final List<Predicate<String>> s3 = list(a, b, c); final List<TestPredicate> s3 = of(a, b, c);
final Predicate<String> n2 = and(a, b); final Predicate<String> n2 = and(a, b);
assertNotSame(n2, n2.copy(s2)); assertNotSame(n2, n2.copy(s2));
@ -148,8 +148,4 @@ public class AndPredicateTest {
assertEquals("Need at least two predicates", e.getMessage()); assertEquals("Need at least two predicates", e.getMessage());
} }
} }
private static List<Predicate<String>> list(final Predicate<String>... predicates) {
return Arrays.asList(predicates);
}
} }

View File

@ -14,6 +14,7 @@
package com.google.gerrit.server.query; package com.google.gerrit.server.query;
import static com.google.common.collect.ImmutableList.of;
import static com.google.gerrit.server.query.Predicate.or; import static com.google.gerrit.server.query.Predicate.or;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertFalse;
@ -23,7 +24,6 @@ import static org.junit.Assert.assertTrue;
import org.junit.Test; import org.junit.Test;
import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
@ -70,23 +70,23 @@ public class OrPredicateTest {
n.getChildren().clear(); n.getChildren().clear();
} catch (RuntimeException e) { } catch (RuntimeException e) {
} }
assertChildren("clear", n, list(a, b)); assertChildren("clear", n, of(a, b));
try { try {
n.getChildren().remove(0); n.getChildren().remove(0);
} catch (RuntimeException e) { } catch (RuntimeException e) {
} }
assertChildren("remove(0)", n, list(a, b)); assertChildren("remove(0)", n, of(a, b));
try { try {
n.getChildren().iterator().remove(); n.getChildren().iterator().remove();
} catch (RuntimeException e) { } catch (RuntimeException e) {
} }
assertChildren("remove(0)", n, list(a, b)); assertChildren("remove(0)", n, of(a, b));
} }
private static void assertChildren(String o, Predicate<String> p, private static void assertChildren(String o, Predicate<String> p,
final List<Predicate<String>> l) { List<? extends Predicate<String>> l) {
assertEquals(o + " did not affect child", l, p.getChildren()); assertEquals(o + " did not affect child", l, p.getChildren());
} }
@ -134,8 +134,8 @@ public class OrPredicateTest {
final TestPredicate a = f("author", "alice"); final TestPredicate a = f("author", "alice");
final TestPredicate b = f("author", "bob"); final TestPredicate b = f("author", "bob");
final TestPredicate c = f("author", "charlie"); final TestPredicate c = f("author", "charlie");
final List<Predicate<String>> s2 = list(a, b); final List<TestPredicate> s2 = of(a, b);
final List<Predicate<String>> s3 = list(a, b, c); final List<TestPredicate> s3 = of(a, b, c);
final Predicate<String> n2 = or(a, b); final Predicate<String> n2 = or(a, b);
assertNotSame(n2, n2.copy(s2)); assertNotSame(n2, n2.copy(s2));
@ -148,8 +148,4 @@ public class OrPredicateTest {
assertEquals("Need at least two predicates", e.getMessage()); assertEquals("Need at least two predicates", e.getMessage());
} }
} }
private static <T> List<Predicate<T>> list(final Predicate<T>... predicates) {
return Arrays.asList(predicates);
}
} }

View File

@ -404,6 +404,7 @@ public class SshDaemon extends SshServer implements SshInfo, LifecycleListener {
new HMACSHA196.Factory())); new HMACSHA196.Factory()));
} }
@SafeVarargs
private static <T> List<NamedFactory<T>> filter(final Config cfg, private static <T> List<NamedFactory<T>> filter(final Config cfg,
final String key, final NamedFactory<T>... avail) { final String key, final NamedFactory<T>... avail) {
final ArrayList<NamedFactory<T>> def = new ArrayList<NamedFactory<T>>(); final ArrayList<NamedFactory<T>> def = new ArrayList<NamedFactory<T>>();
@ -460,6 +461,7 @@ public class SshDaemon extends SshServer implements SshInfo, LifecycleListener {
return def; return def;
} }
@SafeVarargs
private static <T> NamedFactory<T> find(final String name, private static <T> NamedFactory<T> find(final String name,
final NamedFactory<T>... avail) { final NamedFactory<T>... avail) {
for (final NamedFactory<T> n : avail) { for (final NamedFactory<T> n : avail) {