Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Resolve sonar code smells #273

Merged
merged 10 commits into from
Dec 27, 2018
29 changes: 17 additions & 12 deletions formats/src/main/java/io/parsingdata/metal/format/JPEG.java
Original file line number Diff line number Diff line change
Expand Up @@ -39,31 +39,36 @@
*/
public final class JPEG {

public static final String MARKER = "marker";
public static final String IDENTIFIER = "identifier";
public static final String LENGTH = "length";
public static final String PAYLOAD = "payload";

private JPEG() {}

private static final Token HEADER =
seq("start of image",
def("marker", con(1), eq(con(0xff))),
def("identifier", con(1), eq(con(0xd8))));
def(MARKER, con(1), eq(con(0xff))),
def(IDENTIFIER, con(1), eq(con(0xd8))));

private static final Token FOOTER =
seq("end of image",
def("marker", con(1), eq(con(0xff))),
def("identifier", con(1), eq(con(0xd9))));
def(MARKER, con(1), eq(con(0xff))),
def(IDENTIFIER, con(1), eq(con(0xd9))));

private static final Token SIZED_SEGMENT =
seq("sized segment",
def("marker", con(1), eq(con(0xff))),
def("identifier", con(1), or(ltNum(con(0xd8)), gtNum(con(0xda)))),
def("length", con(2)),
def("payload", sub(last(ref("length")), con(2))));
def(MARKER, con(1), eq(con(0xff))),
def(IDENTIFIER, con(1), or(ltNum(con(0xd8)), gtNum(con(0xda)))),
def(LENGTH, con(2)),
def(PAYLOAD, sub(last(ref(LENGTH)), con(2))));

private static final Token SCAN_SEGMENT =
seq("scan segment",
def("marker", con(1), eq(con(0xff))),
def("identifier", con(1), eq(con(0xda))),
def("length", con(2)),
def("payload", sub(last(ref("length")), con(2))),
def(MARKER, con(1), eq(con(0xff))),
def(IDENTIFIER, con(1), eq(con(0xda))),
def(LENGTH, con(2)),
def(PAYLOAD, sub(last(ref(LENGTH)), con(2))),
rep(cho(def("scandata", con(1), not(eq(con(0xff)))),
def("escape", con(2), or(eq(con(0xff00)), and(gtNum(con(0xffcf)), ltNum(con(0xffd8))))))));

Expand Down
20 changes: 13 additions & 7 deletions formats/src/main/java/io/parsingdata/metal/format/PNG.java
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,12 @@

public final class PNG {

public static final String LENGTH = "length";
public static final String TYPE = "type";
public static final String CRC_32 = "crc32";
public static final String IEND = "IEND";
public static final String DATA = "data";

private PNG() {}

private static final Token HEADER =
Expand All @@ -43,16 +49,16 @@ private PNG() {}

private static final Token FOOTER =
seq("footer",
def("footerlength", con(4), eqNum(con(0))),
def("footertype", con(4), eq(con("IEND"))),
def("footercrc32", con(4), eq(con(0xae, 0x42, 0x60, 0x82))));
def(LENGTH, con(4), eqNum(con(0))),
def(TYPE, con(4), eq(con(IEND))),
def(CRC_32, con(4), eq(con(0xae, 0x42, 0x60, 0x82))));

private static final Token STRUCT =
seq("chunk",
def("length", con(4)),
def("chunktype", con(4), not(eq(con("IEND")))),
def("chunkdata", last(ref("length"))),
def("crc32", con(4), eq(crc32(cat(last(ref("chunktype")), last(ref("chunkdata")))))));
def(LENGTH, con(4)),
def(TYPE, con(4), not(eq(con(IEND)))),
def(DATA, last(ref(LENGTH))),
def(CRC_32, con(4), eq(crc32(cat(last(ref(TYPE)), last(ref(DATA)))))));

public static final Token FORMAT =
seq("PNG", DEFAULT_ENCODING,
Expand Down
77 changes: 46 additions & 31 deletions formats/src/main/java/io/parsingdata/metal/format/ZIP.java
Original file line number Diff line number Diff line change
Expand Up @@ -46,38 +46,53 @@
*/
public final class ZIP {

public static final String CRC_32 = "crc32";
public static final String COMPRESSED_SIZE = "compressedsize";
public static final String FILE_NAME_SIZE = "filenamesize";
public static final String EXTRA_FIELD_SIZE = "extrafieldsize";
public static final String EXTRACT_VERSION = "extractversion";
public static final String BIT_FLAG = "bitflag";
public static final String COMPRESSION_METHOD = "compressionmethod";
public static final String LAST_MOD_TIME = "lastmodtime";
public static final String LAST_MOD_DATE = "lastmoddate";
public static final String UNCOMPRESSED_SIZE = "uncompressedsize";
public static final String FILE_NAME = "filename";
public static final String COMPRESSED_DATA = "compresseddata";
public static final String DIR_SIGNATURE = "dirsignature";
public static final String EXTRA_FIELD = "extrafield";
jvdb marked this conversation as resolved.
Show resolved Hide resolved

private ZIP() {}

private static Token localFileBody(final String name, final int cm, final Expression crc, final Expression cs, final Expression usp) {
return
seq(name,
def("filesignature", con(4), eq(con(0x50, 0x4b, 0x03, 0x04))),
def("extractversion", con(2)),
def("bitflag", con(2)),
def("compressionmethod", con(2), eqNum(con(cm))),
def("lastmodtime", con(2)),
def("lastmoddate", con(2)),
def("crc32", con(4), crc),
def("compressedsize", con(4), cs),
def("uncompressedsize", con(4), usp),
def("filenamesize", con(2)),
def("extrafieldsize", con(2)),
def("filename", last(ref("filenamesize"))),
def("extrafield", last(ref("extrafieldsize"))));
def(EXTRACT_VERSION, con(2)),
def(BIT_FLAG, con(2)),
def(COMPRESSION_METHOD, con(2), eqNum(con(cm))),
def(LAST_MOD_TIME, con(2)),
def(LAST_MOD_DATE, con(2)),
def(CRC_32, con(4), crc),
def(COMPRESSED_SIZE, con(4), cs),
def(UNCOMPRESSED_SIZE, con(4), usp),
def(FILE_NAME_SIZE, con(2)),
def(EXTRA_FIELD_SIZE, con(2)),
def(FILE_NAME, last(ref(FILE_NAME_SIZE))),
def(EXTRA_FIELD, last(ref(EXTRA_FIELD_SIZE))));
}

private static final Token LOCAL_DEFLATED_FILE =
seq("localdeflatedfile",
localFileBody("", 8, TRUE, TRUE, TRUE),
def("compresseddata", last(ref("compressedsize")), eqNum(crc32(inflate(SELF)), last(ref("crc32")))));
def(COMPRESSED_DATA, last(ref(COMPRESSED_SIZE)), eqNum(crc32(inflate(SELF)), last(ref(CRC_32)))));

private static final Token LOCAL_EMPTY_FILE =
localFileBody("localemptyfile", 0, eqNum(con(0)), eqNum(con(0)), eqNum(con(0)));

private static final Token LOCAL_STORED_FILE =
seq("localstoredfile",
localFileBody("", 0, TRUE, TRUE, eq(last(ref("compressedsize")))),
def("compresseddata", last(ref("compressedsize")), eqNum(crc32(SELF), last(ref("crc32")))));
localFileBody("", 0, TRUE, TRUE, eq(last(ref(COMPRESSED_SIZE)))),
def(COMPRESSED_DATA, last(ref(COMPRESSED_SIZE)), eqNum(crc32(SELF), last(ref(CRC_32)))));

private static final Token FILES =
rep("files",
Expand All @@ -87,25 +102,25 @@ private static Token localFileBody(final String name, final int cm, final Expres

private static final Token DIR_ENTRY =
seq("direntry",
def("dirsignature", con(4), eq(con(0x50, 0x4b, 0x01, 0x02))),
def(DIR_SIGNATURE, con(4), eq(con(0x50, 0x4b, 0x01, 0x02))),
def("makeversion", con(2)),
def("extractversion", con(2)),
def("bitflag", con(2)),
def("compressionmethod", con(2)),
def("lastmodtime", con(2)),
def("lastmoddate", con(2)),
def("crc32", con(4)),
def("compressedsize", con(4)),
def("uncompressedsize", con(4)),
def("filenamesize", con(2)),
def("extrafieldsize", con(2)),
def(EXTRACT_VERSION, con(2)),
def(BIT_FLAG, con(2)),
def(COMPRESSION_METHOD, con(2)),
def(LAST_MOD_TIME, con(2)),
def(LAST_MOD_DATE, con(2)),
def(CRC_32, con(4)),
def(COMPRESSED_SIZE, con(4)),
def(UNCOMPRESSED_SIZE, con(4)),
def(FILE_NAME_SIZE, con(2)),
def(EXTRA_FIELD_SIZE, con(2)),
def("filecommentsize", con(2)),
def("filedisk", con(2), eqNum(con(0))),
def("intfileattr", con(2)),
def("extfileattr", con(4)),
def("offset", con(4)),
def("filename", last(ref("filenamesize"))),
def("extrafield", last(ref("extrafieldsize"))),
def(FILE_NAME, last(ref(FILE_NAME_SIZE))),
def(EXTRA_FIELD, last(ref(EXTRA_FIELD_SIZE))),
def("filecomment", last(ref("filecommentsize"))));

private static final Token DIRS =
Expand All @@ -117,10 +132,10 @@ private static Token localFileBody(final String name, final int cm, final Expres
def("endofdirsignature", con(4), eq(con(0x50, 0x4b, 0x05, 0x06))),
def("disknumber", con(2), eqNum(con(0))),
def("dirdisk", con(2), eqNum(con(0))),
def("numlocaldirs", con(2), eqNum(count(ref("dirsignature")))),
def("numlocaldirs", con(2), eqNum(count(ref(DIR_SIGNATURE)))),
def("numtotaldirs", con(2), eqNum(last(ref("numlocaldirs")))),
def("dirsize", con(4), eqNum(sub(offset(last(ref("endofdirsignature"))), offset(first(ref("dirsignature")))))),
def("diroffset", con(4), eqNum(offset(first(ref("dirsignature"))))),
def("dirsize", con(4), eqNum(sub(offset(last(ref("endofdirsignature"))), offset(first(ref(DIR_SIGNATURE)))))),
def("diroffset", con(4), eqNum(offset(first(ref(DIR_SIGNATURE))))),
def("commentsize", con(2)),
def("comment", last(ref("commentsize"))));

Expand Down