diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/OptimizeMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/OptimizeMojo.java index b901f3684b..d96126d143 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/OptimizeMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/OptimizeMojo.java @@ -27,20 +27,25 @@ import com.jcabi.xml.XML; import com.jcabi.xml.XMLDocument; import com.yegor256.xsline.Shift; +import com.yegor256.xsline.StClasspath; +import com.yegor256.xsline.TrClasspath; +import com.yegor256.xsline.TrDefault; +import com.yegor256.xsline.TrFast; +import com.yegor256.xsline.TrLambda; import com.yegor256.xsline.Train; +import com.yegor256.xsline.Xsline; import java.nio.file.Path; import java.util.Collection; +import java.util.function.Function; import org.apache.maven.plugins.annotations.LifecyclePhase; import org.apache.maven.plugins.annotations.Mojo; import org.apache.maven.plugins.annotations.Parameter; import org.cactoos.iterable.Filtered; import org.eolang.maven.footprint.FpDefault; -import org.eolang.maven.optimization.OptSpy; -import org.eolang.maven.optimization.OptTrain; -import org.eolang.maven.optimization.Optimization; import org.eolang.maven.tojos.ForeignTojo; import org.eolang.maven.tojos.TojoHash; import org.eolang.maven.util.Threaded; +import org.eolang.parser.StEoLogged; import org.eolang.parser.TrParsing; /** @@ -88,7 +93,7 @@ public final class OptimizeMojo extends SafeMojo { public void exec() { final long start = System.currentTimeMillis(); final Collection tojos = this.scopedTojos().withXmir(); - final Optimization optimization = this.optimization(); + final Function optimization = this.optimization(); final int total = new Threaded<>( new Filtered<>( ForeignTojo::notOptimized, @@ -115,7 +120,7 @@ public void exec() { * @return Amount of optimized XMIR files * @throws Exception If fails */ - private int optimized(final ForeignTojo tojo, final Optimization optimization) + private int optimized(final ForeignTojo tojo, final Function optimization) throws Exception { final Path source = tojo.xmir(); final XML xmir = new XMLDocument(source); @@ -138,18 +143,167 @@ private int optimized(final ForeignTojo tojo, final Optimization optimization) * Common optimization for all tojos. * @return Optimization for all tojos. */ - private Optimization optimization() { - final Optimization opt; + private Function optimization() { + final Function opt; final Train train = this.measured(new TrParsing()); if (this.trackOptimizationSteps) { - opt = new OptSpy( + opt = new OptimizeMojo.OptSpy( train, this.targetDir.toPath().resolve(OptimizeMojo.STEPS) ); } else { - opt = new OptTrain(train); + opt = new OptimizeMojo.OptTrain(train); } return opt; } + /** + * Optimization that spies. + * @since 0.68.0 + */ + static final class OptSpy implements Function { + /** + * Optimizations train. + */ + private final Train train; + + /** + * Where to track optimization steps. + */ + private final Path target; + + /** + * Ctor. + * @param target Where to track optimization steps. + */ + OptSpy(final Path target) { + this(OptTrain.DEFAULT_TRAIN, target); + } + + /** + * The main constructor. + * @param trn Optimizations train. + * @param target Where to track optimization steps. + */ + OptSpy(final Train trn, final Path target) { + this.train = trn; + this.target = target; + } + + @Override + public XML apply(final XML xml) { + final Path dir = new Place(xml.xpath("/program/@name").get(0)).make(this.target, ""); + Logger.debug(this, "Optimization steps will be tracked to %[file]s", dir); + return new OptTrain(new SpyTrain(this.train, dir)).apply(xml); + } + } + + /** + * Optimisation train of XLS`s. + * @since 0.68.0 + * @todo #3115:30min Return constant-folding.xsl when it's ready. + * This optimization was removed from the train because it's not really + * ready and works only with `bool` object which was removed. We + * need to make this optimization great again and add to the train. + */ + static final class OptTrain implements Function { + + /** + * Parsing train with XSLs. + * @implNote The list of applied XSLs is adjusted during execution. + *
Separate instance of the train is used of each optimization + * thread since {@link com.jcabi.xml.XSLDocument}, which is used under + * the hood in {@link com.yegor256.xsline.TrClasspath}, is not thread-safe. + */ + static final Train DEFAULT_TRAIN = new TrFast( + new TrLambda( + new TrClasspath<>( + "/org/eolang/parser/optimize/globals-to-abstracts.xsl", + "/org/eolang/parser/optimize/remove-refs.xsl", + "/org/eolang/parser/optimize/abstracts-float-up.xsl", + "/org/eolang/parser/optimize/remove-levels.xsl", + "/org/eolang/parser/add-refs.xsl", + "/org/eolang/parser/optimize/fix-missed-names.xsl", + "/org/eolang/parser/add-refs.xsl", + "/org/eolang/parser/set-locators.xsl", + "/org/eolang/parser/blank-xsd-schema.xsl" + ).back(), + StEoLogged::new + ), + TrFast.class, + 500L + ); + + /** + * Delegate. + */ + private final Function delegate; + + /** + * Xsline with applied shifts. + */ + private final Xsline xsline; + + /** + * The default constructor with the default preset of xsl optimizations. + */ + OptTrain() { + this(OptTrain.DEFAULT_TRAIN); + } + + /** + * Constructor that accepts train of shifts. + * @param shifts XLS shifts. + */ + OptTrain(final Train shifts) { + this(xml -> xml, shifts); + } + + /** + * Constructor for single {@link com.yegor256.xsline.StClasspath} optimization. + * @param delegate Optimizations that have to be done before. + * @param xls File from classpath. + */ + OptTrain(final Function delegate, final String xls) { + this( + delegate, + new TrDefault().with(new StClasspath(xls)) + ); + } + + /** + * Ctor that accepts train of shifts to apply with {@link com.yegor256.xsline.Xsline}. + * @param delegate Optimizations that have to be done before. + * @param shifts To apply + */ + OptTrain( + final Function delegate, + final Train shifts + ) { + this( + delegate, + new Xsline(shifts) + ); + } + + /** + * Main ctor. + * @param delegate Optimizations that have to be done before. + * @param xsline Xsline with applied shifts. + */ + OptTrain( + final Function delegate, + final Xsline xsline + ) { + this.delegate = delegate; + this.xsline = xsline; + } + + @Override + public XML apply(final XML xml) { + return this.xsline.pass( + this.delegate.apply(xml) + ); + } + } } diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/ShakeMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/ShakeMojo.java index 995a2b8a6a..a98476213f 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/ShakeMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/ShakeMojo.java @@ -28,14 +28,12 @@ import com.jcabi.xml.XMLDocument; import java.nio.file.Path; import java.util.Collection; +import java.util.function.Function; import org.apache.maven.plugins.annotations.LifecyclePhase; import org.apache.maven.plugins.annotations.Mojo; import org.apache.maven.plugins.annotations.Parameter; import org.cactoos.iterable.Filtered; import org.eolang.maven.footprint.FpDefault; -import org.eolang.maven.optimization.OptSpy; -import org.eolang.maven.optimization.OptTrain; -import org.eolang.maven.optimization.Optimization; import org.eolang.maven.tojos.ForeignTojo; import org.eolang.maven.tojos.TojoHash; import org.eolang.maven.util.Threaded; @@ -80,7 +78,7 @@ public final class ShakeMojo extends SafeMojo { void exec() { final long start = System.currentTimeMillis(); final Collection tojos = this.scopedTojos().withOptimized(); - final Optimization optimization = this.optimization(); + final Function optimization = this.optimization(); final int total = new Threaded<>( new Filtered<>( ForeignTojo::notShaken, @@ -107,7 +105,10 @@ void exec() { * @return Amount of optimized XMIR files * @throws Exception If fails */ - private int shaken(final ForeignTojo tojo, final Optimization optimization) throws Exception { + private int shaken( + final ForeignTojo tojo, + final Function optimization + ) throws Exception { final Path source = tojo.optimized(); final XML xmir = new XMLDocument(source); final String name = xmir.xpath("/program/@name").get(0); @@ -130,12 +131,14 @@ private int shaken(final ForeignTojo tojo, final Optimization optimization) thro * * @return Shake optimizations */ - private Optimization optimization() { - final Optimization opt; + private Function optimization() { + final Function opt; if (this.trackOptimizationSteps) { - opt = new OptSpy(this.targetDir.toPath().resolve(ShakeMojo.STEPS)); + opt = new OptimizeMojo.OptSpy( + this.targetDir.toPath().resolve(ShakeMojo.STEPS) + ); } else { - opt = new OptTrain(); + opt = new OptimizeMojo.OptTrain(); } return opt; } diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/TranspileMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/TranspileMojo.java index c67aff0323..77d111d198 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/TranspileMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/TranspileMojo.java @@ -41,6 +41,7 @@ import java.util.Collection; import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicInteger; +import java.util.function.Function; import java.util.function.Supplier; import org.apache.maven.plugins.annotations.LifecyclePhase; import org.apache.maven.plugins.annotations.Mojo; @@ -57,8 +58,6 @@ import org.eolang.maven.footprint.FpIgnore; import org.eolang.maven.footprint.FpUpdateBoth; import org.eolang.maven.footprint.FpUpdateFromCache; -import org.eolang.maven.optimization.OptSpy; -import org.eolang.maven.optimization.Optimization; import org.eolang.maven.tojos.AttributeNotFoundException; import org.eolang.maven.tojos.ForeignTojo; import org.eolang.maven.tojos.TojoHash; @@ -163,7 +162,7 @@ public final class TranspileMojo extends SafeMojo { @Override public void exec() { final Collection sources = this.scopedTojos().withShaken(); - final Optimization optimization = this.transpilation(); + final Function optimization = this.transpilation(); final int saved = new Threaded<>( sources, tojo -> this.transpiled(tojo, optimization) @@ -195,12 +194,12 @@ public void exec() { * @return Number of transpiled files. * @throws java.io.IOException If any issues with I/O */ - private int transpiled(final ForeignTojo tojo, final Optimization transpilation) + private int transpiled(final ForeignTojo tojo, final Function transpilation) throws IOException { final Path source; try { source = tojo.shaken(); - } catch (final AttributeNotFoundException exception) { + } catch (final AttributeNotFoundException exception) { throw new IllegalStateException( "You should check that 'Verify' goal of the plugin was run first", exception @@ -229,8 +228,8 @@ private int transpiled(final ForeignTojo tojo, final Optimization transpilation) * Transpile optimization. * @return Optimization that transpiles */ - private Optimization transpilation() { - return new OptSpy( + private Function transpilation() { + return new OptimizeMojo.OptSpy( this.measured(TranspileMojo.TRAIN), this.targetDir.toPath().resolve(TranspileMojo.PRE) ); diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/OptSpy.java b/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/OptSpy.java deleted file mode 100644 index ca6999a621..0000000000 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/OptSpy.java +++ /dev/null @@ -1,73 +0,0 @@ -/* - * The MIT License (MIT) - * - * Copyright (c) 2016-2024 Objectionary.com - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE - * SOFTWARE. - */ -package org.eolang.maven.optimization; - -import com.jcabi.log.Logger; -import com.jcabi.xml.XML; -import com.yegor256.xsline.Shift; -import com.yegor256.xsline.Train; -import java.nio.file.Path; -import org.eolang.maven.Place; -import org.eolang.maven.SpyTrain; - -/** - * Optimization that spies. - * @since 0.28.12 - */ -public final class OptSpy implements Optimization { - /** - * Optimizations train. - */ - private final Train train; - - /** - * Where to track optimization steps. - */ - private final Path target; - - /** - * Ctor. - * @param target Where to track optimization steps. - */ - public OptSpy(final Path target) { - this(OptTrain.DEFAULT_TRAIN, target); - } - - /** - * The main constructor. - * @param trn Optimizations train. - * @param target Where to track optimization steps. - */ - public OptSpy(final Train trn, final Path target) { - this.train = trn; - this.target = target; - } - - @Override - public XML apply(final XML xml) { - final Path dir = new Place(xml.xpath("/program/@name").get(0)).make(this.target, ""); - Logger.debug(this, "Optimization steps will be tracked to %[file]s", dir); - return new OptTrain(new SpyTrain(this.train, dir)).apply(xml); - } -} diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/OptTrain.java b/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/OptTrain.java deleted file mode 100644 index 91493c413c..0000000000 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/OptTrain.java +++ /dev/null @@ -1,129 +0,0 @@ -/* - * The MIT License (MIT) - * - * Copyright (c) 2016-2024 Objectionary.com - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE - * SOFTWARE. - */ -package org.eolang.maven.optimization; - -import com.jcabi.xml.XML; -import com.yegor256.xsline.Shift; -import com.yegor256.xsline.StClasspath; -import com.yegor256.xsline.TrClasspath; -import com.yegor256.xsline.TrDefault; -import com.yegor256.xsline.TrFast; -import com.yegor256.xsline.TrLambda; -import com.yegor256.xsline.Train; -import com.yegor256.xsline.Xsline; -import org.eolang.parser.StEoLogged; - -/** - * Optimisation train of XLS`s. - * @since 0.28.12 - * @todo #3115:30min Return constant-folding.xsl when it's ready. This optimization was removed from - * the train because it's not really ready and works only with `bool` object which was removed. We - * need to make this optimization great again and add to the train. - */ -public final class OptTrain implements Optimization { - - /** - * Parsing train with XSLs. - * - * @implNote The list of applied XSLs is adjusted during execution. - *
Separate instance of the train is used of each optimization - * thread since {@link com.jcabi.xml.XSLDocument}, which is used under - * the hood in {@link TrClasspath}, is not thread-safe. - */ - static final Train DEFAULT_TRAIN = new TrFast( - new TrLambda( - new TrClasspath<>( - "/org/eolang/parser/optimize/globals-to-abstracts.xsl", - "/org/eolang/parser/optimize/remove-refs.xsl", - "/org/eolang/parser/optimize/abstracts-float-up.xsl", - "/org/eolang/parser/optimize/remove-levels.xsl", - "/org/eolang/parser/add-refs.xsl", - "/org/eolang/parser/optimize/fix-missed-names.xsl", - "/org/eolang/parser/add-refs.xsl", - "/org/eolang/parser/set-locators.xsl", - "/org/eolang/parser/blank-xsd-schema.xsl" - ).back(), - StEoLogged::new - ), - TrFast.class, - 500L - ); - - /** - * Delegate. - */ - private final Optimization delegate; - - /** - * Shifts that we are going to apply. - */ - private final Train shifts; - - /** - * The default constructor with the default preset of xsl optimizations. - */ - public OptTrain() { - this(OptTrain.DEFAULT_TRAIN); - } - - /** - * Constructor that accepts train of shifts. - * - * @param shifts XLS shifts. - */ - public OptTrain(final Train shifts) { - this(xml -> xml, shifts); - } - - /** - * Constructor for single {@link StClasspath} optimization. - * - * @param delegate Optimizations that have to be done before. - * @param xls File from classpath. - */ - public OptTrain(final Optimization delegate, final String xls) { - this( - delegate, - new TrDefault().with(new StClasspath(xls)) - ); - } - - /** - * The default constructor. - * @param delegate Optimizations that have to be done before. - * @param shifts To apply - */ - public OptTrain( - final Optimization delegate, - final Train shifts - ) { - this.delegate = delegate; - this.shifts = shifts; - } - - @Override - public XML apply(final XML xml) { - return new Xsline(this.shifts).pass(this.delegate.apply(xml)); - } -} diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/Optimization.java b/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/Optimization.java deleted file mode 100644 index 78efed87ba..0000000000 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/Optimization.java +++ /dev/null @@ -1,36 +0,0 @@ -/* - * The MIT License (MIT) - * - * Copyright (c) 2016-2024 Objectionary.com - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE - * SOFTWARE. - */ -package org.eolang.maven.optimization; - -import com.jcabi.xml.XML; -import java.util.function.Function; - -/** - * Abstraction for XML optimizations. - * - * @since 0.28.11 - */ -@FunctionalInterface -public interface Optimization extends Function { -} diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/package-info.java b/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/package-info.java deleted file mode 100644 index 65a3637239..0000000000 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/optimization/package-info.java +++ /dev/null @@ -1,32 +0,0 @@ -/* - * The MIT License (MIT) - * - * Copyright (c) 2016-2024 Objectionary.com - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE - * SOFTWARE. - */ -/** - * Optimizations package. - * The main purpose of classes under the package is to provide different implementations - * of xml optimizations: - * - {@link org.eolang.maven.optimization.OptCached} - looks for optimization in cache first - * - {@link org.eolang.maven.optimization.OptSpy} - makes XLS optimizations that are tracked - * - {@link org.eolang.maven.optimization.OptTrain} - makes XLS optimizations directly - */ -package org.eolang.maven.optimization;