aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sonar-core/src/main/java/org/sonar/core/util/ProtobufJsonFormat.java224
-rw-r--r--sonar-core/src/test/gen-java/org/sonar/core/test/Test.java2268
-rw-r--r--sonar-core/src/test/java/org/sonar/core/util/ProtobufJsonFormatTest.java110
-rw-r--r--sonar-core/src/test/java/org/sonar/core/util/ProtobufTest.java12
-rw-r--r--sonar-core/src/test/protobuf/test.proto32
5 files changed, 2050 insertions, 596 deletions
diff --git a/sonar-core/src/main/java/org/sonar/core/util/ProtobufJsonFormat.java b/sonar-core/src/main/java/org/sonar/core/util/ProtobufJsonFormat.java
index e156c17f432..30bc9bccd69 100644
--- a/sonar-core/src/main/java/org/sonar/core/util/ProtobufJsonFormat.java
+++ b/sonar-core/src/main/java/org/sonar/core/util/ProtobufJsonFormat.java
@@ -19,15 +19,54 @@
*/
package org.sonar.core.util;
+import com.google.common.base.Preconditions;
+import com.google.common.collect.BiMap;
+import com.google.common.collect.HashBiMap;
import com.google.protobuf.Descriptors;
import com.google.protobuf.Message;
+import java.io.StringWriter;
+import java.util.ArrayList;
import java.util.Collection;
+import java.util.HashMap;
+import java.util.List;
import java.util.Map;
import org.sonar.api.utils.text.JsonWriter;
/**
* Converts a Protocol Buffers message to JSON. Unknown fields, binary fields, (deprecated) groups
- * and maps are not supported.
+ * and maps are not supported. Absent fields are ignored, so it's possible to distinguish
+ * null strings (field is absent) and empty strings (field is present with value {@code ""}).
+ * <p/>
+ * <h2>Empty Arrays</h2>
+ * Protobuf does not make the difference between absent arrays and empty arrays (size is zero).
+ * The consequence is that arrays are always output in JSON. Empty arrays are converted to {@code []}.
+ * <p/>
+ * A workaround is implemented in {@link ProtobufJsonFormat} to not generate absent arrays into JSON document.
+ * A boolean field is used to declare if the related repeated field (the array) is present or not. The
+ * name of the boolean field must be the array field name suffixed with "PresentIfEmpty". This field is "for internal
+ * use" and is not generated into JSON document. It is ignored when the array is not empty.
+ *
+ * For example:
+ * <pre>
+ * // proto specification
+ * message Response {
+ * optional bool issuesPresentIfEmpty = 1;
+ * repeated Issue issues = 2;
+ * }
+ * </pre>
+ * <pre>
+ * // Java usage
+ *
+ * Response.newBuilder().build();
+ * // output: {}
+ *
+ * Response.newBuilder().setIssuesPresentIfEmpty(true).build();
+ * // output: {"issues": []}
+ *
+ * // no need to set the flag to true when the array is not empty
+ * Response.newBuilder().setIssues(atLeastOneIssues).build();
+ * // output: {"issues": [{...}, {...}]}
+ * </pre>
*/
public class ProtobufJsonFormat {
@@ -35,33 +74,183 @@ public class ProtobufJsonFormat {
// only statics
}
+ private static abstract class MessageField {
+ protected final Descriptors.FieldDescriptor descriptor;
+
+ public MessageField(Descriptors.FieldDescriptor descriptor) {
+ this.descriptor = descriptor;
+ }
+
+ public String getName() {
+ return descriptor.getName();
+ }
+
+ public Descriptors.FieldDescriptor.JavaType getJavaType() {
+ return descriptor.getJavaType();
+ }
+
+ public abstract boolean isRepeated();
+
+ public abstract boolean hasValue(Message message);
+
+ public abstract Object getValue(Message message);
+ }
+
+ private static class MessageNonRepeatedField extends MessageField {
+ public MessageNonRepeatedField(Descriptors.FieldDescriptor descriptor) {
+ super(descriptor);
+ Preconditions.checkArgument(!descriptor.isRepeated());
+ }
+
+ @Override
+ public boolean isRepeated() {
+ return false;
+ }
+
+ @Override
+ public boolean hasValue(Message message) {
+ return message.hasField(descriptor);
+ }
+
+ @Override
+ public Object getValue(Message message) {
+ return message.getField(descriptor);
+ }
+ }
+
+ private static class MessageRepeatedField extends MessageField {
+ public MessageRepeatedField(Descriptors.FieldDescriptor descriptor) {
+ super(descriptor);
+ Preconditions.checkArgument(descriptor.isRepeated());
+ }
+
+ @Override
+ public boolean isRepeated() {
+ return true;
+ }
+
+ @Override
+ public boolean hasValue(Message message) {
+ return true;
+ }
+
+ @Override
+ public Object getValue(Message message) {
+ return message.getField(descriptor);
+ }
+ }
+
+ private static class MessageNullableRepeatedField extends MessageField {
+ private final Descriptors.FieldDescriptor booleanDesc;
+
+ public MessageNullableRepeatedField(Descriptors.FieldDescriptor booleanDesc, Descriptors.FieldDescriptor arrayDescriptor) {
+ super(arrayDescriptor);
+ Preconditions.checkArgument(arrayDescriptor.isRepeated());
+ Preconditions.checkArgument(booleanDesc.getJavaType() == Descriptors.FieldDescriptor.JavaType.BOOLEAN);
+ this.booleanDesc = booleanDesc;
+ }
+
+ @Override
+ public boolean isRepeated() {
+ return true;
+ }
+
+ @Override
+ public boolean hasValue(Message message) {
+ if (((Collection) message.getField(descriptor)).isEmpty()) {
+ return message.hasField(booleanDesc) && (boolean) message.getField(booleanDesc);
+ }
+ return true;
+ }
+
+ @Override
+ public Object getValue(Message message) {
+ return message.getField(descriptor);
+ }
+ }
+
+ static class MessageJsonDescriptor {
+ private static final Map<Class<? extends Message>, MessageJsonDescriptor> BY_CLASS = new HashMap<>();
+ private final MessageField[] fields;
+
+ private MessageJsonDescriptor(MessageField[] fields) {
+ this.fields = fields;
+ }
+
+ MessageField[] getFields() {
+ return fields;
+ }
+
+ static MessageJsonDescriptor of(Message message) {
+ MessageJsonDescriptor desc = BY_CLASS.get(message.getClass());
+ if (desc == null) {
+ desc = introspect(message);
+ BY_CLASS.put(message.getClass(), desc);
+ }
+ return desc;
+ }
+
+ private static MessageJsonDescriptor introspect(Message message) {
+ List<MessageField> fields = new ArrayList<>();
+ BiMap<Descriptors.FieldDescriptor, Descriptors.FieldDescriptor> repeatedToBoolean = HashBiMap.create();
+ for (Descriptors.FieldDescriptor desc : message.getDescriptorForType().getFields()) {
+ if (desc.isRepeated()) {
+ String booleanName = desc.getName() + "PresentIfEmpty";
+ Descriptors.FieldDescriptor booleanDesc = message.getDescriptorForType().findFieldByName(booleanName);
+ if (booleanDesc != null && booleanDesc.getJavaType() == Descriptors.FieldDescriptor.JavaType.BOOLEAN) {
+ repeatedToBoolean.put(desc, booleanDesc);
+ }
+ }
+ }
+ for (Descriptors.FieldDescriptor descriptor : message.getDescriptorForType().getFields()) {
+ if (descriptor.isRepeated()) {
+ Descriptors.FieldDescriptor booleanDesc = repeatedToBoolean.get(descriptor);
+ if (booleanDesc == null) {
+ fields.add(new MessageRepeatedField(descriptor));
+ } else {
+ fields.add(new MessageNullableRepeatedField(booleanDesc, descriptor));
+ }
+ } else if (!repeatedToBoolean.containsValue(descriptor)) {
+ fields.add(new MessageNonRepeatedField(descriptor));
+ }
+ }
+ return new MessageJsonDescriptor(fields.toArray(new MessageField[fields.size()]));
+ }
+ }
+
public static void write(Message message, JsonWriter writer) {
+ writer.setSerializeNulls(false).setSerializeEmptys(true);
writer.beginObject();
writeMessage(message, writer);
writer.endObject();
}
- private static void writeMessage(Message message, JsonWriter writer) {
- for (Map.Entry<Descriptors.FieldDescriptor, Object> entry : message.getAllFields().entrySet()) {
- writeField(entry.getKey(), entry.getValue(), writer);
- }
+ public static String toJson(Message message) {
+ StringWriter json = new StringWriter();
+ JsonWriter jsonWriter = JsonWriter.of(json);
+ write(message, jsonWriter);
+ return json.toString();
}
- private static void writeField(Descriptors.FieldDescriptor field, Object value, JsonWriter writer) {
- writer.name(field.getName());
- if (field.isRepeated()) {
- // Repeated field. Print each element.
- writer.beginArray();
- for (Object o : (Collection) value) {
- writeFieldValue(field, o, writer);
+ private static void writeMessage(Message message, JsonWriter writer) {
+ MessageJsonDescriptor fields = MessageJsonDescriptor.of(message);
+ for (MessageField field : fields.getFields()) {
+ if (field.hasValue(message)) {
+ writer.name(field.getName());
+ if (field.isRepeated()) {
+ writer.beginArray();
+ for (Object o : (Collection) field.getValue(message)) {
+ writeFieldValue(field, o, writer);
+ }
+ writer.endArray();
+ } else {
+ writeFieldValue(field, field.getValue(message), writer);
+ }
}
- writer.endArray();
- } else {
- writeFieldValue(field, value, writer);
}
}
- private static void writeFieldValue(Descriptors.FieldDescriptor field, Object value, JsonWriter writer) {
+ private static void writeFieldValue(MessageField field, Object value, JsonWriter writer) {
switch (field.getJavaType()) {
case INT:
writer.value((Integer) value);
@@ -78,8 +267,6 @@ public class ProtobufJsonFormat {
case STRING:
writer.value((String) value);
break;
- case BYTE_STRING:
- throw new IllegalStateException(String.format("JSON format does not support the binary field '%s'", field.getName()));
case ENUM:
writer.value(((Descriptors.EnumValueDescriptor) value).getName());
break;
@@ -89,6 +276,7 @@ public class ProtobufJsonFormat {
writer.endObject();
break;
default:
+ throw new IllegalStateException(String.format("JSON format does not support type '%s' of field '%s'", field.getJavaType(), field.getName()));
}
}
}
diff --git a/sonar-core/src/test/gen-java/org/sonar/core/test/Test.java b/sonar-core/src/test/gen-java/org/sonar/core/test/Test.java
index 18826a8f16d..c687af5b8b8 100644
--- a/sonar-core/src/test/gen-java/org/sonar/core/test/Test.java
+++ b/sonar-core/src/test/gen-java/org/sonar/core/test/Test.java
@@ -104,125 +104,679 @@ public final class Test {
com.google.protobuf.MessageOrBuilder {
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string label = 1;</code>
*/
- boolean hasAString();
+ boolean hasLabel();
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string label = 1;</code>
*/
- java.lang.String getAString();
+ java.lang.String getLabel();
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string label = 1;</code>
*/
com.google.protobuf.ByteString
- getAStringBytes();
+ getLabelBytes();
/**
- * <code>optional int32 anInt = 2;</code>
+ * <code>optional int32 line = 2;</code>
*/
- boolean hasAnInt();
+ boolean hasLine();
/**
- * <code>optional int32 anInt = 2;</code>
+ * <code>optional int32 line = 2;</code>
*/
- int getAnInt();
+ int getLine();
+ }
+ /**
+ * Protobuf type {@code Fake}
+ */
+ public static final class Fake extends
+ com.google.protobuf.GeneratedMessage implements
+ // @@protoc_insertion_point(message_implements:Fake)
+ FakeOrBuilder {
+ // Use Fake.newBuilder() to construct.
+ private Fake(com.google.protobuf.GeneratedMessage.Builder<?> builder) {
+ super(builder);
+ this.unknownFields = builder.getUnknownFields();
+ }
+ private Fake(boolean noInit) { this.unknownFields = com.google.protobuf.UnknownFieldSet.getDefaultInstance(); }
+
+ private static final Fake defaultInstance;
+ public static Fake getDefaultInstance() {
+ return defaultInstance;
+ }
+
+ public Fake getDefaultInstanceForType() {
+ return defaultInstance;
+ }
+
+ private final com.google.protobuf.UnknownFieldSet unknownFields;
+ @java.lang.Override
+ public final com.google.protobuf.UnknownFieldSet
+ getUnknownFields() {
+ return this.unknownFields;
+ }
+ private Fake(
+ com.google.protobuf.CodedInputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ initFields();
+ int mutable_bitField0_ = 0;
+ com.google.protobuf.UnknownFieldSet.Builder unknownFields =
+ com.google.protobuf.UnknownFieldSet.newBuilder();
+ try {
+ boolean done = false;
+ while (!done) {
+ int tag = input.readTag();
+ switch (tag) {
+ case 0:
+ done = true;
+ break;
+ default: {
+ if (!parseUnknownField(input, unknownFields,
+ extensionRegistry, tag)) {
+ done = true;
+ }
+ break;
+ }
+ case 10: {
+ com.google.protobuf.ByteString bs = input.readBytes();
+ bitField0_ |= 0x00000001;
+ label_ = bs;
+ break;
+ }
+ case 16: {
+ bitField0_ |= 0x00000002;
+ line_ = input.readInt32();
+ break;
+ }
+ }
+ }
+ } catch (com.google.protobuf.InvalidProtocolBufferException e) {
+ throw e.setUnfinishedMessage(this);
+ } catch (java.io.IOException e) {
+ throw new com.google.protobuf.InvalidProtocolBufferException(
+ e.getMessage()).setUnfinishedMessage(this);
+ } finally {
+ this.unknownFields = unknownFields.build();
+ makeExtensionsImmutable();
+ }
+ }
+ public static final com.google.protobuf.Descriptors.Descriptor
+ getDescriptor() {
+ return org.sonar.core.test.Test.internal_static_Fake_descriptor;
+ }
+
+ protected com.google.protobuf.GeneratedMessage.FieldAccessorTable
+ internalGetFieldAccessorTable() {
+ return org.sonar.core.test.Test.internal_static_Fake_fieldAccessorTable
+ .ensureFieldAccessorsInitialized(
+ org.sonar.core.test.Test.Fake.class, org.sonar.core.test.Test.Fake.Builder.class);
+ }
+
+ public static com.google.protobuf.Parser<Fake> PARSER =
+ new com.google.protobuf.AbstractParser<Fake>() {
+ public Fake parsePartialFrom(
+ com.google.protobuf.CodedInputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ return new Fake(input, extensionRegistry);
+ }
+ };
+
+ @java.lang.Override
+ public com.google.protobuf.Parser<Fake> getParserForType() {
+ return PARSER;
+ }
+ private int bitField0_;
+ public static final int LABEL_FIELD_NUMBER = 1;
+ private java.lang.Object label_;
/**
- * <code>optional int64 aLong = 3;</code>
+ * <code>optional string label = 1;</code>
*/
- boolean hasALong();
+ public boolean hasLabel() {
+ return ((bitField0_ & 0x00000001) == 0x00000001);
+ }
/**
- * <code>optional int64 aLong = 3;</code>
+ * <code>optional string label = 1;</code>
*/
- long getALong();
+ public java.lang.String getLabel() {
+ java.lang.Object ref = label_;
+ if (ref instanceof java.lang.String) {
+ return (java.lang.String) ref;
+ } else {
+ com.google.protobuf.ByteString bs =
+ (com.google.protobuf.ByteString) ref;
+ java.lang.String s = bs.toStringUtf8();
+ if (bs.isValidUtf8()) {
+ label_ = s;
+ }
+ return s;
+ }
+ }
+ /**
+ * <code>optional string label = 1;</code>
+ */
+ public com.google.protobuf.ByteString
+ getLabelBytes() {
+ java.lang.Object ref = label_;
+ if (ref instanceof java.lang.String) {
+ com.google.protobuf.ByteString b =
+ com.google.protobuf.ByteString.copyFromUtf8(
+ (java.lang.String) ref);
+ label_ = b;
+ return b;
+ } else {
+ return (com.google.protobuf.ByteString) ref;
+ }
+ }
+ public static final int LINE_FIELD_NUMBER = 2;
+ private int line_;
/**
- * <code>optional double aDouble = 4;</code>
+ * <code>optional int32 line = 2;</code>
*/
- boolean hasADouble();
+ public boolean hasLine() {
+ return ((bitField0_ & 0x00000002) == 0x00000002);
+ }
/**
- * <code>optional double aDouble = 4;</code>
+ * <code>optional int32 line = 2;</code>
*/
- double getADouble();
+ public int getLine() {
+ return line_;
+ }
+
+ private void initFields() {
+ label_ = "";
+ line_ = 0;
+ }
+ private byte memoizedIsInitialized = -1;
+ public final boolean isInitialized() {
+ byte isInitialized = memoizedIsInitialized;
+ if (isInitialized == 1) return true;
+ if (isInitialized == 0) return false;
+
+ memoizedIsInitialized = 1;
+ return true;
+ }
+
+ public void writeTo(com.google.protobuf.CodedOutputStream output)
+ throws java.io.IOException {
+ getSerializedSize();
+ if (((bitField0_ & 0x00000001) == 0x00000001)) {
+ output.writeBytes(1, getLabelBytes());
+ }
+ if (((bitField0_ & 0x00000002) == 0x00000002)) {
+ output.writeInt32(2, line_);
+ }
+ getUnknownFields().writeTo(output);
+ }
+
+ private int memoizedSerializedSize = -1;
+ public int getSerializedSize() {
+ int size = memoizedSerializedSize;
+ if (size != -1) return size;
+
+ size = 0;
+ if (((bitField0_ & 0x00000001) == 0x00000001)) {
+ size += com.google.protobuf.CodedOutputStream
+ .computeBytesSize(1, getLabelBytes());
+ }
+ if (((bitField0_ & 0x00000002) == 0x00000002)) {
+ size += com.google.protobuf.CodedOutputStream
+ .computeInt32Size(2, line_);
+ }
+ size += getUnknownFields().getSerializedSize();
+ memoizedSerializedSize = size;
+ return size;
+ }
+
+ private static final long serialVersionUID = 0L;
+ @java.lang.Override
+ protected java.lang.Object writeReplace()
+ throws java.io.ObjectStreamException {
+ return super.writeReplace();
+ }
+
+ public static org.sonar.core.test.Test.Fake parseFrom(
+ com.google.protobuf.ByteString data)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ return PARSER.parseFrom(data);
+ }
+ public static org.sonar.core.test.Test.Fake parseFrom(
+ com.google.protobuf.ByteString data,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ return PARSER.parseFrom(data, extensionRegistry);
+ }
+ public static org.sonar.core.test.Test.Fake parseFrom(byte[] data)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ return PARSER.parseFrom(data);
+ }
+ public static org.sonar.core.test.Test.Fake parseFrom(
+ byte[] data,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ return PARSER.parseFrom(data, extensionRegistry);
+ }
+ public static org.sonar.core.test.Test.Fake parseFrom(java.io.InputStream input)
+ throws java.io.IOException {
+ return PARSER.parseFrom(input);
+ }
+ public static org.sonar.core.test.Test.Fake parseFrom(
+ java.io.InputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws java.io.IOException {
+ return PARSER.parseFrom(input, extensionRegistry);
+ }
+ public static org.sonar.core.test.Test.Fake parseDelimitedFrom(java.io.InputStream input)
+ throws java.io.IOException {
+ return PARSER.parseDelimitedFrom(input);
+ }
+ public static org.sonar.core.test.Test.Fake parseDelimitedFrom(
+ java.io.InputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws java.io.IOException {
+ return PARSER.parseDelimitedFrom(input, extensionRegistry);
+ }
+ public static org.sonar.core.test.Test.Fake parseFrom(
+ com.google.protobuf.CodedInputStream input)
+ throws java.io.IOException {
+ return PARSER.parseFrom(input);
+ }
+ public static org.sonar.core.test.Test.Fake parseFrom(
+ com.google.protobuf.CodedInputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws java.io.IOException {
+ return PARSER.parseFrom(input, extensionRegistry);
+ }
+
+ public static Builder newBuilder() { return Builder.create(); }
+ public Builder newBuilderForType() { return newBuilder(); }
+ public static Builder newBuilder(org.sonar.core.test.Test.Fake prototype) {
+ return newBuilder().mergeFrom(prototype);
+ }
+ public Builder toBuilder() { return newBuilder(this); }
+ @java.lang.Override
+ protected Builder newBuilderForType(
+ com.google.protobuf.GeneratedMessage.BuilderParent parent) {
+ Builder builder = new Builder(parent);
+ return builder;
+ }
/**
- * <code>optional bool aBoolean = 5;</code>
+ * Protobuf type {@code Fake}
*/
- boolean hasABoolean();
+ public static final class Builder extends
+ com.google.protobuf.GeneratedMessage.Builder<Builder> implements
+ // @@protoc_insertion_point(builder_implements:Fake)
+ org.sonar.core.test.Test.FakeOrBuilder {
+ public static final com.google.protobuf.Descriptors.Descriptor
+ getDescriptor() {
+ return org.sonar.core.test.Test.internal_static_Fake_descriptor;
+ }
+
+ protected com.google.protobuf.GeneratedMessage.FieldAccessorTable
+ internalGetFieldAccessorTable() {
+ return org.sonar.core.test.Test.internal_static_Fake_fieldAccessorTable
+ .ensureFieldAccessorsInitialized(
+ org.sonar.core.test.Test.Fake.class, org.sonar.core.test.Test.Fake.Builder.class);
+ }
+
+ // Construct using org.sonar.core.test.Test.Fake.newBuilder()
+ private Builder() {
+ maybeForceBuilderInitialization();
+ }
+
+ private Builder(
+ com.google.protobuf.GeneratedMessage.BuilderParent parent) {
+ super(parent);
+ maybeForceBuilderInitialization();
+ }
+ private void maybeForceBuilderInitialization() {
+ if (com.google.protobuf.GeneratedMessage.alwaysUseFieldBuilders) {
+ }
+ }
+ private static Builder create() {
+ return new Builder();
+ }
+
+ public Builder clear() {
+ super.clear();
+ label_ = "";
+ bitField0_ = (bitField0_ & ~0x00000001);
+ line_ = 0;
+ bitField0_ = (bitField0_ & ~0x00000002);
+ return this;
+ }
+
+ public Builder clone() {
+ return create().mergeFrom(buildPartial());
+ }
+
+ public com.google.protobuf.Descriptors.Descriptor
+ getDescriptorForType() {
+ return org.sonar.core.test.Test.internal_static_Fake_descriptor;
+ }
+
+ public org.sonar.core.test.Test.Fake getDefaultInstanceForType() {
+ return org.sonar.core.test.Test.Fake.getDefaultInstance();
+ }
+
+ public org.sonar.core.test.Test.Fake build() {
+ org.sonar.core.test.Test.Fake result = buildPartial();
+ if (!result.isInitialized()) {
+ throw newUninitializedMessageException(result);
+ }
+ return result;
+ }
+
+ public org.sonar.core.test.Test.Fake buildPartial() {
+ org.sonar.core.test.Test.Fake result = new org.sonar.core.test.Test.Fake(this);
+ int from_bitField0_ = bitField0_;
+ int to_bitField0_ = 0;
+ if (((from_bitField0_ & 0x00000001) == 0x00000001)) {
+ to_bitField0_ |= 0x00000001;
+ }
+ result.label_ = label_;
+ if (((from_bitField0_ & 0x00000002) == 0x00000002)) {
+ to_bitField0_ |= 0x00000002;
+ }
+ result.line_ = line_;
+ result.bitField0_ = to_bitField0_;
+ onBuilt();
+ return result;
+ }
+
+ public Builder mergeFrom(com.google.protobuf.Message other) {
+ if (other instanceof org.sonar.core.test.Test.Fake) {
+ return mergeFrom((org.sonar.core.test.Test.Fake)other);
+ } else {
+ super.mergeFrom(other);
+ return this;
+ }
+ }
+
+ public Builder mergeFrom(org.sonar.core.test.Test.Fake other) {
+ if (other == org.sonar.core.test.Test.Fake.getDefaultInstance()) return this;
+ if (other.hasLabel()) {
+ bitField0_ |= 0x00000001;
+ label_ = other.label_;
+ onChanged();
+ }
+ if (other.hasLine()) {
+ setLine(other.getLine());
+ }
+ this.mergeUnknownFields(other.getUnknownFields());
+ return this;
+ }
+
+ public final boolean isInitialized() {
+ return true;
+ }
+
+ public Builder mergeFrom(
+ com.google.protobuf.CodedInputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws java.io.IOException {
+ org.sonar.core.test.Test.Fake parsedMessage = null;
+ try {
+ parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
+ } catch (com.google.protobuf.InvalidProtocolBufferException e) {
+ parsedMessage = (org.sonar.core.test.Test.Fake) e.getUnfinishedMessage();
+ throw e;
+ } finally {
+ if (parsedMessage != null) {
+ mergeFrom(parsedMessage);
+ }
+ }
+ return this;
+ }
+ private int bitField0_;
+
+ private java.lang.Object label_ = "";
+ /**
+ * <code>optional string label = 1;</code>
+ */
+ public boolean hasLabel() {
+ return ((bitField0_ & 0x00000001) == 0x00000001);
+ }
+ /**
+ * <code>optional string label = 1;</code>
+ */
+ public java.lang.String getLabel() {
+ java.lang.Object ref = label_;
+ if (!(ref instanceof java.lang.String)) {
+ com.google.protobuf.ByteString bs =
+ (com.google.protobuf.ByteString) ref;
+ java.lang.String s = bs.toStringUtf8();
+ if (bs.isValidUtf8()) {
+ label_ = s;
+ }
+ return s;
+ } else {
+ return (java.lang.String) ref;
+ }
+ }
+ /**
+ * <code>optional string label = 1;</code>
+ */
+ public com.google.protobuf.ByteString
+ getLabelBytes() {
+ java.lang.Object ref = label_;
+ if (ref instanceof String) {
+ com.google.protobuf.ByteString b =
+ com.google.protobuf.ByteString.copyFromUtf8(
+ (java.lang.String) ref);
+ label_ = b;
+ return b;
+ } else {
+ return (com.google.protobuf.ByteString) ref;
+ }
+ }
+ /**
+ * <code>optional string label = 1;</code>
+ */
+ public Builder setLabel(
+ java.lang.String value) {
+ if (value == null) {
+ throw new NullPointerException();
+ }
+ bitField0_ |= 0x00000001;
+ label_ = value;
+ onChanged();
+ return this;
+ }
+ /**
+ * <code>optional string label = 1;</code>
+ */
+ public Builder clearLabel() {
+ bitField0_ = (bitField0_ & ~0x00000001);
+ label_ = getDefaultInstance().getLabel();
+ onChanged();
+ return this;
+ }
+ /**
+ * <code>optional string label = 1;</code>
+ */
+ public Builder setLabelBytes(
+ com.google.protobuf.ByteString value) {
+ if (value == null) {
+ throw new NullPointerException();
+ }
+ bitField0_ |= 0x00000001;
+ label_ = value;
+ onChanged();
+ return this;
+ }
+
+ private int line_ ;
+ /**
+ * <code>optional int32 line = 2;</code>
+ */
+ public boolean hasLine() {
+ return ((bitField0_ & 0x00000002) == 0x00000002);
+ }
+ /**
+ * <code>optional int32 line = 2;</code>
+ */
+ public int getLine() {
+ return line_;
+ }
+ /**
+ * <code>optional int32 line = 2;</code>
+ */
+ public Builder setLine(int value) {
+ bitField0_ |= 0x00000002;
+ line_ = value;
+ onChanged();
+ return this;
+ }
+ /**
+ * <code>optional int32 line = 2;</code>
+ */
+ public Builder clearLine() {
+ bitField0_ = (bitField0_ & ~0x00000002);
+ line_ = 0;
+ onChanged();
+ return this;
+ }
+
+ // @@protoc_insertion_point(builder_scope:Fake)
+ }
+
+ static {
+ defaultInstance = new Fake(true);
+ defaultInstance.initFields();
+ }
+
+ // @@protoc_insertion_point(class_scope:Fake)
+ }
+
+ public interface JsonTestOrBuilder extends
+ // @@protoc_insertion_point(interface_extends:JsonTest)
+ com.google.protobuf.MessageOrBuilder {
+
+ /**
+ * <code>optional string stringField = 1;</code>
+ */
+ boolean hasStringField();
+ /**
+ * <code>optional string stringField = 1;</code>
+ */
+ java.lang.String getStringField();
/**
- * <code>optional bool aBoolean = 5;</code>
+ * <code>optional string stringField = 1;</code>
*/
- boolean getABoolean();
+ com.google.protobuf.ByteString
+ getStringFieldBytes();
/**
- * <code>optional .FakeEnum anEnum = 6;</code>
+ * <code>optional int32 intField = 2;</code>
*/
- boolean hasAnEnum();
+ boolean hasIntField();
/**
- * <code>optional .FakeEnum anEnum = 6;</code>
+ * <code>optional int32 intField = 2;</code>
*/
- org.sonar.core.test.Test.FakeEnum getAnEnum();
+ int getIntField();
/**
- * <code>optional bytes someBytes = 7;</code>
+ * <code>optional int64 longField = 3;</code>
*/
- boolean hasSomeBytes();
+ boolean hasLongField();
/**
- * <code>optional bytes someBytes = 7;</code>
+ * <code>optional int64 longField = 3;</code>
*/
- com.google.protobuf.ByteString getSomeBytes();
+ long getLongField();
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>optional double doubleField = 4;</code>
*/
- com.google.protobuf.ProtocolStringList
- getAnArrayList();
+ boolean hasDoubleField();
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>optional double doubleField = 4;</code>
*/
- int getAnArrayCount();
+ double getDoubleField();
+
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>optional bool booleanField = 5;</code>
*/
- java.lang.String getAnArray(int index);
+ boolean hasBooleanField();
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>optional bool booleanField = 5;</code>
*/
- com.google.protobuf.ByteString
- getAnArrayBytes(int index);
+ boolean getBooleanField();
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>optional .FakeEnum enumField = 6;</code>
*/
- boolean hasANestedMessage();
+ boolean hasEnumField();
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>optional .FakeEnum enumField = 6;</code>
*/
- org.sonar.core.test.Test.NestedFake getANestedMessage();
+ org.sonar.core.test.Test.FakeEnum getEnumField();
+
+ /**
+ * <code>optional bytes bytesField = 7;</code>
+ */
+ boolean hasBytesField();
+ /**
+ * <code>optional bytes bytesField = 7;</code>
+ */
+ com.google.protobuf.ByteString getBytesField();
+
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ boolean hasNested();
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ org.sonar.core.test.Test.NestedJsonTest getNested();
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ org.sonar.core.test.Test.NestedJsonTestOrBuilder getNestedOrBuilder();
+
+ /**
+ * <code>repeated string anArray = 9;</code>
+ */
+ com.google.protobuf.ProtocolStringList
+ getAnArrayList();
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>repeated string anArray = 9;</code>
*/
- org.sonar.core.test.Test.NestedFakeOrBuilder getANestedMessageOrBuilder();
+ int getAnArrayCount();
+ /**
+ * <code>repeated string anArray = 9;</code>
+ */
+ java.lang.String getAnArray(int index);
+ /**
+ * <code>repeated string anArray = 9;</code>
+ */
+ com.google.protobuf.ByteString
+ getAnArrayBytes(int index);
}
/**
- * Protobuf type {@code Fake}
+ * Protobuf type {@code JsonTest}
*/
- public static final class Fake extends
+ public static final class JsonTest extends
com.google.protobuf.GeneratedMessage implements
- // @@protoc_insertion_point(message_implements:Fake)
- FakeOrBuilder {
- // Use Fake.newBuilder() to construct.
- private Fake(com.google.protobuf.GeneratedMessage.Builder<?> builder) {
+ // @@protoc_insertion_point(message_implements:JsonTest)
+ JsonTestOrBuilder {
+ // Use JsonTest.newBuilder() to construct.
+ private JsonTest(com.google.protobuf.GeneratedMessage.Builder<?> builder) {
super(builder);
this.unknownFields = builder.getUnknownFields();
}
- private Fake(boolean noInit) { this.unknownFields = com.google.protobuf.UnknownFieldSet.getDefaultInstance(); }
+ private JsonTest(boolean noInit) { this.unknownFields = com.google.protobuf.UnknownFieldSet.getDefaultInstance(); }
- private static final Fake defaultInstance;
- public static Fake getDefaultInstance() {
+ private static final JsonTest defaultInstance;
+ public static JsonTest getDefaultInstance() {
return defaultInstance;
}
- public Fake getDefaultInstanceForType() {
+ public JsonTest getDefaultInstanceForType() {
return defaultInstance;
}
@@ -232,7 +786,7 @@ public final class Test {
getUnknownFields() {
return this.unknownFields;
}
- private Fake(
+ private JsonTest(
com.google.protobuf.CodedInputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws com.google.protobuf.InvalidProtocolBufferException {
@@ -258,27 +812,27 @@ public final class Test {
case 10: {
com.google.protobuf.ByteString bs = input.readBytes();
bitField0_ |= 0x00000001;
- aString_ = bs;
+ stringField_ = bs;
break;
}
case 16: {
bitField0_ |= 0x00000002;
- anInt_ = input.readInt32();
+ intField_ = input.readInt32();
break;
}
case 24: {
bitField0_ |= 0x00000004;
- aLong_ = input.readInt64();
+ longField_ = input.readInt64();
break;
}
case 33: {
bitField0_ |= 0x00000008;
- aDouble_ = input.readDouble();
+ doubleField_ = input.readDouble();
break;
}
case 40: {
bitField0_ |= 0x00000010;
- aBoolean_ = input.readBool();
+ booleanField_ = input.readBool();
break;
}
case 48: {
@@ -288,37 +842,37 @@ public final class Test {
unknownFields.mergeVarintField(6, rawValue);
} else {
bitField0_ |= 0x00000020;
- anEnum_ = value;
+ enumField_ = value;
}
break;
}
case 58: {
bitField0_ |= 0x00000040;
- someBytes_ = input.readBytes();
+ bytesField_ = input.readBytes();
break;
}
case 66: {
- com.google.protobuf.ByteString bs = input.readBytes();
- if (!((mutable_bitField0_ & 0x00000080) == 0x00000080)) {
- anArray_ = new com.google.protobuf.LazyStringArrayList();
- mutable_bitField0_ |= 0x00000080;
- }
- anArray_.add(bs);
- break;
- }
- case 74: {
- org.sonar.core.test.Test.NestedFake.Builder subBuilder = null;
+ org.sonar.core.test.Test.NestedJsonTest.Builder subBuilder = null;
if (((bitField0_ & 0x00000080) == 0x00000080)) {
- subBuilder = aNestedMessage_.toBuilder();
+ subBuilder = nested_.toBuilder();
}
- aNestedMessage_ = input.readMessage(org.sonar.core.test.Test.NestedFake.PARSER, extensionRegistry);
+ nested_ = input.readMessage(org.sonar.core.test.Test.NestedJsonTest.PARSER, extensionRegistry);
if (subBuilder != null) {
- subBuilder.mergeFrom(aNestedMessage_);
- aNestedMessage_ = subBuilder.buildPartial();
+ subBuilder.mergeFrom(nested_);
+ nested_ = subBuilder.buildPartial();
}
bitField0_ |= 0x00000080;
break;
}
+ case 74: {
+ com.google.protobuf.ByteString bs = input.readBytes();
+ if (!((mutable_bitField0_ & 0x00000100) == 0x00000100)) {
+ anArray_ = new com.google.protobuf.LazyStringArrayList();
+ mutable_bitField0_ |= 0x00000100;
+ }
+ anArray_.add(bs);
+ break;
+ }
}
}
} catch (com.google.protobuf.InvalidProtocolBufferException e) {
@@ -327,7 +881,7 @@ public final class Test {
throw new com.google.protobuf.InvalidProtocolBufferException(
e.getMessage()).setUnfinishedMessage(this);
} finally {
- if (((mutable_bitField0_ & 0x00000080) == 0x00000080)) {
+ if (((mutable_bitField0_ & 0x00000100) == 0x00000100)) {
anArray_ = anArray_.getUnmodifiableView();
}
this.unknownFields = unknownFields.build();
@@ -336,45 +890,45 @@ public final class Test {
}
public static final com.google.protobuf.Descriptors.Descriptor
getDescriptor() {
- return org.sonar.core.test.Test.internal_static_Fake_descriptor;
+ return org.sonar.core.test.Test.internal_static_JsonTest_descriptor;
}
protected com.google.protobuf.GeneratedMessage.FieldAccessorTable
internalGetFieldAccessorTable() {
- return org.sonar.core.test.Test.internal_static_Fake_fieldAccessorTable
+ return org.sonar.core.test.Test.internal_static_JsonTest_fieldAccessorTable
.ensureFieldAccessorsInitialized(
- org.sonar.core.test.Test.Fake.class, org.sonar.core.test.Test.Fake.Builder.class);
+ org.sonar.core.test.Test.JsonTest.class, org.sonar.core.test.Test.JsonTest.Builder.class);
}
- public static com.google.protobuf.Parser<Fake> PARSER =
- new com.google.protobuf.AbstractParser<Fake>() {
- public Fake parsePartialFrom(
+ public static com.google.protobuf.Parser<JsonTest> PARSER =
+ new com.google.protobuf.AbstractParser<JsonTest>() {
+ public JsonTest parsePartialFrom(
com.google.protobuf.CodedInputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws com.google.protobuf.InvalidProtocolBufferException {
- return new Fake(input, extensionRegistry);
+ return new JsonTest(input, extensionRegistry);
}
};
@java.lang.Override
- public com.google.protobuf.Parser<Fake> getParserForType() {
+ public com.google.protobuf.Parser<JsonTest> getParserForType() {
return PARSER;
}
private int bitField0_;
- public static final int ASTRING_FIELD_NUMBER = 1;
- private java.lang.Object aString_;
+ public static final int STRINGFIELD_FIELD_NUMBER = 1;
+ private java.lang.Object stringField_;
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string stringField = 1;</code>
*/
- public boolean hasAString() {
+ public boolean hasStringField() {
return ((bitField0_ & 0x00000001) == 0x00000001);
}
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string stringField = 1;</code>
*/
- public java.lang.String getAString() {
- java.lang.Object ref = aString_;
+ public java.lang.String getStringField() {
+ java.lang.Object ref = stringField_;
if (ref instanceof java.lang.String) {
return (java.lang.String) ref;
} else {
@@ -382,178 +936,178 @@ public final class Test {
(com.google.protobuf.ByteString) ref;
java.lang.String s = bs.toStringUtf8();
if (bs.isValidUtf8()) {
- aString_ = s;
+ stringField_ = s;
}
return s;
}
}
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string stringField = 1;</code>
*/
public com.google.protobuf.ByteString
- getAStringBytes() {
- java.lang.Object ref = aString_;
+ getStringFieldBytes() {
+ java.lang.Object ref = stringField_;
if (ref instanceof java.lang.String) {
com.google.protobuf.ByteString b =
com.google.protobuf.ByteString.copyFromUtf8(
(java.lang.String) ref);
- aString_ = b;
+ stringField_ = b;
return b;
} else {
return (com.google.protobuf.ByteString) ref;
}
}
- public static final int ANINT_FIELD_NUMBER = 2;
- private int anInt_;
+ public static final int INTFIELD_FIELD_NUMBER = 2;
+ private int intField_;
/**
- * <code>optional int32 anInt = 2;</code>
+ * <code>optional int32 intField = 2;</code>
*/
- public boolean hasAnInt() {
+ public boolean hasIntField() {
return ((bitField0_ & 0x00000002) == 0x00000002);
}
/**
- * <code>optional int32 anInt = 2;</code>
+ * <code>optional int32 intField = 2;</code>
*/
- public int getAnInt() {
- return anInt_;
+ public int getIntField() {
+ return intField_;
}
- public static final int ALONG_FIELD_NUMBER = 3;
- private long aLong_;
+ public static final int LONGFIELD_FIELD_NUMBER = 3;
+ private long longField_;
/**
- * <code>optional int64 aLong = 3;</code>
+ * <code>optional int64 longField = 3;</code>
*/
- public boolean hasALong() {
+ public boolean hasLongField() {
return ((bitField0_ & 0x00000004) == 0x00000004);
}
/**
- * <code>optional int64 aLong = 3;</code>
+ * <code>optional int64 longField = 3;</code>
*/
- public long getALong() {
- return aLong_;
+ public long getLongField() {
+ return longField_;
}
- public static final int ADOUBLE_FIELD_NUMBER = 4;
- private double aDouble_;
+ public static final int DOUBLEFIELD_FIELD_NUMBER = 4;
+ private double doubleField_;
/**
- * <code>optional double aDouble = 4;</code>
+ * <code>optional double doubleField = 4;</code>
*/
- public boolean hasADouble() {
+ public boolean hasDoubleField() {
return ((bitField0_ & 0x00000008) == 0x00000008);
}
/**
- * <code>optional double aDouble = 4;</code>
+ * <code>optional double doubleField = 4;</code>
*/
- public double getADouble() {
- return aDouble_;
+ public double getDoubleField() {
+ return doubleField_;
}
- public static final int ABOOLEAN_FIELD_NUMBER = 5;
- private boolean aBoolean_;
+ public static final int BOOLEANFIELD_FIELD_NUMBER = 5;
+ private boolean booleanField_;
/**
- * <code>optional bool aBoolean = 5;</code>
+ * <code>optional bool booleanField = 5;</code>
*/
- public boolean hasABoolean() {
+ public boolean hasBooleanField() {
return ((bitField0_ & 0x00000010) == 0x00000010);
}
/**
- * <code>optional bool aBoolean = 5;</code>
+ * <code>optional bool booleanField = 5;</code>
*/
- public boolean getABoolean() {
- return aBoolean_;
+ public boolean getBooleanField() {
+ return booleanField_;
}
- public static final int ANENUM_FIELD_NUMBER = 6;
- private org.sonar.core.test.Test.FakeEnum anEnum_;
+ public static final int ENUMFIELD_FIELD_NUMBER = 6;
+ private org.sonar.core.test.Test.FakeEnum enumField_;
/**
- * <code>optional .FakeEnum anEnum = 6;</code>
+ * <code>optional .FakeEnum enumField = 6;</code>
*/
- public boolean hasAnEnum() {
+ public boolean hasEnumField() {
return ((bitField0_ & 0x00000020) == 0x00000020);
}
/**
- * <code>optional .FakeEnum anEnum = 6;</code>
+ * <code>optional .FakeEnum enumField = 6;</code>
*/
- public org.sonar.core.test.Test.FakeEnum getAnEnum() {
- return anEnum_;
+ public org.sonar.core.test.Test.FakeEnum getEnumField() {
+ return enumField_;
}
- public static final int SOMEBYTES_FIELD_NUMBER = 7;
- private com.google.protobuf.ByteString someBytes_;
+ public static final int BYTESFIELD_FIELD_NUMBER = 7;
+ private com.google.protobuf.ByteString bytesField_;
/**
- * <code>optional bytes someBytes = 7;</code>
+ * <code>optional bytes bytesField = 7;</code>
*/
- public boolean hasSomeBytes() {
+ public boolean hasBytesField() {
return ((bitField0_ & 0x00000040) == 0x00000040);
}
/**
- * <code>optional bytes someBytes = 7;</code>
+ * <code>optional bytes bytesField = 7;</code>
+ */
+ public com.google.protobuf.ByteString getBytesField() {
+ return bytesField_;
+ }
+
+ public static final int NESTED_FIELD_NUMBER = 8;
+ private org.sonar.core.test.Test.NestedJsonTest nested_;
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ public boolean hasNested() {
+ return ((bitField0_ & 0x00000080) == 0x00000080);
+ }
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ public org.sonar.core.test.Test.NestedJsonTest getNested() {
+ return nested_;
+ }
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
*/
- public com.google.protobuf.ByteString getSomeBytes() {
- return someBytes_;
+ public org.sonar.core.test.Test.NestedJsonTestOrBuilder getNestedOrBuilder() {
+ return nested_;
}
- public static final int ANARRAY_FIELD_NUMBER = 8;
+ public static final int ANARRAY_FIELD_NUMBER = 9;
private com.google.protobuf.LazyStringList anArray_;
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public com.google.protobuf.ProtocolStringList
getAnArrayList() {
return anArray_;
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public int getAnArrayCount() {
return anArray_.size();
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public java.lang.String getAnArray(int index) {
return anArray_.get(index);
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public com.google.protobuf.ByteString
getAnArrayBytes(int index) {
return anArray_.getByteString(index);
}
- public static final int ANESTEDMESSAGE_FIELD_NUMBER = 9;
- private org.sonar.core.test.Test.NestedFake aNestedMessage_;
- /**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
- */
- public boolean hasANestedMessage() {
- return ((bitField0_ & 0x00000080) == 0x00000080);
- }
- /**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
- */
- public org.sonar.core.test.Test.NestedFake getANestedMessage() {
- return aNestedMessage_;
- }
- /**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
- */
- public org.sonar.core.test.Test.NestedFakeOrBuilder getANestedMessageOrBuilder() {
- return aNestedMessage_;
- }
-
private void initFields() {
- aString_ = "";
- anInt_ = 0;
- aLong_ = 0L;
- aDouble_ = 0D;
- aBoolean_ = false;
- anEnum_ = org.sonar.core.test.Test.FakeEnum.BLUE;
- someBytes_ = com.google.protobuf.ByteString.EMPTY;
+ stringField_ = "";
+ intField_ = 0;
+ longField_ = 0L;
+ doubleField_ = 0D;
+ booleanField_ = false;
+ enumField_ = org.sonar.core.test.Test.FakeEnum.BLUE;
+ bytesField_ = com.google.protobuf.ByteString.EMPTY;
+ nested_ = org.sonar.core.test.Test.NestedJsonTest.getDefaultInstance();
anArray_ = com.google.protobuf.LazyStringArrayList.EMPTY;
- aNestedMessage_ = org.sonar.core.test.Test.NestedFake.getDefaultInstance();
}
private byte memoizedIsInitialized = -1;
public final boolean isInitialized() {
@@ -569,31 +1123,31 @@ public final class Test {
throws java.io.IOException {
getSerializedSize();
if (((bitField0_ & 0x00000001) == 0x00000001)) {
- output.writeBytes(1, getAStringBytes());
+ output.writeBytes(1, getStringFieldBytes());
}
if (((bitField0_ & 0x00000002) == 0x00000002)) {
- output.writeInt32(2, anInt_);
+ output.writeInt32(2, intField_);
}
if (((bitField0_ & 0x00000004) == 0x00000004)) {
- output.writeInt64(3, aLong_);
+ output.writeInt64(3, longField_);
}
if (((bitField0_ & 0x00000008) == 0x00000008)) {
- output.writeDouble(4, aDouble_);
+ output.writeDouble(4, doubleField_);
}
if (((bitField0_ & 0x00000010) == 0x00000010)) {
- output.writeBool(5, aBoolean_);
+ output.writeBool(5, booleanField_);
}
if (((bitField0_ & 0x00000020) == 0x00000020)) {
- output.writeEnum(6, anEnum_.getNumber());
+ output.writeEnum(6, enumField_.getNumber());
}
if (((bitField0_ & 0x00000040) == 0x00000040)) {
- output.writeBytes(7, someBytes_);
- }
- for (int i = 0; i < anArray_.size(); i++) {
- output.writeBytes(8, anArray_.getByteString(i));
+ output.writeBytes(7, bytesField_);
}
if (((bitField0_ & 0x00000080) == 0x00000080)) {
- output.writeMessage(9, aNestedMessage_);
+ output.writeMessage(8, nested_);
+ }
+ for (int i = 0; i < anArray_.size(); i++) {
+ output.writeBytes(9, anArray_.getByteString(i));
}
getUnknownFields().writeTo(output);
}
@@ -606,31 +1160,35 @@ public final class Test {
size = 0;
if (((bitField0_ & 0x00000001) == 0x00000001)) {
size += com.google.protobuf.CodedOutputStream
- .computeBytesSize(1, getAStringBytes());
+ .computeBytesSize(1, getStringFieldBytes());
}
if (((bitField0_ & 0x00000002) == 0x00000002)) {
size += com.google.protobuf.CodedOutputStream
- .computeInt32Size(2, anInt_);
+ .computeInt32Size(2, intField_);
}
if (((bitField0_ & 0x00000004) == 0x00000004)) {
size += com.google.protobuf.CodedOutputStream
- .computeInt64Size(3, aLong_);
+ .computeInt64Size(3, longField_);
}
if (((bitField0_ & 0x00000008) == 0x00000008)) {
size += com.google.protobuf.CodedOutputStream
- .computeDoubleSize(4, aDouble_);
+ .computeDoubleSize(4, doubleField_);
}
if (((bitField0_ & 0x00000010) == 0x00000010)) {
size += com.google.protobuf.CodedOutputStream
- .computeBoolSize(5, aBoolean_);
+ .computeBoolSize(5, booleanField_);
}
if (((bitField0_ & 0x00000020) == 0x00000020)) {
size += com.google.protobuf.CodedOutputStream
- .computeEnumSize(6, anEnum_.getNumber());
+ .computeEnumSize(6, enumField_.getNumber());
}
if (((bitField0_ & 0x00000040) == 0x00000040)) {
size += com.google.protobuf.CodedOutputStream
- .computeBytesSize(7, someBytes_);
+ .computeBytesSize(7, bytesField_);
+ }
+ if (((bitField0_ & 0x00000080) == 0x00000080)) {
+ size += com.google.protobuf.CodedOutputStream
+ .computeMessageSize(8, nested_);
}
{
int dataSize = 0;
@@ -641,10 +1199,6 @@ public final class Test {
size += dataSize;
size += 1 * getAnArrayList().size();
}
- if (((bitField0_ & 0x00000080) == 0x00000080)) {
- size += com.google.protobuf.CodedOutputStream
- .computeMessageSize(9, aNestedMessage_);
- }
size += getUnknownFields().getSerializedSize();
memoizedSerializedSize = size;
return size;
@@ -657,53 +1211,53 @@ public final class Test {
return super.writeReplace();
}
- public static org.sonar.core.test.Test.Fake parseFrom(
+ public static org.sonar.core.test.Test.JsonTest parseFrom(
com.google.protobuf.ByteString data)
throws com.google.protobuf.InvalidProtocolBufferException {
return PARSER.parseFrom(data);
}
- public static org.sonar.core.test.Test.Fake parseFrom(
+ public static org.sonar.core.test.Test.JsonTest parseFrom(
com.google.protobuf.ByteString data,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws com.google.protobuf.InvalidProtocolBufferException {
return PARSER.parseFrom(data, extensionRegistry);
}
- public static org.sonar.core.test.Test.Fake parseFrom(byte[] data)
+ public static org.sonar.core.test.Test.JsonTest parseFrom(byte[] data)
throws com.google.protobuf.InvalidProtocolBufferException {
return PARSER.parseFrom(data);
}
- public static org.sonar.core.test.Test.Fake parseFrom(
+ public static org.sonar.core.test.Test.JsonTest parseFrom(
byte[] data,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws com.google.protobuf.InvalidProtocolBufferException {
return PARSER.parseFrom(data, extensionRegistry);
}
- public static org.sonar.core.test.Test.Fake parseFrom(java.io.InputStream input)
+ public static org.sonar.core.test.Test.JsonTest parseFrom(java.io.InputStream input)
throws java.io.IOException {
return PARSER.parseFrom(input);
}
- public static org.sonar.core.test.Test.Fake parseFrom(
+ public static org.sonar.core.test.Test.JsonTest parseFrom(
java.io.InputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws java.io.IOException {
return PARSER.parseFrom(input, extensionRegistry);
}
- public static org.sonar.core.test.Test.Fake parseDelimitedFrom(java.io.InputStream input)
+ public static org.sonar.core.test.Test.JsonTest parseDelimitedFrom(java.io.InputStream input)
throws java.io.IOException {
return PARSER.parseDelimitedFrom(input);
}
- public static org.sonar.core.test.Test.Fake parseDelimitedFrom(
+ public static org.sonar.core.test.Test.JsonTest parseDelimitedFrom(
java.io.InputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws java.io.IOException {
return PARSER.parseDelimitedFrom(input, extensionRegistry);
}
- public static org.sonar.core.test.Test.Fake parseFrom(
+ public static org.sonar.core.test.Test.JsonTest parseFrom(
com.google.protobuf.CodedInputStream input)
throws java.io.IOException {
return PARSER.parseFrom(input);
}
- public static org.sonar.core.test.Test.Fake parseFrom(
+ public static org.sonar.core.test.Test.JsonTest parseFrom(
com.google.protobuf.CodedInputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws java.io.IOException {
@@ -712,7 +1266,7 @@ public final class Test {
public static Builder newBuilder() { return Builder.create(); }
public Builder newBuilderForType() { return newBuilder(); }
- public static Builder newBuilder(org.sonar.core.test.Test.Fake prototype) {
+ public static Builder newBuilder(org.sonar.core.test.Test.JsonTest prototype) {
return newBuilder().mergeFrom(prototype);
}
public Builder toBuilder() { return newBuilder(this); }
@@ -724,25 +1278,25 @@ public final class Test {
return builder;
}
/**
- * Protobuf type {@code Fake}
+ * Protobuf type {@code JsonTest}
*/
public static final class Builder extends
com.google.protobuf.GeneratedMessage.Builder<Builder> implements
- // @@protoc_insertion_point(builder_implements:Fake)
- org.sonar.core.test.Test.FakeOrBuilder {
+ // @@protoc_insertion_point(builder_implements:JsonTest)
+ org.sonar.core.test.Test.JsonTestOrBuilder {
public static final com.google.protobuf.Descriptors.Descriptor
getDescriptor() {
- return org.sonar.core.test.Test.internal_static_Fake_descriptor;
+ return org.sonar.core.test.Test.internal_static_JsonTest_descriptor;
}
protected com.google.protobuf.GeneratedMessage.FieldAccessorTable
internalGetFieldAccessorTable() {
- return org.sonar.core.test.Test.internal_static_Fake_fieldAccessorTable
+ return org.sonar.core.test.Test.internal_static_JsonTest_fieldAccessorTable
.ensureFieldAccessorsInitialized(
- org.sonar.core.test.Test.Fake.class, org.sonar.core.test.Test.Fake.Builder.class);
+ org.sonar.core.test.Test.JsonTest.class, org.sonar.core.test.Test.JsonTest.Builder.class);
}
- // Construct using org.sonar.core.test.Test.Fake.newBuilder()
+ // Construct using org.sonar.core.test.Test.JsonTest.newBuilder()
private Builder() {
maybeForceBuilderInitialization();
}
@@ -754,7 +1308,7 @@ public final class Test {
}
private void maybeForceBuilderInitialization() {
if (com.google.protobuf.GeneratedMessage.alwaysUseFieldBuilders) {
- getANestedMessageFieldBuilder();
+ getNestedFieldBuilder();
}
}
private static Builder create() {
@@ -763,27 +1317,27 @@ public final class Test {
public Builder clear() {
super.clear();
- aString_ = "";
+ stringField_ = "";
bitField0_ = (bitField0_ & ~0x00000001);
- anInt_ = 0;
+ intField_ = 0;
bitField0_ = (bitField0_ & ~0x00000002);
- aLong_ = 0L;
+ longField_ = 0L;
bitField0_ = (bitField0_ & ~0x00000004);
- aDouble_ = 0D;
+ doubleField_ = 0D;
bitField0_ = (bitField0_ & ~0x00000008);
- aBoolean_ = false;
+ booleanField_ = false;
bitField0_ = (bitField0_ & ~0x00000010);
- anEnum_ = org.sonar.core.test.Test.FakeEnum.BLUE;
+ enumField_ = org.sonar.core.test.Test.FakeEnum.BLUE;
bitField0_ = (bitField0_ & ~0x00000020);
- someBytes_ = com.google.protobuf.ByteString.EMPTY;
+ bytesField_ = com.google.protobuf.ByteString.EMPTY;
bitField0_ = (bitField0_ & ~0x00000040);
- anArray_ = com.google.protobuf.LazyStringArrayList.EMPTY;
- bitField0_ = (bitField0_ & ~0x00000080);
- if (aNestedMessageBuilder_ == null) {
- aNestedMessage_ = org.sonar.core.test.Test.NestedFake.getDefaultInstance();
+ if (nestedBuilder_ == null) {
+ nested_ = org.sonar.core.test.Test.NestedJsonTest.getDefaultInstance();
} else {
- aNestedMessageBuilder_.clear();
+ nestedBuilder_.clear();
}
+ bitField0_ = (bitField0_ & ~0x00000080);
+ anArray_ = com.google.protobuf.LazyStringArrayList.EMPTY;
bitField0_ = (bitField0_ & ~0x00000100);
return this;
}
@@ -794,118 +1348,118 @@ public final class Test {
public com.google.protobuf.Descriptors.Descriptor
getDescriptorForType() {
- return org.sonar.core.test.Test.internal_static_Fake_descriptor;
+ return org.sonar.core.test.Test.internal_static_JsonTest_descriptor;
}
- public org.sonar.core.test.Test.Fake getDefaultInstanceForType() {
- return org.sonar.core.test.Test.Fake.getDefaultInstance();
+ public org.sonar.core.test.Test.JsonTest getDefaultInstanceForType() {
+ return org.sonar.core.test.Test.JsonTest.getDefaultInstance();
}
- public org.sonar.core.test.Test.Fake build() {
- org.sonar.core.test.Test.Fake result = buildPartial();
+ public org.sonar.core.test.Test.JsonTest build() {
+ org.sonar.core.test.Test.JsonTest result = buildPartial();
if (!result.isInitialized()) {
throw newUninitializedMessageException(result);
}
return result;
}
- public org.sonar.core.test.Test.Fake buildPartial() {
- org.sonar.core.test.Test.Fake result = new org.sonar.core.test.Test.Fake(this);
+ public org.sonar.core.test.Test.JsonTest buildPartial() {
+ org.sonar.core.test.Test.JsonTest result = new org.sonar.core.test.Test.JsonTest(this);
int from_bitField0_ = bitField0_;
int to_bitField0_ = 0;
if (((from_bitField0_ & 0x00000001) == 0x00000001)) {
to_bitField0_ |= 0x00000001;
}
- result.aString_ = aString_;
+ result.stringField_ = stringField_;
if (((from_bitField0_ & 0x00000002) == 0x00000002)) {
to_bitField0_ |= 0x00000002;
}
- result.anInt_ = anInt_;
+ result.intField_ = intField_;
if (((from_bitField0_ & 0x00000004) == 0x00000004)) {
to_bitField0_ |= 0x00000004;
}
- result.aLong_ = aLong_;
+ result.longField_ = longField_;
if (((from_bitField0_ & 0x00000008) == 0x00000008)) {
to_bitField0_ |= 0x00000008;
}
- result.aDouble_ = aDouble_;
+ result.doubleField_ = doubleField_;
if (((from_bitField0_ & 0x00000010) == 0x00000010)) {
to_bitField0_ |= 0x00000010;
}
- result.aBoolean_ = aBoolean_;
+ result.booleanField_ = booleanField_;
if (((from_bitField0_ & 0x00000020) == 0x00000020)) {
to_bitField0_ |= 0x00000020;
}
- result.anEnum_ = anEnum_;
+ result.enumField_ = enumField_;
if (((from_bitField0_ & 0x00000040) == 0x00000040)) {
to_bitField0_ |= 0x00000040;
}
- result.someBytes_ = someBytes_;
- if (((bitField0_ & 0x00000080) == 0x00000080)) {
- anArray_ = anArray_.getUnmodifiableView();
- bitField0_ = (bitField0_ & ~0x00000080);
- }
- result.anArray_ = anArray_;
- if (((from_bitField0_ & 0x00000100) == 0x00000100)) {
+ result.bytesField_ = bytesField_;
+ if (((from_bitField0_ & 0x00000080) == 0x00000080)) {
to_bitField0_ |= 0x00000080;
}
- if (aNestedMessageBuilder_ == null) {
- result.aNestedMessage_ = aNestedMessage_;
+ if (nestedBuilder_ == null) {
+ result.nested_ = nested_;
} else {
- result.aNestedMessage_ = aNestedMessageBuilder_.build();
+ result.nested_ = nestedBuilder_.build();
+ }
+ if (((bitField0_ & 0x00000100) == 0x00000100)) {
+ anArray_ = anArray_.getUnmodifiableView();
+ bitField0_ = (bitField0_ & ~0x00000100);
}
+ result.anArray_ = anArray_;
result.bitField0_ = to_bitField0_;
onBuilt();
return result;
}
public Builder mergeFrom(com.google.protobuf.Message other) {
- if (other instanceof org.sonar.core.test.Test.Fake) {
- return mergeFrom((org.sonar.core.test.Test.Fake)other);
+ if (other instanceof org.sonar.core.test.Test.JsonTest) {
+ return mergeFrom((org.sonar.core.test.Test.JsonTest)other);
} else {
super.mergeFrom(other);
return this;
}
}
- public Builder mergeFrom(org.sonar.core.test.Test.Fake other) {
- if (other == org.sonar.core.test.Test.Fake.getDefaultInstance()) return this;
- if (other.hasAString()) {
+ public Builder mergeFrom(org.sonar.core.test.Test.JsonTest other) {
+ if (other == org.sonar.core.test.Test.JsonTest.getDefaultInstance()) return this;
+ if (other.hasStringField()) {
bitField0_ |= 0x00000001;
- aString_ = other.aString_;
+ stringField_ = other.stringField_;
onChanged();
}
- if (other.hasAnInt()) {
- setAnInt(other.getAnInt());
+ if (other.hasIntField()) {
+ setIntField(other.getIntField());
+ }
+ if (other.hasLongField()) {
+ setLongField(other.getLongField());
}
- if (other.hasALong()) {
- setALong(other.getALong());
+ if (other.hasDoubleField()) {
+ setDoubleField(other.getDoubleField());
}
- if (other.hasADouble()) {
- setADouble(other.getADouble());
+ if (other.hasBooleanField()) {
+ setBooleanField(other.getBooleanField());
}
- if (other.hasABoolean()) {
- setABoolean(other.getABoolean());
+ if (other.hasEnumField()) {
+ setEnumField(other.getEnumField());
}
- if (other.hasAnEnum()) {
- setAnEnum(other.getAnEnum());
+ if (other.hasBytesField()) {
+ setBytesField(other.getBytesField());
}
- if (other.hasSomeBytes()) {
- setSomeBytes(other.getSomeBytes());
+ if (other.hasNested()) {
+ mergeNested(other.getNested());
}
if (!other.anArray_.isEmpty()) {
if (anArray_.isEmpty()) {
anArray_ = other.anArray_;
- bitField0_ = (bitField0_ & ~0x00000080);
+ bitField0_ = (bitField0_ & ~0x00000100);
} else {
ensureAnArrayIsMutable();
anArray_.addAll(other.anArray_);
}
onChanged();
}
- if (other.hasANestedMessage()) {
- mergeANestedMessage(other.getANestedMessage());
- }
this.mergeUnknownFields(other.getUnknownFields());
return this;
}
@@ -918,11 +1472,11 @@ public final class Test {
com.google.protobuf.CodedInputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws java.io.IOException {
- org.sonar.core.test.Test.Fake parsedMessage = null;
+ org.sonar.core.test.Test.JsonTest parsedMessage = null;
try {
parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
} catch (com.google.protobuf.InvalidProtocolBufferException e) {
- parsedMessage = (org.sonar.core.test.Test.Fake) e.getUnfinishedMessage();
+ parsedMessage = (org.sonar.core.test.Test.JsonTest) e.getUnfinishedMessage();
throw e;
} finally {
if (parsedMessage != null) {
@@ -933,24 +1487,24 @@ public final class Test {
}
private int bitField0_;
- private java.lang.Object aString_ = "";
+ private java.lang.Object stringField_ = "";
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string stringField = 1;</code>
*/
- public boolean hasAString() {
+ public boolean hasStringField() {
return ((bitField0_ & 0x00000001) == 0x00000001);
}
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string stringField = 1;</code>
*/
- public java.lang.String getAString() {
- java.lang.Object ref = aString_;
+ public java.lang.String getStringField() {
+ java.lang.Object ref = stringField_;
if (!(ref instanceof java.lang.String)) {
com.google.protobuf.ByteString bs =
(com.google.protobuf.ByteString) ref;
java.lang.String s = bs.toStringUtf8();
if (bs.isValidUtf8()) {
- aString_ = s;
+ stringField_ = s;
}
return s;
} else {
@@ -958,290 +1512,406 @@ public final class Test {
}
}
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string stringField = 1;</code>
*/
public com.google.protobuf.ByteString
- getAStringBytes() {
- java.lang.Object ref = aString_;
+ getStringFieldBytes() {
+ java.lang.Object ref = stringField_;
if (ref instanceof String) {
com.google.protobuf.ByteString b =
com.google.protobuf.ByteString.copyFromUtf8(
(java.lang.String) ref);
- aString_ = b;
+ stringField_ = b;
return b;
} else {
return (com.google.protobuf.ByteString) ref;
}
}
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string stringField = 1;</code>
*/
- public Builder setAString(
+ public Builder setStringField(
java.lang.String value) {
if (value == null) {
throw new NullPointerException();
}
bitField0_ |= 0x00000001;
- aString_ = value;
+ stringField_ = value;
onChanged();
return this;
}
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string stringField = 1;</code>
*/
- public Builder clearAString() {
+ public Builder clearStringField() {
bitField0_ = (bitField0_ & ~0x00000001);
- aString_ = getDefaultInstance().getAString();
+ stringField_ = getDefaultInstance().getStringField();
onChanged();
return this;
}
/**
- * <code>optional string aString = 1;</code>
+ * <code>optional string stringField = 1;</code>
*/
- public Builder setAStringBytes(
+ public Builder setStringFieldBytes(
com.google.protobuf.ByteString value) {
if (value == null) {
throw new NullPointerException();
}
bitField0_ |= 0x00000001;
- aString_ = value;
+ stringField_ = value;
onChanged();
return this;
}
- private int anInt_ ;
+ private int intField_ ;
/**
- * <code>optional int32 anInt = 2;</code>
+ * <code>optional int32 intField = 2;</code>
*/
- public boolean hasAnInt() {
+ public boolean hasIntField() {
return ((bitField0_ & 0x00000002) == 0x00000002);
}
/**
- * <code>optional int32 anInt = 2;</code>
+ * <code>optional int32 intField = 2;</code>
*/
- public int getAnInt() {
- return anInt_;
+ public int getIntField() {
+ return intField_;
}
/**
- * <code>optional int32 anInt = 2;</code>
+ * <code>optional int32 intField = 2;</code>
*/
- public Builder setAnInt(int value) {
+ public Builder setIntField(int value) {
bitField0_ |= 0x00000002;
- anInt_ = value;
+ intField_ = value;
onChanged();
return this;
}
/**
- * <code>optional int32 anInt = 2;</code>
+ * <code>optional int32 intField = 2;</code>
*/
- public Builder clearAnInt() {
+ public Builder clearIntField() {
bitField0_ = (bitField0_ & ~0x00000002);
- anInt_ = 0;
+ intField_ = 0;
onChanged();
return this;
}
- private long aLong_ ;
+ private long longField_ ;
/**
- * <code>optional int64 aLong = 3;</code>
+ * <code>optional int64 longField = 3;</code>
*/
- public boolean hasALong() {
+ public boolean hasLongField() {
return ((bitField0_ & 0x00000004) == 0x00000004);
}
/**
- * <code>optional int64 aLong = 3;</code>
+ * <code>optional int64 longField = 3;</code>
*/
- public long getALong() {
- return aLong_;
+ public long getLongField() {
+ return longField_;
}
/**
- * <code>optional int64 aLong = 3;</code>
+ * <code>optional int64 longField = 3;</code>
*/
- public Builder setALong(long value) {
+ public Builder setLongField(long value) {
bitField0_ |= 0x00000004;
- aLong_ = value;
+ longField_ = value;
onChanged();
return this;
}
/**
- * <code>optional int64 aLong = 3;</code>
+ * <code>optional int64 longField = 3;</code>
*/
- public Builder clearALong() {
+ public Builder clearLongField() {
bitField0_ = (bitField0_ & ~0x00000004);
- aLong_ = 0L;
+ longField_ = 0L;
onChanged();
return this;
}
- private double aDouble_ ;
+ private double doubleField_ ;
/**
- * <code>optional double aDouble = 4;</code>
+ * <code>optional double doubleField = 4;</code>
*/
- public boolean hasADouble() {
+ public boolean hasDoubleField() {
return ((bitField0_ & 0x00000008) == 0x00000008);
}
/**
- * <code>optional double aDouble = 4;</code>
+ * <code>optional double doubleField = 4;</code>
*/
- public double getADouble() {
- return aDouble_;
+ public double getDoubleField() {
+ return doubleField_;
}
/**
- * <code>optional double aDouble = 4;</code>
+ * <code>optional double doubleField = 4;</code>
*/
- public Builder setADouble(double value) {
+ public Builder setDoubleField(double value) {
bitField0_ |= 0x00000008;
- aDouble_ = value;
+ doubleField_ = value;
onChanged();
return this;
}
/**
- * <code>optional double aDouble = 4;</code>
+ * <code>optional double doubleField = 4;</code>
*/
- public Builder clearADouble() {
+ public Builder clearDoubleField() {
bitField0_ = (bitField0_ & ~0x00000008);
- aDouble_ = 0D;
+ doubleField_ = 0D;
onChanged();
return this;
}
- private boolean aBoolean_ ;
+ private boolean booleanField_ ;
/**
- * <code>optional bool aBoolean = 5;</code>
+ * <code>optional bool booleanField = 5;</code>
*/
- public boolean hasABoolean() {
+ public boolean hasBooleanField() {
return ((bitField0_ & 0x00000010) == 0x00000010);
}
/**
- * <code>optional bool aBoolean = 5;</code>
+ * <code>optional bool booleanField = 5;</code>
*/
- public boolean getABoolean() {
- return aBoolean_;
+ public boolean getBooleanField() {
+ return booleanField_;
}
/**
- * <code>optional bool aBoolean = 5;</code>
+ * <code>optional bool booleanField = 5;</code>
*/
- public Builder setABoolean(boolean value) {
+ public Builder setBooleanField(boolean value) {
bitField0_ |= 0x00000010;
- aBoolean_ = value;
+ booleanField_ = value;
onChanged();
return this;
}
/**
- * <code>optional bool aBoolean = 5;</code>
+ * <code>optional bool booleanField = 5;</code>
*/
- public Builder clearABoolean() {
+ public Builder clearBooleanField() {
bitField0_ = (bitField0_ & ~0x00000010);
- aBoolean_ = false;
+ booleanField_ = false;
onChanged();
return this;
}
- private org.sonar.core.test.Test.FakeEnum anEnum_ = org.sonar.core.test.Test.FakeEnum.BLUE;
+ private org.sonar.core.test.Test.FakeEnum enumField_ = org.sonar.core.test.Test.FakeEnum.BLUE;
/**
- * <code>optional .FakeEnum anEnum = 6;</code>
+ * <code>optional .FakeEnum enumField = 6;</code>
*/
- public boolean hasAnEnum() {
+ public boolean hasEnumField() {
return ((bitField0_ & 0x00000020) == 0x00000020);
}
/**
- * <code>optional .FakeEnum anEnum = 6;</code>
+ * <code>optional .FakeEnum enumField = 6;</code>
*/
- public org.sonar.core.test.Test.FakeEnum getAnEnum() {
- return anEnum_;
+ public org.sonar.core.test.Test.FakeEnum getEnumField() {
+ return enumField_;
}
/**
- * <code>optional .FakeEnum anEnum = 6;</code>
+ * <code>optional .FakeEnum enumField = 6;</code>
*/
- public Builder setAnEnum(org.sonar.core.test.Test.FakeEnum value) {
+ public Builder setEnumField(org.sonar.core.test.Test.FakeEnum value) {
if (value == null) {
throw new NullPointerException();
}
bitField0_ |= 0x00000020;
- anEnum_ = value;
+ enumField_ = value;
onChanged();
return this;
}
/**
- * <code>optional .FakeEnum anEnum = 6;</code>
+ * <code>optional .FakeEnum enumField = 6;</code>
*/
- public Builder clearAnEnum() {
+ public Builder clearEnumField() {
bitField0_ = (bitField0_ & ~0x00000020);
- anEnum_ = org.sonar.core.test.Test.FakeEnum.BLUE;
+ enumField_ = org.sonar.core.test.Test.FakeEnum.BLUE;
onChanged();
return this;
}
- private com.google.protobuf.ByteString someBytes_ = com.google.protobuf.ByteString.EMPTY;
+ private com.google.protobuf.ByteString bytesField_ = com.google.protobuf.ByteString.EMPTY;
/**
- * <code>optional bytes someBytes = 7;</code>
+ * <code>optional bytes bytesField = 7;</code>
*/
- public boolean hasSomeBytes() {
+ public boolean hasBytesField() {
return ((bitField0_ & 0x00000040) == 0x00000040);
}
/**
- * <code>optional bytes someBytes = 7;</code>
+ * <code>optional bytes bytesField = 7;</code>
*/
- public com.google.protobuf.ByteString getSomeBytes() {
- return someBytes_;
+ public com.google.protobuf.ByteString getBytesField() {
+ return bytesField_;
}
/**
- * <code>optional bytes someBytes = 7;</code>
+ * <code>optional bytes bytesField = 7;</code>
*/
- public Builder setSomeBytes(com.google.protobuf.ByteString value) {
+ public Builder setBytesField(com.google.protobuf.ByteString value) {
if (value == null) {
throw new NullPointerException();
}
bitField0_ |= 0x00000040;
- someBytes_ = value;
+ bytesField_ = value;
onChanged();
return this;
}
/**
- * <code>optional bytes someBytes = 7;</code>
+ * <code>optional bytes bytesField = 7;</code>
*/
- public Builder clearSomeBytes() {
+ public Builder clearBytesField() {
bitField0_ = (bitField0_ & ~0x00000040);
- someBytes_ = getDefaultInstance().getSomeBytes();
+ bytesField_ = getDefaultInstance().getBytesField();
onChanged();
return this;
}
+ private org.sonar.core.test.Test.NestedJsonTest nested_ = org.sonar.core.test.Test.NestedJsonTest.getDefaultInstance();
+ private com.google.protobuf.SingleFieldBuilder<
+ org.sonar.core.test.Test.NestedJsonTest, org.sonar.core.test.Test.NestedJsonTest.Builder, org.sonar.core.test.Test.NestedJsonTestOrBuilder> nestedBuilder_;
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ public boolean hasNested() {
+ return ((bitField0_ & 0x00000080) == 0x00000080);
+ }
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ public org.sonar.core.test.Test.NestedJsonTest getNested() {
+ if (nestedBuilder_ == null) {
+ return nested_;
+ } else {
+ return nestedBuilder_.getMessage();
+ }
+ }
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ public Builder setNested(org.sonar.core.test.Test.NestedJsonTest value) {
+ if (nestedBuilder_ == null) {
+ if (value == null) {
+ throw new NullPointerException();
+ }
+ nested_ = value;
+ onChanged();
+ } else {
+ nestedBuilder_.setMessage(value);
+ }
+ bitField0_ |= 0x00000080;
+ return this;
+ }
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ public Builder setNested(
+ org.sonar.core.test.Test.NestedJsonTest.Builder builderForValue) {
+ if (nestedBuilder_ == null) {
+ nested_ = builderForValue.build();
+ onChanged();
+ } else {
+ nestedBuilder_.setMessage(builderForValue.build());
+ }
+ bitField0_ |= 0x00000080;
+ return this;
+ }
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ public Builder mergeNested(org.sonar.core.test.Test.NestedJsonTest value) {
+ if (nestedBuilder_ == null) {
+ if (((bitField0_ & 0x00000080) == 0x00000080) &&
+ nested_ != org.sonar.core.test.Test.NestedJsonTest.getDefaultInstance()) {
+ nested_ =
+ org.sonar.core.test.Test.NestedJsonTest.newBuilder(nested_).mergeFrom(value).buildPartial();
+ } else {
+ nested_ = value;
+ }
+ onChanged();
+ } else {
+ nestedBuilder_.mergeFrom(value);
+ }
+ bitField0_ |= 0x00000080;
+ return this;
+ }
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ public Builder clearNested() {
+ if (nestedBuilder_ == null) {
+ nested_ = org.sonar.core.test.Test.NestedJsonTest.getDefaultInstance();
+ onChanged();
+ } else {
+ nestedBuilder_.clear();
+ }
+ bitField0_ = (bitField0_ & ~0x00000080);
+ return this;
+ }
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ public org.sonar.core.test.Test.NestedJsonTest.Builder getNestedBuilder() {
+ bitField0_ |= 0x00000080;
+ onChanged();
+ return getNestedFieldBuilder().getBuilder();
+ }
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ public org.sonar.core.test.Test.NestedJsonTestOrBuilder getNestedOrBuilder() {
+ if (nestedBuilder_ != null) {
+ return nestedBuilder_.getMessageOrBuilder();
+ } else {
+ return nested_;
+ }
+ }
+ /**
+ * <code>optional .NestedJsonTest nested = 8;</code>
+ */
+ private com.google.protobuf.SingleFieldBuilder<
+ org.sonar.core.test.Test.NestedJsonTest, org.sonar.core.test.Test.NestedJsonTest.Builder, org.sonar.core.test.Test.NestedJsonTestOrBuilder>
+ getNestedFieldBuilder() {
+ if (nestedBuilder_ == null) {
+ nestedBuilder_ = new com.google.protobuf.SingleFieldBuilder<
+ org.sonar.core.test.Test.NestedJsonTest, org.sonar.core.test.Test.NestedJsonTest.Builder, org.sonar.core.test.Test.NestedJsonTestOrBuilder>(
+ getNested(),
+ getParentForChildren(),
+ isClean());
+ nested_ = null;
+ }
+ return nestedBuilder_;
+ }
+
private com.google.protobuf.LazyStringList anArray_ = com.google.protobuf.LazyStringArrayList.EMPTY;
private void ensureAnArrayIsMutable() {
- if (!((bitField0_ & 0x00000080) == 0x00000080)) {
+ if (!((bitField0_ & 0x00000100) == 0x00000100)) {
anArray_ = new com.google.protobuf.LazyStringArrayList(anArray_);
- bitField0_ |= 0x00000080;
+ bitField0_ |= 0x00000100;
}
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public com.google.protobuf.ProtocolStringList
getAnArrayList() {
return anArray_.getUnmodifiableView();
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public int getAnArrayCount() {
return anArray_.size();
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public java.lang.String getAnArray(int index) {
return anArray_.get(index);
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public com.google.protobuf.ByteString
getAnArrayBytes(int index) {
return anArray_.getByteString(index);
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public Builder setAnArray(
int index, java.lang.String value) {
@@ -1254,7 +1924,7 @@ public final class Test {
return this;
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public Builder addAnArray(
java.lang.String value) {
@@ -1267,7 +1937,7 @@ public final class Test {
return this;
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public Builder addAllAnArray(
java.lang.Iterable<java.lang.String> values) {
@@ -1278,16 +1948,16 @@ public final class Test {
return this;
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public Builder clearAnArray() {
anArray_ = com.google.protobuf.LazyStringArrayList.EMPTY;
- bitField0_ = (bitField0_ & ~0x00000080);
+ bitField0_ = (bitField0_ & ~0x00000100);
onChanged();
return this;
}
/**
- * <code>repeated string anArray = 8;</code>
+ * <code>repeated string anArray = 9;</code>
*/
public Builder addAnArrayBytes(
com.google.protobuf.ByteString value) {
@@ -1300,135 +1970,639 @@ public final class Test {
return this;
}
- private org.sonar.core.test.Test.NestedFake aNestedMessage_ = org.sonar.core.test.Test.NestedFake.getDefaultInstance();
- private com.google.protobuf.SingleFieldBuilder<
- org.sonar.core.test.Test.NestedFake, org.sonar.core.test.Test.NestedFake.Builder, org.sonar.core.test.Test.NestedFakeOrBuilder> aNestedMessageBuilder_;
+ // @@protoc_insertion_point(builder_scope:JsonTest)
+ }
+
+ static {
+ defaultInstance = new JsonTest(true);
+ defaultInstance.initFields();
+ }
+
+ // @@protoc_insertion_point(class_scope:JsonTest)
+ }
+
+ public interface JsonArrayTestOrBuilder extends
+ // @@protoc_insertion_point(interface_extends:JsonArrayTest)
+ com.google.protobuf.MessageOrBuilder {
+
+ /**
+ * <code>optional bool aNullableArrayPresentIfEmpty = 1;</code>
+ *
+ * <pre>
+ * naming convention. A boolean field is used
+ * to know if the array field is present.
+ * </pre>
+ */
+ boolean hasANullableArrayPresentIfEmpty();
+ /**
+ * <code>optional bool aNullableArrayPresentIfEmpty = 1;</code>
+ *
+ * <pre>
+ * naming convention. A boolean field is used
+ * to know if the array field is present.
+ * </pre>
+ */
+ boolean getANullableArrayPresentIfEmpty();
+
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ com.google.protobuf.ProtocolStringList
+ getANullableArrayList();
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ int getANullableArrayCount();
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ java.lang.String getANullableArray(int index);
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ com.google.protobuf.ByteString
+ getANullableArrayBytes(int index);
+ }
+ /**
+ * Protobuf type {@code JsonArrayTest}
+ */
+ public static final class JsonArrayTest extends
+ com.google.protobuf.GeneratedMessage implements
+ // @@protoc_insertion_point(message_implements:JsonArrayTest)
+ JsonArrayTestOrBuilder {
+ // Use JsonArrayTest.newBuilder() to construct.
+ private JsonArrayTest(com.google.protobuf.GeneratedMessage.Builder<?> builder) {
+ super(builder);
+ this.unknownFields = builder.getUnknownFields();
+ }
+ private JsonArrayTest(boolean noInit) { this.unknownFields = com.google.protobuf.UnknownFieldSet.getDefaultInstance(); }
+
+ private static final JsonArrayTest defaultInstance;
+ public static JsonArrayTest getDefaultInstance() {
+ return defaultInstance;
+ }
+
+ public JsonArrayTest getDefaultInstanceForType() {
+ return defaultInstance;
+ }
+
+ private final com.google.protobuf.UnknownFieldSet unknownFields;
+ @java.lang.Override
+ public final com.google.protobuf.UnknownFieldSet
+ getUnknownFields() {
+ return this.unknownFields;
+ }
+ private JsonArrayTest(
+ com.google.protobuf.CodedInputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ initFields();
+ int mutable_bitField0_ = 0;
+ com.google.protobuf.UnknownFieldSet.Builder unknownFields =
+ com.google.protobuf.UnknownFieldSet.newBuilder();
+ try {
+ boolean done = false;
+ while (!done) {
+ int tag = input.readTag();
+ switch (tag) {
+ case 0:
+ done = true;
+ break;
+ default: {
+ if (!parseUnknownField(input, unknownFields,
+ extensionRegistry, tag)) {
+ done = true;
+ }
+ break;
+ }
+ case 8: {
+ bitField0_ |= 0x00000001;
+ aNullableArrayPresentIfEmpty_ = input.readBool();
+ break;
+ }
+ case 18: {
+ com.google.protobuf.ByteString bs = input.readBytes();
+ if (!((mutable_bitField0_ & 0x00000002) == 0x00000002)) {
+ aNullableArray_ = new com.google.protobuf.LazyStringArrayList();
+ mutable_bitField0_ |= 0x00000002;
+ }
+ aNullableArray_.add(bs);
+ break;
+ }
+ }
+ }
+ } catch (com.google.protobuf.InvalidProtocolBufferException e) {
+ throw e.setUnfinishedMessage(this);
+ } catch (java.io.IOException e) {
+ throw new com.google.protobuf.InvalidProtocolBufferException(
+ e.getMessage()).setUnfinishedMessage(this);
+ } finally {
+ if (((mutable_bitField0_ & 0x00000002) == 0x00000002)) {
+ aNullableArray_ = aNullableArray_.getUnmodifiableView();
+ }
+ this.unknownFields = unknownFields.build();
+ makeExtensionsImmutable();
+ }
+ }
+ public static final com.google.protobuf.Descriptors.Descriptor
+ getDescriptor() {
+ return org.sonar.core.test.Test.internal_static_JsonArrayTest_descriptor;
+ }
+
+ protected com.google.protobuf.GeneratedMessage.FieldAccessorTable
+ internalGetFieldAccessorTable() {
+ return org.sonar.core.test.Test.internal_static_JsonArrayTest_fieldAccessorTable
+ .ensureFieldAccessorsInitialized(
+ org.sonar.core.test.Test.JsonArrayTest.class, org.sonar.core.test.Test.JsonArrayTest.Builder.class);
+ }
+
+ public static com.google.protobuf.Parser<JsonArrayTest> PARSER =
+ new com.google.protobuf.AbstractParser<JsonArrayTest>() {
+ public JsonArrayTest parsePartialFrom(
+ com.google.protobuf.CodedInputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ return new JsonArrayTest(input, extensionRegistry);
+ }
+ };
+
+ @java.lang.Override
+ public com.google.protobuf.Parser<JsonArrayTest> getParserForType() {
+ return PARSER;
+ }
+
+ private int bitField0_;
+ public static final int ANULLABLEARRAYPRESENTIFEMPTY_FIELD_NUMBER = 1;
+ private boolean aNullableArrayPresentIfEmpty_;
+ /**
+ * <code>optional bool aNullableArrayPresentIfEmpty = 1;</code>
+ *
+ * <pre>
+ * naming convention. A boolean field is used
+ * to know if the array field is present.
+ * </pre>
+ */
+ public boolean hasANullableArrayPresentIfEmpty() {
+ return ((bitField0_ & 0x00000001) == 0x00000001);
+ }
+ /**
+ * <code>optional bool aNullableArrayPresentIfEmpty = 1;</code>
+ *
+ * <pre>
+ * naming convention. A boolean field is used
+ * to know if the array field is present.
+ * </pre>
+ */
+ public boolean getANullableArrayPresentIfEmpty() {
+ return aNullableArrayPresentIfEmpty_;
+ }
+
+ public static final int ANULLABLEARRAY_FIELD_NUMBER = 2;
+ private com.google.protobuf.LazyStringList aNullableArray_;
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ public com.google.protobuf.ProtocolStringList
+ getANullableArrayList() {
+ return aNullableArray_;
+ }
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ public int getANullableArrayCount() {
+ return aNullableArray_.size();
+ }
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ public java.lang.String getANullableArray(int index) {
+ return aNullableArray_.get(index);
+ }
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ public com.google.protobuf.ByteString
+ getANullableArrayBytes(int index) {
+ return aNullableArray_.getByteString(index);
+ }
+
+ private void initFields() {
+ aNullableArrayPresentIfEmpty_ = false;
+ aNullableArray_ = com.google.protobuf.LazyStringArrayList.EMPTY;
+ }
+ private byte memoizedIsInitialized = -1;
+ public final boolean isInitialized() {
+ byte isInitialized = memoizedIsInitialized;
+ if (isInitialized == 1) return true;
+ if (isInitialized == 0) return false;
+
+ memoizedIsInitialized = 1;
+ return true;
+ }
+
+ public void writeTo(com.google.protobuf.CodedOutputStream output)
+ throws java.io.IOException {
+ getSerializedSize();
+ if (((bitField0_ & 0x00000001) == 0x00000001)) {
+ output.writeBool(1, aNullableArrayPresentIfEmpty_);
+ }
+ for (int i = 0; i < aNullableArray_.size(); i++) {
+ output.writeBytes(2, aNullableArray_.getByteString(i));
+ }
+ getUnknownFields().writeTo(output);
+ }
+
+ private int memoizedSerializedSize = -1;
+ public int getSerializedSize() {
+ int size = memoizedSerializedSize;
+ if (size != -1) return size;
+
+ size = 0;
+ if (((bitField0_ & 0x00000001) == 0x00000001)) {
+ size += com.google.protobuf.CodedOutputStream
+ .computeBoolSize(1, aNullableArrayPresentIfEmpty_);
+ }
+ {
+ int dataSize = 0;
+ for (int i = 0; i < aNullableArray_.size(); i++) {
+ dataSize += com.google.protobuf.CodedOutputStream
+ .computeBytesSizeNoTag(aNullableArray_.getByteString(i));
+ }
+ size += dataSize;
+ size += 1 * getANullableArrayList().size();
+ }
+ size += getUnknownFields().getSerializedSize();
+ memoizedSerializedSize = size;
+ return size;
+ }
+
+ private static final long serialVersionUID = 0L;
+ @java.lang.Override
+ protected java.lang.Object writeReplace()
+ throws java.io.ObjectStreamException {
+ return super.writeReplace();
+ }
+
+ public static org.sonar.core.test.Test.JsonArrayTest parseFrom(
+ com.google.protobuf.ByteString data)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ return PARSER.parseFrom(data);
+ }
+ public static org.sonar.core.test.Test.JsonArrayTest parseFrom(
+ com.google.protobuf.ByteString data,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ return PARSER.parseFrom(data, extensionRegistry);
+ }
+ public static org.sonar.core.test.Test.JsonArrayTest parseFrom(byte[] data)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ return PARSER.parseFrom(data);
+ }
+ public static org.sonar.core.test.Test.JsonArrayTest parseFrom(
+ byte[] data,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws com.google.protobuf.InvalidProtocolBufferException {
+ return PARSER.parseFrom(data, extensionRegistry);
+ }
+ public static org.sonar.core.test.Test.JsonArrayTest parseFrom(java.io.InputStream input)
+ throws java.io.IOException {
+ return PARSER.parseFrom(input);
+ }
+ public static org.sonar.core.test.Test.JsonArrayTest parseFrom(
+ java.io.InputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws java.io.IOException {
+ return PARSER.parseFrom(input, extensionRegistry);
+ }
+ public static org.sonar.core.test.Test.JsonArrayTest parseDelimitedFrom(java.io.InputStream input)
+ throws java.io.IOException {
+ return PARSER.parseDelimitedFrom(input);
+ }
+ public static org.sonar.core.test.Test.JsonArrayTest parseDelimitedFrom(
+ java.io.InputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws java.io.IOException {
+ return PARSER.parseDelimitedFrom(input, extensionRegistry);
+ }
+ public static org.sonar.core.test.Test.JsonArrayTest parseFrom(
+ com.google.protobuf.CodedInputStream input)
+ throws java.io.IOException {
+ return PARSER.parseFrom(input);
+ }
+ public static org.sonar.core.test.Test.JsonArrayTest parseFrom(
+ com.google.protobuf.CodedInputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws java.io.IOException {
+ return PARSER.parseFrom(input, extensionRegistry);
+ }
+
+ public static Builder newBuilder() { return Builder.create(); }
+ public Builder newBuilderForType() { return newBuilder(); }
+ public static Builder newBuilder(org.sonar.core.test.Test.JsonArrayTest prototype) {
+ return newBuilder().mergeFrom(prototype);
+ }
+ public Builder toBuilder() { return newBuilder(this); }
+
+ @java.lang.Override
+ protected Builder newBuilderForType(
+ com.google.protobuf.GeneratedMessage.BuilderParent parent) {
+ Builder builder = new Builder(parent);
+ return builder;
+ }
+ /**
+ * Protobuf type {@code JsonArrayTest}
+ */
+ public static final class Builder extends
+ com.google.protobuf.GeneratedMessage.Builder<Builder> implements
+ // @@protoc_insertion_point(builder_implements:JsonArrayTest)
+ org.sonar.core.test.Test.JsonArrayTestOrBuilder {
+ public static final com.google.protobuf.Descriptors.Descriptor
+ getDescriptor() {
+ return org.sonar.core.test.Test.internal_static_JsonArrayTest_descriptor;
+ }
+
+ protected com.google.protobuf.GeneratedMessage.FieldAccessorTable
+ internalGetFieldAccessorTable() {
+ return org.sonar.core.test.Test.internal_static_JsonArrayTest_fieldAccessorTable
+ .ensureFieldAccessorsInitialized(
+ org.sonar.core.test.Test.JsonArrayTest.class, org.sonar.core.test.Test.JsonArrayTest.Builder.class);
+ }
+
+ // Construct using org.sonar.core.test.Test.JsonArrayTest.newBuilder()
+ private Builder() {
+ maybeForceBuilderInitialization();
+ }
+
+ private Builder(
+ com.google.protobuf.GeneratedMessage.BuilderParent parent) {
+ super(parent);
+ maybeForceBuilderInitialization();
+ }
+ private void maybeForceBuilderInitialization() {
+ if (com.google.protobuf.GeneratedMessage.alwaysUseFieldBuilders) {
+ }
+ }
+ private static Builder create() {
+ return new Builder();
+ }
+
+ public Builder clear() {
+ super.clear();
+ aNullableArrayPresentIfEmpty_ = false;
+ bitField0_ = (bitField0_ & ~0x00000001);
+ aNullableArray_ = com.google.protobuf.LazyStringArrayList.EMPTY;
+ bitField0_ = (bitField0_ & ~0x00000002);
+ return this;
+ }
+
+ public Builder clone() {
+ return create().mergeFrom(buildPartial());
+ }
+
+ public com.google.protobuf.Descriptors.Descriptor
+ getDescriptorForType() {
+ return org.sonar.core.test.Test.internal_static_JsonArrayTest_descriptor;
+ }
+
+ public org.sonar.core.test.Test.JsonArrayTest getDefaultInstanceForType() {
+ return org.sonar.core.test.Test.JsonArrayTest.getDefaultInstance();
+ }
+
+ public org.sonar.core.test.Test.JsonArrayTest build() {
+ org.sonar.core.test.Test.JsonArrayTest result = buildPartial();
+ if (!result.isInitialized()) {
+ throw newUninitializedMessageException(result);
+ }
+ return result;
+ }
+
+ public org.sonar.core.test.Test.JsonArrayTest buildPartial() {
+ org.sonar.core.test.Test.JsonArrayTest result = new org.sonar.core.test.Test.JsonArrayTest(this);
+ int from_bitField0_ = bitField0_;
+ int to_bitField0_ = 0;
+ if (((from_bitField0_ & 0x00000001) == 0x00000001)) {
+ to_bitField0_ |= 0x00000001;
+ }
+ result.aNullableArrayPresentIfEmpty_ = aNullableArrayPresentIfEmpty_;
+ if (((bitField0_ & 0x00000002) == 0x00000002)) {
+ aNullableArray_ = aNullableArray_.getUnmodifiableView();
+ bitField0_ = (bitField0_ & ~0x00000002);
+ }
+ result.aNullableArray_ = aNullableArray_;
+ result.bitField0_ = to_bitField0_;
+ onBuilt();
+ return result;
+ }
+
+ public Builder mergeFrom(com.google.protobuf.Message other) {
+ if (other instanceof org.sonar.core.test.Test.JsonArrayTest) {
+ return mergeFrom((org.sonar.core.test.Test.JsonArrayTest)other);
+ } else {
+ super.mergeFrom(other);
+ return this;
+ }
+ }
+
+ public Builder mergeFrom(org.sonar.core.test.Test.JsonArrayTest other) {
+ if (other == org.sonar.core.test.Test.JsonArrayTest.getDefaultInstance()) return this;
+ if (other.hasANullableArrayPresentIfEmpty()) {
+ setANullableArrayPresentIfEmpty(other.getANullableArrayPresentIfEmpty());
+ }
+ if (!other.aNullableArray_.isEmpty()) {
+ if (aNullableArray_.isEmpty()) {
+ aNullableArray_ = other.aNullableArray_;
+ bitField0_ = (bitField0_ & ~0x00000002);
+ } else {
+ ensureANullableArrayIsMutable();
+ aNullableArray_.addAll(other.aNullableArray_);
+ }
+ onChanged();
+ }
+ this.mergeUnknownFields(other.getUnknownFields());
+ return this;
+ }
+
+ public final boolean isInitialized() {
+ return true;
+ }
+
+ public Builder mergeFrom(
+ com.google.protobuf.CodedInputStream input,
+ com.google.protobuf.ExtensionRegistryLite extensionRegistry)
+ throws java.io.IOException {
+ org.sonar.core.test.Test.JsonArrayTest parsedMessage = null;
+ try {
+ parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
+ } catch (com.google.protobuf.InvalidProtocolBufferException e) {
+ parsedMessage = (org.sonar.core.test.Test.JsonArrayTest) e.getUnfinishedMessage();
+ throw e;
+ } finally {
+ if (parsedMessage != null) {
+ mergeFrom(parsedMessage);
+ }
+ }
+ return this;
+ }
+ private int bitField0_;
+
+ private boolean aNullableArrayPresentIfEmpty_ ;
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>optional bool aNullableArrayPresentIfEmpty = 1;</code>
+ *
+ * <pre>
+ * naming convention. A boolean field is used
+ * to know if the array field is present.
+ * </pre>
*/
- public boolean hasANestedMessage() {
- return ((bitField0_ & 0x00000100) == 0x00000100);
+ public boolean hasANullableArrayPresentIfEmpty() {
+ return ((bitField0_ & 0x00000001) == 0x00000001);
}
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>optional bool aNullableArrayPresentIfEmpty = 1;</code>
+ *
+ * <pre>
+ * naming convention. A boolean field is used
+ * to know if the array field is present.
+ * </pre>
*/
- public org.sonar.core.test.Test.NestedFake getANestedMessage() {
- if (aNestedMessageBuilder_ == null) {
- return aNestedMessage_;
- } else {
- return aNestedMessageBuilder_.getMessage();
- }
+ public boolean getANullableArrayPresentIfEmpty() {
+ return aNullableArrayPresentIfEmpty_;
}
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>optional bool aNullableArrayPresentIfEmpty = 1;</code>
+ *
+ * <pre>
+ * naming convention. A boolean field is used
+ * to know if the array field is present.
+ * </pre>
*/
- public Builder setANestedMessage(org.sonar.core.test.Test.NestedFake value) {
- if (aNestedMessageBuilder_ == null) {
- if (value == null) {
- throw new NullPointerException();
- }
- aNestedMessage_ = value;
- onChanged();
- } else {
- aNestedMessageBuilder_.setMessage(value);
- }
- bitField0_ |= 0x00000100;
+ public Builder setANullableArrayPresentIfEmpty(boolean value) {
+ bitField0_ |= 0x00000001;
+ aNullableArrayPresentIfEmpty_ = value;
+ onChanged();
return this;
}
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>optional bool aNullableArrayPresentIfEmpty = 1;</code>
+ *
+ * <pre>
+ * naming convention. A boolean field is used
+ * to know if the array field is present.
+ * </pre>
*/
- public Builder setANestedMessage(
- org.sonar.core.test.Test.NestedFake.Builder builderForValue) {
- if (aNestedMessageBuilder_ == null) {
- aNestedMessage_ = builderForValue.build();
- onChanged();
- } else {
- aNestedMessageBuilder_.setMessage(builderForValue.build());
- }
- bitField0_ |= 0x00000100;
+ public Builder clearANullableArrayPresentIfEmpty() {
+ bitField0_ = (bitField0_ & ~0x00000001);
+ aNullableArrayPresentIfEmpty_ = false;
+ onChanged();
return this;
}
+
+ private com.google.protobuf.LazyStringList aNullableArray_ = com.google.protobuf.LazyStringArrayList.EMPTY;
+ private void ensureANullableArrayIsMutable() {
+ if (!((bitField0_ & 0x00000002) == 0x00000002)) {
+ aNullableArray_ = new com.google.protobuf.LazyStringArrayList(aNullableArray_);
+ bitField0_ |= 0x00000002;
+ }
+ }
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>repeated string aNullableArray = 2;</code>
*/
- public Builder mergeANestedMessage(org.sonar.core.test.Test.NestedFake value) {
- if (aNestedMessageBuilder_ == null) {
- if (((bitField0_ & 0x00000100) == 0x00000100) &&
- aNestedMessage_ != org.sonar.core.test.Test.NestedFake.getDefaultInstance()) {
- aNestedMessage_ =
- org.sonar.core.test.Test.NestedFake.newBuilder(aNestedMessage_).mergeFrom(value).buildPartial();
- } else {
- aNestedMessage_ = value;
- }
- onChanged();
- } else {
- aNestedMessageBuilder_.mergeFrom(value);
- }
- bitField0_ |= 0x00000100;
+ public com.google.protobuf.ProtocolStringList
+ getANullableArrayList() {
+ return aNullableArray_.getUnmodifiableView();
+ }
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ public int getANullableArrayCount() {
+ return aNullableArray_.size();
+ }
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ public java.lang.String getANullableArray(int index) {
+ return aNullableArray_.get(index);
+ }
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ public com.google.protobuf.ByteString
+ getANullableArrayBytes(int index) {
+ return aNullableArray_.getByteString(index);
+ }
+ /**
+ * <code>repeated string aNullableArray = 2;</code>
+ */
+ public Builder setANullableArray(
+ int index, java.lang.String value) {
+ if (value == null) {
+ throw new NullPointerException();
+ }
+ ensureANullableArrayIsMutable();
+ aNullableArray_.set(index, value);
+ onChanged();
return this;
}
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>repeated string aNullableArray = 2;</code>
*/
- public Builder clearANestedMessage() {
- if (aNestedMessageBuilder_ == null) {
- aNestedMessage_ = org.sonar.core.test.Test.NestedFake.getDefaultInstance();
- onChanged();
- } else {
- aNestedMessageBuilder_.clear();
- }
- bitField0_ = (bitField0_ & ~0x00000100);
+ public Builder addANullableArray(
+ java.lang.String value) {
+ if (value == null) {
+ throw new NullPointerException();
+ }
+ ensureANullableArrayIsMutable();
+ aNullableArray_.add(value);
+ onChanged();
return this;
}
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>repeated string aNullableArray = 2;</code>
*/
- public org.sonar.core.test.Test.NestedFake.Builder getANestedMessageBuilder() {
- bitField0_ |= 0x00000100;
+ public Builder addAllANullableArray(
+ java.lang.Iterable<java.lang.String> values) {
+ ensureANullableArrayIsMutable();
+ com.google.protobuf.AbstractMessageLite.Builder.addAll(
+ values, aNullableArray_);
onChanged();
- return getANestedMessageFieldBuilder().getBuilder();
+ return this;
}
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>repeated string aNullableArray = 2;</code>
*/
- public org.sonar.core.test.Test.NestedFakeOrBuilder getANestedMessageOrBuilder() {
- if (aNestedMessageBuilder_ != null) {
- return aNestedMessageBuilder_.getMessageOrBuilder();
- } else {
- return aNestedMessage_;
- }
+ public Builder clearANullableArray() {
+ aNullableArray_ = com.google.protobuf.LazyStringArrayList.EMPTY;
+ bitField0_ = (bitField0_ & ~0x00000002);
+ onChanged();
+ return this;
}
/**
- * <code>optional .NestedFake aNestedMessage = 9;</code>
+ * <code>repeated string aNullableArray = 2;</code>
*/
- private com.google.protobuf.SingleFieldBuilder<
- org.sonar.core.test.Test.NestedFake, org.sonar.core.test.Test.NestedFake.Builder, org.sonar.core.test.Test.NestedFakeOrBuilder>
- getANestedMessageFieldBuilder() {
- if (aNestedMessageBuilder_ == null) {
- aNestedMessageBuilder_ = new com.google.protobuf.SingleFieldBuilder<
- org.sonar.core.test.Test.NestedFake, org.sonar.core.test.Test.NestedFake.Builder, org.sonar.core.test.Test.NestedFakeOrBuilder>(
- getANestedMessage(),
- getParentForChildren(),
- isClean());
- aNestedMessage_ = null;
- }
- return aNestedMessageBuilder_;
+ public Builder addANullableArrayBytes(
+ com.google.protobuf.ByteString value) {
+ if (value == null) {
+ throw new NullPointerException();
+ }
+ ensureANullableArrayIsMutable();
+ aNullableArray_.add(value);
+ onChanged();
+ return this;
}
- // @@protoc_insertion_point(builder_scope:Fake)
+ // @@protoc_insertion_point(builder_scope:JsonArrayTest)
}
static {
- defaultInstance = new Fake(true);
+ defaultInstance = new JsonArrayTest(true);
defaultInstance.initFields();
}
- // @@protoc_insertion_point(class_scope:Fake)
+ // @@protoc_insertion_point(class_scope:JsonArrayTest)
}
- public interface NestedFakeOrBuilder extends
- // @@protoc_insertion_point(interface_extends:NestedFake)
+ public interface NestedJsonTestOrBuilder extends
+ // @@protoc_insertion_point(interface_extends:NestedJsonTest)
com.google.protobuf.MessageOrBuilder {
/**
@@ -1446,25 +2620,25 @@ public final class Test {
getLabelBytes();
}
/**
- * Protobuf type {@code NestedFake}
+ * Protobuf type {@code NestedJsonTest}
*/
- public static final class NestedFake extends
+ public static final class NestedJsonTest extends
com.google.protobuf.GeneratedMessage implements
- // @@protoc_insertion_point(message_implements:NestedFake)
- NestedFakeOrBuilder {
- // Use NestedFake.newBuilder() to construct.
- private NestedFake(com.google.protobuf.GeneratedMessage.Builder<?> builder) {
+ // @@protoc_insertion_point(message_implements:NestedJsonTest)
+ NestedJsonTestOrBuilder {
+ // Use NestedJsonTest.newBuilder() to construct.
+ private NestedJsonTest(com.google.protobuf.GeneratedMessage.Builder<?> builder) {
super(builder);
this.unknownFields = builder.getUnknownFields();
}
- private NestedFake(boolean noInit) { this.unknownFields = com.google.protobuf.UnknownFieldSet.getDefaultInstance(); }
+ private NestedJsonTest(boolean noInit) { this.unknownFields = com.google.protobuf.UnknownFieldSet.getDefaultInstance(); }
- private static final NestedFake defaultInstance;
- public static NestedFake getDefaultInstance() {
+ private static final NestedJsonTest defaultInstance;
+ public static NestedJsonTest getDefaultInstance() {
return defaultInstance;
}
- public NestedFake getDefaultInstanceForType() {
+ public NestedJsonTest getDefaultInstanceForType() {
return defaultInstance;
}
@@ -1474,7 +2648,7 @@ public final class Test {
getUnknownFields() {
return this.unknownFields;
}
- private NestedFake(
+ private NestedJsonTest(
com.google.protobuf.CodedInputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws com.google.protobuf.InvalidProtocolBufferException {
@@ -1517,28 +2691,28 @@ public final class Test {
}
public static final com.google.protobuf.Descriptors.Descriptor
getDescriptor() {
- return org.sonar.core.test.Test.internal_static_NestedFake_descriptor;
+ return org.sonar.core.test.Test.internal_static_NestedJsonTest_descriptor;
}
protected com.google.protobuf.GeneratedMessage.FieldAccessorTable
internalGetFieldAccessorTable() {
- return org.sonar.core.test.Test.internal_static_NestedFake_fieldAccessorTable
+ return org.sonar.core.test.Test.internal_static_NestedJsonTest_fieldAccessorTable
.ensureFieldAccessorsInitialized(
- org.sonar.core.test.Test.NestedFake.class, org.sonar.core.test.Test.NestedFake.Builder.class);
+ org.sonar.core.test.Test.NestedJsonTest.class, org.sonar.core.test.Test.NestedJsonTest.Builder.class);
}
- public static com.google.protobuf.Parser<NestedFake> PARSER =
- new com.google.protobuf.AbstractParser<NestedFake>() {
- public NestedFake parsePartialFrom(
+ public static com.google.protobuf.Parser<NestedJsonTest> PARSER =
+ new com.google.protobuf.AbstractParser<NestedJsonTest>() {
+ public NestedJsonTest parsePartialFrom(
com.google.protobuf.CodedInputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws com.google.protobuf.InvalidProtocolBufferException {
- return new NestedFake(input, extensionRegistry);
+ return new NestedJsonTest(input, extensionRegistry);
}
};
@java.lang.Override
- public com.google.protobuf.Parser<NestedFake> getParserForType() {
+ public com.google.protobuf.Parser<NestedJsonTest> getParserForType() {
return PARSER;
}
@@ -1629,53 +2803,53 @@ public final class Test {
return super.writeReplace();
}
- public static org.sonar.core.test.Test.NestedFake parseFrom(
+ public static org.sonar.core.test.Test.NestedJsonTest parseFrom(
com.google.protobuf.ByteString data)
throws com.google.protobuf.InvalidProtocolBufferException {
return PARSER.parseFrom(data);
}
- public static org.sonar.core.test.Test.NestedFake parseFrom(
+ public static org.sonar.core.test.Test.NestedJsonTest parseFrom(
com.google.protobuf.ByteString data,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws com.google.protobuf.InvalidProtocolBufferException {
return PARSER.parseFrom(data, extensionRegistry);
}
- public static org.sonar.core.test.Test.NestedFake parseFrom(byte[] data)
+ public static org.sonar.core.test.Test.NestedJsonTest parseFrom(byte[] data)
throws com.google.protobuf.InvalidProtocolBufferException {
return PARSER.parseFrom(data);
}
- public static org.sonar.core.test.Test.NestedFake parseFrom(
+ public static org.sonar.core.test.Test.NestedJsonTest parseFrom(
byte[] data,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws com.google.protobuf.InvalidProtocolBufferException {
return PARSER.parseFrom(data, extensionRegistry);
}
- public static org.sonar.core.test.Test.NestedFake parseFrom(java.io.InputStream input)
+ public static org.sonar.core.test.Test.NestedJsonTest parseFrom(java.io.InputStream input)
throws java.io.IOException {
return PARSER.parseFrom(input);
}
- public static org.sonar.core.test.Test.NestedFake parseFrom(
+ public static org.sonar.core.test.Test.NestedJsonTest parseFrom(
java.io.InputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws java.io.IOException {
return PARSER.parseFrom(input, extensionRegistry);
}
- public static org.sonar.core.test.Test.NestedFake parseDelimitedFrom(java.io.InputStream input)
+ public static org.sonar.core.test.Test.NestedJsonTest parseDelimitedFrom(java.io.InputStream input)
throws java.io.IOException {
return PARSER.parseDelimitedFrom(input);
}
- public static org.sonar.core.test.Test.NestedFake parseDelimitedFrom(
+ public static org.sonar.core.test.Test.NestedJsonTest parseDelimitedFrom(
java.io.InputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws java.io.IOException {
return PARSER.parseDelimitedFrom(input, extensionRegistry);
}
- public static org.sonar.core.test.Test.NestedFake parseFrom(
+ public static org.sonar.core.test.Test.NestedJsonTest parseFrom(
com.google.protobuf.CodedInputStream input)
throws java.io.IOException {
return PARSER.parseFrom(input);
}
- public static org.sonar.core.test.Test.NestedFake parseFrom(
+ public static org.sonar.core.test.Test.NestedJsonTest parseFrom(
com.google.protobuf.CodedInputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws java.io.IOException {
@@ -1684,7 +2858,7 @@ public final class Test {
public static Builder newBuilder() { return Builder.create(); }
public Builder newBuilderForType() { return newBuilder(); }
- public static Builder newBuilder(org.sonar.core.test.Test.NestedFake prototype) {
+ public static Builder newBuilder(org.sonar.core.test.Test.NestedJsonTest prototype) {
return newBuilder().mergeFrom(prototype);
}
public Builder toBuilder() { return newBuilder(this); }
@@ -1696,25 +2870,25 @@ public final class Test {
return builder;
}
/**
- * Protobuf type {@code NestedFake}
+ * Protobuf type {@code NestedJsonTest}
*/
public static final class Builder extends
com.google.protobuf.GeneratedMessage.Builder<Builder> implements
- // @@protoc_insertion_point(builder_implements:NestedFake)
- org.sonar.core.test.Test.NestedFakeOrBuilder {
+ // @@protoc_insertion_point(builder_implements:NestedJsonTest)
+ org.sonar.core.test.Test.NestedJsonTestOrBuilder {
public static final com.google.protobuf.Descriptors.Descriptor
getDescriptor() {
- return org.sonar.core.test.Test.internal_static_NestedFake_descriptor;
+ return org.sonar.core.test.Test.internal_static_NestedJsonTest_descriptor;
}
protected com.google.protobuf.GeneratedMessage.FieldAccessorTable
internalGetFieldAccessorTable() {
- return org.sonar.core.test.Test.internal_static_NestedFake_fieldAccessorTable
+ return org.sonar.core.test.Test.internal_static_NestedJsonTest_fieldAccessorTable
.ensureFieldAccessorsInitialized(
- org.sonar.core.test.Test.NestedFake.class, org.sonar.core.test.Test.NestedFake.Builder.class);
+ org.sonar.core.test.Test.NestedJsonTest.class, org.sonar.core.test.Test.NestedJsonTest.Builder.class);
}
- // Construct using org.sonar.core.test.Test.NestedFake.newBuilder()
+ // Construct using org.sonar.core.test.Test.NestedJsonTest.newBuilder()
private Builder() {
maybeForceBuilderInitialization();
}
@@ -1745,23 +2919,23 @@ public final class Test {
public com.google.protobuf.Descriptors.Descriptor
getDescriptorForType() {
- return org.sonar.core.test.Test.internal_static_NestedFake_descriptor;
+ return org.sonar.core.test.Test.internal_static_NestedJsonTest_descriptor;
}
- public org.sonar.core.test.Test.NestedFake getDefaultInstanceForType() {
- return org.sonar.core.test.Test.NestedFake.getDefaultInstance();
+ public org.sonar.core.test.Test.NestedJsonTest getDefaultInstanceForType() {
+ return org.sonar.core.test.Test.NestedJsonTest.getDefaultInstance();
}
- public org.sonar.core.test.Test.NestedFake build() {
- org.sonar.core.test.Test.NestedFake result = buildPartial();
+ public org.sonar.core.test.Test.NestedJsonTest build() {
+ org.sonar.core.test.Test.NestedJsonTest result = buildPartial();
if (!result.isInitialized()) {
throw newUninitializedMessageException(result);
}
return result;
}
- public org.sonar.core.test.Test.NestedFake buildPartial() {
- org.sonar.core.test.Test.NestedFake result = new org.sonar.core.test.Test.NestedFake(this);
+ public org.sonar.core.test.Test.NestedJsonTest buildPartial() {
+ org.sonar.core.test.Test.NestedJsonTest result = new org.sonar.core.test.Test.NestedJsonTest(this);
int from_bitField0_ = bitField0_;
int to_bitField0_ = 0;
if (((from_bitField0_ & 0x00000001) == 0x00000001)) {
@@ -1774,16 +2948,16 @@ public final class Test {
}
public Builder mergeFrom(com.google.protobuf.Message other) {
- if (other instanceof org.sonar.core.test.Test.NestedFake) {
- return mergeFrom((org.sonar.core.test.Test.NestedFake)other);
+ if (other instanceof org.sonar.core.test.Test.NestedJsonTest) {
+ return mergeFrom((org.sonar.core.test.Test.NestedJsonTest)other);
} else {
super.mergeFrom(other);
return this;
}
}
- public Builder mergeFrom(org.sonar.core.test.Test.NestedFake other) {
- if (other == org.sonar.core.test.Test.NestedFake.getDefaultInstance()) return this;
+ public Builder mergeFrom(org.sonar.core.test.Test.NestedJsonTest other) {
+ if (other == org.sonar.core.test.Test.NestedJsonTest.getDefaultInstance()) return this;
if (other.hasLabel()) {
bitField0_ |= 0x00000001;
label_ = other.label_;
@@ -1801,11 +2975,11 @@ public final class Test {
com.google.protobuf.CodedInputStream input,
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
throws java.io.IOException {
- org.sonar.core.test.Test.NestedFake parsedMessage = null;
+ org.sonar.core.test.Test.NestedJsonTest parsedMessage = null;
try {
parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
} catch (com.google.protobuf.InvalidProtocolBufferException e) {
- parsedMessage = (org.sonar.core.test.Test.NestedFake) e.getUnfinishedMessage();
+ parsedMessage = (org.sonar.core.test.Test.NestedJsonTest) e.getUnfinishedMessage();
throw e;
} finally {
if (parsedMessage != null) {
@@ -1892,15 +3066,15 @@ public final class Test {
return this;
}
- // @@protoc_insertion_point(builder_scope:NestedFake)
+ // @@protoc_insertion_point(builder_scope:NestedJsonTest)
}
static {
- defaultInstance = new NestedFake(true);
+ defaultInstance = new NestedJsonTest(true);
defaultInstance.initFields();
}
- // @@protoc_insertion_point(class_scope:NestedFake)
+ // @@protoc_insertion_point(class_scope:NestedJsonTest)
}
private static final com.google.protobuf.Descriptors.Descriptor
@@ -1909,10 +3083,20 @@ public final class Test {
com.google.protobuf.GeneratedMessage.FieldAccessorTable
internal_static_Fake_fieldAccessorTable;
private static final com.google.protobuf.Descriptors.Descriptor
- internal_static_NestedFake_descriptor;
+ internal_static_JsonTest_descriptor;
private static
com.google.protobuf.GeneratedMessage.FieldAccessorTable
- internal_static_NestedFake_fieldAccessorTable;
+ internal_static_JsonTest_fieldAccessorTable;
+ private static final com.google.protobuf.Descriptors.Descriptor
+ internal_static_JsonArrayTest_descriptor;
+ private static
+ com.google.protobuf.GeneratedMessage.FieldAccessorTable
+ internal_static_JsonArrayTest_fieldAccessorTable;
+ private static final com.google.protobuf.Descriptors.Descriptor
+ internal_static_NestedJsonTest_descriptor;
+ private static
+ com.google.protobuf.GeneratedMessage.FieldAccessorTable
+ internal_static_NestedJsonTest_fieldAccessorTable;
public static com.google.protobuf.Descriptors.FileDescriptor
getDescriptor() {
@@ -1922,14 +3106,18 @@ public final class Test {
descriptor;
static {
java.lang.String[] descriptorData = {
- "\n\ntest.proto\"\274\001\n\004Fake\022\017\n\007aString\030\001 \001(\t\022\r" +
- "\n\005anInt\030\002 \001(\005\022\r\n\005aLong\030\003 \001(\003\022\017\n\007aDouble\030" +
- "\004 \001(\001\022\020\n\010aBoolean\030\005 \001(\010\022\031\n\006anEnum\030\006 \001(\0162" +
- "\t.FakeEnum\022\021\n\tsomeBytes\030\007 \001(\014\022\017\n\007anArray" +
- "\030\010 \003(\t\022#\n\016aNestedMessage\030\t \001(\0132\013.NestedF" +
- "ake\"\033\n\nNestedFake\022\r\n\005label\030\001 \001(\t*(\n\010Fake" +
- "Enum\022\010\n\004BLUE\020\000\022\007\n\003RED\020\001\022\t\n\005GREEN\020\002B\027\n\023or" +
- "g.sonar.core.testH\001"
+ "\n\ntest.proto\"#\n\004Fake\022\r\n\005label\030\001 \001(\t\022\014\n\004l" +
+ "ine\030\002 \001(\005\"\323\001\n\010JsonTest\022\023\n\013stringField\030\001 " +
+ "\001(\t\022\020\n\010intField\030\002 \001(\005\022\021\n\tlongField\030\003 \001(\003" +
+ "\022\023\n\013doubleField\030\004 \001(\001\022\024\n\014booleanField\030\005 " +
+ "\001(\010\022\034\n\tenumField\030\006 \001(\0162\t.FakeEnum\022\022\n\nbyt" +
+ "esField\030\007 \001(\014\022\037\n\006nested\030\010 \001(\0132\017.NestedJs" +
+ "onTest\022\017\n\007anArray\030\t \003(\t\"M\n\rJsonArrayTest" +
+ "\022$\n\034aNullableArrayPresentIfEmpty\030\001 \001(\010\022\026" +
+ "\n\016aNullableArray\030\002 \003(\t\"\037\n\016NestedJsonTest" +
+ "\022\r\n\005label\030\001 \001(\t*(\n\010FakeEnum\022\010\n\004BLUE\020\000\022\007\n",
+ "\003RED\020\001\022\t\n\005GREEN\020\002B\027\n\023org.sonar.core.test" +
+ "H\001"
};
com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner =
new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() {
@@ -1948,12 +3136,24 @@ public final class Test {
internal_static_Fake_fieldAccessorTable = new
com.google.protobuf.GeneratedMessage.FieldAccessorTable(
internal_static_Fake_descriptor,
- new java.lang.String[] { "AString", "AnInt", "ALong", "ADouble", "ABoolean", "AnEnum", "SomeBytes", "AnArray", "ANestedMessage", });
- internal_static_NestedFake_descriptor =
+ new java.lang.String[] { "Label", "Line", });
+ internal_static_JsonTest_descriptor =
getDescriptor().getMessageTypes().get(1);
- internal_static_NestedFake_fieldAccessorTable = new
+ internal_static_JsonTest_fieldAccessorTable = new
+ com.google.protobuf.GeneratedMessage.FieldAccessorTable(
+ internal_static_JsonTest_descriptor,
+ new java.lang.String[] { "StringField", "IntField", "LongField", "DoubleField", "BooleanField", "EnumField", "BytesField", "Nested", "AnArray", });
+ internal_static_JsonArrayTest_descriptor =
+ getDescriptor().getMessageTypes().get(2);
+ internal_static_JsonArrayTest_fieldAccessorTable = new
+ com.google.protobuf.GeneratedMessage.FieldAccessorTable(
+ internal_static_JsonArrayTest_descriptor,
+ new java.lang.String[] { "ANullableArrayPresentIfEmpty", "ANullableArray", });
+ internal_static_NestedJsonTest_descriptor =
+ getDescriptor().getMessageTypes().get(3);
+ internal_static_NestedJsonTest_fieldAccessorTable = new
com.google.protobuf.GeneratedMessage.FieldAccessorTable(
- internal_static_NestedFake_descriptor,
+ internal_static_NestedJsonTest_descriptor,
new java.lang.String[] { "Label", });
}
diff --git a/sonar-core/src/test/java/org/sonar/core/util/ProtobufJsonFormatTest.java b/sonar-core/src/test/java/org/sonar/core/util/ProtobufJsonFormatTest.java
index d81033e5fd8..19a4e09a176 100644
--- a/sonar-core/src/test/java/org/sonar/core/util/ProtobufJsonFormatTest.java
+++ b/sonar-core/src/test/java/org/sonar/core/util/ProtobufJsonFormatTest.java
@@ -25,9 +25,12 @@ import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.ExpectedException;
import org.sonar.api.utils.text.JsonWriter;
+import org.sonar.core.test.Test.JsonArrayTest;
+import org.sonar.core.test.Test.JsonTest;
import static java.util.Arrays.asList;
import static org.assertj.core.api.Assertions.assertThat;
+import static org.sonar.core.util.ProtobufJsonFormat.toJson;
public class ProtobufJsonFormatTest {
@@ -35,49 +38,100 @@ public class ProtobufJsonFormatTest {
public ExpectedException expectedException = ExpectedException.none();
@Test
- public void convert_protobuf_to_json() throws Exception {
- org.sonar.core.test.Test.Fake protobuf = org.sonar.core.test.Test.Fake.newBuilder()
- .setAString("foo")
- .setAnInt(10)
- .setALong(100L)
- .setABoolean(true)
- .setADouble(3.14)
- .setAnEnum(org.sonar.core.test.Test.FakeEnum.GREEN)
+ public void convert_protobuf_to_json() {
+ JsonTest protobuf = JsonTest.newBuilder()
+ .setStringField("foo")
+ .setIntField(10)
+ .setLongField(100L)
+ .setDoubleField(3.14)
+ .setBooleanField(true)
+ .setEnumField(org.sonar.core.test.Test.FakeEnum.GREEN)
.addAllAnArray(asList("one", "two", "three"))
- .setANestedMessage(org.sonar.core.test.Test.NestedFake.newBuilder().setLabel("bar").build())
+ .setNested(org.sonar.core.test.Test.NestedJsonTest.newBuilder().setLabel("bar").build())
.build();
- StringWriter json = new StringWriter();
- JsonWriter jsonWriter = JsonWriter.of(json);
- ProtobufJsonFormat.write(protobuf, jsonWriter);
-
- assertThat(json.toString())
- .isEqualTo("{\"aString\":\"foo\",\"anInt\":10,\"aLong\":100,\"aDouble\":3.14,\"aBoolean\":true,\"anEnum\":\"GREEN\",\"anArray\":[\"one\",\"two\",\"three\"],\"aNestedMessage\":{\"label\":\"bar\"}}");
+ assertThat(toJson(protobuf))
+ .isEqualTo(
+ "{\"stringField\":\"foo\",\"intField\":10,\"longField\":100,\"doubleField\":3.14,\"booleanField\":true,\"enumField\":\"GREEN\",\"nested\":{\"label\":\"bar\"},\"anArray\":[\"one\",\"two\",\"three\"]}");
}
@Test
- public void protobuf_bytes_field_can_not_be_converted_to_json() throws Exception {
+ public void protobuf_bytes_field_can_not_be_converted_to_json() {
expectedException.expect(RuntimeException.class);
- expectedException.expectMessage("JSON format does not support the binary field 'someBytes'");
+ expectedException.expectMessage("JSON format does not support type 'BYTE_STRING' of field 'bytesField'");
- org.sonar.core.test.Test.Fake protobuf = org.sonar.core.test.Test.Fake.newBuilder()
- .setSomeBytes(ByteString.copyFrom(new byte[]{2, 4}))
+ JsonTest protobuf = JsonTest.newBuilder()
+ .setBytesField(ByteString.copyFrom(new byte[]{2, 4}))
.build();
ProtobufJsonFormat.write(protobuf, JsonWriter.of(new StringWriter()));
}
@Test
- public void protobuf_empty_strings_are_not_output() throws Exception {
- org.sonar.core.test.Test.Fake protobuf = org.sonar.core.test.Test.Fake.newBuilder().build();
+ public void protobuf_absent_fields_are_not_output() {
+ JsonTest msg = JsonTest.newBuilder().build();
+
+ // fields are absent
+ assertThat(msg.hasStringField()).isFalse();
+ assertThat(msg.hasIntField()).isFalse();
+
+ // the repeated field "anArray" is always present. This is the standard behavior of protobuf. It
+ // does not make the difference between null and empty arrays.
+ assertThat(toJson(msg)).isEqualTo("{\"anArray\":[]}");
+ }
+
+ @Test
+ public void protobuf_present_and_empty_string_field_is_output() {
+ JsonTest msg = JsonTest.newBuilder().setStringField("").build();
+
+ // field is present
+ assertThat(msg.hasStringField()).isTrue();
+ assertThat(msg.getStringField()).isEqualTo("");
+
+ assertThat(toJson(msg)).contains("\"stringField\":\"\"");
+ }
+
+
+ @Test
+ public void protobuf_empty_array_marked_as_present_is_output() {
+ JsonArrayTest msg = JsonArrayTest.newBuilder()
+ .setANullableArrayPresentIfEmpty(true)
+ .build();
+
+ // repeated field "aNullableArray" is marked as present through the boolean field "aNullableArrayPresentIfEmpty"
+ assertThat(msg.hasANullableArrayPresentIfEmpty()).isTrue();
+ assertThat(msg.getANullableArrayPresentIfEmpty()).isTrue();
+
+ // JSON contains the repeated field, but not the boolean marker field
+ assertThat(toJson(msg)).isEqualTo("{\"aNullableArray\":[]}");
+ }
+
+ @Test
+ public void protobuf_empty_array_marked_as_absent_is_not_output() {
+ JsonArrayTest msg = JsonArrayTest.newBuilder()
+ .setANullableArrayPresentIfEmpty(false)
+ .build();
+
+ // repeated field "aNullableArray" is marked as absent through the boolean field "aNullableArrayPresentIfEmpty"
+ assertThat(msg.hasANullableArrayPresentIfEmpty()).isTrue();
+ assertThat(msg.getANullableArrayPresentIfEmpty()).isFalse();
+
+ // JSON does not contain the array nor the boolean marker
+ assertThat(toJson(msg)).isEqualTo("{}");
+ }
+
+ @Test
+ public void protobuf_non_empty_array_is_output_even_if_not_marked_as_present() {
+ JsonArrayTest msg = JsonArrayTest.newBuilder()
+ .addANullableArray("foo")
+ .build();
- // field is not set but value is "", not null
- assertThat(protobuf.hasAString()).isFalse();
- assertThat(protobuf.getAString()).isEqualTo("");
+ // repeated field "aNullableArray" is present, but the boolean marker "aNullableArrayPresentIfEmpty"
+ // is not set.
+ assertThat(msg.hasANullableArrayPresentIfEmpty()).isFalse();
+ assertThat(msg.getANullableArrayPresentIfEmpty()).isFalse();
- StringWriter json = new StringWriter();
- JsonWriter jsonWriter = JsonWriter.of(json);
- ProtobufJsonFormat.write(protobuf, jsonWriter);
- assertThat(json.toString()).isEqualTo("{}");
+ // JSON contains the array but not the boolean marker
+ assertThat(toJson(msg)).isEqualTo("{\"aNullableArray\":[\"foo\"]}");
}
}
diff --git a/sonar-core/src/test/java/org/sonar/core/util/ProtobufTest.java b/sonar-core/src/test/java/org/sonar/core/util/ProtobufTest.java
index d0e0d603a5c..493da413789 100644
--- a/sonar-core/src/test/java/org/sonar/core/util/ProtobufTest.java
+++ b/sonar-core/src/test/java/org/sonar/core/util/ProtobufTest.java
@@ -84,17 +84,17 @@ public class ProtobufTest {
public void write_and_read_streams() throws Exception {
File file = temp.newFile();
- Fake item1 = Fake.newBuilder().setAString("one").setAnInt(1).build();
- Fake item2 = Fake.newBuilder().setAString("two").build();
+ Fake item1 = Fake.newBuilder().setLabel("one").setLine(1).build();
+ Fake item2 = Fake.newBuilder().setLabel("two").build();
Protobuf.writeStream(asList(item1, item2), file, false);
CloseableIterator<Fake> it = Protobuf.readStream(file, Fake.PARSER);
Fake read = it.next();
- assertThat(read.getAString()).isEqualTo("one");
- assertThat(read.getAnInt()).isEqualTo(1);
+ assertThat(read.getLabel()).isEqualTo("one");
+ assertThat(read.getLine()).isEqualTo(1);
read = it.next();
- assertThat(read.getAString()).isEqualTo("two");
- assertThat(read.hasAnInt()).isFalse();
+ assertThat(read.getLabel()).isEqualTo("two");
+ assertThat(read.hasLine()).isFalse();
assertThat(it.hasNext()).isFalse();
}
diff --git a/sonar-core/src/test/protobuf/test.proto b/sonar-core/src/test/protobuf/test.proto
index fa51e06995b..2e1c09a00ae 100644
--- a/sonar-core/src/test/protobuf/test.proto
+++ b/sonar-core/src/test/protobuf/test.proto
@@ -24,15 +24,8 @@ option java_package = "org.sonar.core.test";
option optimize_for = SPEED;
message Fake {
- optional string aString = 1;
- optional int32 anInt = 2;
- optional int64 aLong = 3;
- optional double aDouble = 4;
- optional bool aBoolean = 5;
- optional FakeEnum anEnum = 6;
- optional bytes someBytes = 7;
- repeated string anArray = 8;
- optional NestedFake aNestedMessage = 9;
+ optional string label = 1;
+ optional int32 line = 2;
}
enum FakeEnum {
@@ -41,6 +34,25 @@ enum FakeEnum {
GREEN = 2;
}
-message NestedFake {
+message JsonTest {
+ optional string stringField = 1;
+ optional int32 intField = 2;
+ optional int64 longField = 3;
+ optional double doubleField = 4;
+ optional bool booleanField = 5;
+ optional FakeEnum enumField = 6;
+ optional bytes bytesField = 7;
+ optional NestedJsonTest nested = 8;
+ repeated string anArray = 9;
+}
+
+message JsonArrayTest {
+// naming convention. A boolean field is used
+ // to know if the array field is present.
+ optional bool aNullableArrayPresentIfEmpty = 1;
+ repeated string aNullableArray = 2;
+}
+
+message NestedJsonTest {
optional string label = 1;
}