This commit is contained in:
redkale
2024-10-19 19:42:40 +08:00
parent 9a085536fb
commit 9cf402f18c
6 changed files with 41 additions and 10 deletions

View File

@@ -42,7 +42,7 @@ public class ProtobufArrayEncoder<T> extends ArrayEncoder<ProtobufWriter, T>
protected void convertObjectTo(final ProtobufWriter out, @Nonnull EnMember member, T[] value) {
ProtobufEncodeable itemEncoder = (ProtobufEncodeable) this.componentEncoder;
//out.writeArrayB(value.length, itemEncoder, value);
// out.writeArrayB(value.length, itemEncoder, value);
boolean first = true;
for (T item : value) {
if (!first) {
@@ -55,7 +55,7 @@ public class ProtobufArrayEncoder<T> extends ArrayEncoder<ProtobufWriter, T>
}
first = false;
}
//out.writeArrayE();
// out.writeArrayE();
}
protected void convertPrimitivedTo(final ProtobufWriter out, @Nonnull EnMember member, T[] value) {
@@ -70,6 +70,12 @@ public class ProtobufArrayEncoder<T> extends ArrayEncoder<ProtobufWriter, T>
}
}
// 对象是否为空
@Override
public boolean isEmpty(ProtobufWriter out, T[] value) {
return value == null || value.length == 0;
}
@Override
public int computeSize(ProtobufWriter out, int tagSize, T[] value) {
if (value == null || value.length == 0) {

View File

@@ -42,7 +42,7 @@ public class ProtobufCollectionEncoder<T> extends CollectionEncoder<ProtobufWrit
protected void convertObjectTo(final ProtobufWriter out, @Nonnull EnMember member, Collection<T> value) {
ProtobufEncodeable itemEncoder = (ProtobufEncodeable) this.componentEncoder;
//out.writeArrayB(value.size(), itemEncoder, value);
// out.writeArrayB(value.size(), itemEncoder, value);
boolean first = true;
for (T item : value) {
if (!first) {
@@ -55,7 +55,7 @@ public class ProtobufCollectionEncoder<T> extends CollectionEncoder<ProtobufWrit
}
first = false;
}
//out.writeArrayE();
// out.writeArrayE();
}
protected void convertPrimitivedTo(final ProtobufWriter out, @Nonnull EnMember member, Collection<T> value) {
@@ -70,6 +70,12 @@ public class ProtobufCollectionEncoder<T> extends CollectionEncoder<ProtobufWrit
}
}
// 对象是否为空
@Override
public boolean isEmpty(ProtobufWriter out, Collection<T> value) {
return value == null || value.isEmpty();
}
@Override
public int computeSize(ProtobufWriter out, int tagSize, Collection<T> value) {
if (value == null || value.isEmpty()) {

View File

@@ -24,8 +24,11 @@ public interface ProtobufEncodeable<W extends Writer, T> extends Encodeable<W, T
convertTo(out, value);
}
// 对象是否为空
default boolean isEmpty(W out, T value) {
return false;
}
// 计算内容长度
public int computeSize(ProtobufWriter out, int tagSize, T value);
}

View File

@@ -51,7 +51,7 @@ public class ProtobufMapEncoder<K, V> extends MapEncoder<ProtobufWriter, K, V>
BiFunction<K, V, V> mapFieldFunc = out.mapFieldFunc();
ProtobufEncodeable kencoder = (ProtobufEncodeable) this.keyEncoder;
ProtobufEncodeable vencoder = (ProtobufEncodeable) this.valueEncoder;
//out.writeMapB(values.size(), kencoder, vencoder, value);
// out.writeMapB(values.size(), kencoder, vencoder, value);
AtomicBoolean first = new AtomicBoolean(true);
values.forEach((key, val0) -> {
if (ignoreColumns == null || !ignoreColumns.contains(key.toString())) {
@@ -76,7 +76,7 @@ public class ProtobufMapEncoder<K, V> extends MapEncoder<ProtobufWriter, K, V>
first.set(false);
}
});
//out.writeMapE();
// out.writeMapE();
}
protected int computeSize(ProtobufWriter out, K key, V val) {
@@ -87,6 +87,12 @@ public class ProtobufMapEncoder<K, V> extends MapEncoder<ProtobufWriter, K, V>
return (keyMember.getTagSize() + keySize) + (valueMember.getTagSize() + valSize);
}
// 对象是否为空
@Override
public boolean isEmpty(ProtobufWriter out, Map<K, V> value) {
return value == null || value.isEmpty();
}
@Override
public int computeSize(ProtobufWriter out, int tagSize, Map<K, V> value) {
if (Utility.isEmpty(value)) {

View File

@@ -43,7 +43,7 @@ public class ProtobufStreamEncoder<T> extends StreamEncoder<ProtobufWriter, T>
protected void convertObjectTo(final ProtobufWriter out, @Nonnull EnMember member, Object[] value) {
ProtobufEncodeable itemEncoder = (ProtobufEncodeable) this.componentEncoder;
//out.writeArrayB(value.length, itemEncoder, value);
// out.writeArrayB(value.length, itemEncoder, value);
boolean first = true;
for (Object item : value) {
if (!first) {
@@ -56,7 +56,7 @@ public class ProtobufStreamEncoder<T> extends StreamEncoder<ProtobufWriter, T>
}
first = false;
}
//out.writeArrayE();
// out.writeArrayE();
}
protected void convertPrimitivedTo(final ProtobufWriter out, @Nonnull EnMember member, Object[] value) {
@@ -71,6 +71,13 @@ public class ProtobufStreamEncoder<T> extends StreamEncoder<ProtobufWriter, T>
}
}
// 对象是否为空
@Override
public boolean isEmpty(ProtobufWriter out, Stream<T> value) {
Object[] array = out.putStreamArray(value);
return array == null || array.length == 0;
}
@Override
public int computeSize(ProtobufWriter out, int tagSize, Stream<T> value) {
Object[] array = out.putStreamArray(value);

View File

@@ -1065,6 +1065,9 @@ public abstract class ProtobufWriter extends Writer {
return;
}
ProtobufEncodeable encoder = (ProtobufEncodeable) member.getEncoder();
if (encoder.isEmpty(this, value)) {
return;
}
this.writeField(member);
encoder.convertTo(this, member, value);
}