From 1595ba1c65fd5f26444ef6161980b3cbd08f9ba5 Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Mon, 4 Dec 2023 18:01:00 +0300 Subject: [PATCH 1/4] #2649 rename addRust, add documentation, create todo --- .../org/eolang/maven/BinarizeParseMojo.java | 23 +++++++++++-------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java index 26f360a4ad..ba5a211944 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java @@ -70,7 +70,9 @@ public final class BinarizeParseMojo extends SafeMojo { public static final Path DIR = Paths.get("binarize"); /** - * Parsing train with XSLs. + * Parsing train with XSLs. The task of XSLs is to find all the FFI inserts and put them at + * the end of the xmir file. When adding a new language for FFI inserts, you need to add the + * appropriate XSL transformation. */ static final Train TRAIN = new TrBulk<>( new TrClasspath<>( @@ -122,11 +124,11 @@ public void exec() throws IOException { } /** - * Creates a "rust" section in xml file and returns the resulting XML. + * Creates sections for each language for FFI insert in xmir and returns the resulting XML file. * @param input The .xmir file - * @return The content of rust section + * @return The content of FFI inserts sections */ - private XML addRust( + private XML addFFIs( final XML input ) { final String name = input.xpath("/program/@name").get(0); @@ -142,14 +144,17 @@ private XML addRust( * Add ffi node via xsl transformation and return list of them. * @param input Input xmir. * @return FFI nodes. - * @todo #2609:90min We can make the current class more generic - * by transferring this.addRust(input) snippet to corresponding - * FFINode- {@link RustNode}. We wanna make the class independent of - * ffi-insert as a result. + * @todo #2649:90min This method may be more general. We need to get rid from rust dependencies + * in this method, because when adding another type of inserts it will be just copy-paste here. + * First of all, the for-loop must create all kinds of FFI nodes, not only {@link RustNode}. I + * think we can implement it, using something like {@code FFINodeBuilder}, that will return + * appropriate FFI node for every XML node from {@code nodes}. Also it will be great to move + * paths to XML FFI insert nodes (such as {@code "/program/rusts/rust"}) from this method to + * a class field. * @checkstyle AbbreviationAsWordInNameCheck (8 lines) */ private Collection getFFIs(final XML input) { - final List nodes = this.addRust(input).nodes("/program/rusts/rust"); + final List nodes = this.addFFIs(input).nodes("/program/rusts/rust"); final Collection ret = new ArrayList<>(nodes.size()); for (final XML node : nodes) { ret.add( From a72959b25a1441c934011673705dddb24a84b863 Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Mon, 4 Dec 2023 18:08:41 +0300 Subject: [PATCH 2/4] #2649 fix checkstyle --- .../src/main/java/org/eolang/maven/BinarizeParseMojo.java | 1 + 1 file changed, 1 insertion(+) diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java index ba5a211944..6f2588fe82 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java @@ -127,6 +127,7 @@ public void exec() throws IOException { * Creates sections for each language for FFI insert in xmir and returns the resulting XML file. * @param input The .xmir file * @return The content of FFI inserts sections + * @checkstyle AbbreviationAsWordInNameCheck (8 lines) */ private XML addFFIs( final XML input From c73e86466235f24b27156cdaa4709e80a768f133 Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Mon, 4 Dec 2023 18:12:18 +0300 Subject: [PATCH 3/4] #2649 fix todo --- .../src/main/java/org/eolang/maven/BinarizeParseMojo.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java index 6f2588fe82..294dc1a3db 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java @@ -148,7 +148,7 @@ private XML addFFIs( * @todo #2649:90min This method may be more general. We need to get rid from rust dependencies * in this method, because when adding another type of inserts it will be just copy-paste here. * First of all, the for-loop must create all kinds of FFI nodes, not only {@link RustNode}. I - * think we can implement it, using something like {@code FFINodeBuilder}, that will return + * think we can implement it, using something like {@code FFINodeFactory}, that will return * appropriate FFI node for every XML node from {@code nodes}. Also it will be great to move * paths to XML FFI insert nodes (such as {@code "/program/rusts/rust"}) from this method to * a class field. From dd418e84ba1a56c14facea69d1164fca65f23ee9 Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Mon, 4 Dec 2023 18:40:28 +0300 Subject: [PATCH 4/4] #2649 fix todo --- .../src/main/java/org/eolang/maven/BinarizeParseMojo.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java index 294dc1a3db..a767798df6 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParseMojo.java @@ -151,7 +151,7 @@ private XML addFFIs( * think we can implement it, using something like {@code FFINodeFactory}, that will return * appropriate FFI node for every XML node from {@code nodes}. Also it will be great to move * paths to XML FFI insert nodes (such as {@code "/program/rusts/rust"}) from this method to - * a class field. + * a static class field. * @checkstyle AbbreviationAsWordInNameCheck (8 lines) */ private Collection getFFIs(final XML input) {