mirror of https://github.com/apache/druid.git
Find duplicate lines with checkstyle; enable some duplicate inspections in IntelliJ (#6558)
Not putting this to 0.13 milestone because the found bugs are not critical (one is a harmless DI config duplicate, and another is in a benchmark. Change in `DumpSegment` is just an indentation change.
This commit is contained in:
parent
03df481c9c
commit
887c645675
|
@ -29,6 +29,11 @@
|
||||||
<inspection_tool class="Contract" enabled="true" level="ERROR" enabled_by_default="true" />
|
<inspection_tool class="Contract" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
<inspection_tool class="CopyConstructorMissesField" enabled="true" level="ERROR" enabled_by_default="true" />
|
<inspection_tool class="CopyConstructorMissesField" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
<inspection_tool class="CovariantEquals" enabled="true" level="ERROR" enabled_by_default="true" />
|
<inspection_tool class="CovariantEquals" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
|
<inspection_tool class="DuplicateBooleanBranch" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
|
<inspection_tool class="DuplicateCondition" enabled="true" level="ERROR" enabled_by_default="true">
|
||||||
|
<option name="ignoreSideEffectConditions" value="true" />
|
||||||
|
</inspection_tool>
|
||||||
|
<inspection_tool class="DuplicateThrows" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
<inspection_tool class="EmptyInitializer" enabled="true" level="ERROR" enabled_by_default="true" />
|
<inspection_tool class="EmptyInitializer" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
<inspection_tool class="EmptyStatementBody" enabled="true" level="WARNING" enabled_by_default="true">
|
<inspection_tool class="EmptyStatementBody" enabled="true" level="WARNING" enabled_by_default="true">
|
||||||
<option name="m_reportEmptyBlocks" value="true" />
|
<option name="m_reportEmptyBlocks" value="true" />
|
||||||
|
@ -71,6 +76,7 @@
|
||||||
<inspection_tool class="InvalidComparatorMethodReference" enabled="true" level="ERROR" enabled_by_default="true" />
|
<inspection_tool class="InvalidComparatorMethodReference" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
<inspection_tool class="IteratorHasNextCallsIteratorNext" enabled="true" level="ERROR" enabled_by_default="true" />
|
<inspection_tool class="IteratorHasNextCallsIteratorNext" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
<inspection_tool class="IteratorNextDoesNotThrowNoSuchElementException" enabled="true" level="WARNING" enabled_by_default="true" />
|
<inspection_tool class="IteratorNextDoesNotThrowNoSuchElementException" enabled="true" level="WARNING" enabled_by_default="true" />
|
||||||
|
<inspection_tool class="JsonDuplicatePropertyKeys" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
<inspection_tool class="JsonStandardCompliance" enabled="true" level="WARNING" enabled_by_default="true" />
|
<inspection_tool class="JsonStandardCompliance" enabled="true" level="WARNING" enabled_by_default="true" />
|
||||||
<inspection_tool class="LengthOneStringInIndexOf" enabled="true" level="ERROR" enabled_by_default="true" />
|
<inspection_tool class="LengthOneStringInIndexOf" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
<inspection_tool class="ListIndexOfReplaceableByContains" enabled="true" level="ERROR" enabled_by_default="true" />
|
<inspection_tool class="ListIndexOfReplaceableByContains" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
|
@ -80,6 +86,8 @@
|
||||||
</inspection_tool>
|
</inspection_tool>
|
||||||
<inspection_tool class="MalformedRegex" enabled="true" level="ERROR" enabled_by_default="true" />
|
<inspection_tool class="MalformedRegex" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
<inspection_tool class="MathRandomCastToInt" enabled="true" level="ERROR" enabled_by_default="true" />
|
<inspection_tool class="MathRandomCastToInt" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
|
<inspection_tool class="MavenDuplicateDependenciesInspection" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
|
<inspection_tool class="MavenDuplicatePluginInspection" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
<inspection_tool class="MavenModelInspection" enabled="true" level="WARNING" enabled_by_default="true" />
|
<inspection_tool class="MavenModelInspection" enabled="true" level="WARNING" enabled_by_default="true" />
|
||||||
<inspection_tool class="MismatchedArrayReadWrite" enabled="true" level="ERROR" enabled_by_default="true" />
|
<inspection_tool class="MismatchedArrayReadWrite" enabled="true" level="ERROR" enabled_by_default="true" />
|
||||||
<inspection_tool class="MismatchedCollectionQueryUpdate" enabled="true" level="ERROR" enabled_by_default="true">
|
<inspection_tool class="MismatchedCollectionQueryUpdate" enabled="true" level="ERROR" enabled_by_default="true">
|
||||||
|
|
|
@ -282,7 +282,9 @@ public class SearchBenchmark
|
||||||
|
|
||||||
private static SearchQueryBuilder basicD(final BenchmarkSchemaInfo basicSchema)
|
private static SearchQueryBuilder basicD(final BenchmarkSchemaInfo basicSchema)
|
||||||
{
|
{
|
||||||
final QuerySegmentSpec intervalSpec = new MultipleIntervalSegmentSpec(Collections.singletonList(basicSchema.getDataInterval()));
|
final QuerySegmentSpec intervalSpec = new MultipleIntervalSegmentSpec(
|
||||||
|
Collections.singletonList(basicSchema.getDataInterval())
|
||||||
|
);
|
||||||
|
|
||||||
final List<String> dimUniformFilterVals = new ArrayList<>();
|
final List<String> dimUniformFilterVals = new ArrayList<>();
|
||||||
final int resultNum = (int) (100000 * 0.1);
|
final int resultNum = (int) (100000 * 0.1);
|
||||||
|
@ -296,9 +298,6 @@ public class SearchBenchmark
|
||||||
dimFilters.add(new InDimFilter(dimName, dimUniformFilterVals, null));
|
dimFilters.add(new InDimFilter(dimName, dimUniformFilterVals, null));
|
||||||
dimFilters.add(new SelectorDimFilter(dimName, "3", null));
|
dimFilters.add(new SelectorDimFilter(dimName, "3", null));
|
||||||
dimFilters.add(new BoundDimFilter(dimName, "100", "10000", true, true, true, null, null));
|
dimFilters.add(new BoundDimFilter(dimName, "100", "10000", true, true, true, null, null));
|
||||||
dimFilters.add(new InDimFilter(dimName, dimUniformFilterVals, null));
|
|
||||||
dimFilters.add(new InDimFilter(dimName, dimUniformFilterVals, null));
|
|
||||||
dimFilters.add(new InDimFilter(dimName, dimUniformFilterVals, null));
|
|
||||||
|
|
||||||
return Druids.newSearchQueryBuilder()
|
return Druids.newSearchQueryBuilder()
|
||||||
.dataSource("blah")
|
.dataSource("blah")
|
||||||
|
|
|
@ -50,13 +50,16 @@
|
||||||
|
|
||||||
<suppress checks="Indentation" files="[\\/]target[\\/]generated-test-sources[\\/]" />
|
<suppress checks="Indentation" files="[\\/]target[\\/]generated-test-sources[\\/]" />
|
||||||
<suppress checks="Indentation" files="ProtoTestEventWrapper.java" />
|
<suppress checks="Indentation" files="ProtoTestEventWrapper.java" />
|
||||||
<suppress checks="Regex" files="ProtoTestEventWrapper.java" />
|
<suppress checks="Regexp" id="argumentLineBreaking" files="ProtoTestEventWrapper.java" />
|
||||||
|
|
||||||
<suppress checks="OneStatementPerLine" files="[\\/]target[\\/]generated-test-sources[\\/]" />
|
<suppress checks="OneStatementPerLine" files="[\\/]target[\\/]generated-test-sources[\\/]" />
|
||||||
|
|
||||||
<!-- extendedset is a fork of Alessandro Colantonio's CONCISE (COmpressed 'N' Composable Integer SEt) repository and licensed to ASF under a CLA is not true. -->
|
<!-- extendedset is a fork of Alessandro Colantonio's CONCISE (COmpressed 'N' Composable Integer SEt) repository
|
||||||
|
and licensed to ASF under a CLA is not true. -->
|
||||||
<suppress checks="Header" files="[\\/]extendedset[\\/]" />
|
<suppress checks="Header" files="[\\/]extendedset[\\/]" />
|
||||||
|
|
||||||
|
<suppress checks="Regexp" id="duplicateLine" files="[\\/]src[\\/]test[\\/]" />
|
||||||
|
|
||||||
<!-- See https://github.com/checkstyle/checkstyle/issues/5510 and the ImportOrder definition in checkstyle.xml -->
|
<!-- See https://github.com/checkstyle/checkstyle/issues/5510 and the ImportOrder definition in checkstyle.xml -->
|
||||||
<suppress checks="ImportOrder" message="^'java\..*'.*" />
|
<suppress checks="ImportOrder" message="^'java\..*'.*" />
|
||||||
|
|
||||||
|
|
|
@ -221,6 +221,7 @@
|
||||||
</module>
|
</module>
|
||||||
|
|
||||||
<module name="Regexp">
|
<module name="Regexp">
|
||||||
|
<property name="id" value="argumentLineBreaking"/>
|
||||||
<property
|
<property
|
||||||
name="format"
|
name="format"
|
||||||
value='(?<!ImmutableMap.of|Types.mapOf|orderedMap|makeSelectResults|makeListOfPairs)\(\s*\n +([^,\n\(\{"</]+|[^,\n\(\{" /]+> [a-zA-Z0-9_]+)\, ++[^,\n/]+'
|
value='(?<!ImmutableMap.of|Types.mapOf|orderedMap|makeSelectResults|makeListOfPairs)\(\s*\n +([^,\n\(\{"</]+|[^,\n\(\{" /]+> [a-zA-Z0-9_]+)\, ++[^,\n/]+'
|
||||||
|
@ -277,5 +278,12 @@ If you encouter a map-like or a pair-accepting method that is reported by this&#
|
||||||
checkstyle rule, you should add it as an exception in the corresponding rule in
|
checkstyle rule, you should add it as an exception in the corresponding rule in
|
||||||
codestyle/checkstyle.xml. "/>
|
codestyle/checkstyle.xml. "/>
|
||||||
</module>
|
</module>
|
||||||
|
|
||||||
|
<module name="Regexp">
|
||||||
|
<property name="id" value="duplicateLine"/>
|
||||||
|
<property name="format" value="^(.*;)(\r?\n\1)+$"/>
|
||||||
|
<property name="illegalPattern" value="true"/>
|
||||||
|
<property name="message" value="Duplicate line"/>
|
||||||
|
</module>
|
||||||
</module>
|
</module>
|
||||||
</module>
|
</module>
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
package org.apache.druid.jackson;
|
package org.apache.druid.jackson;
|
||||||
|
|
||||||
import com.fasterxml.jackson.core.JsonParser;
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
|
||||||
import com.fasterxml.jackson.databind.DeserializationContext;
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
import com.fasterxml.jackson.databind.deser.std.StdScalarDeserializer;
|
import com.fasterxml.jackson.databind.deser.std.StdScalarDeserializer;
|
||||||
|
|
||||||
|
@ -39,7 +38,7 @@ public class CommaListJoinDeserializer extends StdScalarDeserializer<List<String
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<String> deserialize(JsonParser jsonParser, DeserializationContext deserializationContext)
|
public List<String> deserialize(JsonParser jsonParser, DeserializationContext deserializationContext)
|
||||||
throws IOException, JsonProcessingException
|
throws IOException
|
||||||
{
|
{
|
||||||
return Arrays.asList(jsonParser.getText().split(","));
|
return Arrays.asList(jsonParser.getText().split(","));
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,6 @@
|
||||||
|
|
||||||
package org.apache.druid.jackson;
|
package org.apache.druid.jackson;
|
||||||
|
|
||||||
import com.fasterxml.jackson.core.JsonGenerationException;
|
|
||||||
import com.fasterxml.jackson.core.JsonGenerator;
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
import com.fasterxml.jackson.databind.SerializerProvider;
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
import com.fasterxml.jackson.databind.ser.std.StdScalarSerializer;
|
import com.fasterxml.jackson.databind.ser.std.StdScalarSerializer;
|
||||||
|
@ -40,8 +39,7 @@ public class CommaListJoinSerializer extends StdScalarSerializer<List<String>>
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void serialize(List<String> value, JsonGenerator jgen, SerializerProvider provider)
|
public void serialize(List<String> value, JsonGenerator jgen, SerializerProvider provider) throws IOException
|
||||||
throws IOException, JsonGenerationException
|
|
||||||
{
|
{
|
||||||
jgen.writeString(joiner.join(value));
|
jgen.writeString(joiner.join(value));
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
package org.apache.druid.indexer;
|
package org.apache.druid.indexer;
|
||||||
|
|
||||||
import com.fasterxml.jackson.core.JsonParser;
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
|
||||||
import com.fasterxml.jackson.core.JsonToken;
|
import com.fasterxml.jackson.core.JsonToken;
|
||||||
import com.fasterxml.jackson.databind.DeserializationContext;
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
|
@ -109,8 +108,7 @@ public class TaskStatusPlusTest
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public DateTime deserialize(JsonParser jp, DeserializationContext ctxt)
|
public DateTime deserialize(JsonParser jp, DeserializationContext ctxt) throws IOException
|
||||||
throws IOException, JsonProcessingException
|
|
||||||
{
|
{
|
||||||
JsonToken t = jp.getCurrentToken();
|
JsonToken t = jp.getCurrentToken();
|
||||||
if (t == JsonToken.VALUE_NUMBER_INT) {
|
if (t == JsonToken.VALUE_NUMBER_INT) {
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
package org.apache.druid.query.aggregation.datasketches.tuple;
|
package org.apache.druid.query.aggregation.datasketches.tuple;
|
||||||
|
|
||||||
import com.fasterxml.jackson.core.JsonGenerator;
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
|
||||||
import com.fasterxml.jackson.databind.JsonSerializer;
|
import com.fasterxml.jackson.databind.JsonSerializer;
|
||||||
import com.fasterxml.jackson.databind.SerializerProvider;
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
import com.yahoo.sketches.tuple.ArrayOfDoublesSketch;
|
import com.yahoo.sketches.tuple.ArrayOfDoublesSketch;
|
||||||
|
@ -35,7 +34,7 @@ public class ArrayOfDoublesSketchJsonSerializer extends JsonSerializer<ArrayOfDo
|
||||||
final ArrayOfDoublesSketch sketch,
|
final ArrayOfDoublesSketch sketch,
|
||||||
final JsonGenerator generator,
|
final JsonGenerator generator,
|
||||||
final SerializerProvider provider
|
final SerializerProvider provider
|
||||||
) throws IOException, JsonProcessingException
|
) throws IOException
|
||||||
{
|
{
|
||||||
generator.writeBinary(sketch.toByteArray());
|
generator.writeBinary(sketch.toByteArray());
|
||||||
}
|
}
|
||||||
|
|
|
@ -276,12 +276,7 @@ public class JdbcExtractionNamespaceTest
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
Closeable closeable = () -> {
|
try (final Closeable ignore = () -> setupFuture.cancel(true)) {
|
||||||
if (!setupFuture.isDone() && !setupFuture.cancel(true) && !setupFuture.isDone()) {
|
|
||||||
throw new IOException("Unable to stop future");
|
|
||||||
}
|
|
||||||
};
|
|
||||||
try (final Closeable c = closeable) {
|
|
||||||
handleRef = setupFuture.get(10, TimeUnit.SECONDS);
|
handleRef = setupFuture.get(10, TimeUnit.SECONDS);
|
||||||
}
|
}
|
||||||
Assert.assertNotNull(handleRef);
|
Assert.assertNotNull(handleRef);
|
||||||
|
|
|
@ -33,6 +33,5 @@ public class NullHandlingModule implements Module
|
||||||
{
|
{
|
||||||
JsonConfigProvider.bind(binder, "druid.generic", NullValueHandlingConfig.class);
|
JsonConfigProvider.bind(binder, "druid.generic", NullValueHandlingConfig.class);
|
||||||
binder.requestStaticInjection(NullHandling.class);
|
binder.requestStaticInjection(NullHandling.class);
|
||||||
binder.requestStaticInjection(NullHandling.class);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,6 @@ package org.apache.druid.jackson;
|
||||||
|
|
||||||
import com.fasterxml.jackson.core.JsonGenerator;
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
import com.fasterxml.jackson.core.JsonParser;
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
|
||||||
import com.fasterxml.jackson.databind.DeserializationContext;
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
import com.fasterxml.jackson.databind.JsonDeserializer;
|
import com.fasterxml.jackson.databind.JsonDeserializer;
|
||||||
import com.fasterxml.jackson.databind.JsonSerializer;
|
import com.fasterxml.jackson.databind.JsonSerializer;
|
||||||
|
@ -70,8 +69,7 @@ public class DruidDefaultSerializersModule extends SimpleModule
|
||||||
DateTimeZone dateTimeZone,
|
DateTimeZone dateTimeZone,
|
||||||
JsonGenerator jsonGenerator,
|
JsonGenerator jsonGenerator,
|
||||||
SerializerProvider serializerProvider
|
SerializerProvider serializerProvider
|
||||||
)
|
) throws IOException
|
||||||
throws IOException, JsonProcessingException
|
|
||||||
{
|
{
|
||||||
jsonGenerator.writeString(dateTimeZone.getID());
|
jsonGenerator.writeString(dateTimeZone.getID());
|
||||||
}
|
}
|
||||||
|
@ -83,7 +81,7 @@ public class DruidDefaultSerializersModule extends SimpleModule
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void serialize(Sequence value, final JsonGenerator jgen, SerializerProvider provider)
|
public void serialize(Sequence value, final JsonGenerator jgen, SerializerProvider provider)
|
||||||
throws IOException, JsonProcessingException
|
throws IOException
|
||||||
{
|
{
|
||||||
jgen.writeStartArray();
|
jgen.writeStartArray();
|
||||||
value.accumulate(
|
value.accumulate(
|
||||||
|
@ -113,7 +111,7 @@ public class DruidDefaultSerializersModule extends SimpleModule
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void serialize(Yielder yielder, final JsonGenerator jgen, SerializerProvider provider)
|
public void serialize(Yielder yielder, final JsonGenerator jgen, SerializerProvider provider)
|
||||||
throws IOException, JsonProcessingException
|
throws IOException
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
jgen.writeStartArray();
|
jgen.writeStartArray();
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
package org.apache.druid.jackson;
|
package org.apache.druid.jackson;
|
||||||
|
|
||||||
import com.fasterxml.jackson.core.JsonParser;
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
|
||||||
import com.fasterxml.jackson.core.JsonToken;
|
import com.fasterxml.jackson.core.JsonToken;
|
||||||
import com.fasterxml.jackson.databind.DeserializationContext;
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
import com.fasterxml.jackson.databind.JsonDeserializer;
|
import com.fasterxml.jackson.databind.JsonDeserializer;
|
||||||
|
@ -71,7 +70,7 @@ class JodaStuff
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Interval deserialize(JsonParser jsonParser, DeserializationContext deserializationContext)
|
public Interval deserialize(JsonParser jsonParser, DeserializationContext deserializationContext)
|
||||||
throws IOException, JsonProcessingException
|
throws IOException
|
||||||
{
|
{
|
||||||
return Intervals.of(jsonParser.getText());
|
return Intervals.of(jsonParser.getText());
|
||||||
}
|
}
|
||||||
|
@ -94,8 +93,7 @@ class JodaStuff
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public DateTime deserialize(JsonParser jp, DeserializationContext ctxt)
|
public DateTime deserialize(JsonParser jp, DeserializationContext ctxt) throws IOException
|
||||||
throws IOException, JsonProcessingException
|
|
||||||
{
|
{
|
||||||
JsonToken t = jp.getCurrentToken();
|
JsonToken t = jp.getCurrentToken();
|
||||||
if (t == JsonToken.VALUE_NUMBER_INT) {
|
if (t == JsonToken.VALUE_NUMBER_INT) {
|
||||||
|
|
|
@ -343,50 +343,49 @@ public class DumpSegment extends GuiceRunnable
|
||||||
@Override
|
@Override
|
||||||
public Object apply(final OutputStream out)
|
public Object apply(final OutputStream out)
|
||||||
{
|
{
|
||||||
try {
|
try (final JsonGenerator jg = objectMapper.getFactory().createGenerator(out)) {
|
||||||
final JsonGenerator jg = objectMapper.getFactory().createGenerator(out);
|
|
||||||
|
|
||||||
jg.writeStartObject();
|
|
||||||
jg.writeObjectField("bitmapSerdeFactory", bitmapSerdeFactory);
|
|
||||||
jg.writeFieldName("bitmaps");
|
|
||||||
jg.writeStartObject();
|
jg.writeStartObject();
|
||||||
|
{
|
||||||
|
jg.writeObjectField("bitmapSerdeFactory", bitmapSerdeFactory);
|
||||||
|
jg.writeFieldName("bitmaps");
|
||||||
|
jg.writeStartObject();
|
||||||
|
{
|
||||||
|
for (final String columnName : columnNames) {
|
||||||
|
final ColumnHolder columnHolder = index.getColumnHolder(columnName);
|
||||||
|
final BitmapIndex bitmapIndex = columnHolder.getBitmapIndex();
|
||||||
|
|
||||||
for (final String columnName : columnNames) {
|
if (bitmapIndex == null) {
|
||||||
final ColumnHolder columnHolder = index.getColumnHolder(columnName);
|
jg.writeNullField(columnName);
|
||||||
final BitmapIndex bitmapIndex = columnHolder.getBitmapIndex();
|
} else {
|
||||||
|
jg.writeFieldName(columnName);
|
||||||
if (bitmapIndex == null) {
|
jg.writeStartObject();
|
||||||
jg.writeNullField(columnName);
|
for (int i = 0; i < bitmapIndex.getCardinality(); i++) {
|
||||||
} else {
|
String val = NullHandling.nullToEmptyIfNeeded(bitmapIndex.getValue(i));
|
||||||
jg.writeFieldName(columnName);
|
if (val != null) {
|
||||||
jg.writeStartObject();
|
final ImmutableBitmap bitmap = bitmapIndex.getBitmap(i);
|
||||||
for (int i = 0; i < bitmapIndex.getCardinality(); i++) {
|
if (decompressBitmaps) {
|
||||||
String val = NullHandling.nullToEmptyIfNeeded(bitmapIndex.getValue(i));
|
jg.writeStartArray();
|
||||||
if (val != null) {
|
final IntIterator iterator = bitmap.iterator();
|
||||||
final ImmutableBitmap bitmap = bitmapIndex.getBitmap(i);
|
while (iterator.hasNext()) {
|
||||||
if (decompressBitmaps) {
|
final int rowNum = iterator.next();
|
||||||
jg.writeStartArray();
|
jg.writeNumber(rowNum);
|
||||||
final IntIterator iterator = bitmap.iterator();
|
}
|
||||||
while (iterator.hasNext()) {
|
jg.writeEndArray();
|
||||||
final int rowNum = iterator.next();
|
} else {
|
||||||
jg.writeNumber(rowNum);
|
byte[] bytes = bitmapSerdeFactory.getObjectStrategy().toBytes(bitmap);
|
||||||
}
|
if (bytes != null) {
|
||||||
jg.writeEndArray();
|
jg.writeBinary(bytes);
|
||||||
} else {
|
}
|
||||||
byte[] bytes = bitmapSerdeFactory.getObjectStrategy().toBytes(bitmap);
|
}
|
||||||
if (bytes != null) {
|
|
||||||
jg.writeBinary(bytes);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
jg.writeEndObject();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
jg.writeEndObject();
|
|
||||||
}
|
}
|
||||||
|
jg.writeEndObject();
|
||||||
}
|
}
|
||||||
|
|
||||||
jg.writeEndObject();
|
jg.writeEndObject();
|
||||||
jg.writeEndObject();
|
|
||||||
jg.close();
|
|
||||||
}
|
}
|
||||||
catch (IOException e) {
|
catch (IOException e) {
|
||||||
throw Throwables.propagate(e);
|
throw Throwables.propagate(e);
|
||||||
|
|
Loading…
Reference in New Issue