diff --git a/lib/xdrgen/generators/java.rb b/lib/xdrgen/generators/java.rb index e1562cf32..1c82dc8f6 100644 --- a/lib/xdrgen/generators/java.rb +++ b/lib/xdrgen/generators/java.rb @@ -48,56 +48,17 @@ def add_imports_for_definition(defn, imports) imports.add("java.io.ByteArrayOutputStream") case defn - when AST::Definitions::Struct ; - defn.members.each do |m| - if is_decl_array(m.declaration) - imports.add('java.util.Arrays') - else - imports.add('java.util.Objects') - end - end - # if we have more than one member field then the - # hash code will be computed by - # Objects.hash(field1, field2, ..., fieldN) - # therefore, we should always import java.util.Objects - if defn.members.length > 1 - imports.add("java.util.Objects") - end - when AST::Definitions::Enum ; - # no imports required for enums - when AST::Definitions::Union ; - nonVoidArms = defn.arms.select { |arm| !arm.void? } - # add 1 because of the discriminant - totalFields = nonVoidArms.length + 1 - - if is_type_array(defn.discriminant.type) - imports.add('java.util.Arrays') - else - imports.add('java.util.Objects') - end - - nonVoidArms.each do |a| - if is_decl_array(a.declaration) - imports.add('java.util.Arrays') - else - imports.add('java.util.Objects') - end - end - - # if we have more than one field then the - # hash code will be computed by - # Objects.hash(field1, field2, ..., fieldN) - # therefore, we should always import java.util.Objects - # if we have more than one field - if totalFields > 1 - imports.add("java.util.Objects") - end - when AST::Definitions::Typedef ; - if is_decl_array(defn.declaration) - imports.add('java.util.Arrays') - else - imports.add('java.util.Objects') - end + when AST::Definitions::Struct, AST::Definitions::Union + imports.add("lombok.Data") + imports.add("lombok.NoArgsConstructor") + imports.add("lombok.AllArgsConstructor") + imports.add("lombok.Builder") + imports.add("static #{@namespace}.Constants.*") + when AST::Definitions::Typedef + imports.add("lombok.Data") + imports.add("lombok.NoArgsConstructor") + imports.add("lombok.AllArgsConstructor") + imports.add("static #{@namespace}.Constants.*") end if defn.respond_to? :nested_definitions @@ -111,21 +72,21 @@ def render_definition(defn, constants_container) case defn when AST::Definitions::Struct ; - render_element "public class", imports, defn do |out| + render_element defn, imports, defn do |out| render_struct defn, out render_nested_definitions defn, out end when AST::Definitions::Enum ; - render_element "public enum", imports, defn do |out| + render_element defn, imports, defn do |out| render_enum defn, out end when AST::Definitions::Union ; - render_element "public class", imports, defn do |out| + render_element defn, imports, defn do |out| render_union defn, out render_nested_definitions defn, out end when AST::Definitions::Typedef ; - render_element "public class", imports, defn do |out| + render_element defn, imports, defn do |out| render_typedef defn, out end when AST::Definitions::Const ; @@ -142,6 +103,10 @@ def render_nested_definitions(defn, out, post_name="implements XdrElement") case ndefn when AST::Definitions::Struct ; name = name ndefn + out.puts "@Data" + out.puts "@NoArgsConstructor" + out.puts "@AllArgsConstructor" + out.puts "@Builder(toBuilder = true)" out.puts "public static class #{name} #{post_name} {" out.indent do render_struct ndefn, out @@ -157,6 +122,10 @@ def render_nested_definitions(defn, out, post_name="implements XdrElement") out.puts "}" when AST::Definitions::Union ; name = name ndefn + out.puts "@Data" + out.puts "@NoArgsConstructor" + out.puts "@AllArgsConstructor" + out.puts "@Builder(toBuilder = true)" out.puts "public static class #{name} #{post_name} {" out.indent do render_union ndefn, out @@ -165,6 +134,9 @@ def render_nested_definitions(defn, out, post_name="implements XdrElement") out.puts "}" when AST::Definitions::Typedef ; name = name ndefn + out.puts "@Data" + out.puts "@NoArgsConstructor" + out.puts "@AllArgsConstructor" out.puts "public static class #{name} #{post_name} {" out.indent do render_typedef ndefn, out @@ -174,18 +146,31 @@ def render_nested_definitions(defn, out, post_name="implements XdrElement") } end - def render_element(type, imports, element, post_name="implements XdrElement") + def render_element(defn, imports, element, post_name="implements XdrElement") path = element.name.camelize + ".java" name = name_string element.name out = @output.open(path) render_top_matter out - out.puts "import static #{@namespace}.Constants.*;" imports.each do |import| out.puts "import #{import};" end out.puts "\n" render_source_comment out, element - out.puts "#{type} #{name} #{post_name} {" + case defn + when AST::Definitions::Struct, AST::Definitions::Union + out.puts "@Data" + out.puts "@NoArgsConstructor" + out.puts "@AllArgsConstructor" + out.puts "@Builder(toBuilder = true)" + out.puts "public class #{name} #{post_name} {" + when AST::Definitions::Enum + out.puts "public enum #{name} #{post_name} {" + when AST::Definitions::Typedef + out.puts "@Data" + out.puts "@NoArgsConstructor" + out.puts "@AllArgsConstructor" + out.puts "public class #{name} #{post_name} {" + end out.indent do yield out out.unbreak @@ -208,20 +193,20 @@ def render_constants(constants_container) def render_enum(enum, out) out.balance_after /,[\s]*/ do - enum.members.each do |em| - out.puts "#{em.name}(#{em.value})," + enum.members.each_with_index do |em, index| + out.puts "#{em.name}(#{em.value})#{index == enum.members.size - 1 ? ';' : ','}" end end - out.puts ";\n" + out.break out.puts <<-EOS.strip_heredoc - private int mValue; + private final int value; #{name_string enum.name}(int value) { - mValue = value; + this.value = value; } public int getValue() { - return mValue; + return value; } public static #{name_string enum.name} decode(XdrDataInputStream stream) throws IOException { @@ -252,20 +237,10 @@ def render_enum(enum, out) end def render_struct(struct, out) - out.puts "public #{name struct} () {}" struct.members.each do |m| - out.puts <<-EOS.strip_heredoc - private #{decl_string(m.declaration)} #{m.name}; - public #{decl_string(m.declaration)} get#{m.name.slice(0,1).capitalize+m.name.slice(1..-1)}() { - return this.#{m.name}; - } - public void set#{m.name.slice(0,1).capitalize+m.name.slice(1..-1)}(#{decl_string m.declaration} value) { - this.#{m.name} = value; - } - EOS + out.puts "private #{decl_string(m.declaration)} #{m.name};" end - out.puts "public static void encode(XdrDataOutputStream stream, #{name struct} encoded#{name struct}) throws IOException{" struct.members.each do |m| out.indent do @@ -294,117 +269,12 @@ def render_struct(struct, out) end out.puts "}" - hashCodeExpression = case struct.members.length - when 0 - "0" - when 1 - if is_decl_array(struct.members[0].declaration) - "Arrays.hashCode(this.#{struct.members[0].name})" - else - "Objects.hash(this.#{struct.members[0].name})" - end - else - "Objects.hash(#{ - (struct.members.map { |m| - if is_decl_array(m.declaration) - "Arrays.hashCode(this.#{m.name})" - else - "this.#{m.name}" - end - }).join(", ") - })" - end - out.puts <<-EOS.strip_heredoc - @Override - public int hashCode() { - return #{hashCodeExpression}; - } - EOS - - equalParts = struct.members.map { |m| - if is_decl_array(m.declaration) - "Arrays.equals(this.#{m.name}, other.#{m.name})" - else - "Objects.equals(this.#{m.name}, other.#{m.name})" - end - } - equalExpression = case equalParts.length - when 0 - "true" - else - equalParts.join(" && ") - end - type = name struct - out.puts <<-EOS.strip_heredoc - @Override - public boolean equals(Object object) { - if (!(object instanceof #{type})) { - return false; - } - - #{type} other = (#{type}) object; - return #{equalExpression}; - } - - EOS - render_base64((name struct), out) - - out.puts "public static final class Builder {" - out.indent do - struct.members.map { |m| - out.puts "private #{decl_string(m.declaration)} #{m.name};" - } - - struct.members.map { |m| - out.puts <<-EOS.strip_heredoc - - public Builder #{m.name}(#{decl_string(m.declaration)} #{m.name}) { - this.#{m.name} = #{m.name}; - return this; - } - EOS - } - - end - - - out.indent do - out.break - out.puts "public #{name struct} build() {" - out.indent do - out.puts "#{name struct} val = new #{name struct}();" - struct.members.map { |m| - out.puts "val.set#{m.name.slice(0,1).capitalize+m.name.slice(1..-1)}(this.#{m.name});" - } - out.puts "return val;" - end - out.puts "}" - end - out.puts "}" out.break end def render_typedef(typedef, out) - out.puts <<-EOS.strip_heredoc - private #{decl_string typedef.declaration} #{typedef.name}; - - public #{typedef.name.camelize}() {} - - public #{typedef.name.camelize}(#{decl_string typedef.declaration} #{typedef.name}) { - this.#{typedef.name} = #{typedef.name}; - } - - public #{decl_string typedef.declaration} get#{typedef.name.slice(0,1).capitalize+typedef.name.slice(1..-1)}() { - return this.#{typedef.name}; - } - - public void set#{typedef.name.slice(0,1).capitalize+typedef.name.slice(1..-1)}(#{decl_string typedef.declaration} value) { - this.#{typedef.name} = value; - } - - EOS - + out.puts "private #{decl_string typedef.declaration} #{typedef.name};" out.puts "public static void encode(XdrDataOutputStream stream, #{name typedef} encoded#{name typedef}) throws IOException {" out.indent do encode_member "encoded#{name typedef}", typedef, out @@ -428,113 +298,17 @@ def render_typedef(typedef, out) end out.puts "}" out.break - - hash_coder_for_decl = - if is_decl_array(typedef.declaration) - "Arrays.hashCode" - else - "Objects.hash" - end - out.puts <<-EOS.strip_heredoc - @Override - public int hashCode() { - return #{hash_coder_for_decl}(this.#{typedef.name}); - } - - EOS - - equals_for_decl = - if is_decl_array(typedef.declaration) - "Arrays.equals" - else - "Objects.equals" - end - type = name_string typedef.name - out.puts <<-EOS.strip_heredoc - @Override - public boolean equals(Object object) { - if (!(object instanceof #{type})) { - return false; - } - - #{type} other = (#{type}) object; - return #{equals_for_decl}(this.#{typedef.name}, other.#{typedef.name}); - } - EOS render_base64(typedef.name.camelize, out) end def render_union(union, out) - out.puts "public #{name union} () {}" - out.puts <<-EOS.strip_heredoc - #{type_string union.discriminant.type} #{union.discriminant.name}; - public #{type_string union.discriminant.type} getDiscriminant() { - return this.#{union.discriminant.name}; - } - public void setDiscriminant(#{type_string union.discriminant.type} value) { - this.#{union.discriminant.name} = value; - } - EOS + out.puts "private #{type_string union.discriminant.type} discriminant;" union.arms.each do |arm| next if arm.void? - out.puts <<-EOS.strip_heredoc - private #{decl_string(arm.declaration)} #{arm.name}; - public #{decl_string(arm.declaration)} get#{arm.name.slice(0,1).capitalize+arm.name.slice(1..-1)}() { - return this.#{arm.name}; - } - public void set#{arm.name.slice(0,1).capitalize+arm.name.slice(1..-1)}(#{decl_string arm.declaration} value) { - this.#{arm.name} = value; - } - EOS - end - out.break - - out.puts "public static final class Builder {" - out.indent do - out.puts "private #{type_string union.discriminant.type} discriminant;" - union.arms.each do |arm| - next if arm.void? - out.puts "private #{decl_string(arm.declaration)} #{arm.name};" - end - out.break - - out.puts <<-EOS.strip_heredoc - public Builder discriminant(#{type_string union.discriminant.type} discriminant) { - this.discriminant = discriminant; - return this; - } - EOS - - union.arms.each do |arm| - next if arm.void? - out.puts <<-EOS.strip_heredoc - - public Builder #{arm.name}(#{decl_string(arm.declaration)} #{arm.name}) { - this.#{arm.name} = #{arm.name}; - return this; - } - EOS - end - end - - out.indent do - out.break - out.puts "public #{name union} build() {" - out.indent do - out.puts "#{name union} val = new #{name union}();" - out.puts "val.setDiscriminant(discriminant);" - union.arms.each do |arm| - next if arm.void? - out.puts "val.set#{arm.name.slice(0,1).capitalize+arm.name.slice(1..-1)}(this.#{arm.name});" - end - out.puts "return val;" - end - out.puts "}" + out.puts "private #{decl_string(arm.declaration)} #{arm.name};" end - out.puts "}" out.break - out.puts "public static void encode(XdrDataOutputStream stream, #{name union} encoded#{name union}) throws IOException {" out.puts('//' + union.discriminant.type.class.to_s) out.puts("//" + type_string(union.discriminant.type)) @@ -622,65 +396,6 @@ def render_union(union, out) out.puts "return decoded#{name union};" end out.puts "}" - - nonVoidArms = union.arms.select { |arm| !arm.void? } - - discriminantPart = if is_type_array(union.discriminant.type) - "Arrays.hashCode(this.#{union.discriminant.name})" - else - "this.#{union.discriminant.name}" - end - - parts = nonVoidArms.map { |a| - if is_decl_array(a.declaration) - "Arrays.hashCode(this.#{a.name})" - else - "this.#{a.name}" - end - } - parts.append(discriminantPart) - - hashCodeExpression = "Objects.hash(#{parts.join(", ")})" - out.puts <<-EOS.strip_heredoc - @Override - public int hashCode() { - return #{hashCodeExpression}; - } - EOS - - equalParts = nonVoidArms.map { |a| - if is_decl_array(a.declaration) - "Arrays.equals(this.#{a.name}, other.#{a.name})" - else - "Objects.equals(this.#{a.name}, other.#{a.name})" - end - } - equalParts.append( - if is_type_array(union.discriminant.type) - "Arrays.equals(this.#{union.discriminant.name}, other.#{union.discriminant.name})" - else - "Objects.equals(this.#{union.discriminant.name}, other.#{union.discriminant.name})" - end - ) - - equalExpression = case equalParts.length - when 0 - "true" - else - equalParts.join(" && ") - end - type = name union - out.puts <<-EOS.strip_heredoc - @Override - public boolean equals(Object object) { - if (!(object instanceof #{type})) { - return false; - } - - #{type} other = (#{type}) object; - return #{equalExpression}; - } - EOS render_base64((name union), out) out.break end @@ -748,20 +463,20 @@ def encode_member(value, member, out) end case member.declaration when AST::Declarations::Opaque ; - out.puts "int #{member.name}size = #{value}.#{member.name}.length;" + out.puts "int #{member.name}Size = #{value}.#{member.name}.length;" unless member.declaration.fixed? - out.puts "stream.writeInt(#{member.name}size);" + out.puts "stream.writeInt(#{member.name}Size);" end out.puts <<-EOS.strip_heredoc - stream.write(#{value}.get#{member.name.slice(0,1).capitalize+member.name.slice(1..-1)}(), 0, #{member.name}size); + stream.write(#{value}.get#{member.name.slice(0,1).capitalize+member.name.slice(1..-1)}(), 0, #{member.name}Size); EOS when AST::Declarations::Array ; - out.puts "int #{member.name}size = #{value}.get#{member.name.slice(0,1).capitalize+member.name.slice(1..-1)}().length;" + out.puts "int #{member.name}Size = #{value}.get#{member.name.slice(0,1).capitalize+member.name.slice(1..-1)}().length;" unless member.declaration.fixed? - out.puts "stream.writeInt(#{member.name}size);" + out.puts "stream.writeInt(#{member.name}Size);" end out.puts <<-EOS.strip_heredoc - for (int i = 0; i < #{member.name}size; i++) { + for (int i = 0; i < #{member.name}Size; i++) { #{encode_type member.declaration.type, "#{value}.#{member.name}[i]"}; } EOS @@ -818,23 +533,23 @@ def decode_member(value, member, out) case member.declaration when AST::Declarations::Opaque ; if (member.declaration.fixed?) - out.puts "int #{member.name}size = #{member.declaration.size};" + out.puts "int #{member.name}Size = #{member.declaration.size};" else - out.puts "int #{member.name}size = stream.readInt();" + out.puts "int #{member.name}Size = stream.readInt();" end out.puts <<-EOS.strip_heredoc - #{value}.#{member.name} = new byte[#{member.name}size]; - stream.read(#{value}.#{member.name}, 0, #{member.name}size); + #{value}.#{member.name} = new byte[#{member.name}Size]; + stream.read(#{value}.#{member.name}, 0, #{member.name}Size); EOS when AST::Declarations::Array ; if (member.declaration.fixed?) - out.puts "int #{member.name}size = #{member.declaration.size};" + out.puts "int #{member.name}Size = #{member.declaration.size};" else - out.puts "int #{member.name}size = stream.readInt();" + out.puts "int #{member.name}Size = stream.readInt();" end out.puts <<-EOS.strip_heredoc - #{value}.#{member.name} = new #{type_string member.type}[#{member.name}size]; - for (int i = 0; i < #{member.name}size; i++) { + #{value}.#{member.name} = new #{type_string member.type}[#{member.name}Size]; + for (int i = 0; i < #{member.name}Size; i++) { #{value}.#{member.name}[i] = #{decode_type member.declaration}; } EOS diff --git a/lib/xdrgen/generators/java/XdrString.erb b/lib/xdrgen/generators/java/XdrString.erb index bfad40c7f..89a2b0931 100644 --- a/lib/xdrgen/generators/java/XdrString.erb +++ b/lib/xdrgen/generators/java/XdrString.erb @@ -4,90 +4,72 @@ import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InvalidClassException; -import java.nio.charset.Charset; -import java.util.Arrays; +import java.nio.charset.StandardCharsets; +import lombok.Value; import org.stellar.sdk.Base64Factory; +@Value public class XdrString implements XdrElement { - private byte[] bytes; + byte[] bytes; - public XdrString(byte[] bytes) { - this.bytes = bytes; - } + public XdrString(byte[] bytes) { + this.bytes = bytes; + } - public XdrString(String text) { - this.bytes = text.getBytes(Charset.forName("UTF-8")); - } + public XdrString(String text) { + this.bytes = text.getBytes(StandardCharsets.UTF_8); + } - @Override - public void encode(XdrDataOutputStream stream) throws IOException { - stream.writeInt(this.bytes.length); - stream.write(this.bytes, 0, this.bytes.length); - } + @Override + public void encode(XdrDataOutputStream stream) throws IOException { + stream.writeInt(this.bytes.length); + stream.write(this.bytes, 0, this.bytes.length); + } - public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { - int size = stream.readInt(); - if (size > maxSize) { - throw new InvalidClassException("String length "+size+" exceeds max size "+maxSize); - } - byte[] bytes = new byte[size]; - stream.read(bytes); - return new XdrString(bytes); + public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { + int size = stream.readInt(); + if (size > maxSize) { + throw new InvalidClassException("String length " + size + " exceeds max size " + maxSize); } + byte[] bytes = new byte[size]; + stream.read(bytes); + return new XdrString(bytes); + } - public byte[] getBytes() { - return this.bytes; - } + @Override + public String toXdrBase64() throws IOException { + return Base64Factory.getInstance().encodeToString(toXdrByteArray()); + } - @Override - public String toXdrBase64() throws IOException { - return Base64Factory.getInstance().encodeToString(toXdrByteArray()); - } - - @Override - public byte[] toXdrByteArray() throws IOException { - ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); - encode(xdrDataOutputStream); - return byteArrayOutputStream.toByteArray(); - } - - public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { - byte[] bytes = Base64Factory.getInstance().decode(xdr); - return fromXdrByteArray(bytes, maxSize); - } - - public static XdrString fromXdrBase64(String xdr) throws IOException { - return fromXdrBase64(xdr, Integer.MAX_VALUE); - } - - public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { - ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); - XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); - return decode(xdrDataInputStream, maxSize); - } - - public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { - return fromXdrByteArray(xdr, Integer.MAX_VALUE); - } + @Override + public byte[] toXdrByteArray() throws IOException { + ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); + XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); + encode(xdrDataOutputStream); + return byteArrayOutputStream.toByteArray(); + } - @Override - public int hashCode() { - return Arrays.hashCode(this.bytes); - } + public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { + byte[] bytes = Base64Factory.getInstance().decode(xdr); + return fromXdrByteArray(bytes, maxSize); + } - @Override - public boolean equals(Object object) { - if (object == null || !(object instanceof XdrString)) { - return false; - } + public static XdrString fromXdrBase64(String xdr) throws IOException { + return fromXdrBase64(xdr, Integer.MAX_VALUE); + } - XdrString other = (XdrString) object; - return Arrays.equals(this.bytes, other.bytes); - } + public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { + ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); + XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); + return decode(xdrDataInputStream, maxSize); + } - @Override - public String toString() { - return new String(bytes, Charset.forName("UTF-8")); - } -} \ No newline at end of file + public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { + return fromXdrByteArray(xdr, Integer.MAX_VALUE); + } + + @Override + public String toString() { + return new String(bytes, StandardCharsets.UTF_8); + } +} diff --git a/lib/xdrgen/generators/java/XdrUnsignedHyperInteger.erb b/lib/xdrgen/generators/java/XdrUnsignedHyperInteger.erb index 6c05ca57d..6c732ebc9 100644 --- a/lib/xdrgen/generators/java/XdrUnsignedHyperInteger.erb +++ b/lib/xdrgen/generators/java/XdrUnsignedHyperInteger.erb @@ -1,10 +1,10 @@ -package org.stellar.sdk.xdr; +package <%= @namespace %>; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.math.BigInteger; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -13,10 +13,11 @@ import org.stellar.sdk.Base64Factory; * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedHyperInteger implements XdrElement { public static final BigInteger MAX_VALUE = new BigInteger("18446744073709551615"); public static final BigInteger MIN_VALUE = BigInteger.ZERO; - private final BigInteger number; + BigInteger number; public XdrUnsignedHyperInteger(BigInteger number) { if (number.compareTo(MIN_VALUE) < 0 || number.compareTo(MAX_VALUE) > 0) { @@ -55,10 +56,6 @@ public class XdrUnsignedHyperInteger implements XdrElement { return paddedBytes; } - public BigInteger getNumber() { - return number; - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -82,23 +79,4 @@ public class XdrUnsignedHyperInteger implements XdrElement { XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedHyperInteger)) { - return false; - } - - XdrUnsignedHyperInteger other = (XdrUnsignedHyperInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/lib/xdrgen/generators/java/XdrUnsignedInteger.erb b/lib/xdrgen/generators/java/XdrUnsignedInteger.erb index 8f2a52395..223b872e9 100644 --- a/lib/xdrgen/generators/java/XdrUnsignedInteger.erb +++ b/lib/xdrgen/generators/java/XdrUnsignedInteger.erb @@ -1,9 +1,9 @@ -package org.stellar.sdk.xdr; +package <%= @namespace %>; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -12,10 +12,11 @@ import org.stellar.sdk.Base64Factory; * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedInteger implements XdrElement { public static final long MAX_VALUE = (1L << 32) - 1; public static final long MIN_VALUE = 0; - private final Long number; + Long number; public XdrUnsignedInteger(Long number) { if (number < MIN_VALUE || number > MAX_VALUE) { @@ -32,10 +33,6 @@ public class XdrUnsignedInteger implements XdrElement { this.number = number.longValue(); } - public Long getNumber() { - return number; - } - public static XdrUnsignedInteger decode(XdrDataInputStream stream) throws IOException { int intValue = stream.readInt(); long uint32Value = Integer.toUnsignedLong(intValue); @@ -70,23 +67,4 @@ public class XdrUnsignedInteger implements XdrElement { XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedInteger)) { - return false; - } - - XdrUnsignedInteger other = (XdrUnsignedInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/block_comments.x/AccountFlags.java b/spec/output/generator_spec_java/block_comments.x/AccountFlags.java index 5da6b929d..8ce3d380f 100644 --- a/spec/output/generator_spec_java/block_comments.x/AccountFlags.java +++ b/spec/output/generator_spec_java/block_comments.x/AccountFlags.java @@ -5,7 +5,6 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; @@ -20,16 +19,16 @@ * */ public enum AccountFlags implements XdrElement { - AUTH_REQUIRED_FLAG(1), - ; - private int mValue; + AUTH_REQUIRED_FLAG(1); + + private final int value; AccountFlags(int value) { - mValue = value; + this.value = value; } public int getValue() { - return mValue; + return value; } public static AccountFlags decode(XdrDataInputStream stream) throws IOException { diff --git a/spec/output/generator_spec_java/block_comments.x/XdrString.java b/spec/output/generator_spec_java/block_comments.x/XdrString.java index bb4e81fb4..2d8f8bbc9 100644 --- a/spec/output/generator_spec_java/block_comments.x/XdrString.java +++ b/spec/output/generator_spec_java/block_comments.x/XdrString.java @@ -4,90 +4,72 @@ import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InvalidClassException; -import java.nio.charset.Charset; -import java.util.Arrays; +import java.nio.charset.StandardCharsets; +import lombok.Value; import org.stellar.sdk.Base64Factory; +@Value public class XdrString implements XdrElement { - private byte[] bytes; + byte[] bytes; - public XdrString(byte[] bytes) { - this.bytes = bytes; - } + public XdrString(byte[] bytes) { + this.bytes = bytes; + } - public XdrString(String text) { - this.bytes = text.getBytes(Charset.forName("UTF-8")); - } + public XdrString(String text) { + this.bytes = text.getBytes(StandardCharsets.UTF_8); + } - @Override - public void encode(XdrDataOutputStream stream) throws IOException { - stream.writeInt(this.bytes.length); - stream.write(this.bytes, 0, this.bytes.length); - } + @Override + public void encode(XdrDataOutputStream stream) throws IOException { + stream.writeInt(this.bytes.length); + stream.write(this.bytes, 0, this.bytes.length); + } - public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { - int size = stream.readInt(); - if (size > maxSize) { - throw new InvalidClassException("String length "+size+" exceeds max size "+maxSize); - } - byte[] bytes = new byte[size]; - stream.read(bytes); - return new XdrString(bytes); + public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { + int size = stream.readInt(); + if (size > maxSize) { + throw new InvalidClassException("String length " + size + " exceeds max size " + maxSize); } + byte[] bytes = new byte[size]; + stream.read(bytes); + return new XdrString(bytes); + } - public byte[] getBytes() { - return this.bytes; - } + @Override + public String toXdrBase64() throws IOException { + return Base64Factory.getInstance().encodeToString(toXdrByteArray()); + } - @Override - public String toXdrBase64() throws IOException { - return Base64Factory.getInstance().encodeToString(toXdrByteArray()); - } - - @Override - public byte[] toXdrByteArray() throws IOException { - ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); - encode(xdrDataOutputStream); - return byteArrayOutputStream.toByteArray(); - } - - public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { - byte[] bytes = Base64Factory.getInstance().decode(xdr); - return fromXdrByteArray(bytes, maxSize); - } - - public static XdrString fromXdrBase64(String xdr) throws IOException { - return fromXdrBase64(xdr, Integer.MAX_VALUE); - } - - public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { - ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); - XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); - return decode(xdrDataInputStream, maxSize); - } - - public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { - return fromXdrByteArray(xdr, Integer.MAX_VALUE); - } + @Override + public byte[] toXdrByteArray() throws IOException { + ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); + XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); + encode(xdrDataOutputStream); + return byteArrayOutputStream.toByteArray(); + } - @Override - public int hashCode() { - return Arrays.hashCode(this.bytes); - } + public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { + byte[] bytes = Base64Factory.getInstance().decode(xdr); + return fromXdrByteArray(bytes, maxSize); + } - @Override - public boolean equals(Object object) { - if (object == null || !(object instanceof XdrString)) { - return false; - } + public static XdrString fromXdrBase64(String xdr) throws IOException { + return fromXdrBase64(xdr, Integer.MAX_VALUE); + } - XdrString other = (XdrString) object; - return Arrays.equals(this.bytes, other.bytes); - } + public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { + ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); + XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); + return decode(xdrDataInputStream, maxSize); + } - @Override - public String toString() { - return new String(bytes, Charset.forName("UTF-8")); - } + public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { + return fromXdrByteArray(xdr, Integer.MAX_VALUE); + } + + @Override + public String toString() { + return new String(bytes, StandardCharsets.UTF_8); + } } diff --git a/spec/output/generator_spec_java/block_comments.x/XdrUnsignedHyperInteger.java b/spec/output/generator_spec_java/block_comments.x/XdrUnsignedHyperInteger.java index 6c05ca57d..204aa83de 100644 --- a/spec/output/generator_spec_java/block_comments.x/XdrUnsignedHyperInteger.java +++ b/spec/output/generator_spec_java/block_comments.x/XdrUnsignedHyperInteger.java @@ -1,10 +1,10 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.math.BigInteger; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -13,10 +13,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedHyperInteger implements XdrElement { public static final BigInteger MAX_VALUE = new BigInteger("18446744073709551615"); public static final BigInteger MIN_VALUE = BigInteger.ZERO; - private final BigInteger number; + BigInteger number; public XdrUnsignedHyperInteger(BigInteger number) { if (number.compareTo(MIN_VALUE) < 0 || number.compareTo(MAX_VALUE) > 0) { @@ -55,10 +56,6 @@ private byte[] getBytes() { return paddedBytes; } - public BigInteger getNumber() { - return number; - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -82,23 +79,4 @@ public static XdrUnsignedHyperInteger fromXdrByteArray(byte[] xdr) throws IOExce XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedHyperInteger)) { - return false; - } - - XdrUnsignedHyperInteger other = (XdrUnsignedHyperInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/block_comments.x/XdrUnsignedInteger.java b/spec/output/generator_spec_java/block_comments.x/XdrUnsignedInteger.java index 8f2a52395..a56ad657d 100644 --- a/spec/output/generator_spec_java/block_comments.x/XdrUnsignedInteger.java +++ b/spec/output/generator_spec_java/block_comments.x/XdrUnsignedInteger.java @@ -1,9 +1,9 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -12,10 +12,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedInteger implements XdrElement { public static final long MAX_VALUE = (1L << 32) - 1; public static final long MIN_VALUE = 0; - private final Long number; + Long number; public XdrUnsignedInteger(Long number) { if (number < MIN_VALUE || number > MAX_VALUE) { @@ -32,10 +33,6 @@ public XdrUnsignedInteger(Integer number) { this.number = number.longValue(); } - public Long getNumber() { - return number; - } - public static XdrUnsignedInteger decode(XdrDataInputStream stream) throws IOException { int intValue = stream.readInt(); long uint32Value = Integer.toUnsignedLong(intValue); @@ -70,23 +67,4 @@ public static XdrUnsignedInteger fromXdrByteArray(byte[] xdr) throws IOException XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedInteger)) { - return false; - } - - XdrUnsignedInteger other = (XdrUnsignedInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/const.x/TestArray.java b/spec/output/generator_spec_java/const.x/TestArray.java index d7cd318e8..50fcb0495 100644 --- a/spec/output/generator_spec_java/const.x/TestArray.java +++ b/spec/output/generator_spec_java/const.x/TestArray.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * TestArray's original definition in the XDR file is: @@ -17,26 +19,14 @@ * typedef int TestArray[FOO]; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class TestArray implements XdrElement { private Integer[] TestArray; - - public TestArray() {} - - public TestArray(Integer[] TestArray) { - this.TestArray = TestArray; - } - - public Integer[] getTestArray() { - return this.TestArray; - } - - public void setTestArray(Integer[] value) { - this.TestArray = value; - } - public static void encode(XdrDataOutputStream stream, TestArray encodedTestArray) throws IOException { - int TestArraysize = encodedTestArray.getTestArray().length; - for (int i = 0; i < TestArraysize; i++) { + int TestArraySize = encodedTestArray.getTestArray().length; + for (int i = 0; i < TestArraySize; i++) { stream.writeInt(encodedTestArray.TestArray[i]); } } @@ -46,28 +36,14 @@ public void encode(XdrDataOutputStream stream) throws IOException { } public static TestArray decode(XdrDataInputStream stream) throws IOException { TestArray decodedTestArray = new TestArray(); - int TestArraysize = FOO; - decodedTestArray.TestArray = new Integer[TestArraysize]; - for (int i = 0; i < TestArraysize; i++) { + int TestArraySize = FOO; + decodedTestArray.TestArray = new Integer[TestArraySize]; + for (int i = 0; i < TestArraySize; i++) { decodedTestArray.TestArray[i] = stream.readInt(); } return decodedTestArray; } - @Override - public int hashCode() { - return Arrays.hashCode(this.TestArray); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof TestArray)) { - return false; - } - - TestArray other = (TestArray) object; - return Arrays.equals(this.TestArray, other.TestArray); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/const.x/TestArray2.java b/spec/output/generator_spec_java/const.x/TestArray2.java index ba2fe8cfc..0636dc6df 100644 --- a/spec/output/generator_spec_java/const.x/TestArray2.java +++ b/spec/output/generator_spec_java/const.x/TestArray2.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * TestArray2's original definition in the XDR file is: @@ -17,27 +19,15 @@ * typedef int TestArray2<FOO>; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class TestArray2 implements XdrElement { private Integer[] TestArray2; - - public TestArray2() {} - - public TestArray2(Integer[] TestArray2) { - this.TestArray2 = TestArray2; - } - - public Integer[] getTestArray2() { - return this.TestArray2; - } - - public void setTestArray2(Integer[] value) { - this.TestArray2 = value; - } - public static void encode(XdrDataOutputStream stream, TestArray2 encodedTestArray2) throws IOException { - int TestArray2size = encodedTestArray2.getTestArray2().length; - stream.writeInt(TestArray2size); - for (int i = 0; i < TestArray2size; i++) { + int TestArray2Size = encodedTestArray2.getTestArray2().length; + stream.writeInt(TestArray2Size); + for (int i = 0; i < TestArray2Size; i++) { stream.writeInt(encodedTestArray2.TestArray2[i]); } } @@ -47,28 +37,14 @@ public void encode(XdrDataOutputStream stream) throws IOException { } public static TestArray2 decode(XdrDataInputStream stream) throws IOException { TestArray2 decodedTestArray2 = new TestArray2(); - int TestArray2size = stream.readInt(); - decodedTestArray2.TestArray2 = new Integer[TestArray2size]; - for (int i = 0; i < TestArray2size; i++) { + int TestArray2Size = stream.readInt(); + decodedTestArray2.TestArray2 = new Integer[TestArray2Size]; + for (int i = 0; i < TestArray2Size; i++) { decodedTestArray2.TestArray2[i] = stream.readInt(); } return decodedTestArray2; } - @Override - public int hashCode() { - return Arrays.hashCode(this.TestArray2); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof TestArray2)) { - return false; - } - - TestArray2 other = (TestArray2) object; - return Arrays.equals(this.TestArray2, other.TestArray2); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/const.x/XdrString.java b/spec/output/generator_spec_java/const.x/XdrString.java index bb4e81fb4..2d8f8bbc9 100644 --- a/spec/output/generator_spec_java/const.x/XdrString.java +++ b/spec/output/generator_spec_java/const.x/XdrString.java @@ -4,90 +4,72 @@ import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InvalidClassException; -import java.nio.charset.Charset; -import java.util.Arrays; +import java.nio.charset.StandardCharsets; +import lombok.Value; import org.stellar.sdk.Base64Factory; +@Value public class XdrString implements XdrElement { - private byte[] bytes; + byte[] bytes; - public XdrString(byte[] bytes) { - this.bytes = bytes; - } + public XdrString(byte[] bytes) { + this.bytes = bytes; + } - public XdrString(String text) { - this.bytes = text.getBytes(Charset.forName("UTF-8")); - } + public XdrString(String text) { + this.bytes = text.getBytes(StandardCharsets.UTF_8); + } - @Override - public void encode(XdrDataOutputStream stream) throws IOException { - stream.writeInt(this.bytes.length); - stream.write(this.bytes, 0, this.bytes.length); - } + @Override + public void encode(XdrDataOutputStream stream) throws IOException { + stream.writeInt(this.bytes.length); + stream.write(this.bytes, 0, this.bytes.length); + } - public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { - int size = stream.readInt(); - if (size > maxSize) { - throw new InvalidClassException("String length "+size+" exceeds max size "+maxSize); - } - byte[] bytes = new byte[size]; - stream.read(bytes); - return new XdrString(bytes); + public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { + int size = stream.readInt(); + if (size > maxSize) { + throw new InvalidClassException("String length " + size + " exceeds max size " + maxSize); } + byte[] bytes = new byte[size]; + stream.read(bytes); + return new XdrString(bytes); + } - public byte[] getBytes() { - return this.bytes; - } + @Override + public String toXdrBase64() throws IOException { + return Base64Factory.getInstance().encodeToString(toXdrByteArray()); + } - @Override - public String toXdrBase64() throws IOException { - return Base64Factory.getInstance().encodeToString(toXdrByteArray()); - } - - @Override - public byte[] toXdrByteArray() throws IOException { - ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); - encode(xdrDataOutputStream); - return byteArrayOutputStream.toByteArray(); - } - - public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { - byte[] bytes = Base64Factory.getInstance().decode(xdr); - return fromXdrByteArray(bytes, maxSize); - } - - public static XdrString fromXdrBase64(String xdr) throws IOException { - return fromXdrBase64(xdr, Integer.MAX_VALUE); - } - - public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { - ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); - XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); - return decode(xdrDataInputStream, maxSize); - } - - public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { - return fromXdrByteArray(xdr, Integer.MAX_VALUE); - } + @Override + public byte[] toXdrByteArray() throws IOException { + ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); + XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); + encode(xdrDataOutputStream); + return byteArrayOutputStream.toByteArray(); + } - @Override - public int hashCode() { - return Arrays.hashCode(this.bytes); - } + public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { + byte[] bytes = Base64Factory.getInstance().decode(xdr); + return fromXdrByteArray(bytes, maxSize); + } - @Override - public boolean equals(Object object) { - if (object == null || !(object instanceof XdrString)) { - return false; - } + public static XdrString fromXdrBase64(String xdr) throws IOException { + return fromXdrBase64(xdr, Integer.MAX_VALUE); + } - XdrString other = (XdrString) object; - return Arrays.equals(this.bytes, other.bytes); - } + public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { + ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); + XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); + return decode(xdrDataInputStream, maxSize); + } - @Override - public String toString() { - return new String(bytes, Charset.forName("UTF-8")); - } + public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { + return fromXdrByteArray(xdr, Integer.MAX_VALUE); + } + + @Override + public String toString() { + return new String(bytes, StandardCharsets.UTF_8); + } } diff --git a/spec/output/generator_spec_java/const.x/XdrUnsignedHyperInteger.java b/spec/output/generator_spec_java/const.x/XdrUnsignedHyperInteger.java index 6c05ca57d..204aa83de 100644 --- a/spec/output/generator_spec_java/const.x/XdrUnsignedHyperInteger.java +++ b/spec/output/generator_spec_java/const.x/XdrUnsignedHyperInteger.java @@ -1,10 +1,10 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.math.BigInteger; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -13,10 +13,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedHyperInteger implements XdrElement { public static final BigInteger MAX_VALUE = new BigInteger("18446744073709551615"); public static final BigInteger MIN_VALUE = BigInteger.ZERO; - private final BigInteger number; + BigInteger number; public XdrUnsignedHyperInteger(BigInteger number) { if (number.compareTo(MIN_VALUE) < 0 || number.compareTo(MAX_VALUE) > 0) { @@ -55,10 +56,6 @@ private byte[] getBytes() { return paddedBytes; } - public BigInteger getNumber() { - return number; - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -82,23 +79,4 @@ public static XdrUnsignedHyperInteger fromXdrByteArray(byte[] xdr) throws IOExce XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedHyperInteger)) { - return false; - } - - XdrUnsignedHyperInteger other = (XdrUnsignedHyperInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/const.x/XdrUnsignedInteger.java b/spec/output/generator_spec_java/const.x/XdrUnsignedInteger.java index 8f2a52395..a56ad657d 100644 --- a/spec/output/generator_spec_java/const.x/XdrUnsignedInteger.java +++ b/spec/output/generator_spec_java/const.x/XdrUnsignedInteger.java @@ -1,9 +1,9 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -12,10 +12,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedInteger implements XdrElement { public static final long MAX_VALUE = (1L << 32) - 1; public static final long MIN_VALUE = 0; - private final Long number; + Long number; public XdrUnsignedInteger(Long number) { if (number < MIN_VALUE || number > MAX_VALUE) { @@ -32,10 +33,6 @@ public XdrUnsignedInteger(Integer number) { this.number = number.longValue(); } - public Long getNumber() { - return number; - } - public static XdrUnsignedInteger decode(XdrDataInputStream stream) throws IOException { int intValue = stream.readInt(); long uint32Value = Integer.toUnsignedLong(intValue); @@ -70,23 +67,4 @@ public static XdrUnsignedInteger fromXdrByteArray(byte[] xdr) throws IOException XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedInteger)) { - return false; - } - - XdrUnsignedInteger other = (XdrUnsignedInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/enum.x/Color.java b/spec/output/generator_spec_java/enum.x/Color.java index 546993fa8..a56cc062c 100644 --- a/spec/output/generator_spec_java/enum.x/Color.java +++ b/spec/output/generator_spec_java/enum.x/Color.java @@ -5,7 +5,6 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; @@ -23,16 +22,16 @@ public enum Color implements XdrElement { RED(0), GREEN(1), - BLUE(2), - ; - private int mValue; + BLUE(2); + + private final int value; Color(int value) { - mValue = value; + this.value = value; } public int getValue() { - return mValue; + return value; } public static Color decode(XdrDataInputStream stream) throws IOException { diff --git a/spec/output/generator_spec_java/enum.x/Color2.java b/spec/output/generator_spec_java/enum.x/Color2.java index 9662817a0..56496d71c 100644 --- a/spec/output/generator_spec_java/enum.x/Color2.java +++ b/spec/output/generator_spec_java/enum.x/Color2.java @@ -5,7 +5,6 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; @@ -23,16 +22,16 @@ public enum Color2 implements XdrElement { RED2(0), GREEN2(1), - BLUE2(2), - ; - private int mValue; + BLUE2(2); + + private final int value; Color2(int value) { - mValue = value; + this.value = value; } public int getValue() { - return mValue; + return value; } public static Color2 decode(XdrDataInputStream stream) throws IOException { diff --git a/spec/output/generator_spec_java/enum.x/MessageType.java b/spec/output/generator_spec_java/enum.x/MessageType.java index f2be344cc..5043b7b88 100644 --- a/spec/output/generator_spec_java/enum.x/MessageType.java +++ b/spec/output/generator_spec_java/enum.x/MessageType.java @@ -5,7 +5,6 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; @@ -52,16 +51,16 @@ public enum MessageType implements XdrElement { JSON_TRANSACTION(10), GET_FBA_QUORUMSET(11), FBA_QUORUMSET(12), - FBA_MESSAGE(13), - ; - private int mValue; + FBA_MESSAGE(13); + + private final int value; MessageType(int value) { - mValue = value; + this.value = value; } public int getValue() { - return mValue; + return value; } public static MessageType decode(XdrDataInputStream stream) throws IOException { diff --git a/spec/output/generator_spec_java/enum.x/XdrString.java b/spec/output/generator_spec_java/enum.x/XdrString.java index bb4e81fb4..2d8f8bbc9 100644 --- a/spec/output/generator_spec_java/enum.x/XdrString.java +++ b/spec/output/generator_spec_java/enum.x/XdrString.java @@ -4,90 +4,72 @@ import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InvalidClassException; -import java.nio.charset.Charset; -import java.util.Arrays; +import java.nio.charset.StandardCharsets; +import lombok.Value; import org.stellar.sdk.Base64Factory; +@Value public class XdrString implements XdrElement { - private byte[] bytes; + byte[] bytes; - public XdrString(byte[] bytes) { - this.bytes = bytes; - } + public XdrString(byte[] bytes) { + this.bytes = bytes; + } - public XdrString(String text) { - this.bytes = text.getBytes(Charset.forName("UTF-8")); - } + public XdrString(String text) { + this.bytes = text.getBytes(StandardCharsets.UTF_8); + } - @Override - public void encode(XdrDataOutputStream stream) throws IOException { - stream.writeInt(this.bytes.length); - stream.write(this.bytes, 0, this.bytes.length); - } + @Override + public void encode(XdrDataOutputStream stream) throws IOException { + stream.writeInt(this.bytes.length); + stream.write(this.bytes, 0, this.bytes.length); + } - public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { - int size = stream.readInt(); - if (size > maxSize) { - throw new InvalidClassException("String length "+size+" exceeds max size "+maxSize); - } - byte[] bytes = new byte[size]; - stream.read(bytes); - return new XdrString(bytes); + public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { + int size = stream.readInt(); + if (size > maxSize) { + throw new InvalidClassException("String length " + size + " exceeds max size " + maxSize); } + byte[] bytes = new byte[size]; + stream.read(bytes); + return new XdrString(bytes); + } - public byte[] getBytes() { - return this.bytes; - } + @Override + public String toXdrBase64() throws IOException { + return Base64Factory.getInstance().encodeToString(toXdrByteArray()); + } - @Override - public String toXdrBase64() throws IOException { - return Base64Factory.getInstance().encodeToString(toXdrByteArray()); - } - - @Override - public byte[] toXdrByteArray() throws IOException { - ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); - encode(xdrDataOutputStream); - return byteArrayOutputStream.toByteArray(); - } - - public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { - byte[] bytes = Base64Factory.getInstance().decode(xdr); - return fromXdrByteArray(bytes, maxSize); - } - - public static XdrString fromXdrBase64(String xdr) throws IOException { - return fromXdrBase64(xdr, Integer.MAX_VALUE); - } - - public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { - ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); - XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); - return decode(xdrDataInputStream, maxSize); - } - - public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { - return fromXdrByteArray(xdr, Integer.MAX_VALUE); - } + @Override + public byte[] toXdrByteArray() throws IOException { + ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); + XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); + encode(xdrDataOutputStream); + return byteArrayOutputStream.toByteArray(); + } - @Override - public int hashCode() { - return Arrays.hashCode(this.bytes); - } + public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { + byte[] bytes = Base64Factory.getInstance().decode(xdr); + return fromXdrByteArray(bytes, maxSize); + } - @Override - public boolean equals(Object object) { - if (object == null || !(object instanceof XdrString)) { - return false; - } + public static XdrString fromXdrBase64(String xdr) throws IOException { + return fromXdrBase64(xdr, Integer.MAX_VALUE); + } - XdrString other = (XdrString) object; - return Arrays.equals(this.bytes, other.bytes); - } + public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { + ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); + XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); + return decode(xdrDataInputStream, maxSize); + } - @Override - public String toString() { - return new String(bytes, Charset.forName("UTF-8")); - } + public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { + return fromXdrByteArray(xdr, Integer.MAX_VALUE); + } + + @Override + public String toString() { + return new String(bytes, StandardCharsets.UTF_8); + } } diff --git a/spec/output/generator_spec_java/enum.x/XdrUnsignedHyperInteger.java b/spec/output/generator_spec_java/enum.x/XdrUnsignedHyperInteger.java index 6c05ca57d..204aa83de 100644 --- a/spec/output/generator_spec_java/enum.x/XdrUnsignedHyperInteger.java +++ b/spec/output/generator_spec_java/enum.x/XdrUnsignedHyperInteger.java @@ -1,10 +1,10 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.math.BigInteger; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -13,10 +13,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedHyperInteger implements XdrElement { public static final BigInteger MAX_VALUE = new BigInteger("18446744073709551615"); public static final BigInteger MIN_VALUE = BigInteger.ZERO; - private final BigInteger number; + BigInteger number; public XdrUnsignedHyperInteger(BigInteger number) { if (number.compareTo(MIN_VALUE) < 0 || number.compareTo(MAX_VALUE) > 0) { @@ -55,10 +56,6 @@ private byte[] getBytes() { return paddedBytes; } - public BigInteger getNumber() { - return number; - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -82,23 +79,4 @@ public static XdrUnsignedHyperInteger fromXdrByteArray(byte[] xdr) throws IOExce XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedHyperInteger)) { - return false; - } - - XdrUnsignedHyperInteger other = (XdrUnsignedHyperInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/enum.x/XdrUnsignedInteger.java b/spec/output/generator_spec_java/enum.x/XdrUnsignedInteger.java index 8f2a52395..a56ad657d 100644 --- a/spec/output/generator_spec_java/enum.x/XdrUnsignedInteger.java +++ b/spec/output/generator_spec_java/enum.x/XdrUnsignedInteger.java @@ -1,9 +1,9 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -12,10 +12,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedInteger implements XdrElement { public static final long MAX_VALUE = (1L << 32) - 1; public static final long MIN_VALUE = 0; - private final Long number; + Long number; public XdrUnsignedInteger(Long number) { if (number < MIN_VALUE || number > MAX_VALUE) { @@ -32,10 +33,6 @@ public XdrUnsignedInteger(Integer number) { this.number = number.longValue(); } - public Long getNumber() { - return number; - } - public static XdrUnsignedInteger decode(XdrDataInputStream stream) throws IOException { int intValue = stream.readInt(); long uint32Value = Integer.toUnsignedLong(intValue); @@ -70,23 +67,4 @@ public static XdrUnsignedInteger fromXdrByteArray(byte[] xdr) throws IOException XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedInteger)) { - return false; - } - - XdrUnsignedInteger other = (XdrUnsignedInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/nesting.x/Foo.java b/spec/output/generator_spec_java/nesting.x/Foo.java index 7c53c1371..9ee721188 100644 --- a/spec/output/generator_spec_java/nesting.x/Foo.java +++ b/spec/output/generator_spec_java/nesting.x/Foo.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Foo's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef int Foo; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Foo implements XdrElement { private Integer Foo; - - public Foo() {} - - public Foo(Integer Foo) { - this.Foo = Foo; - } - - public Integer getFoo() { - return this.Foo; - } - - public void setFoo(Integer value) { - this.Foo = value; - } - public static void encode(XdrDataOutputStream stream, Foo encodedFoo) throws IOException { stream.writeInt(encodedFoo.Foo); } @@ -47,20 +37,6 @@ public static Foo decode(XdrDataInputStream stream) throws IOException { return decodedFoo; } - @Override - public int hashCode() { - return Objects.hash(this.Foo); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Foo)) { - return false; - } - - Foo other = (Foo) object; - return Objects.equals(this.Foo, other.Foo); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/nesting.x/MyUnion.java b/spec/output/generator_spec_java/nesting.x/MyUnion.java index ab29d0fbd..f63690615 100644 --- a/spec/output/generator_spec_java/nesting.x/MyUnion.java +++ b/spec/output/generator_spec_java/nesting.x/MyUnion.java @@ -5,11 +5,14 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import lombok.Builder; +import static MyXDR.Constants.*; /** * MyUnion's original definition in the XDR file is: @@ -32,58 +35,14 @@ * }; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Builder(toBuilder = true) public class MyUnion implements XdrElement { - public MyUnion () {} - UnionKey type; - public UnionKey getDiscriminant() { - return this.type; - } - public void setDiscriminant(UnionKey value) { - this.type = value; - } + private UnionKey discriminant; private MyUnionOne one; - public MyUnionOne getOne() { - return this.one; - } - public void setOne(MyUnionOne value) { - this.one = value; - } private MyUnionTwo two; - public MyUnionTwo getTwo() { - return this.two; - } - public void setTwo(MyUnionTwo value) { - this.two = value; - } - - public static final class Builder { - private UnionKey discriminant; - private MyUnionOne one; - private MyUnionTwo two; - - public Builder discriminant(UnionKey discriminant) { - this.discriminant = discriminant; - return this; - } - - public Builder one(MyUnionOne one) { - this.one = one; - return this; - } - - public Builder two(MyUnionTwo two) { - this.two = two; - return this; - } - - public MyUnion build() { - MyUnion val = new MyUnion(); - val.setDiscriminant(discriminant); - val.setOne(this.one); - val.setTwo(this.two); - return val; - } - } public static void encode(XdrDataOutputStream stream, MyUnion encodedMyUnion) throws IOException { //Xdrgen::AST::Identifier @@ -120,19 +79,6 @@ public static MyUnion decode(XdrDataInputStream stream) throws IOException { return decodedMyUnion; } @Override - public int hashCode() { - return Objects.hash(this.one, this.two, this.type); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof MyUnion)) { - return false; - } - - MyUnion other = (MyUnion) object; - return Objects.equals(this.one, other.one) && Objects.equals(this.two, other.two) && Objects.equals(this.type, other.type); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); } @@ -164,15 +110,12 @@ public static MyUnion fromXdrByteArray(byte[] xdr) throws IOException { * } * */ + @Data + @NoArgsConstructor + @AllArgsConstructor + @Builder(toBuilder = true) public static class MyUnionOne implements XdrElement { - public MyUnionOne () {} private Integer someInt; - public Integer getSomeInt() { - return this.someInt; - } - public void setSomeInt(Integer value) { - this.someInt = value; - } public static void encode(XdrDataOutputStream stream, MyUnionOne encodedMyUnionOne) throws IOException{ stream.writeInt(encodedMyUnionOne.someInt); } @@ -184,20 +127,6 @@ public static MyUnionOne decode(XdrDataInputStream stream) throws IOException { decodedMyUnionOne.someInt = stream.readInt(); return decodedMyUnionOne; } - @Override - public int hashCode() { - return Objects.hash(this.someInt); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof MyUnionOne)) { - return false; - } - - MyUnionOne other = (MyUnionOne) object; - return Objects.equals(this.someInt, other.someInt); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -221,20 +150,6 @@ public static MyUnionOne fromXdrByteArray(byte[] xdr) throws IOException { XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - public static final class Builder { - private Integer someInt; - - public Builder someInt(Integer someInt) { - this.someInt = someInt; - return this; - } - - public MyUnionOne build() { - MyUnionOne val = new MyUnionOne(); - val.setSomeInt(this.someInt); - return val; - } - } } /** @@ -246,22 +161,13 @@ public MyUnionOne build() { * } * */ + @Data + @NoArgsConstructor + @AllArgsConstructor + @Builder(toBuilder = true) public static class MyUnionTwo implements XdrElement { - public MyUnionTwo () {} private Integer someInt; - public Integer getSomeInt() { - return this.someInt; - } - public void setSomeInt(Integer value) { - this.someInt = value; - } private Foo foo; - public Foo getFoo() { - return this.foo; - } - public void setFoo(Foo value) { - this.foo = value; - } public static void encode(XdrDataOutputStream stream, MyUnionTwo encodedMyUnionTwo) throws IOException{ stream.writeInt(encodedMyUnionTwo.someInt); Foo.encode(stream, encodedMyUnionTwo.foo); @@ -275,20 +181,6 @@ public static MyUnionTwo decode(XdrDataInputStream stream) throws IOException { decodedMyUnionTwo.foo = Foo.decode(stream); return decodedMyUnionTwo; } - @Override - public int hashCode() { - return Objects.hash(this.someInt, this.foo); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof MyUnionTwo)) { - return false; - } - - MyUnionTwo other = (MyUnionTwo) object; - return Objects.equals(this.someInt, other.someInt) && Objects.equals(this.foo, other.foo); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -312,27 +204,6 @@ public static MyUnionTwo fromXdrByteArray(byte[] xdr) throws IOException { XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - public static final class Builder { - private Integer someInt; - private Foo foo; - - public Builder someInt(Integer someInt) { - this.someInt = someInt; - return this; - } - - public Builder foo(Foo foo) { - this.foo = foo; - return this; - } - - public MyUnionTwo build() { - MyUnionTwo val = new MyUnionTwo(); - val.setSomeInt(this.someInt); - val.setFoo(this.foo); - return val; - } - } } } diff --git a/spec/output/generator_spec_java/nesting.x/UnionKey.java b/spec/output/generator_spec_java/nesting.x/UnionKey.java index fb3136582..3118cdb76 100644 --- a/spec/output/generator_spec_java/nesting.x/UnionKey.java +++ b/spec/output/generator_spec_java/nesting.x/UnionKey.java @@ -5,7 +5,6 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; @@ -23,16 +22,16 @@ public enum UnionKey implements XdrElement { ONE(1), TWO(2), - OFFER(3), - ; - private int mValue; + OFFER(3); + + private final int value; UnionKey(int value) { - mValue = value; + this.value = value; } public int getValue() { - return mValue; + return value; } public static UnionKey decode(XdrDataInputStream stream) throws IOException { diff --git a/spec/output/generator_spec_java/nesting.x/XdrString.java b/spec/output/generator_spec_java/nesting.x/XdrString.java index bb4e81fb4..2d8f8bbc9 100644 --- a/spec/output/generator_spec_java/nesting.x/XdrString.java +++ b/spec/output/generator_spec_java/nesting.x/XdrString.java @@ -4,90 +4,72 @@ import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InvalidClassException; -import java.nio.charset.Charset; -import java.util.Arrays; +import java.nio.charset.StandardCharsets; +import lombok.Value; import org.stellar.sdk.Base64Factory; +@Value public class XdrString implements XdrElement { - private byte[] bytes; + byte[] bytes; - public XdrString(byte[] bytes) { - this.bytes = bytes; - } + public XdrString(byte[] bytes) { + this.bytes = bytes; + } - public XdrString(String text) { - this.bytes = text.getBytes(Charset.forName("UTF-8")); - } + public XdrString(String text) { + this.bytes = text.getBytes(StandardCharsets.UTF_8); + } - @Override - public void encode(XdrDataOutputStream stream) throws IOException { - stream.writeInt(this.bytes.length); - stream.write(this.bytes, 0, this.bytes.length); - } + @Override + public void encode(XdrDataOutputStream stream) throws IOException { + stream.writeInt(this.bytes.length); + stream.write(this.bytes, 0, this.bytes.length); + } - public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { - int size = stream.readInt(); - if (size > maxSize) { - throw new InvalidClassException("String length "+size+" exceeds max size "+maxSize); - } - byte[] bytes = new byte[size]; - stream.read(bytes); - return new XdrString(bytes); + public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { + int size = stream.readInt(); + if (size > maxSize) { + throw new InvalidClassException("String length " + size + " exceeds max size " + maxSize); } + byte[] bytes = new byte[size]; + stream.read(bytes); + return new XdrString(bytes); + } - public byte[] getBytes() { - return this.bytes; - } + @Override + public String toXdrBase64() throws IOException { + return Base64Factory.getInstance().encodeToString(toXdrByteArray()); + } - @Override - public String toXdrBase64() throws IOException { - return Base64Factory.getInstance().encodeToString(toXdrByteArray()); - } - - @Override - public byte[] toXdrByteArray() throws IOException { - ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); - encode(xdrDataOutputStream); - return byteArrayOutputStream.toByteArray(); - } - - public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { - byte[] bytes = Base64Factory.getInstance().decode(xdr); - return fromXdrByteArray(bytes, maxSize); - } - - public static XdrString fromXdrBase64(String xdr) throws IOException { - return fromXdrBase64(xdr, Integer.MAX_VALUE); - } - - public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { - ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); - XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); - return decode(xdrDataInputStream, maxSize); - } - - public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { - return fromXdrByteArray(xdr, Integer.MAX_VALUE); - } + @Override + public byte[] toXdrByteArray() throws IOException { + ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); + XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); + encode(xdrDataOutputStream); + return byteArrayOutputStream.toByteArray(); + } - @Override - public int hashCode() { - return Arrays.hashCode(this.bytes); - } + public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { + byte[] bytes = Base64Factory.getInstance().decode(xdr); + return fromXdrByteArray(bytes, maxSize); + } - @Override - public boolean equals(Object object) { - if (object == null || !(object instanceof XdrString)) { - return false; - } + public static XdrString fromXdrBase64(String xdr) throws IOException { + return fromXdrBase64(xdr, Integer.MAX_VALUE); + } - XdrString other = (XdrString) object; - return Arrays.equals(this.bytes, other.bytes); - } + public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { + ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); + XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); + return decode(xdrDataInputStream, maxSize); + } - @Override - public String toString() { - return new String(bytes, Charset.forName("UTF-8")); - } + public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { + return fromXdrByteArray(xdr, Integer.MAX_VALUE); + } + + @Override + public String toString() { + return new String(bytes, StandardCharsets.UTF_8); + } } diff --git a/spec/output/generator_spec_java/nesting.x/XdrUnsignedHyperInteger.java b/spec/output/generator_spec_java/nesting.x/XdrUnsignedHyperInteger.java index 6c05ca57d..204aa83de 100644 --- a/spec/output/generator_spec_java/nesting.x/XdrUnsignedHyperInteger.java +++ b/spec/output/generator_spec_java/nesting.x/XdrUnsignedHyperInteger.java @@ -1,10 +1,10 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.math.BigInteger; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -13,10 +13,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedHyperInteger implements XdrElement { public static final BigInteger MAX_VALUE = new BigInteger("18446744073709551615"); public static final BigInteger MIN_VALUE = BigInteger.ZERO; - private final BigInteger number; + BigInteger number; public XdrUnsignedHyperInteger(BigInteger number) { if (number.compareTo(MIN_VALUE) < 0 || number.compareTo(MAX_VALUE) > 0) { @@ -55,10 +56,6 @@ private byte[] getBytes() { return paddedBytes; } - public BigInteger getNumber() { - return number; - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -82,23 +79,4 @@ public static XdrUnsignedHyperInteger fromXdrByteArray(byte[] xdr) throws IOExce XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedHyperInteger)) { - return false; - } - - XdrUnsignedHyperInteger other = (XdrUnsignedHyperInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/nesting.x/XdrUnsignedInteger.java b/spec/output/generator_spec_java/nesting.x/XdrUnsignedInteger.java index 8f2a52395..a56ad657d 100644 --- a/spec/output/generator_spec_java/nesting.x/XdrUnsignedInteger.java +++ b/spec/output/generator_spec_java/nesting.x/XdrUnsignedInteger.java @@ -1,9 +1,9 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -12,10 +12,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedInteger implements XdrElement { public static final long MAX_VALUE = (1L << 32) - 1; public static final long MIN_VALUE = 0; - private final Long number; + Long number; public XdrUnsignedInteger(Long number) { if (number < MIN_VALUE || number > MAX_VALUE) { @@ -32,10 +33,6 @@ public XdrUnsignedInteger(Integer number) { this.number = number.longValue(); } - public Long getNumber() { - return number; - } - public static XdrUnsignedInteger decode(XdrDataInputStream stream) throws IOException { int intValue = stream.readInt(); long uint32Value = Integer.toUnsignedLong(intValue); @@ -70,23 +67,4 @@ public static XdrUnsignedInteger fromXdrByteArray(byte[] xdr) throws IOException XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedInteger)) { - return false; - } - - XdrUnsignedInteger other = (XdrUnsignedInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/optional.x/Arr.java b/spec/output/generator_spec_java/optional.x/Arr.java index 860b59f87..a2ff03d6f 100644 --- a/spec/output/generator_spec_java/optional.x/Arr.java +++ b/spec/output/generator_spec_java/optional.x/Arr.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Arr's original definition in the XDR file is: @@ -17,26 +19,14 @@ * typedef int Arr[2]; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Arr implements XdrElement { private Integer[] Arr; - - public Arr() {} - - public Arr(Integer[] Arr) { - this.Arr = Arr; - } - - public Integer[] getArr() { - return this.Arr; - } - - public void setArr(Integer[] value) { - this.Arr = value; - } - public static void encode(XdrDataOutputStream stream, Arr encodedArr) throws IOException { - int Arrsize = encodedArr.getArr().length; - for (int i = 0; i < Arrsize; i++) { + int ArrSize = encodedArr.getArr().length; + for (int i = 0; i < ArrSize; i++) { stream.writeInt(encodedArr.Arr[i]); } } @@ -46,28 +36,14 @@ public void encode(XdrDataOutputStream stream) throws IOException { } public static Arr decode(XdrDataInputStream stream) throws IOException { Arr decodedArr = new Arr(); - int Arrsize = 2; - decodedArr.Arr = new Integer[Arrsize]; - for (int i = 0; i < Arrsize; i++) { + int ArrSize = 2; + decodedArr.Arr = new Integer[ArrSize]; + for (int i = 0; i < ArrSize; i++) { decodedArr.Arr[i] = stream.readInt(); } return decodedArr; } - @Override - public int hashCode() { - return Arrays.hashCode(this.Arr); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Arr)) { - return false; - } - - Arr other = (Arr) object; - return Arrays.equals(this.Arr, other.Arr); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/optional.x/HasOptions.java b/spec/output/generator_spec_java/optional.x/HasOptions.java index 4c07e944c..607da9213 100644 --- a/spec/output/generator_spec_java/optional.x/HasOptions.java +++ b/spec/output/generator_spec_java/optional.x/HasOptions.java @@ -5,11 +5,14 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import lombok.Builder; +import static MyXDR.Constants.*; /** * HasOptions's original definition in the XDR file is: @@ -22,29 +25,14 @@ * }; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Builder(toBuilder = true) public class HasOptions implements XdrElement { - public HasOptions () {} private Integer firstOption; - public Integer getFirstOption() { - return this.firstOption; - } - public void setFirstOption(Integer value) { - this.firstOption = value; - } private Integer secondOption; - public Integer getSecondOption() { - return this.secondOption; - } - public void setSecondOption(Integer value) { - this.secondOption = value; - } private Arr thirdOption; - public Arr getThirdOption() { - return this.thirdOption; - } - public void setThirdOption(Arr value) { - this.thirdOption = value; - } public static void encode(XdrDataOutputStream stream, HasOptions encodedHasOptions) throws IOException{ if (encodedHasOptions.firstOption != null) { stream.writeInt(1); @@ -84,20 +72,6 @@ public static HasOptions decode(XdrDataInputStream stream) throws IOException { } return decodedHasOptions; } - @Override - public int hashCode() { - return Objects.hash(this.firstOption, this.secondOption, this.thirdOption); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof HasOptions)) { - return false; - } - - HasOptions other = (HasOptions) object; - return Objects.equals(this.firstOption, other.firstOption) && Objects.equals(this.secondOption, other.secondOption) && Objects.equals(this.thirdOption, other.thirdOption); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -121,32 +95,4 @@ public static HasOptions fromXdrByteArray(byte[] xdr) throws IOException { XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - public static final class Builder { - private Integer firstOption; - private Integer secondOption; - private Arr thirdOption; - - public Builder firstOption(Integer firstOption) { - this.firstOption = firstOption; - return this; - } - - public Builder secondOption(Integer secondOption) { - this.secondOption = secondOption; - return this; - } - - public Builder thirdOption(Arr thirdOption) { - this.thirdOption = thirdOption; - return this; - } - - public HasOptions build() { - HasOptions val = new HasOptions(); - val.setFirstOption(this.firstOption); - val.setSecondOption(this.secondOption); - val.setThirdOption(this.thirdOption); - return val; - } - } } diff --git a/spec/output/generator_spec_java/optional.x/XdrString.java b/spec/output/generator_spec_java/optional.x/XdrString.java index bb4e81fb4..2d8f8bbc9 100644 --- a/spec/output/generator_spec_java/optional.x/XdrString.java +++ b/spec/output/generator_spec_java/optional.x/XdrString.java @@ -4,90 +4,72 @@ import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InvalidClassException; -import java.nio.charset.Charset; -import java.util.Arrays; +import java.nio.charset.StandardCharsets; +import lombok.Value; import org.stellar.sdk.Base64Factory; +@Value public class XdrString implements XdrElement { - private byte[] bytes; + byte[] bytes; - public XdrString(byte[] bytes) { - this.bytes = bytes; - } + public XdrString(byte[] bytes) { + this.bytes = bytes; + } - public XdrString(String text) { - this.bytes = text.getBytes(Charset.forName("UTF-8")); - } + public XdrString(String text) { + this.bytes = text.getBytes(StandardCharsets.UTF_8); + } - @Override - public void encode(XdrDataOutputStream stream) throws IOException { - stream.writeInt(this.bytes.length); - stream.write(this.bytes, 0, this.bytes.length); - } + @Override + public void encode(XdrDataOutputStream stream) throws IOException { + stream.writeInt(this.bytes.length); + stream.write(this.bytes, 0, this.bytes.length); + } - public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { - int size = stream.readInt(); - if (size > maxSize) { - throw new InvalidClassException("String length "+size+" exceeds max size "+maxSize); - } - byte[] bytes = new byte[size]; - stream.read(bytes); - return new XdrString(bytes); + public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { + int size = stream.readInt(); + if (size > maxSize) { + throw new InvalidClassException("String length " + size + " exceeds max size " + maxSize); } + byte[] bytes = new byte[size]; + stream.read(bytes); + return new XdrString(bytes); + } - public byte[] getBytes() { - return this.bytes; - } + @Override + public String toXdrBase64() throws IOException { + return Base64Factory.getInstance().encodeToString(toXdrByteArray()); + } - @Override - public String toXdrBase64() throws IOException { - return Base64Factory.getInstance().encodeToString(toXdrByteArray()); - } - - @Override - public byte[] toXdrByteArray() throws IOException { - ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); - encode(xdrDataOutputStream); - return byteArrayOutputStream.toByteArray(); - } - - public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { - byte[] bytes = Base64Factory.getInstance().decode(xdr); - return fromXdrByteArray(bytes, maxSize); - } - - public static XdrString fromXdrBase64(String xdr) throws IOException { - return fromXdrBase64(xdr, Integer.MAX_VALUE); - } - - public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { - ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); - XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); - return decode(xdrDataInputStream, maxSize); - } - - public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { - return fromXdrByteArray(xdr, Integer.MAX_VALUE); - } + @Override + public byte[] toXdrByteArray() throws IOException { + ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); + XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); + encode(xdrDataOutputStream); + return byteArrayOutputStream.toByteArray(); + } - @Override - public int hashCode() { - return Arrays.hashCode(this.bytes); - } + public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { + byte[] bytes = Base64Factory.getInstance().decode(xdr); + return fromXdrByteArray(bytes, maxSize); + } - @Override - public boolean equals(Object object) { - if (object == null || !(object instanceof XdrString)) { - return false; - } + public static XdrString fromXdrBase64(String xdr) throws IOException { + return fromXdrBase64(xdr, Integer.MAX_VALUE); + } - XdrString other = (XdrString) object; - return Arrays.equals(this.bytes, other.bytes); - } + public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { + ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); + XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); + return decode(xdrDataInputStream, maxSize); + } - @Override - public String toString() { - return new String(bytes, Charset.forName("UTF-8")); - } + public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { + return fromXdrByteArray(xdr, Integer.MAX_VALUE); + } + + @Override + public String toString() { + return new String(bytes, StandardCharsets.UTF_8); + } } diff --git a/spec/output/generator_spec_java/optional.x/XdrUnsignedHyperInteger.java b/spec/output/generator_spec_java/optional.x/XdrUnsignedHyperInteger.java index 6c05ca57d..204aa83de 100644 --- a/spec/output/generator_spec_java/optional.x/XdrUnsignedHyperInteger.java +++ b/spec/output/generator_spec_java/optional.x/XdrUnsignedHyperInteger.java @@ -1,10 +1,10 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.math.BigInteger; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -13,10 +13,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedHyperInteger implements XdrElement { public static final BigInteger MAX_VALUE = new BigInteger("18446744073709551615"); public static final BigInteger MIN_VALUE = BigInteger.ZERO; - private final BigInteger number; + BigInteger number; public XdrUnsignedHyperInteger(BigInteger number) { if (number.compareTo(MIN_VALUE) < 0 || number.compareTo(MAX_VALUE) > 0) { @@ -55,10 +56,6 @@ private byte[] getBytes() { return paddedBytes; } - public BigInteger getNumber() { - return number; - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -82,23 +79,4 @@ public static XdrUnsignedHyperInteger fromXdrByteArray(byte[] xdr) throws IOExce XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedHyperInteger)) { - return false; - } - - XdrUnsignedHyperInteger other = (XdrUnsignedHyperInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/optional.x/XdrUnsignedInteger.java b/spec/output/generator_spec_java/optional.x/XdrUnsignedInteger.java index 8f2a52395..a56ad657d 100644 --- a/spec/output/generator_spec_java/optional.x/XdrUnsignedInteger.java +++ b/spec/output/generator_spec_java/optional.x/XdrUnsignedInteger.java @@ -1,9 +1,9 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -12,10 +12,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedInteger implements XdrElement { public static final long MAX_VALUE = (1L << 32) - 1; public static final long MIN_VALUE = 0; - private final Long number; + Long number; public XdrUnsignedInteger(Long number) { if (number < MIN_VALUE || number > MAX_VALUE) { @@ -32,10 +33,6 @@ public XdrUnsignedInteger(Integer number) { this.number = number.longValue(); } - public Long getNumber() { - return number; - } - public static XdrUnsignedInteger decode(XdrDataInputStream stream) throws IOException { int intValue = stream.readInt(); long uint32Value = Integer.toUnsignedLong(intValue); @@ -70,23 +67,4 @@ public static XdrUnsignedInteger fromXdrByteArray(byte[] xdr) throws IOException XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedInteger)) { - return false; - } - - XdrUnsignedInteger other = (XdrUnsignedInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/struct.x/Int64.java b/spec/output/generator_spec_java/struct.x/Int64.java index d5029d25d..1c0f9a595 100644 --- a/spec/output/generator_spec_java/struct.x/Int64.java +++ b/spec/output/generator_spec_java/struct.x/Int64.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Int64's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef hyper int64; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Int64 implements XdrElement { private Long int64; - - public Int64() {} - - public Int64(Long int64) { - this.int64 = int64; - } - - public Long getInt64() { - return this.int64; - } - - public void setInt64(Long value) { - this.int64 = value; - } - public static void encode(XdrDataOutputStream stream, Int64 encodedInt64) throws IOException { stream.writeLong(encodedInt64.int64); } @@ -47,20 +37,6 @@ public static Int64 decode(XdrDataInputStream stream) throws IOException { return decodedInt64; } - @Override - public int hashCode() { - return Objects.hash(this.int64); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Int64)) { - return false; - } - - Int64 other = (Int64) object; - return Objects.equals(this.int64, other.int64); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/struct.x/MyStruct.java b/spec/output/generator_spec_java/struct.x/MyStruct.java index 6396b1fe9..11972e22c 100644 --- a/spec/output/generator_spec_java/struct.x/MyStruct.java +++ b/spec/output/generator_spec_java/struct.x/MyStruct.java @@ -5,12 +5,14 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import lombok.Builder; +import static MyXDR.Constants.*; /** * MyStruct's original definition in the XDR file is: @@ -25,48 +27,21 @@ * }; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Builder(toBuilder = true) public class MyStruct implements XdrElement { - public MyStruct () {} private Integer someInt; - public Integer getSomeInt() { - return this.someInt; - } - public void setSomeInt(Integer value) { - this.someInt = value; - } private Int64 aBigInt; - public Int64 getABigInt() { - return this.aBigInt; - } - public void setABigInt(Int64 value) { - this.aBigInt = value; - } private byte[] someOpaque; - public byte[] getSomeOpaque() { - return this.someOpaque; - } - public void setSomeOpaque(byte[] value) { - this.someOpaque = value; - } private XdrString someString; - public XdrString getSomeString() { - return this.someString; - } - public void setSomeString(XdrString value) { - this.someString = value; - } private XdrString maxString; - public XdrString getMaxString() { - return this.maxString; - } - public void setMaxString(XdrString value) { - this.maxString = value; - } public static void encode(XdrDataOutputStream stream, MyStruct encodedMyStruct) throws IOException{ stream.writeInt(encodedMyStruct.someInt); Int64.encode(stream, encodedMyStruct.aBigInt); - int someOpaquesize = encodedMyStruct.someOpaque.length; - stream.write(encodedMyStruct.getSomeOpaque(), 0, someOpaquesize); + int someOpaqueSize = encodedMyStruct.someOpaque.length; + stream.write(encodedMyStruct.getSomeOpaque(), 0, someOpaqueSize); encodedMyStruct.someString.encode(stream); encodedMyStruct.maxString.encode(stream); } @@ -77,27 +52,13 @@ public static MyStruct decode(XdrDataInputStream stream) throws IOException { MyStruct decodedMyStruct = new MyStruct(); decodedMyStruct.someInt = stream.readInt(); decodedMyStruct.aBigInt = Int64.decode(stream); - int someOpaquesize = 10; - decodedMyStruct.someOpaque = new byte[someOpaquesize]; - stream.read(decodedMyStruct.someOpaque, 0, someOpaquesize); + int someOpaqueSize = 10; + decodedMyStruct.someOpaque = new byte[someOpaqueSize]; + stream.read(decodedMyStruct.someOpaque, 0, someOpaqueSize); decodedMyStruct.someString = XdrString.decode(stream, Integer.MAX_VALUE); decodedMyStruct.maxString = XdrString.decode(stream, 100); return decodedMyStruct; } - @Override - public int hashCode() { - return Objects.hash(this.someInt, this.aBigInt, Arrays.hashCode(this.someOpaque), this.someString, this.maxString); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof MyStruct)) { - return false; - } - - MyStruct other = (MyStruct) object; - return Objects.equals(this.someInt, other.someInt) && Objects.equals(this.aBigInt, other.aBigInt) && Arrays.equals(this.someOpaque, other.someOpaque) && Objects.equals(this.someString, other.someString) && Objects.equals(this.maxString, other.maxString); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -121,46 +82,4 @@ public static MyStruct fromXdrByteArray(byte[] xdr) throws IOException { XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - public static final class Builder { - private Integer someInt; - private Int64 aBigInt; - private byte[] someOpaque; - private XdrString someString; - private XdrString maxString; - - public Builder someInt(Integer someInt) { - this.someInt = someInt; - return this; - } - - public Builder aBigInt(Int64 aBigInt) { - this.aBigInt = aBigInt; - return this; - } - - public Builder someOpaque(byte[] someOpaque) { - this.someOpaque = someOpaque; - return this; - } - - public Builder someString(XdrString someString) { - this.someString = someString; - return this; - } - - public Builder maxString(XdrString maxString) { - this.maxString = maxString; - return this; - } - - public MyStruct build() { - MyStruct val = new MyStruct(); - val.setSomeInt(this.someInt); - val.setABigInt(this.aBigInt); - val.setSomeOpaque(this.someOpaque); - val.setSomeString(this.someString); - val.setMaxString(this.maxString); - return val; - } - } } diff --git a/spec/output/generator_spec_java/struct.x/XdrString.java b/spec/output/generator_spec_java/struct.x/XdrString.java index bb4e81fb4..2d8f8bbc9 100644 --- a/spec/output/generator_spec_java/struct.x/XdrString.java +++ b/spec/output/generator_spec_java/struct.x/XdrString.java @@ -4,90 +4,72 @@ import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InvalidClassException; -import java.nio.charset.Charset; -import java.util.Arrays; +import java.nio.charset.StandardCharsets; +import lombok.Value; import org.stellar.sdk.Base64Factory; +@Value public class XdrString implements XdrElement { - private byte[] bytes; + byte[] bytes; - public XdrString(byte[] bytes) { - this.bytes = bytes; - } + public XdrString(byte[] bytes) { + this.bytes = bytes; + } - public XdrString(String text) { - this.bytes = text.getBytes(Charset.forName("UTF-8")); - } + public XdrString(String text) { + this.bytes = text.getBytes(StandardCharsets.UTF_8); + } - @Override - public void encode(XdrDataOutputStream stream) throws IOException { - stream.writeInt(this.bytes.length); - stream.write(this.bytes, 0, this.bytes.length); - } + @Override + public void encode(XdrDataOutputStream stream) throws IOException { + stream.writeInt(this.bytes.length); + stream.write(this.bytes, 0, this.bytes.length); + } - public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { - int size = stream.readInt(); - if (size > maxSize) { - throw new InvalidClassException("String length "+size+" exceeds max size "+maxSize); - } - byte[] bytes = new byte[size]; - stream.read(bytes); - return new XdrString(bytes); + public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { + int size = stream.readInt(); + if (size > maxSize) { + throw new InvalidClassException("String length " + size + " exceeds max size " + maxSize); } + byte[] bytes = new byte[size]; + stream.read(bytes); + return new XdrString(bytes); + } - public byte[] getBytes() { - return this.bytes; - } + @Override + public String toXdrBase64() throws IOException { + return Base64Factory.getInstance().encodeToString(toXdrByteArray()); + } - @Override - public String toXdrBase64() throws IOException { - return Base64Factory.getInstance().encodeToString(toXdrByteArray()); - } - - @Override - public byte[] toXdrByteArray() throws IOException { - ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); - encode(xdrDataOutputStream); - return byteArrayOutputStream.toByteArray(); - } - - public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { - byte[] bytes = Base64Factory.getInstance().decode(xdr); - return fromXdrByteArray(bytes, maxSize); - } - - public static XdrString fromXdrBase64(String xdr) throws IOException { - return fromXdrBase64(xdr, Integer.MAX_VALUE); - } - - public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { - ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); - XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); - return decode(xdrDataInputStream, maxSize); - } - - public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { - return fromXdrByteArray(xdr, Integer.MAX_VALUE); - } + @Override + public byte[] toXdrByteArray() throws IOException { + ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); + XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); + encode(xdrDataOutputStream); + return byteArrayOutputStream.toByteArray(); + } - @Override - public int hashCode() { - return Arrays.hashCode(this.bytes); - } + public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { + byte[] bytes = Base64Factory.getInstance().decode(xdr); + return fromXdrByteArray(bytes, maxSize); + } - @Override - public boolean equals(Object object) { - if (object == null || !(object instanceof XdrString)) { - return false; - } + public static XdrString fromXdrBase64(String xdr) throws IOException { + return fromXdrBase64(xdr, Integer.MAX_VALUE); + } - XdrString other = (XdrString) object; - return Arrays.equals(this.bytes, other.bytes); - } + public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { + ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); + XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); + return decode(xdrDataInputStream, maxSize); + } - @Override - public String toString() { - return new String(bytes, Charset.forName("UTF-8")); - } + public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { + return fromXdrByteArray(xdr, Integer.MAX_VALUE); + } + + @Override + public String toString() { + return new String(bytes, StandardCharsets.UTF_8); + } } diff --git a/spec/output/generator_spec_java/struct.x/XdrUnsignedHyperInteger.java b/spec/output/generator_spec_java/struct.x/XdrUnsignedHyperInteger.java index 6c05ca57d..204aa83de 100644 --- a/spec/output/generator_spec_java/struct.x/XdrUnsignedHyperInteger.java +++ b/spec/output/generator_spec_java/struct.x/XdrUnsignedHyperInteger.java @@ -1,10 +1,10 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.math.BigInteger; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -13,10 +13,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedHyperInteger implements XdrElement { public static final BigInteger MAX_VALUE = new BigInteger("18446744073709551615"); public static final BigInteger MIN_VALUE = BigInteger.ZERO; - private final BigInteger number; + BigInteger number; public XdrUnsignedHyperInteger(BigInteger number) { if (number.compareTo(MIN_VALUE) < 0 || number.compareTo(MAX_VALUE) > 0) { @@ -55,10 +56,6 @@ private byte[] getBytes() { return paddedBytes; } - public BigInteger getNumber() { - return number; - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -82,23 +79,4 @@ public static XdrUnsignedHyperInteger fromXdrByteArray(byte[] xdr) throws IOExce XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedHyperInteger)) { - return false; - } - - XdrUnsignedHyperInteger other = (XdrUnsignedHyperInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/struct.x/XdrUnsignedInteger.java b/spec/output/generator_spec_java/struct.x/XdrUnsignedInteger.java index 8f2a52395..a56ad657d 100644 --- a/spec/output/generator_spec_java/struct.x/XdrUnsignedInteger.java +++ b/spec/output/generator_spec_java/struct.x/XdrUnsignedInteger.java @@ -1,9 +1,9 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -12,10 +12,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedInteger implements XdrElement { public static final long MAX_VALUE = (1L << 32) - 1; public static final long MIN_VALUE = 0; - private final Long number; + Long number; public XdrUnsignedInteger(Long number) { if (number < MIN_VALUE || number > MAX_VALUE) { @@ -32,10 +33,6 @@ public XdrUnsignedInteger(Integer number) { this.number = number.longValue(); } - public Long getNumber() { - return number; - } - public static XdrUnsignedInteger decode(XdrDataInputStream stream) throws IOException { int intValue = stream.readInt(); long uint32Value = Integer.toUnsignedLong(intValue); @@ -70,23 +67,4 @@ public static XdrUnsignedInteger fromXdrByteArray(byte[] xdr) throws IOException XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedInteger)) { - return false; - } - - XdrUnsignedInteger other = (XdrUnsignedInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/test.x/Color.java b/spec/output/generator_spec_java/test.x/Color.java index 8b64c3648..fd00aeaa9 100644 --- a/spec/output/generator_spec_java/test.x/Color.java +++ b/spec/output/generator_spec_java/test.x/Color.java @@ -5,7 +5,6 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; @@ -23,16 +22,16 @@ public enum Color implements XdrElement { RED(0), BLUE(5), - GREEN(6), - ; - private int mValue; + GREEN(6); + + private final int value; Color(int value) { - mValue = value; + this.value = value; } public int getValue() { - return mValue; + return value; } public static Color decode(XdrDataInputStream stream) throws IOException { diff --git a/spec/output/generator_spec_java/test.x/HasStuff.java b/spec/output/generator_spec_java/test.x/HasStuff.java index 3015f1726..33b21798c 100644 --- a/spec/output/generator_spec_java/test.x/HasStuff.java +++ b/spec/output/generator_spec_java/test.x/HasStuff.java @@ -5,11 +5,14 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import lombok.Builder; +import static MyXDR.Constants.*; /** * HasStuff's original definition in the XDR file is: @@ -20,15 +23,12 @@ * }; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Builder(toBuilder = true) public class HasStuff implements XdrElement { - public HasStuff () {} private LotsOfMyStructs data; - public LotsOfMyStructs getData() { - return this.data; - } - public void setData(LotsOfMyStructs value) { - this.data = value; - } public static void encode(XdrDataOutputStream stream, HasStuff encodedHasStuff) throws IOException{ LotsOfMyStructs.encode(stream, encodedHasStuff.data); } @@ -40,20 +40,6 @@ public static HasStuff decode(XdrDataInputStream stream) throws IOException { decodedHasStuff.data = LotsOfMyStructs.decode(stream); return decodedHasStuff; } - @Override - public int hashCode() { - return Objects.hash(this.data); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof HasStuff)) { - return false; - } - - HasStuff other = (HasStuff) object; - return Objects.equals(this.data, other.data); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -77,18 +63,4 @@ public static HasStuff fromXdrByteArray(byte[] xdr) throws IOException { XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - public static final class Builder { - private LotsOfMyStructs data; - - public Builder data(LotsOfMyStructs data) { - this.data = data; - return this; - } - - public HasStuff build() { - HasStuff val = new HasStuff(); - val.setData(this.data); - return val; - } - } } diff --git a/spec/output/generator_spec_java/test.x/Hash.java b/spec/output/generator_spec_java/test.x/Hash.java index e5cd4e551..e7851f9b9 100644 --- a/spec/output/generator_spec_java/test.x/Hash.java +++ b/spec/output/generator_spec_java/test.x/Hash.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Hash's original definition in the XDR file is: @@ -17,26 +19,14 @@ * typedef opaque Hash[32]; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Hash implements XdrElement { private byte[] Hash; - - public Hash() {} - - public Hash(byte[] Hash) { - this.Hash = Hash; - } - - public byte[] getHash() { - return this.Hash; - } - - public void setHash(byte[] value) { - this.Hash = value; - } - public static void encode(XdrDataOutputStream stream, Hash encodedHash) throws IOException { - int Hashsize = encodedHash.Hash.length; - stream.write(encodedHash.getHash(), 0, Hashsize); + int HashSize = encodedHash.Hash.length; + stream.write(encodedHash.getHash(), 0, HashSize); } public void encode(XdrDataOutputStream stream) throws IOException { @@ -44,26 +34,12 @@ public void encode(XdrDataOutputStream stream) throws IOException { } public static Hash decode(XdrDataInputStream stream) throws IOException { Hash decodedHash = new Hash(); - int Hashsize = 32; - decodedHash.Hash = new byte[Hashsize]; - stream.read(decodedHash.Hash, 0, Hashsize); + int HashSize = 32; + decodedHash.Hash = new byte[HashSize]; + stream.read(decodedHash.Hash, 0, HashSize); return decodedHash; } - @Override - public int hashCode() { - return Arrays.hashCode(this.Hash); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Hash)) { - return false; - } - - Hash other = (Hash) object; - return Arrays.equals(this.Hash, other.Hash); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Hashes1.java b/spec/output/generator_spec_java/test.x/Hashes1.java index f69adbcba..e40e91a47 100644 --- a/spec/output/generator_spec_java/test.x/Hashes1.java +++ b/spec/output/generator_spec_java/test.x/Hashes1.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Hashes1's original definition in the XDR file is: @@ -17,26 +19,14 @@ * typedef Hash Hashes1[12]; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Hashes1 implements XdrElement { private Hash[] Hashes1; - - public Hashes1() {} - - public Hashes1(Hash[] Hashes1) { - this.Hashes1 = Hashes1; - } - - public Hash[] getHashes1() { - return this.Hashes1; - } - - public void setHashes1(Hash[] value) { - this.Hashes1 = value; - } - public static void encode(XdrDataOutputStream stream, Hashes1 encodedHashes1) throws IOException { - int Hashes1size = encodedHashes1.getHashes1().length; - for (int i = 0; i < Hashes1size; i++) { + int Hashes1Size = encodedHashes1.getHashes1().length; + for (int i = 0; i < Hashes1Size; i++) { Hash.encode(stream, encodedHashes1.Hashes1[i]); } } @@ -46,28 +36,14 @@ public void encode(XdrDataOutputStream stream) throws IOException { } public static Hashes1 decode(XdrDataInputStream stream) throws IOException { Hashes1 decodedHashes1 = new Hashes1(); - int Hashes1size = 12; - decodedHashes1.Hashes1 = new Hash[Hashes1size]; - for (int i = 0; i < Hashes1size; i++) { + int Hashes1Size = 12; + decodedHashes1.Hashes1 = new Hash[Hashes1Size]; + for (int i = 0; i < Hashes1Size; i++) { decodedHashes1.Hashes1[i] = Hash.decode(stream); } return decodedHashes1; } - @Override - public int hashCode() { - return Arrays.hashCode(this.Hashes1); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Hashes1)) { - return false; - } - - Hashes1 other = (Hashes1) object; - return Arrays.equals(this.Hashes1, other.Hashes1); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Hashes2.java b/spec/output/generator_spec_java/test.x/Hashes2.java index 11ff7b448..04675d3bd 100644 --- a/spec/output/generator_spec_java/test.x/Hashes2.java +++ b/spec/output/generator_spec_java/test.x/Hashes2.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Hashes2's original definition in the XDR file is: @@ -17,27 +19,15 @@ * typedef Hash Hashes2<12>; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Hashes2 implements XdrElement { private Hash[] Hashes2; - - public Hashes2() {} - - public Hashes2(Hash[] Hashes2) { - this.Hashes2 = Hashes2; - } - - public Hash[] getHashes2() { - return this.Hashes2; - } - - public void setHashes2(Hash[] value) { - this.Hashes2 = value; - } - public static void encode(XdrDataOutputStream stream, Hashes2 encodedHashes2) throws IOException { - int Hashes2size = encodedHashes2.getHashes2().length; - stream.writeInt(Hashes2size); - for (int i = 0; i < Hashes2size; i++) { + int Hashes2Size = encodedHashes2.getHashes2().length; + stream.writeInt(Hashes2Size); + for (int i = 0; i < Hashes2Size; i++) { Hash.encode(stream, encodedHashes2.Hashes2[i]); } } @@ -47,28 +37,14 @@ public void encode(XdrDataOutputStream stream) throws IOException { } public static Hashes2 decode(XdrDataInputStream stream) throws IOException { Hashes2 decodedHashes2 = new Hashes2(); - int Hashes2size = stream.readInt(); - decodedHashes2.Hashes2 = new Hash[Hashes2size]; - for (int i = 0; i < Hashes2size; i++) { + int Hashes2Size = stream.readInt(); + decodedHashes2.Hashes2 = new Hash[Hashes2Size]; + for (int i = 0; i < Hashes2Size; i++) { decodedHashes2.Hashes2[i] = Hash.decode(stream); } return decodedHashes2; } - @Override - public int hashCode() { - return Arrays.hashCode(this.Hashes2); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Hashes2)) { - return false; - } - - Hashes2 other = (Hashes2) object; - return Arrays.equals(this.Hashes2, other.Hashes2); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Hashes3.java b/spec/output/generator_spec_java/test.x/Hashes3.java index 09fd6afce..7901f81dd 100644 --- a/spec/output/generator_spec_java/test.x/Hashes3.java +++ b/spec/output/generator_spec_java/test.x/Hashes3.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Hashes3's original definition in the XDR file is: @@ -17,27 +19,15 @@ * typedef Hash Hashes3<>; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Hashes3 implements XdrElement { private Hash[] Hashes3; - - public Hashes3() {} - - public Hashes3(Hash[] Hashes3) { - this.Hashes3 = Hashes3; - } - - public Hash[] getHashes3() { - return this.Hashes3; - } - - public void setHashes3(Hash[] value) { - this.Hashes3 = value; - } - public static void encode(XdrDataOutputStream stream, Hashes3 encodedHashes3) throws IOException { - int Hashes3size = encodedHashes3.getHashes3().length; - stream.writeInt(Hashes3size); - for (int i = 0; i < Hashes3size; i++) { + int Hashes3Size = encodedHashes3.getHashes3().length; + stream.writeInt(Hashes3Size); + for (int i = 0; i < Hashes3Size; i++) { Hash.encode(stream, encodedHashes3.Hashes3[i]); } } @@ -47,28 +37,14 @@ public void encode(XdrDataOutputStream stream) throws IOException { } public static Hashes3 decode(XdrDataInputStream stream) throws IOException { Hashes3 decodedHashes3 = new Hashes3(); - int Hashes3size = stream.readInt(); - decodedHashes3.Hashes3 = new Hash[Hashes3size]; - for (int i = 0; i < Hashes3size; i++) { + int Hashes3Size = stream.readInt(); + decodedHashes3.Hashes3 = new Hash[Hashes3Size]; + for (int i = 0; i < Hashes3Size; i++) { decodedHashes3.Hashes3[i] = Hash.decode(stream); } return decodedHashes3; } - @Override - public int hashCode() { - return Arrays.hashCode(this.Hashes3); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Hashes3)) { - return false; - } - - Hashes3 other = (Hashes3) object; - return Arrays.equals(this.Hashes3, other.Hashes3); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Int1.java b/spec/output/generator_spec_java/test.x/Int1.java index ca647afa9..f1dfad8fa 100644 --- a/spec/output/generator_spec_java/test.x/Int1.java +++ b/spec/output/generator_spec_java/test.x/Int1.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Int1's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef int int1; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Int1 implements XdrElement { private Integer int1; - - public Int1() {} - - public Int1(Integer int1) { - this.int1 = int1; - } - - public Integer getInt1() { - return this.int1; - } - - public void setInt1(Integer value) { - this.int1 = value; - } - public static void encode(XdrDataOutputStream stream, Int1 encodedInt1) throws IOException { stream.writeInt(encodedInt1.int1); } @@ -47,20 +37,6 @@ public static Int1 decode(XdrDataInputStream stream) throws IOException { return decodedInt1; } - @Override - public int hashCode() { - return Objects.hash(this.int1); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Int1)) { - return false; - } - - Int1 other = (Int1) object; - return Objects.equals(this.int1, other.int1); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Int2.java b/spec/output/generator_spec_java/test.x/Int2.java index f7cf4e5b5..bcfc76480 100644 --- a/spec/output/generator_spec_java/test.x/Int2.java +++ b/spec/output/generator_spec_java/test.x/Int2.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Int2's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef hyper int2; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Int2 implements XdrElement { private Long int2; - - public Int2() {} - - public Int2(Long int2) { - this.int2 = int2; - } - - public Long getInt2() { - return this.int2; - } - - public void setInt2(Long value) { - this.int2 = value; - } - public static void encode(XdrDataOutputStream stream, Int2 encodedInt2) throws IOException { stream.writeLong(encodedInt2.int2); } @@ -47,20 +37,6 @@ public static Int2 decode(XdrDataInputStream stream) throws IOException { return decodedInt2; } - @Override - public int hashCode() { - return Objects.hash(this.int2); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Int2)) { - return false; - } - - Int2 other = (Int2) object; - return Objects.equals(this.int2, other.int2); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Int3.java b/spec/output/generator_spec_java/test.x/Int3.java index ac255140c..79434be85 100644 --- a/spec/output/generator_spec_java/test.x/Int3.java +++ b/spec/output/generator_spec_java/test.x/Int3.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Int3's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef unsigned int int3; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Int3 implements XdrElement { private XdrUnsignedInteger int3; - - public Int3() {} - - public Int3(XdrUnsignedInteger int3) { - this.int3 = int3; - } - - public XdrUnsignedInteger getInt3() { - return this.int3; - } - - public void setInt3(XdrUnsignedInteger value) { - this.int3 = value; - } - public static void encode(XdrDataOutputStream stream, Int3 encodedInt3) throws IOException { encodedInt3.int3.encode(stream); } @@ -47,20 +37,6 @@ public static Int3 decode(XdrDataInputStream stream) throws IOException { return decodedInt3; } - @Override - public int hashCode() { - return Objects.hash(this.int3); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Int3)) { - return false; - } - - Int3 other = (Int3) object; - return Objects.equals(this.int3, other.int3); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Int4.java b/spec/output/generator_spec_java/test.x/Int4.java index a3df9c1c9..023e58021 100644 --- a/spec/output/generator_spec_java/test.x/Int4.java +++ b/spec/output/generator_spec_java/test.x/Int4.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Int4's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef unsigned hyper int4; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Int4 implements XdrElement { private XdrUnsignedHyperInteger int4; - - public Int4() {} - - public Int4(XdrUnsignedHyperInteger int4) { - this.int4 = int4; - } - - public XdrUnsignedHyperInteger getInt4() { - return this.int4; - } - - public void setInt4(XdrUnsignedHyperInteger value) { - this.int4 = value; - } - public static void encode(XdrDataOutputStream stream, Int4 encodedInt4) throws IOException { encodedInt4.int4.encode(stream); } @@ -47,20 +37,6 @@ public static Int4 decode(XdrDataInputStream stream) throws IOException { return decodedInt4; } - @Override - public int hashCode() { - return Objects.hash(this.int4); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Int4)) { - return false; - } - - Int4 other = (Int4) object; - return Objects.equals(this.int4, other.int4); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/LotsOfMyStructs.java b/spec/output/generator_spec_java/test.x/LotsOfMyStructs.java index 71ac2c54c..5e24fd883 100644 --- a/spec/output/generator_spec_java/test.x/LotsOfMyStructs.java +++ b/spec/output/generator_spec_java/test.x/LotsOfMyStructs.java @@ -5,11 +5,14 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import lombok.Builder; +import static MyXDR.Constants.*; /** * LotsOfMyStructs's original definition in the XDR file is: @@ -20,19 +23,16 @@ * }; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Builder(toBuilder = true) public class LotsOfMyStructs implements XdrElement { - public LotsOfMyStructs () {} private MyStruct[] members; - public MyStruct[] getMembers() { - return this.members; - } - public void setMembers(MyStruct[] value) { - this.members = value; - } public static void encode(XdrDataOutputStream stream, LotsOfMyStructs encodedLotsOfMyStructs) throws IOException{ - int memberssize = encodedLotsOfMyStructs.getMembers().length; - stream.writeInt(memberssize); - for (int i = 0; i < memberssize; i++) { + int membersSize = encodedLotsOfMyStructs.getMembers().length; + stream.writeInt(membersSize); + for (int i = 0; i < membersSize; i++) { MyStruct.encode(stream, encodedLotsOfMyStructs.members[i]); } } @@ -41,27 +41,13 @@ public void encode(XdrDataOutputStream stream) throws IOException { } public static LotsOfMyStructs decode(XdrDataInputStream stream) throws IOException { LotsOfMyStructs decodedLotsOfMyStructs = new LotsOfMyStructs(); - int memberssize = stream.readInt(); - decodedLotsOfMyStructs.members = new MyStruct[memberssize]; - for (int i = 0; i < memberssize; i++) { + int membersSize = stream.readInt(); + decodedLotsOfMyStructs.members = new MyStruct[membersSize]; + for (int i = 0; i < membersSize; i++) { decodedLotsOfMyStructs.members[i] = MyStruct.decode(stream); } return decodedLotsOfMyStructs; } - @Override - public int hashCode() { - return Arrays.hashCode(this.members); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof LotsOfMyStructs)) { - return false; - } - - LotsOfMyStructs other = (LotsOfMyStructs) object; - return Arrays.equals(this.members, other.members); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -85,18 +71,4 @@ public static LotsOfMyStructs fromXdrByteArray(byte[] xdr) throws IOException { XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - public static final class Builder { - private MyStruct[] members; - - public Builder members(MyStruct[] members) { - this.members = members; - return this; - } - - public LotsOfMyStructs build() { - LotsOfMyStructs val = new LotsOfMyStructs(); - val.setMembers(this.members); - return val; - } - } } diff --git a/spec/output/generator_spec_java/test.x/MyStruct.java b/spec/output/generator_spec_java/test.x/MyStruct.java index 09015e925..385e713a9 100644 --- a/spec/output/generator_spec_java/test.x/MyStruct.java +++ b/spec/output/generator_spec_java/test.x/MyStruct.java @@ -5,11 +5,14 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import lombok.Builder; +import static MyXDR.Constants.*; /** * MyStruct's original definition in the XDR file is: @@ -26,57 +29,18 @@ * }; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Builder(toBuilder = true) public class MyStruct implements XdrElement { - public MyStruct () {} private Uint512 field1; - public Uint512 getField1() { - return this.field1; - } - public void setField1(Uint512 value) { - this.field1 = value; - } private OptHash1 field2; - public OptHash1 getField2() { - return this.field2; - } - public void setField2(OptHash1 value) { - this.field2 = value; - } private Int1 field3; - public Int1 getField3() { - return this.field3; - } - public void setField3(Int1 value) { - this.field3 = value; - } private XdrUnsignedInteger field4; - public XdrUnsignedInteger getField4() { - return this.field4; - } - public void setField4(XdrUnsignedInteger value) { - this.field4 = value; - } private Float field5; - public Float getField5() { - return this.field5; - } - public void setField5(Float value) { - this.field5 = value; - } private Double field6; - public Double getField6() { - return this.field6; - } - public void setField6(Double value) { - this.field6 = value; - } private Boolean field7; - public Boolean getField7() { - return this.field7; - } - public void setField7(Boolean value) { - this.field7 = value; - } public static void encode(XdrDataOutputStream stream, MyStruct encodedMyStruct) throws IOException{ Uint512.encode(stream, encodedMyStruct.field1); OptHash1.encode(stream, encodedMyStruct.field2); @@ -100,20 +64,6 @@ public static MyStruct decode(XdrDataInputStream stream) throws IOException { decodedMyStruct.field7 = stream.readInt() == 1 ? true : false; return decodedMyStruct; } - @Override - public int hashCode() { - return Objects.hash(this.field1, this.field2, this.field3, this.field4, this.field5, this.field6, this.field7); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof MyStruct)) { - return false; - } - - MyStruct other = (MyStruct) object; - return Objects.equals(this.field1, other.field1) && Objects.equals(this.field2, other.field2) && Objects.equals(this.field3, other.field3) && Objects.equals(this.field4, other.field4) && Objects.equals(this.field5, other.field5) && Objects.equals(this.field6, other.field6) && Objects.equals(this.field7, other.field7); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -137,60 +87,4 @@ public static MyStruct fromXdrByteArray(byte[] xdr) throws IOException { XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - public static final class Builder { - private Uint512 field1; - private OptHash1 field2; - private Int1 field3; - private XdrUnsignedInteger field4; - private Float field5; - private Double field6; - private Boolean field7; - - public Builder field1(Uint512 field1) { - this.field1 = field1; - return this; - } - - public Builder field2(OptHash1 field2) { - this.field2 = field2; - return this; - } - - public Builder field3(Int1 field3) { - this.field3 = field3; - return this; - } - - public Builder field4(XdrUnsignedInteger field4) { - this.field4 = field4; - return this; - } - - public Builder field5(Float field5) { - this.field5 = field5; - return this; - } - - public Builder field6(Double field6) { - this.field6 = field6; - return this; - } - - public Builder field7(Boolean field7) { - this.field7 = field7; - return this; - } - - public MyStruct build() { - MyStruct val = new MyStruct(); - val.setField1(this.field1); - val.setField2(this.field2); - val.setField3(this.field3); - val.setField4(this.field4); - val.setField5(this.field5); - val.setField6(this.field6); - val.setField7(this.field7); - return val; - } - } } diff --git a/spec/output/generator_spec_java/test.x/Nester.java b/spec/output/generator_spec_java/test.x/Nester.java index 6867dbf2e..876704528 100644 --- a/spec/output/generator_spec_java/test.x/Nester.java +++ b/spec/output/generator_spec_java/test.x/Nester.java @@ -5,11 +5,14 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import lombok.Builder; +import static MyXDR.Constants.*; /** * Nester's original definition in the XDR file is: @@ -36,29 +39,14 @@ * }; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Builder(toBuilder = true) public class Nester implements XdrElement { - public Nester () {} private NesterNestedEnum nestedEnum; - public NesterNestedEnum getNestedEnum() { - return this.nestedEnum; - } - public void setNestedEnum(NesterNestedEnum value) { - this.nestedEnum = value; - } private NesterNestedStruct nestedStruct; - public NesterNestedStruct getNestedStruct() { - return this.nestedStruct; - } - public void setNestedStruct(NesterNestedStruct value) { - this.nestedStruct = value; - } private NesterNestedUnion nestedUnion; - public NesterNestedUnion getNestedUnion() { - return this.nestedUnion; - } - public void setNestedUnion(NesterNestedUnion value) { - this.nestedUnion = value; - } public static void encode(XdrDataOutputStream stream, Nester encodedNester) throws IOException{ NesterNestedEnum.encode(stream, encodedNester.nestedEnum); NesterNestedStruct.encode(stream, encodedNester.nestedStruct); @@ -74,20 +62,6 @@ public static Nester decode(XdrDataInputStream stream) throws IOException { decodedNester.nestedUnion = NesterNestedUnion.decode(stream); return decodedNester; } - @Override - public int hashCode() { - return Objects.hash(this.nestedEnum, this.nestedStruct, this.nestedUnion); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof Nester)) { - return false; - } - - Nester other = (Nester) object; - return Objects.equals(this.nestedEnum, other.nestedEnum) && Objects.equals(this.nestedStruct, other.nestedStruct) && Objects.equals(this.nestedUnion, other.nestedUnion); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -111,34 +85,6 @@ public static Nester fromXdrByteArray(byte[] xdr) throws IOException { XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - public static final class Builder { - private NesterNestedEnum nestedEnum; - private NesterNestedStruct nestedStruct; - private NesterNestedUnion nestedUnion; - - public Builder nestedEnum(NesterNestedEnum nestedEnum) { - this.nestedEnum = nestedEnum; - return this; - } - - public Builder nestedStruct(NesterNestedStruct nestedStruct) { - this.nestedStruct = nestedStruct; - return this; - } - - public Builder nestedUnion(NesterNestedUnion nestedUnion) { - this.nestedUnion = nestedUnion; - return this; - } - - public Nester build() { - Nester val = new Nester(); - val.setNestedEnum(this.nestedEnum); - val.setNestedStruct(this.nestedStruct); - val.setNestedUnion(this.nestedUnion); - return val; - } - } /** * NesterNestedEnum's original definition in the XDR file is: @@ -151,16 +97,16 @@ public Nester build() { */ public static enum NesterNestedEnum implements XdrElement { BLAH_1(0), - BLAH_2(1), - ; - private int mValue; + BLAH_2(1); + + private final int value; NestedEnum(int value) { - mValue = value; + this.value = value; } public int getValue() { - return mValue; + return value; } public static NestedEnum decode(XdrDataInputStream stream) throws IOException { @@ -213,15 +159,12 @@ public static NestedEnum fromXdrByteArray(byte[] xdr) throws IOException { * } * */ + @Data + @NoArgsConstructor + @AllArgsConstructor + @Builder(toBuilder = true) public static class NesterNestedStruct implements XdrElement { - public NesterNestedStruct () {} private Integer blah; - public Integer getBlah() { - return this.blah; - } - public void setBlah(Integer value) { - this.blah = value; - } public static void encode(XdrDataOutputStream stream, NesterNestedStruct encodedNesterNestedStruct) throws IOException{ stream.writeInt(encodedNesterNestedStruct.blah); } @@ -233,20 +176,6 @@ public static NesterNestedStruct decode(XdrDataInputStream stream) throws IOExce decodedNesterNestedStruct.blah = stream.readInt(); return decodedNesterNestedStruct; } - @Override - public int hashCode() { - return Objects.hash(this.blah); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof NesterNestedStruct)) { - return false; - } - - NesterNestedStruct other = (NesterNestedStruct) object; - return Objects.equals(this.blah, other.blah); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -270,20 +199,6 @@ public static NesterNestedStruct fromXdrByteArray(byte[] xdr) throws IOException XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - public static final class Builder { - private Integer blah; - - public Builder blah(Integer blah) { - this.blah = blah; - return this; - } - - public NesterNestedStruct build() { - NesterNestedStruct val = new NesterNestedStruct(); - val.setBlah(this.blah); - return val; - } - } } /** @@ -297,44 +212,13 @@ public NesterNestedStruct build() { * } * */ + @Data + @NoArgsConstructor + @AllArgsConstructor + @Builder(toBuilder = true) public static class NesterNestedUnion implements XdrElement { - public NesterNestedUnion () {} - Color color; - public Color getDiscriminant() { - return this.color; - } - public void setDiscriminant(Color value) { - this.color = value; - } + private Color discriminant; private Integer blah2; - public Integer getBlah2() { - return this.blah2; - } - public void setBlah2(Integer value) { - this.blah2 = value; - } - - public static final class Builder { - private Color discriminant; - private Integer blah2; - - public Builder discriminant(Color discriminant) { - this.discriminant = discriminant; - return this; - } - - public Builder blah2(Integer blah2) { - this.blah2 = blah2; - return this; - } - - public NesterNestedUnion build() { - NesterNestedUnion val = new NesterNestedUnion(); - val.setDiscriminant(discriminant); - val.setBlah2(this.blah2); - return val; - } - } public static void encode(XdrDataOutputStream stream, NesterNestedUnion encodedNesterNestedUnion) throws IOException { //Xdrgen::AST::Identifier @@ -365,19 +249,6 @@ public static NesterNestedUnion decode(XdrDataInputStream stream) throws IOExcep return decodedNesterNestedUnion; } @Override - public int hashCode() { - return Objects.hash(this.blah2, this.color); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof NesterNestedUnion)) { - return false; - } - - NesterNestedUnion other = (NesterNestedUnion) object; - return Objects.equals(this.blah2, other.blah2) && Objects.equals(this.color, other.color); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); } diff --git a/spec/output/generator_spec_java/test.x/OptHash1.java b/spec/output/generator_spec_java/test.x/OptHash1.java index fd8cb2bf8..57eec6dee 100644 --- a/spec/output/generator_spec_java/test.x/OptHash1.java +++ b/spec/output/generator_spec_java/test.x/OptHash1.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * OptHash1's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef Hash *optHash1; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class OptHash1 implements XdrElement { private Hash optHash1; - - public OptHash1() {} - - public OptHash1(Hash optHash1) { - this.optHash1 = optHash1; - } - - public Hash getOptHash1() { - return this.optHash1; - } - - public void setOptHash1(Hash value) { - this.optHash1 = value; - } - public static void encode(XdrDataOutputStream stream, OptHash1 encodedOptHash1) throws IOException { if (encodedOptHash1.optHash1 != null) { stream.writeInt(1); @@ -55,20 +45,6 @@ public static OptHash1 decode(XdrDataInputStream stream) throws IOException { return decodedOptHash1; } - @Override - public int hashCode() { - return Objects.hash(this.optHash1); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof OptHash1)) { - return false; - } - - OptHash1 other = (OptHash1) object; - return Objects.equals(this.optHash1, other.optHash1); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/OptHash2.java b/spec/output/generator_spec_java/test.x/OptHash2.java index 0cacea821..0f853d807 100644 --- a/spec/output/generator_spec_java/test.x/OptHash2.java +++ b/spec/output/generator_spec_java/test.x/OptHash2.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * OptHash2's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef Hash* optHash2; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class OptHash2 implements XdrElement { private Hash optHash2; - - public OptHash2() {} - - public OptHash2(Hash optHash2) { - this.optHash2 = optHash2; - } - - public Hash getOptHash2() { - return this.optHash2; - } - - public void setOptHash2(Hash value) { - this.optHash2 = value; - } - public static void encode(XdrDataOutputStream stream, OptHash2 encodedOptHash2) throws IOException { if (encodedOptHash2.optHash2 != null) { stream.writeInt(1); @@ -55,20 +45,6 @@ public static OptHash2 decode(XdrDataInputStream stream) throws IOException { return decodedOptHash2; } - @Override - public int hashCode() { - return Objects.hash(this.optHash2); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof OptHash2)) { - return false; - } - - OptHash2 other = (OptHash2) object; - return Objects.equals(this.optHash2, other.optHash2); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Str.java b/spec/output/generator_spec_java/test.x/Str.java index b0ab22de2..9bd9154e5 100644 --- a/spec/output/generator_spec_java/test.x/Str.java +++ b/spec/output/generator_spec_java/test.x/Str.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Str's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef string str<64>; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Str implements XdrElement { private XdrString str; - - public Str() {} - - public Str(XdrString str) { - this.str = str; - } - - public XdrString getStr() { - return this.str; - } - - public void setStr(XdrString value) { - this.str = value; - } - public static void encode(XdrDataOutputStream stream, Str encodedStr) throws IOException { encodedStr.str.encode(stream); } @@ -47,20 +37,6 @@ public static Str decode(XdrDataInputStream stream) throws IOException { return decodedStr; } - @Override - public int hashCode() { - return Objects.hash(this.str); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Str)) { - return false; - } - - Str other = (Str) object; - return Objects.equals(this.str, other.str); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Str2.java b/spec/output/generator_spec_java/test.x/Str2.java index 7e820409f..766a54a12 100644 --- a/spec/output/generator_spec_java/test.x/Str2.java +++ b/spec/output/generator_spec_java/test.x/Str2.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Str2's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef string str2<>; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Str2 implements XdrElement { private XdrString str2; - - public Str2() {} - - public Str2(XdrString str2) { - this.str2 = str2; - } - - public XdrString getStr2() { - return this.str2; - } - - public void setStr2(XdrString value) { - this.str2 = value; - } - public static void encode(XdrDataOutputStream stream, Str2 encodedStr2) throws IOException { encodedStr2.str2.encode(stream); } @@ -47,20 +37,6 @@ public static Str2 decode(XdrDataInputStream stream) throws IOException { return decodedStr2; } - @Override - public int hashCode() { - return Objects.hash(this.str2); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Str2)) { - return false; - } - - Str2 other = (Str2) object; - return Objects.equals(this.str2, other.str2); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Uint512.java b/spec/output/generator_spec_java/test.x/Uint512.java index f8819f2ab..568e60a95 100644 --- a/spec/output/generator_spec_java/test.x/Uint512.java +++ b/spec/output/generator_spec_java/test.x/Uint512.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Uint512's original definition in the XDR file is: @@ -17,26 +19,14 @@ * typedef opaque uint512[64]; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Uint512 implements XdrElement { private byte[] uint512; - - public Uint512() {} - - public Uint512(byte[] uint512) { - this.uint512 = uint512; - } - - public byte[] getUint512() { - return this.uint512; - } - - public void setUint512(byte[] value) { - this.uint512 = value; - } - public static void encode(XdrDataOutputStream stream, Uint512 encodedUint512) throws IOException { - int uint512size = encodedUint512.uint512.length; - stream.write(encodedUint512.getUint512(), 0, uint512size); + int uint512Size = encodedUint512.uint512.length; + stream.write(encodedUint512.getUint512(), 0, uint512Size); } public void encode(XdrDataOutputStream stream) throws IOException { @@ -44,26 +34,12 @@ public void encode(XdrDataOutputStream stream) throws IOException { } public static Uint512 decode(XdrDataInputStream stream) throws IOException { Uint512 decodedUint512 = new Uint512(); - int uint512size = 64; - decodedUint512.uint512 = new byte[uint512size]; - stream.read(decodedUint512.uint512, 0, uint512size); + int uint512Size = 64; + decodedUint512.uint512 = new byte[uint512Size]; + stream.read(decodedUint512.uint512, 0, uint512Size); return decodedUint512; } - @Override - public int hashCode() { - return Arrays.hashCode(this.uint512); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Uint512)) { - return false; - } - - Uint512 other = (Uint512) object; - return Arrays.equals(this.uint512, other.uint512); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Uint513.java b/spec/output/generator_spec_java/test.x/Uint513.java index 6c2df51b7..7f9c35e2c 100644 --- a/spec/output/generator_spec_java/test.x/Uint513.java +++ b/spec/output/generator_spec_java/test.x/Uint513.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Uint513's original definition in the XDR file is: @@ -17,27 +19,15 @@ * typedef opaque uint513<64>; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Uint513 implements XdrElement { private byte[] uint513; - - public Uint513() {} - - public Uint513(byte[] uint513) { - this.uint513 = uint513; - } - - public byte[] getUint513() { - return this.uint513; - } - - public void setUint513(byte[] value) { - this.uint513 = value; - } - public static void encode(XdrDataOutputStream stream, Uint513 encodedUint513) throws IOException { - int uint513size = encodedUint513.uint513.length; - stream.writeInt(uint513size); - stream.write(encodedUint513.getUint513(), 0, uint513size); + int uint513Size = encodedUint513.uint513.length; + stream.writeInt(uint513Size); + stream.write(encodedUint513.getUint513(), 0, uint513Size); } public void encode(XdrDataOutputStream stream) throws IOException { @@ -45,26 +35,12 @@ public void encode(XdrDataOutputStream stream) throws IOException { } public static Uint513 decode(XdrDataInputStream stream) throws IOException { Uint513 decodedUint513 = new Uint513(); - int uint513size = stream.readInt(); - decodedUint513.uint513 = new byte[uint513size]; - stream.read(decodedUint513.uint513, 0, uint513size); + int uint513Size = stream.readInt(); + decodedUint513.uint513 = new byte[uint513Size]; + stream.read(decodedUint513.uint513, 0, uint513Size); return decodedUint513; } - @Override - public int hashCode() { - return Arrays.hashCode(this.uint513); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Uint513)) { - return false; - } - - Uint513 other = (Uint513) object; - return Arrays.equals(this.uint513, other.uint513); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/Uint514.java b/spec/output/generator_spec_java/test.x/Uint514.java index e1ad5a6fe..18a2ca997 100644 --- a/spec/output/generator_spec_java/test.x/Uint514.java +++ b/spec/output/generator_spec_java/test.x/Uint514.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Uint514's original definition in the XDR file is: @@ -17,27 +19,15 @@ * typedef opaque uint514<>; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Uint514 implements XdrElement { private byte[] uint514; - - public Uint514() {} - - public Uint514(byte[] uint514) { - this.uint514 = uint514; - } - - public byte[] getUint514() { - return this.uint514; - } - - public void setUint514(byte[] value) { - this.uint514 = value; - } - public static void encode(XdrDataOutputStream stream, Uint514 encodedUint514) throws IOException { - int uint514size = encodedUint514.uint514.length; - stream.writeInt(uint514size); - stream.write(encodedUint514.getUint514(), 0, uint514size); + int uint514Size = encodedUint514.uint514.length; + stream.writeInt(uint514Size); + stream.write(encodedUint514.getUint514(), 0, uint514Size); } public void encode(XdrDataOutputStream stream) throws IOException { @@ -45,26 +35,12 @@ public void encode(XdrDataOutputStream stream) throws IOException { } public static Uint514 decode(XdrDataInputStream stream) throws IOException { Uint514 decodedUint514 = new Uint514(); - int uint514size = stream.readInt(); - decodedUint514.uint514 = new byte[uint514size]; - stream.read(decodedUint514.uint514, 0, uint514size); + int uint514Size = stream.readInt(); + decodedUint514.uint514 = new byte[uint514Size]; + stream.read(decodedUint514.uint514, 0, uint514Size); return decodedUint514; } - @Override - public int hashCode() { - return Arrays.hashCode(this.uint514); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Uint514)) { - return false; - } - - Uint514 other = (Uint514) object; - return Arrays.equals(this.uint514, other.uint514); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/test.x/XdrString.java b/spec/output/generator_spec_java/test.x/XdrString.java index bb4e81fb4..2d8f8bbc9 100644 --- a/spec/output/generator_spec_java/test.x/XdrString.java +++ b/spec/output/generator_spec_java/test.x/XdrString.java @@ -4,90 +4,72 @@ import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InvalidClassException; -import java.nio.charset.Charset; -import java.util.Arrays; +import java.nio.charset.StandardCharsets; +import lombok.Value; import org.stellar.sdk.Base64Factory; +@Value public class XdrString implements XdrElement { - private byte[] bytes; + byte[] bytes; - public XdrString(byte[] bytes) { - this.bytes = bytes; - } + public XdrString(byte[] bytes) { + this.bytes = bytes; + } - public XdrString(String text) { - this.bytes = text.getBytes(Charset.forName("UTF-8")); - } + public XdrString(String text) { + this.bytes = text.getBytes(StandardCharsets.UTF_8); + } - @Override - public void encode(XdrDataOutputStream stream) throws IOException { - stream.writeInt(this.bytes.length); - stream.write(this.bytes, 0, this.bytes.length); - } + @Override + public void encode(XdrDataOutputStream stream) throws IOException { + stream.writeInt(this.bytes.length); + stream.write(this.bytes, 0, this.bytes.length); + } - public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { - int size = stream.readInt(); - if (size > maxSize) { - throw new InvalidClassException("String length "+size+" exceeds max size "+maxSize); - } - byte[] bytes = new byte[size]; - stream.read(bytes); - return new XdrString(bytes); + public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { + int size = stream.readInt(); + if (size > maxSize) { + throw new InvalidClassException("String length " + size + " exceeds max size " + maxSize); } + byte[] bytes = new byte[size]; + stream.read(bytes); + return new XdrString(bytes); + } - public byte[] getBytes() { - return this.bytes; - } + @Override + public String toXdrBase64() throws IOException { + return Base64Factory.getInstance().encodeToString(toXdrByteArray()); + } - @Override - public String toXdrBase64() throws IOException { - return Base64Factory.getInstance().encodeToString(toXdrByteArray()); - } - - @Override - public byte[] toXdrByteArray() throws IOException { - ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); - encode(xdrDataOutputStream); - return byteArrayOutputStream.toByteArray(); - } - - public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { - byte[] bytes = Base64Factory.getInstance().decode(xdr); - return fromXdrByteArray(bytes, maxSize); - } - - public static XdrString fromXdrBase64(String xdr) throws IOException { - return fromXdrBase64(xdr, Integer.MAX_VALUE); - } - - public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { - ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); - XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); - return decode(xdrDataInputStream, maxSize); - } - - public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { - return fromXdrByteArray(xdr, Integer.MAX_VALUE); - } + @Override + public byte[] toXdrByteArray() throws IOException { + ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); + XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); + encode(xdrDataOutputStream); + return byteArrayOutputStream.toByteArray(); + } - @Override - public int hashCode() { - return Arrays.hashCode(this.bytes); - } + public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { + byte[] bytes = Base64Factory.getInstance().decode(xdr); + return fromXdrByteArray(bytes, maxSize); + } - @Override - public boolean equals(Object object) { - if (object == null || !(object instanceof XdrString)) { - return false; - } + public static XdrString fromXdrBase64(String xdr) throws IOException { + return fromXdrBase64(xdr, Integer.MAX_VALUE); + } - XdrString other = (XdrString) object; - return Arrays.equals(this.bytes, other.bytes); - } + public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { + ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); + XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); + return decode(xdrDataInputStream, maxSize); + } - @Override - public String toString() { - return new String(bytes, Charset.forName("UTF-8")); - } + public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { + return fromXdrByteArray(xdr, Integer.MAX_VALUE); + } + + @Override + public String toString() { + return new String(bytes, StandardCharsets.UTF_8); + } } diff --git a/spec/output/generator_spec_java/test.x/XdrUnsignedHyperInteger.java b/spec/output/generator_spec_java/test.x/XdrUnsignedHyperInteger.java index 6c05ca57d..204aa83de 100644 --- a/spec/output/generator_spec_java/test.x/XdrUnsignedHyperInteger.java +++ b/spec/output/generator_spec_java/test.x/XdrUnsignedHyperInteger.java @@ -1,10 +1,10 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.math.BigInteger; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -13,10 +13,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedHyperInteger implements XdrElement { public static final BigInteger MAX_VALUE = new BigInteger("18446744073709551615"); public static final BigInteger MIN_VALUE = BigInteger.ZERO; - private final BigInteger number; + BigInteger number; public XdrUnsignedHyperInteger(BigInteger number) { if (number.compareTo(MIN_VALUE) < 0 || number.compareTo(MAX_VALUE) > 0) { @@ -55,10 +56,6 @@ private byte[] getBytes() { return paddedBytes; } - public BigInteger getNumber() { - return number; - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -82,23 +79,4 @@ public static XdrUnsignedHyperInteger fromXdrByteArray(byte[] xdr) throws IOExce XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedHyperInteger)) { - return false; - } - - XdrUnsignedHyperInteger other = (XdrUnsignedHyperInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/test.x/XdrUnsignedInteger.java b/spec/output/generator_spec_java/test.x/XdrUnsignedInteger.java index 8f2a52395..a56ad657d 100644 --- a/spec/output/generator_spec_java/test.x/XdrUnsignedInteger.java +++ b/spec/output/generator_spec_java/test.x/XdrUnsignedInteger.java @@ -1,9 +1,9 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -12,10 +12,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedInteger implements XdrElement { public static final long MAX_VALUE = (1L << 32) - 1; public static final long MIN_VALUE = 0; - private final Long number; + Long number; public XdrUnsignedInteger(Long number) { if (number < MIN_VALUE || number > MAX_VALUE) { @@ -32,10 +33,6 @@ public XdrUnsignedInteger(Integer number) { this.number = number.longValue(); } - public Long getNumber() { - return number; - } - public static XdrUnsignedInteger decode(XdrDataInputStream stream) throws IOException { int intValue = stream.readInt(); long uint32Value = Integer.toUnsignedLong(intValue); @@ -70,23 +67,4 @@ public static XdrUnsignedInteger fromXdrByteArray(byte[] xdr) throws IOException XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedInteger)) { - return false; - } - - XdrUnsignedInteger other = (XdrUnsignedInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/union.x/Error.java b/spec/output/generator_spec_java/union.x/Error.java index 1fe8a9d43..33888a051 100644 --- a/spec/output/generator_spec_java/union.x/Error.java +++ b/spec/output/generator_spec_java/union.x/Error.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Error's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef int Error; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Error implements XdrElement { private Integer Error; - - public Error() {} - - public Error(Integer Error) { - this.Error = Error; - } - - public Integer getError() { - return this.Error; - } - - public void setError(Integer value) { - this.Error = value; - } - public static void encode(XdrDataOutputStream stream, Error encodedError) throws IOException { stream.writeInt(encodedError.Error); } @@ -47,20 +37,6 @@ public static Error decode(XdrDataInputStream stream) throws IOException { return decodedError; } - @Override - public int hashCode() { - return Objects.hash(this.Error); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Error)) { - return false; - } - - Error other = (Error) object; - return Objects.equals(this.Error, other.Error); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/union.x/IntUnion.java b/spec/output/generator_spec_java/union.x/IntUnion.java index 0b3a6081f..2ae33c648 100644 --- a/spec/output/generator_spec_java/union.x/IntUnion.java +++ b/spec/output/generator_spec_java/union.x/IntUnion.java @@ -5,12 +5,14 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import lombok.Builder; +import static MyXDR.Constants.*; /** * IntUnion's original definition in the XDR file is: @@ -25,58 +27,14 @@ * }; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Builder(toBuilder = true) public class IntUnion implements XdrElement { - public IntUnion () {} - Integer type; - public Integer getDiscriminant() { - return this.type; - } - public void setDiscriminant(Integer value) { - this.type = value; - } + private Integer discriminant; private Error error; - public Error getError() { - return this.error; - } - public void setError(Error value) { - this.error = value; - } private Multi[] things; - public Multi[] getThings() { - return this.things; - } - public void setThings(Multi[] value) { - this.things = value; - } - - public static final class Builder { - private Integer discriminant; - private Error error; - private Multi[] things; - - public Builder discriminant(Integer discriminant) { - this.discriminant = discriminant; - return this; - } - - public Builder error(Error error) { - this.error = error; - return this; - } - - public Builder things(Multi[] things) { - this.things = things; - return this; - } - - public IntUnion build() { - IntUnion val = new IntUnion(); - val.setDiscriminant(discriminant); - val.setError(this.error); - val.setThings(this.things); - return val; - } - } public static void encode(XdrDataOutputStream stream, IntUnion encodedIntUnion) throws IOException { //Xdrgen::AST::Typespecs::Int @@ -87,9 +45,9 @@ public static void encode(XdrDataOutputStream stream, IntUnion encodedIntUnion) Error.encode(stream, encodedIntUnion.error); break; case 1: - int thingssize = encodedIntUnion.getThings().length; - stream.writeInt(thingssize); - for (int i = 0; i < thingssize; i++) { + int thingsSize = encodedIntUnion.getThings().length; + stream.writeInt(thingsSize); + for (int i = 0; i < thingsSize; i++) { Multi.encode(stream, encodedIntUnion.things[i]); } break; @@ -107,9 +65,9 @@ public static IntUnion decode(XdrDataInputStream stream) throws IOException { decodedIntUnion.error = Error.decode(stream); break; case 1: - int thingssize = stream.readInt(); - decodedIntUnion.things = new Multi[thingssize]; - for (int i = 0; i < thingssize; i++) { + int thingsSize = stream.readInt(); + decodedIntUnion.things = new Multi[thingsSize]; + for (int i = 0; i < thingsSize; i++) { decodedIntUnion.things[i] = Multi.decode(stream); } break; @@ -117,19 +75,6 @@ public static IntUnion decode(XdrDataInputStream stream) throws IOException { return decodedIntUnion; } @Override - public int hashCode() { - return Objects.hash(this.error, Arrays.hashCode(this.things), this.type); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof IntUnion)) { - return false; - } - - IntUnion other = (IntUnion) object; - return Objects.equals(this.error, other.error) && Arrays.equals(this.things, other.things) && Objects.equals(this.type, other.type); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); } diff --git a/spec/output/generator_spec_java/union.x/IntUnion2.java b/spec/output/generator_spec_java/union.x/IntUnion2.java index 45ddec6d7..730be0ffd 100644 --- a/spec/output/generator_spec_java/union.x/IntUnion2.java +++ b/spec/output/generator_spec_java/union.x/IntUnion2.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * IntUnion2's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef IntUnion IntUnion2; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class IntUnion2 implements XdrElement { private IntUnion IntUnion2; - - public IntUnion2() {} - - public IntUnion2(IntUnion IntUnion2) { - this.IntUnion2 = IntUnion2; - } - - public IntUnion getIntUnion2() { - return this.IntUnion2; - } - - public void setIntUnion2(IntUnion value) { - this.IntUnion2 = value; - } - public static void encode(XdrDataOutputStream stream, IntUnion2 encodedIntUnion2) throws IOException { IntUnion.encode(stream, encodedIntUnion2.IntUnion2); } @@ -47,20 +37,6 @@ public static IntUnion2 decode(XdrDataInputStream stream) throws IOException { return decodedIntUnion2; } - @Override - public int hashCode() { - return Objects.hash(this.IntUnion2); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof IntUnion2)) { - return false; - } - - IntUnion2 other = (IntUnion2) object; - return Objects.equals(this.IntUnion2, other.IntUnion2); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/union.x/Multi.java b/spec/output/generator_spec_java/union.x/Multi.java index 281454e04..637de5bce 100644 --- a/spec/output/generator_spec_java/union.x/Multi.java +++ b/spec/output/generator_spec_java/union.x/Multi.java @@ -5,11 +5,13 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import static MyXDR.Constants.*; /** * Multi's original definition in the XDR file is: @@ -17,23 +19,11 @@ * typedef int Multi; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor public class Multi implements XdrElement { private Integer Multi; - - public Multi() {} - - public Multi(Integer Multi) { - this.Multi = Multi; - } - - public Integer getMulti() { - return this.Multi; - } - - public void setMulti(Integer value) { - this.Multi = value; - } - public static void encode(XdrDataOutputStream stream, Multi encodedMulti) throws IOException { stream.writeInt(encodedMulti.Multi); } @@ -47,20 +37,6 @@ public static Multi decode(XdrDataInputStream stream) throws IOException { return decodedMulti; } - @Override - public int hashCode() { - return Objects.hash(this.Multi); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof Multi)) { - return false; - } - - Multi other = (Multi) object; - return Objects.equals(this.Multi, other.Multi); - } @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); diff --git a/spec/output/generator_spec_java/union.x/MyUnion.java b/spec/output/generator_spec_java/union.x/MyUnion.java index 90cdebe61..8f9b1daf2 100644 --- a/spec/output/generator_spec_java/union.x/MyUnion.java +++ b/spec/output/generator_spec_java/union.x/MyUnion.java @@ -5,12 +5,14 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.util.Objects; -import java.util.Arrays; +import lombok.Data; +import lombok.NoArgsConstructor; +import lombok.AllArgsConstructor; +import lombok.Builder; +import static MyXDR.Constants.*; /** * MyUnion's original definition in the XDR file is: @@ -26,58 +28,14 @@ * }; * */ +@Data +@NoArgsConstructor +@AllArgsConstructor +@Builder(toBuilder = true) public class MyUnion implements XdrElement { - public MyUnion () {} - UnionKey type; - public UnionKey getDiscriminant() { - return this.type; - } - public void setDiscriminant(UnionKey value) { - this.type = value; - } + private UnionKey discriminant; private Error error; - public Error getError() { - return this.error; - } - public void setError(Error value) { - this.error = value; - } private Multi[] things; - public Multi[] getThings() { - return this.things; - } - public void setThings(Multi[] value) { - this.things = value; - } - - public static final class Builder { - private UnionKey discriminant; - private Error error; - private Multi[] things; - - public Builder discriminant(UnionKey discriminant) { - this.discriminant = discriminant; - return this; - } - - public Builder error(Error error) { - this.error = error; - return this; - } - - public Builder things(Multi[] things) { - this.things = things; - return this; - } - - public MyUnion build() { - MyUnion val = new MyUnion(); - val.setDiscriminant(discriminant); - val.setError(this.error); - val.setThings(this.things); - return val; - } - } public static void encode(XdrDataOutputStream stream, MyUnion encodedMyUnion) throws IOException { //Xdrgen::AST::Identifier @@ -88,9 +46,9 @@ public static void encode(XdrDataOutputStream stream, MyUnion encodedMyUnion) th Error.encode(stream, encodedMyUnion.error); break; case MULTI: - int thingssize = encodedMyUnion.getThings().length; - stream.writeInt(thingssize); - for (int i = 0; i < thingssize; i++) { + int thingsSize = encodedMyUnion.getThings().length; + stream.writeInt(thingsSize); + for (int i = 0; i < thingsSize; i++) { Multi.encode(stream, encodedMyUnion.things[i]); } break; @@ -108,9 +66,9 @@ public static MyUnion decode(XdrDataInputStream stream) throws IOException { decodedMyUnion.error = Error.decode(stream); break; case MULTI: - int thingssize = stream.readInt(); - decodedMyUnion.things = new Multi[thingssize]; - for (int i = 0; i < thingssize; i++) { + int thingsSize = stream.readInt(); + decodedMyUnion.things = new Multi[thingsSize]; + for (int i = 0; i < thingsSize; i++) { decodedMyUnion.things[i] = Multi.decode(stream); } break; @@ -118,19 +76,6 @@ public static MyUnion decode(XdrDataInputStream stream) throws IOException { return decodedMyUnion; } @Override - public int hashCode() { - return Objects.hash(this.error, Arrays.hashCode(this.things), this.type); - } - @Override - public boolean equals(Object object) { - if (!(object instanceof MyUnion)) { - return false; - } - - MyUnion other = (MyUnion) object; - return Objects.equals(this.error, other.error) && Arrays.equals(this.things, other.things) && Objects.equals(this.type, other.type); - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); } diff --git a/spec/output/generator_spec_java/union.x/UnionKey.java b/spec/output/generator_spec_java/union.x/UnionKey.java index 0ca6d26fa..245f4b969 100644 --- a/spec/output/generator_spec_java/union.x/UnionKey.java +++ b/spec/output/generator_spec_java/union.x/UnionKey.java @@ -5,7 +5,6 @@ import java.io.IOException; -import static MyXDR.Constants.*; import org.stellar.sdk.Base64Factory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; @@ -21,16 +20,16 @@ */ public enum UnionKey implements XdrElement { ERROR(0), - MULTI(1), - ; - private int mValue; + MULTI(1); + + private final int value; UnionKey(int value) { - mValue = value; + this.value = value; } public int getValue() { - return mValue; + return value; } public static UnionKey decode(XdrDataInputStream stream) throws IOException { diff --git a/spec/output/generator_spec_java/union.x/XdrString.java b/spec/output/generator_spec_java/union.x/XdrString.java index bb4e81fb4..2d8f8bbc9 100644 --- a/spec/output/generator_spec_java/union.x/XdrString.java +++ b/spec/output/generator_spec_java/union.x/XdrString.java @@ -4,90 +4,72 @@ import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InvalidClassException; -import java.nio.charset.Charset; -import java.util.Arrays; +import java.nio.charset.StandardCharsets; +import lombok.Value; import org.stellar.sdk.Base64Factory; +@Value public class XdrString implements XdrElement { - private byte[] bytes; + byte[] bytes; - public XdrString(byte[] bytes) { - this.bytes = bytes; - } + public XdrString(byte[] bytes) { + this.bytes = bytes; + } - public XdrString(String text) { - this.bytes = text.getBytes(Charset.forName("UTF-8")); - } + public XdrString(String text) { + this.bytes = text.getBytes(StandardCharsets.UTF_8); + } - @Override - public void encode(XdrDataOutputStream stream) throws IOException { - stream.writeInt(this.bytes.length); - stream.write(this.bytes, 0, this.bytes.length); - } + @Override + public void encode(XdrDataOutputStream stream) throws IOException { + stream.writeInt(this.bytes.length); + stream.write(this.bytes, 0, this.bytes.length); + } - public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { - int size = stream.readInt(); - if (size > maxSize) { - throw new InvalidClassException("String length "+size+" exceeds max size "+maxSize); - } - byte[] bytes = new byte[size]; - stream.read(bytes); - return new XdrString(bytes); + public static XdrString decode(XdrDataInputStream stream, int maxSize) throws IOException { + int size = stream.readInt(); + if (size > maxSize) { + throw new InvalidClassException("String length " + size + " exceeds max size " + maxSize); } + byte[] bytes = new byte[size]; + stream.read(bytes); + return new XdrString(bytes); + } - public byte[] getBytes() { - return this.bytes; - } + @Override + public String toXdrBase64() throws IOException { + return Base64Factory.getInstance().encodeToString(toXdrByteArray()); + } - @Override - public String toXdrBase64() throws IOException { - return Base64Factory.getInstance().encodeToString(toXdrByteArray()); - } - - @Override - public byte[] toXdrByteArray() throws IOException { - ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); - encode(xdrDataOutputStream); - return byteArrayOutputStream.toByteArray(); - } - - public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { - byte[] bytes = Base64Factory.getInstance().decode(xdr); - return fromXdrByteArray(bytes, maxSize); - } - - public static XdrString fromXdrBase64(String xdr) throws IOException { - return fromXdrBase64(xdr, Integer.MAX_VALUE); - } - - public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { - ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); - XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); - return decode(xdrDataInputStream, maxSize); - } - - public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { - return fromXdrByteArray(xdr, Integer.MAX_VALUE); - } + @Override + public byte[] toXdrByteArray() throws IOException { + ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); + XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); + encode(xdrDataOutputStream); + return byteArrayOutputStream.toByteArray(); + } - @Override - public int hashCode() { - return Arrays.hashCode(this.bytes); - } + public static XdrString fromXdrBase64(String xdr, int maxSize) throws IOException { + byte[] bytes = Base64Factory.getInstance().decode(xdr); + return fromXdrByteArray(bytes, maxSize); + } - @Override - public boolean equals(Object object) { - if (object == null || !(object instanceof XdrString)) { - return false; - } + public static XdrString fromXdrBase64(String xdr) throws IOException { + return fromXdrBase64(xdr, Integer.MAX_VALUE); + } - XdrString other = (XdrString) object; - return Arrays.equals(this.bytes, other.bytes); - } + public static XdrString fromXdrByteArray(byte[] xdr, int maxSize) throws IOException { + ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xdr); + XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); + return decode(xdrDataInputStream, maxSize); + } - @Override - public String toString() { - return new String(bytes, Charset.forName("UTF-8")); - } + public static XdrString fromXdrByteArray(byte[] xdr) throws IOException { + return fromXdrByteArray(xdr, Integer.MAX_VALUE); + } + + @Override + public String toString() { + return new String(bytes, StandardCharsets.UTF_8); + } } diff --git a/spec/output/generator_spec_java/union.x/XdrUnsignedHyperInteger.java b/spec/output/generator_spec_java/union.x/XdrUnsignedHyperInteger.java index 6c05ca57d..204aa83de 100644 --- a/spec/output/generator_spec_java/union.x/XdrUnsignedHyperInteger.java +++ b/spec/output/generator_spec_java/union.x/XdrUnsignedHyperInteger.java @@ -1,10 +1,10 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.math.BigInteger; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -13,10 +13,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedHyperInteger implements XdrElement { public static final BigInteger MAX_VALUE = new BigInteger("18446744073709551615"); public static final BigInteger MIN_VALUE = BigInteger.ZERO; - private final BigInteger number; + BigInteger number; public XdrUnsignedHyperInteger(BigInteger number) { if (number.compareTo(MIN_VALUE) < 0 || number.compareTo(MAX_VALUE) > 0) { @@ -55,10 +56,6 @@ private byte[] getBytes() { return paddedBytes; } - public BigInteger getNumber() { - return number; - } - @Override public String toXdrBase64() throws IOException { return Base64Factory.getInstance().encodeToString(toXdrByteArray()); @@ -82,23 +79,4 @@ public static XdrUnsignedHyperInteger fromXdrByteArray(byte[] xdr) throws IOExce XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedHyperInteger)) { - return false; - } - - XdrUnsignedHyperInteger other = (XdrUnsignedHyperInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } } diff --git a/spec/output/generator_spec_java/union.x/XdrUnsignedInteger.java b/spec/output/generator_spec_java/union.x/XdrUnsignedInteger.java index 8f2a52395..a56ad657d 100644 --- a/spec/output/generator_spec_java/union.x/XdrUnsignedInteger.java +++ b/spec/output/generator_spec_java/union.x/XdrUnsignedInteger.java @@ -1,9 +1,9 @@ -package org.stellar.sdk.xdr; +package MyXDR; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; -import java.util.Objects; +import lombok.Value; import org.stellar.sdk.Base64Factory; /** @@ -12,10 +12,11 @@ * @see XDR: External Data * Representation Standard */ +@Value public class XdrUnsignedInteger implements XdrElement { public static final long MAX_VALUE = (1L << 32) - 1; public static final long MIN_VALUE = 0; - private final Long number; + Long number; public XdrUnsignedInteger(Long number) { if (number < MIN_VALUE || number > MAX_VALUE) { @@ -32,10 +33,6 @@ public XdrUnsignedInteger(Integer number) { this.number = number.longValue(); } - public Long getNumber() { - return number; - } - public static XdrUnsignedInteger decode(XdrDataInputStream stream) throws IOException { int intValue = stream.readInt(); long uint32Value = Integer.toUnsignedLong(intValue); @@ -70,23 +67,4 @@ public static XdrUnsignedInteger fromXdrByteArray(byte[] xdr) throws IOException XdrDataInputStream xdrDataInputStream = new XdrDataInputStream(byteArrayInputStream); return decode(xdrDataInputStream); } - - @Override - public int hashCode() { - return Objects.hash(this.number); - } - - @Override - public boolean equals(Object object) { - if (!(object instanceof XdrUnsignedInteger)) { - return false; - } - - XdrUnsignedInteger other = (XdrUnsignedInteger) object; - return Objects.equals(this.number, other.number); - } - - public String toString() { - return "XdrUnsignedInteger(number=" + this.getNumber() + ")"; - } }