From 39f726a276e03b20776f729bc09a84792f37aabc Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Mon, 5 Feb 2024 22:53:45 +0000 Subject: [PATCH 01/80] fix(deps): update slf4j monorepo to v2.0.12 --- eo-maven-plugin/pom.xml | 2 +- eo-runtime/pom.xml | 4 ++-- pom.xml | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/eo-maven-plugin/pom.xml b/eo-maven-plugin/pom.xml index 84e00abbae..03e9e18246 100644 --- a/eo-maven-plugin/pom.xml +++ b/eo-maven-plugin/pom.xml @@ -207,7 +207,7 @@ SOFTWARE. org.slf4j slf4j-reload4j - 2.0.11 + 2.0.12 provided diff --git a/eo-runtime/pom.xml b/eo-runtime/pom.xml index a8447eb0ab..2ec3fdebb7 100644 --- a/eo-runtime/pom.xml +++ b/eo-runtime/pom.xml @@ -41,13 +41,13 @@ SOFTWARE. org.slf4j jul-to-slf4j - 2.0.11 + 2.0.12 test org.slf4j slf4j-api - 2.0.11 + 2.0.12 test diff --git a/pom.xml b/pom.xml index a78a084ef7..20c3754fb1 100644 --- a/pom.xml +++ b/pom.xml @@ -219,7 +219,7 @@ SOFTWARE. org.slf4j slf4j-reload4j - 2.0.11 + 2.0.12 log4j From b607ae6eba9c6d12c91cd8d71ea7b27d7e483727 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Tue, 27 Feb 2024 09:53:16 +0000 Subject: [PATCH 02/80] Update yegor256/latexmk-action action to v0.10.9 --- .github/workflows/latexmk.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/latexmk.yml b/.github/workflows/latexmk.yml index a5aee1f682..5592eed7a6 100644 --- a/.github/workflows/latexmk.yml +++ b/.github/workflows/latexmk.yml @@ -14,7 +14,7 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 - - uses: yegor256/latexmk-action@0.10.8 + - uses: yegor256/latexmk-action@0.10.9 with: path: paper opts: -pdf From a6634ede60485017b1a0dd077d064568e06c76e2 Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Tue, 27 Feb 2024 16:38:11 +0300 Subject: [PATCH 03/80] #2716: tuple optimization --- eo-runtime/src/main/eo/org/eolang/tuple.eo | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/eo-runtime/src/main/eo/org/eolang/tuple.eo b/eo-runtime/src/main/eo/org/eolang/tuple.eo index 9ef8d40931..01503d79a2 100644 --- a/eo-runtime/src/main/eo/org/eolang/tuple.eo +++ b/eo-runtime/src/main/eo/org/eolang/tuple.eo @@ -57,10 +57,17 @@ index.lt 0 index.gte len error "Given index is out of tuple bounds" - if. - index.lt (len.plus -1) - ^.head.at index - ^.tail + ^.at-without-checks index + + # Takes element from the tuple without checking i. + # i must be less than len and greater or equal 0. + # This is faster than ^.at. + [i] > at-without-checks + i > idx! + if. > @ + i.lt head.length + ^.head.at-without-checks i + ^.tail # Create a new tuple with this element added to the end of it. [x] > with From 6b7a63adcc477057276976d2996187fba673c0fc Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Tue, 27 Feb 2024 16:40:58 +0300 Subject: [PATCH 04/80] #2716: tuple optimization --- eo-runtime/src/main/eo/org/eolang/tuple.eo | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/eo-runtime/src/main/eo/org/eolang/tuple.eo b/eo-runtime/src/main/eo/org/eolang/tuple.eo index 01503d79a2..354ca204d8 100644 --- a/eo-runtime/src/main/eo/org/eolang/tuple.eo +++ b/eo-runtime/src/main/eo/org/eolang/tuple.eo @@ -60,8 +60,8 @@ ^.at-without-checks index # Takes element from the tuple without checking i. - # i must be less than len and greater or equal 0. - # This is faster than ^.at. + # i must be less than length and greater or equal 0. + # This is faster than at. [i] > at-without-checks i > idx! if. > @ From 668f7303c62d71dbfb300d5c0ffa979bc5fd6657 Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Tue, 27 Feb 2024 16:53:28 +0300 Subject: [PATCH 05/80] #2716: added tests --- eo-runtime/src/test/eo/org/eolang/tuple-tests.eo | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/eo-runtime/src/test/eo/org/eolang/tuple-tests.eo b/eo-runtime/src/test/eo/org/eolang/tuple-tests.eo index 4172211b44..2826de7d90 100644 --- a/eo-runtime/src/test/eo/org/eolang/tuple-tests.eo +++ b/eo-runtime/src/test/eo/org/eolang/tuple-tests.eo @@ -172,6 +172,22 @@ a.at 0 3 +# Test +[] > at-without-checks-with-first-element + eq. > @ + at. + * 100 101 102 + 0 + 100 + +# Test +[] > at-without-checks-with-last-element + eq. > @ + at. + * 100 101 102 + 2 + 102 + # Test. [] > tuple-empty-fluent-with-indented-keyword tuple From 4cbe4c22ebf276b2b81fdaea16240f1d781ba66b Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Tue, 27 Feb 2024 17:16:39 +0300 Subject: [PATCH 06/80] #2716: idx --- eo-runtime/src/main/eo/org/eolang/tuple.eo | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/eo-runtime/src/main/eo/org/eolang/tuple.eo b/eo-runtime/src/main/eo/org/eolang/tuple.eo index 354ca204d8..ac8f01ad3e 100644 --- a/eo-runtime/src/main/eo/org/eolang/tuple.eo +++ b/eo-runtime/src/main/eo/org/eolang/tuple.eo @@ -65,8 +65,8 @@ [i] > at-without-checks i > idx! if. > @ - i.lt head.length - ^.head.at-without-checks i + idx.lt head.length + ^.head.at-without-checks idx ^.tail # Create a new tuple with this element added to the end of it. From d3bcd1e27c893e1e6182d886a8db4651d1922b4f Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Tue, 27 Feb 2024 17:40:54 +0300 Subject: [PATCH 07/80] #2716: placed it inside at. --- eo-runtime/src/main/eo/org/eolang/tuple.eo | 18 +++++++++--------- .../src/test/eo/org/eolang/tuple-tests.eo | 10 ++++++---- 2 files changed, 15 insertions(+), 13 deletions(-) diff --git a/eo-runtime/src/main/eo/org/eolang/tuple.eo b/eo-runtime/src/main/eo/org/eolang/tuple.eo index ac8f01ad3e..f7d9d5014e 100644 --- a/eo-runtime/src/main/eo/org/eolang/tuple.eo +++ b/eo-runtime/src/main/eo/org/eolang/tuple.eo @@ -59,15 +59,15 @@ error "Given index is out of tuple bounds" ^.at-without-checks index - # Takes element from the tuple without checking i. - # i must be less than length and greater or equal 0. - # This is faster than at. - [i] > at-without-checks - i > idx! - if. > @ - idx.lt head.length - ^.head.at-without-checks idx - ^.tail + # Takes element from the tuple without checking i. + # i must be less than length and greater or equal 0. + # This is faster than at. + [i] > at-without-checks + i > idx! + if. > @ + idx.lt head.length + ^.^.head.at.at-without-checks idx + ^.^.tail # Create a new tuple with this element added to the end of it. [x] > with diff --git a/eo-runtime/src/test/eo/org/eolang/tuple-tests.eo b/eo-runtime/src/test/eo/org/eolang/tuple-tests.eo index 2826de7d90..85dd8fff86 100644 --- a/eo-runtime/src/test/eo/org/eolang/tuple-tests.eo +++ b/eo-runtime/src/test/eo/org/eolang/tuple-tests.eo @@ -175,16 +175,18 @@ # Test [] > at-without-checks-with-first-element eq. > @ - at. - * 100 101 102 + at-without-checks. + at. + * 100 101 102 0 100 # Test [] > at-without-checks-with-last-element eq. > @ - at. - * 100 101 102 + at-without-checks. + at. + * 100 101 102 2 102 From 5d97719fa0d37d6a833a084b9f714521801c167f Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Tue, 27 Feb 2024 17:42:32 +0300 Subject: [PATCH 08/80] #2716: placed it inside at. --- eo-runtime/src/main/eo/org/eolang/tuple.eo | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eo-runtime/src/main/eo/org/eolang/tuple.eo b/eo-runtime/src/main/eo/org/eolang/tuple.eo index f7d9d5014e..eda84e69ab 100644 --- a/eo-runtime/src/main/eo/org/eolang/tuple.eo +++ b/eo-runtime/src/main/eo/org/eolang/tuple.eo @@ -57,7 +57,7 @@ index.lt 0 index.gte len error "Given index is out of tuple bounds" - ^.at-without-checks index + ^.at.at-without-checks index # Takes element from the tuple without checking i. # i must be less than length and greater or equal 0. From 49bfd19ed6749ed1d96d93aa95bf22b910c5d861 Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Tue, 27 Feb 2024 18:14:27 +0300 Subject: [PATCH 09/80] #2899 add Java version configuration for sonar --- .github/workflows/sonar.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/sonar.yml b/.github/workflows/sonar.yml index c7c3a45473..5026cc4dbd 100644 --- a/.github/workflows/sonar.yml +++ b/.github/workflows/sonar.yml @@ -35,4 +35,4 @@ jobs: - env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} - run: mvn --batch-mode install -Dinvoker.skip org.sonarsource.scanner.maven:sonar-maven-plugin:sonar -Pjacoco -Dsonar.qualitygate.wait=true + run: mvn --batch-mode install -Dinvoker.skip org.sonarsource.scanner.maven:sonar-maven-plugin:sonar -Pjacoco -Dsonar.java.source=1.8 -Dsonar.qualitygate.wait=true From a04823da59d48c4e3490850ca2b20fc8ac54d3b0 Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Tue, 27 Feb 2024 18:19:51 +0300 Subject: [PATCH 10/80] #2716: Removed commentary that this is faster --- eo-runtime/src/main/eo/org/eolang/tuple.eo | 1 - 1 file changed, 1 deletion(-) diff --git a/eo-runtime/src/main/eo/org/eolang/tuple.eo b/eo-runtime/src/main/eo/org/eolang/tuple.eo index eda84e69ab..ab96988de6 100644 --- a/eo-runtime/src/main/eo/org/eolang/tuple.eo +++ b/eo-runtime/src/main/eo/org/eolang/tuple.eo @@ -61,7 +61,6 @@ # Takes element from the tuple without checking i. # i must be less than length and greater or equal 0. - # This is faster than at. [i] > at-without-checks i > idx! if. > @ From f764cea9b51ddca71424c6bbf9a3c260e7f0a341 Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Tue, 27 Feb 2024 18:37:54 +0300 Subject: [PATCH 11/80] #2716: Removed commentary that this is faster --- eo-runtime/src/main/eo/org/eolang/tuple.eo | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eo-runtime/src/main/eo/org/eolang/tuple.eo b/eo-runtime/src/main/eo/org/eolang/tuple.eo index ab96988de6..2c0ff7e05a 100644 --- a/eo-runtime/src/main/eo/org/eolang/tuple.eo +++ b/eo-runtime/src/main/eo/org/eolang/tuple.eo @@ -57,7 +57,7 @@ index.lt 0 index.gte len error "Given index is out of tuple bounds" - ^.at.at-without-checks index + at-without-checks index # Takes element from the tuple without checking i. # i must be less than length and greater or equal 0. From 071f19845d66879818c13648546b1c2c6a74d418 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Wed, 28 Feb 2024 09:40:56 +0300 Subject: [PATCH 12/80] ec2 large --- .rultor.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.rultor.yml b/.rultor.yml index 931cd1a8ed..36541da144 100644 --- a/.rultor.yml +++ b/.rultor.yml @@ -1,5 +1,7 @@ architect: - yegor256 +ec2: + type: t2.large docker: image: yegor256/rultor-image:1.22.0 assets: From eb1968abf5113ac214f68ccf02284f5105648d1f Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Wed, 28 Feb 2024 12:43:55 +0300 Subject: [PATCH 13/80] #2716: Updated commentary --- eo-runtime/src/main/eo/org/eolang/tuple.eo | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/eo-runtime/src/main/eo/org/eolang/tuple.eo b/eo-runtime/src/main/eo/org/eolang/tuple.eo index 2c0ff7e05a..6b3277daf0 100644 --- a/eo-runtime/src/main/eo/org/eolang/tuple.eo +++ b/eo-runtime/src/main/eo/org/eolang/tuple.eo @@ -59,8 +59,8 @@ error "Given index is out of tuple bounds" at-without-checks index - # Takes element from the tuple without checking i. - # i must be less than length and greater or equal 0. + # Takes element from the tuple without index validation. + # Here i must be an object that can be comparable with int using lt attribute. [i] > at-without-checks i > idx! if. > @ From 7fb26596ca1af8b63800028225272b22e51d09ba Mon Sep 17 00:00:00 2001 From: Danila Danko Date: Wed, 28 Feb 2024 13:42:28 +0300 Subject: [PATCH 14/80] fix: rename VTX -> VERTEX --- eo-parser/src/main/antlr4/org/eolang/parser/Phi.g4 | 5 +++-- .../src/main/java/org/eolang/parser/XePhiListener.java | 6 +++--- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/eo-parser/src/main/antlr4/org/eolang/parser/Phi.g4 b/eo-parser/src/main/antlr4/org/eolang/parser/Phi.g4 index 6cb1b0e342..e5f18ec387 100644 --- a/eo-parser/src/main/antlr4/org/eolang/parser/Phi.g4 +++ b/eo-parser/src/main/antlr4/org/eolang/parser/Phi.g4 @@ -39,7 +39,7 @@ attribute : PHI | RHO | SIGMA - | VTX + | VERTEX | LABEL | alphaAttr ; @@ -131,7 +131,8 @@ RHO : 'ρ' SIGMA : 'σ' ; -VTX : 'ν' +VERTEX + : 'ν' ; DELTA : 'Δ' diff --git a/eo-parser/src/main/java/org/eolang/parser/XePhiListener.java b/eo-parser/src/main/java/org/eolang/parser/XePhiListener.java index 75c871fd83..bf2dfc821c 100644 --- a/eo-parser/src/main/java/org/eolang/parser/XePhiListener.java +++ b/eo-parser/src/main/java/org/eolang/parser/XePhiListener.java @@ -209,13 +209,13 @@ public void enterBinding(final PhiParser.BindingContext ctx) { public void exitBinding(final PhiParser.BindingContext ctx) { if (this.objs.size() > this.packages.size()) { if (ctx.alphaBinding() != null) { - if (ctx.alphaBinding().attribute().VTX() != null) { + if (ctx.alphaBinding().attribute().VERTEX() != null) { this.objects().remove(); } else { this.objects().leave(); } } else if (ctx.emptyBinding() != null) { - if (ctx.emptyBinding().attribute().VTX() != null) { + if (ctx.emptyBinding().attribute().VERTEX() != null) { this.objects().remove(); } else { this.objects().leave(); @@ -244,7 +244,7 @@ public void enterAttribute(final PhiParser.AttributeContext ctx) { attr = "^"; } else if (ctx.SIGMA() != null) { attr = "&"; - } else if (ctx.VTX() != null) { + } else if (ctx.VERTEX() != null) { attr = "<"; } else if (ctx.LABEL() != null) { attr = ctx.LABEL().getText(); From ffc237605649c8d9cf3b6574ac771df44e5a6816 Mon Sep 17 00:00:00 2001 From: maxonfjvipon Date: Wed, 28 Feb 2024 14:10:18 +0300 Subject: [PATCH 15/80] fix(#2873): changed rho with sigma --- .../src/main/resources/org/eolang/maven/phi/to-phi.xsl | 2 +- .../src/test/resources/org/eolang/maven/phi/fibonaci.yaml | 4 ++-- .../src/test/resources/org/eolang/maven/phi/nested.yaml | 8 ++++---- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/eo-maven-plugin/src/main/resources/org/eolang/maven/phi/to-phi.xsl b/eo-maven-plugin/src/main/resources/org/eolang/maven/phi/to-phi.xsl index 2b0cbe1dc6..feb0f8588d 100644 --- a/eo-maven-plugin/src/main/resources/org/eolang/maven/phi/to-phi.xsl +++ b/eo-maven-plugin/src/main/resources/org/eolang/maven/phi/to-phi.xsl @@ -244,7 +244,7 @@ SOFTWARE. - + . diff --git a/eo-maven-plugin/src/test/resources/org/eolang/maven/phi/fibonaci.yaml b/eo-maven-plugin/src/test/resources/org/eolang/maven/phi/fibonaci.yaml index 0627a04e51..6532f578c8 100644 --- a/eo-maven-plugin/src/test/resources/org/eolang/maven/phi/fibonaci.yaml +++ b/eo-maven-plugin/src/test/resources/org/eolang/maven/phi/fibonaci.yaml @@ -28,7 +28,7 @@ phi: | ) ).if( α0 ↦ ξ.n, - α1 ↦ ξ.ρ.fibonacci( + α1 ↦ ξ.σ.fibonacci( α0 ↦ ξ.n.minus( α0 ↦ Φ.org.eolang.int( α0 ↦ Φ.org.eolang.bytes( @@ -37,7 +37,7 @@ phi: | ) ) ).plus( - α0 ↦ ξ.ρ.fibonacci( + α0 ↦ ξ.σ.fibonacci( α0 ↦ ξ.n.minus( α0 ↦ Φ.org.eolang.int( α0 ↦ Φ.org.eolang.bytes( diff --git a/eo-maven-plugin/src/test/resources/org/eolang/maven/phi/nested.yaml b/eo-maven-plugin/src/test/resources/org/eolang/maven/phi/nested.yaml index 8f0a745552..1b9b58899c 100644 --- a/eo-maven-plugin/src/test/resources/org/eolang/maven/phi/nested.yaml +++ b/eo-maven-plugin/src/test/resources/org/eolang/maven/phi/nested.yaml @@ -18,17 +18,17 @@ phi: | a ↦ ∅, x ↦ ⟦ y ↦ ⟦ - d ↦ ξ.ρ.ρ.a, + d ↦ ξ.σ.σ.a, z ↦ ⟦ - five ↦ ξ.ρ.ρ.ρ.ρ.main( + five ↦ ξ.σ.σ.σ.σ.main( α0 ↦ Φ.org.eolang.int( α0 ↦ Φ.org.eolang.bytes( Δ ⤍ 00-00-00-00-00-00-00-05 ) ) ), - b ↦ ξ.ρ.ρ.ρ.a, - e ↦ ξ.ρ.d + b ↦ ξ.σ.σ.σ.a, + e ↦ ξ.σ.d ⟧ ⟧ ⟧ From 75c631a6cd31c92577567e20b788cb56c62adf8c Mon Sep 17 00:00:00 2001 From: maxonfjvipon Date: Wed, 28 Feb 2024 14:15:13 +0300 Subject: [PATCH 16/80] fix(#2873): renamed sigma --- .../src/main/resources/org/eolang/maven/phi/to-phi.xsl | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/eo-maven-plugin/src/main/resources/org/eolang/maven/phi/to-phi.xsl b/eo-maven-plugin/src/main/resources/org/eolang/maven/phi/to-phi.xsl index feb0f8588d..dba1fdb9b3 100644 --- a/eo-maven-plugin/src/main/resources/org/eolang/maven/phi/to-phi.xsl +++ b/eo-maven-plugin/src/main/resources/org/eolang/maven/phi/to-phi.xsl @@ -42,7 +42,7 @@ SOFTWARE. - + @@ -105,11 +105,11 @@ SOFTWARE. - + . - + @@ -243,14 +243,14 @@ SOFTWARE. - + . - + From 760b2a32ce4a4a3f2a0eab210e339814802517bf Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Wed, 28 Feb 2024 14:37:05 +0300 Subject: [PATCH 17/80] #2716: quotes --- eo-runtime/src/main/eo/org/eolang/tuple.eo | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eo-runtime/src/main/eo/org/eolang/tuple.eo b/eo-runtime/src/main/eo/org/eolang/tuple.eo index 6b3277daf0..9a795f82b0 100644 --- a/eo-runtime/src/main/eo/org/eolang/tuple.eo +++ b/eo-runtime/src/main/eo/org/eolang/tuple.eo @@ -60,7 +60,7 @@ at-without-checks index # Takes element from the tuple without index validation. - # Here i must be an object that can be comparable with int using lt attribute. + # Here "i" must be an object that can be comparable with "int" using "lt" attribute. [i] > at-without-checks i > idx! if. > @ From 48e0798ea38b7313f9f80e7c8b9c5849cb51ec1b Mon Sep 17 00:00:00 2001 From: maxonfjvipon Date: Wed, 28 Feb 2024 15:27:50 +0300 Subject: [PATCH 18/80] fix(#2873): pack --- .../maven/phi/iterates-over-counter.yaml | 69 +++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100644 eo-maven-plugin/src/test/resources/org/eolang/maven/phi/iterates-over-counter.yaml diff --git a/eo-maven-plugin/src/test/resources/org/eolang/maven/phi/iterates-over-counter.yaml b/eo-maven-plugin/src/test/resources/org/eolang/maven/phi/iterates-over-counter.yaml new file mode 100644 index 0000000000..874c3c559e --- /dev/null +++ b/eo-maven-plugin/src/test/resources/org/eolang/maven/phi/iterates-over-counter.yaml @@ -0,0 +1,69 @@ +eo: | + # This is the default 64+ symbols comment in front of named abstract object. + [] > iterates-over-simple-counter + memory 0 > x + and. > @ + eq. + x.write 5 + 5 + eq. + while. + x.as-int.lt 10 + [i] + x.write > @ + x.as-int.plus 1 + 11 +phi: | + { + ⟦ + iterates-over-simple-counter ↦ ⟦ + x ↦ Φ.org.eolang.memory( + α0 ↦ Φ.org.eolang.int( + α0 ↦ Φ.org.eolang.bytes( + Δ ⤍ 00-00-00-00-00-00-00-00 + ) + ) + ), + φ ↦ ξ.x.write( + α0 ↦ Φ.org.eolang.int( + α0 ↦ Φ.org.eolang.bytes( + Δ ⤍ 00-00-00-00-00-00-00-05 + ) + ) + ).eq( + α0 ↦ Φ.org.eolang.int( + α0 ↦ Φ.org.eolang.bytes( + Δ ⤍ 00-00-00-00-00-00-00-05 + ) + ) + ).and( + α0 ↦ ξ.x.as-int.lt( + α0 ↦ Φ.org.eolang.int( + α0 ↦ Φ.org.eolang.bytes( + Δ ⤍ 00-00-00-00-00-00-00-0A + ) + ) + ).while( + α0 ↦ ⟦ + i ↦ ∅, + φ ↦ ξ.σ.x.write( + α0 ↦ ξ.σ.x.as-int.plus( + α0 ↦ Φ.org.eolang.int( + α0 ↦ Φ.org.eolang.bytes( + Δ ⤍ 00-00-00-00-00-00-00-01 + ) + ) + ) + ) + ⟧ + ).eq( + α0 ↦ Φ.org.eolang.int( + α0 ↦ Φ.org.eolang.bytes( + Δ ⤍ 00-00-00-00-00-00-00-0B + ) + ) + ) + ) + ⟧ + ⟧ + } \ No newline at end of file From 977935f81cc080bdc558409c2ded524441613ac4 Mon Sep 17 00:00:00 2001 From: maxonfjvipon Date: Wed, 28 Feb 2024 15:37:38 +0300 Subject: [PATCH 19/80] fix(#2873): restart --- eo-parser/src/main/java/org/eolang/parser/ParsingTrain.java | 1 - 1 file changed, 1 deletion(-) diff --git a/eo-parser/src/main/java/org/eolang/parser/ParsingTrain.java b/eo-parser/src/main/java/org/eolang/parser/ParsingTrain.java index 070ff98ac7..032c403b9c 100644 --- a/eo-parser/src/main/java/org/eolang/parser/ParsingTrain.java +++ b/eo-parser/src/main/java/org/eolang/parser/ParsingTrain.java @@ -160,5 +160,4 @@ public ParsingTrain() { ) ); } - } From ce19727052e6eca901cc4593e47d68ee04988edd Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Wed, 28 Feb 2024 16:02:43 +0300 Subject: [PATCH 20/80] #2716: brackets --- eo-runtime/src/main/eo/org/eolang/tuple.eo | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eo-runtime/src/main/eo/org/eolang/tuple.eo b/eo-runtime/src/main/eo/org/eolang/tuple.eo index 9a795f82b0..8c38ba3781 100644 --- a/eo-runtime/src/main/eo/org/eolang/tuple.eo +++ b/eo-runtime/src/main/eo/org/eolang/tuple.eo @@ -60,7 +60,7 @@ at-without-checks index # Takes element from the tuple without index validation. - # Here "i" must be an object that can be comparable with "int" using "lt" attribute. + # Here `i` must be an object that can be comparable with `int` using `lt` attribute. [i] > at-without-checks i > idx! if. > @ From deec038271f58c443b8a4b0c489ae0001f36d280 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 28 Feb 2024 16:13:00 +0000 Subject: [PATCH 21/80] Update dependency ch.qos.logback:logback-classic to v1.5.1 --- eo-runtime/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eo-runtime/pom.xml b/eo-runtime/pom.xml index 0c3ae7d0bc..06f84f8406 100644 --- a/eo-runtime/pom.xml +++ b/eo-runtime/pom.xml @@ -53,7 +53,7 @@ SOFTWARE. ch.qos.logback logback-classic - 1.5.0 + 1.5.1 test From d129c9f5b0d8e86055e23f69242a0aa3e98f9e90 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 16:57:34 +0300 Subject: [PATCH 22/80] #2903 eolang --- paper/.gitignore | 5 +- paper/eolang-paper.tex | 15 +---- paper/sections/acks.tex | 2 +- paper/sections/calculus.tex | 114 +++++++++++++++++----------------- paper/sections/complexity.tex | 8 +-- paper/sections/features.tex | 58 ++++++++--------- paper/sections/four.tex | 6 +- paper/sections/intro.tex | 6 +- paper/sections/pragmatics.tex | 22 +++---- paper/sections/syntax.tex | 24 +++---- paper/sections/xmir.tex | 22 +++---- 11 files changed, 138 insertions(+), 144 deletions(-) diff --git a/paper/.gitignore b/paper/.gitignore index 3c7bc6933a..30cc924adc 100644 --- a/paper/.gitignore +++ b/paper/.gitignore @@ -13,4 +13,7 @@ _minted-* *.out *.synctex.gz *.zip -package/ \ No newline at end of file +package/ +iexec.ret +*-SAVE-ERROR +_eolang/ \ No newline at end of file diff --git a/paper/eolang-paper.tex b/paper/eolang-paper.tex index 6d45a09528..bbd0897150 100644 --- a/paper/eolang-paper.tex +++ b/paper/eolang-paper.tex @@ -25,13 +25,6 @@ \usepackage[utf8]{inputenc} \usepackage[maxnames=1,minnames=1,maxbibnames=100,natbib=true,citestyle=authoryear,bibstyle=authoryear,doi=false,url=false,isbn=false,isbn=false,backend=biber]{biblatex} \addbibresource{main.bib} - -\ifnum\pdfshellescape=1 - \usepackage[finalizecache]{minted} -\else - \usepackage[frozencache]{minted} -\fi - \usepackage[T2A,T1]{fontenc} \usepackage{stmaryrd} % for arrows, like \mapstochar \let\Bbbk\relax\usepackage{amssymb} % for special symbols @@ -45,6 +38,7 @@ \usepackage{paralist} % for inlined lists \usepackage{cancel} % to enable \cancel command \usepackage{anyfontsize} % To get rid of font not found warnings +\usepackage{eolang} % for EO sources and formulas \usepackage{tabularx} % for special tables \usepackage{to-be-determined} % for \tbd command \usepackage{href-ul} % for nicely underscored links @@ -62,9 +56,6 @@ \newcommand\nospell[1]{#1} \newcommand\br{\\[-4pt]} \newcommand\figcap[1]{\caption{#1}\Description{#1}} -\newcommand\phic{$\varphi$-calculus} -\newcommand\eo{{\sffamily EO}} -\newcommand\XMIR{{\sffamily XMIR}} \newcommand\lref[1]{the line no.~\ref{ln:#1}} \newcommand\lrefs[2]{the lines~\ref{ln:#1}--\ref{ln:#2}} @@ -122,7 +113,7 @@ OOP, but none of them managed to cover all the features available in modern OO programming languages, such as C++ or Java. We have made yet another attempt and created \phic{}. We also -created EOLANG (also called \eo{}), an experimental +created EOLANG (also called \eolang{}), an experimental programming language based on \phic{}. \end{abstract} @@ -139,7 +130,7 @@ \section{Introduction} In order to make it easier to understand, we start the discussion with the syntax of the language, while the calculus is derived from it. Then, we discuss the -key features of \eo{} and the differences between it and other +key features of \eolang{} and the differences between it and other programming languages. We also discuss how the absence of traditional OOP features, such as mutability or inheritance, affect the complexity of code. At the end of the paper we overview the work done by others in the area of diff --git a/paper/sections/acks.tex b/paper/sections/acks.tex index 3376c9d136..93f76b0869 100644 --- a/paper/sections/acks.tex +++ b/paper/sections/acks.tex @@ -24,5 +24,5 @@ \nospell{César Soto Valero}, and \nospell{David West} -for their contribution to the development of \eo{} and \phic{}. +for their contribution to the development of \eolang{} and \phic{}. diff --git a/paper/sections/calculus.tex b/paper/sections/calculus.tex index 0e7d0f8c9e..926d2926c7 100644 --- a/paper/sections/calculus.tex +++ b/paper/sections/calculus.tex @@ -1,16 +1,16 @@ The proposed \phic{} is based on set theory~\citep{jech2013set} and lambda calculus, -representing objects as sets of pairs and their internals as $\lambda$-terms. +representing objects as sets of pairs and their internals as \(\lambda\)-terms. The rest of the section contains formal definitions of data, objects, attributes, abstraction, application, decoration, and dataization. \subsection{Objects and Data} \begin{definition}\label{def:object} -An \textbf{object} is a set of ordered pairs $(a_i, v_i)$ such that -$a_i$ is an identifier, all $a_i$ are different, and $v_i$ is an object. +An \textbf{object} is a set of ordered pairs \((a_i, v_i)\) such that +\(a_i\) is an identifier, all \(a_i\) are different, and \(v_i\) is an object. \end{definition} -An identifier is either $\varphi$, $\rho$, $\nu$, or, by convention, a text without +An identifier is either \(\varphi\), \(\rho\), \(\nu\), or, by convention, a text without spaces starting with a small-case English letter in typewriter font. The object at \lref{book} may be represented as @@ -21,7 +21,7 @@ \subsection{Objects and Data} \end{matrix*}\right\}, \end{split} \end{equation} -where \ff{isbn} is an identifier and $\varnothing$ is an empty +where \ff{isbn} is an identifier and \(\varnothing\) is an empty set, which is a proper object, according to the Def.~\ref{def:object}. \begin{definition}\label{def:data} @@ -52,11 +52,11 @@ \subsection{Objects and Data} \subsection{Attributes} \begin{definition}\label{def:attribute} -In an object $x$, $a$ is a free \textbf{attribute} -with the \textbf{name} $a$ -iff $(a, \varnothing) \in x$; it is a bound attribute -with the \textbf{value} $v$ -iff $\exists (a, v)\in x$ and $v\not=\varnothing$; +In an object \(x\), \(a\) is a free \textbf{attribute} +with the \textbf{name} \(a\) +iff \((a, \varnothing) \in x\); it is a bound attribute +with the \textbf{value} \(v\) +iff \(\exists (a, v)\in x\) and \(v\not=\varnothing\); \end{definition} In Eq.~\ref{eq:book2}, identifiers \ff{isbn}, \ff{title}, and \ff{price} @@ -64,7 +64,7 @@ \subsection{Attributes} The attribute \ff{isbn} is free, while the other two are bound. \begin{definition}\label{def:dot} -If $x$ is an object and $\exists (a, v) \in x$, then $v$ may be referenced as $x.a$; +If \(x\) is an object and \(\exists (a, v) \in x\), then \(v\) may be referenced as \(x.a\); this referencing mechanism is called \textbf{dot notation}. \end{definition} @@ -74,14 +74,14 @@ \subsection{Attributes} all attributes are visible to all objects outside of the one they belong to. It is possible to chain attribute references using dot notation, for example -$\ff{book2}.\ff{price}.\ff{neg}$ is a valid expression, which means +\(\ff{book2}.\ff{price}.\ff{neg}\) is a valid expression, which means ``taking the attribute \ff{price} from the object \ff{book2} and then taking the attribute \ff{neg} from it.'' \begin{definition}\label{def:scope} -If $x(a_i, v_i)$ is an object, then $\hat{x}$, a set consisting of all $a_i$, -is its \textbf{scope} and the cardinality of $|\hat{x}|$ is -the \textbf{arity} of $x$. +If \(x(a_i, v_i)\) is an object, then \(\hat{x}\), a set consisting of all \(a_i\), +is its \textbf{scope} and the cardinality of \(|\hat{x}|\) is +the \textbf{arity} of \(x\). \end{definition} For example, the scope of the object at Eq.~\ref{eq:book2} consists of three identifiers: @@ -90,14 +90,14 @@ \subsection{Attributes} \subsection{Abstraction} \begin{definition}\label{def:abstraction} -An object $x$ is \textbf{abstract} iff at least one of its attributes is free, -i.e. $\exists (a, \varnothing)\in x$; +An object \(x\) is \textbf{abstract} iff at least one of its attributes is free, +i.e. \(\exists (a, \varnothing)\in x\); the process of creating such an object is called \textbf{abstraction}. \end{definition} -An alternative ``arrow notation'' may be used to denote an object $x$ in a more +An alternative ``arrow notation'' may be used to denote an object \(x\) in a more compact way, where free attributes stay in the parentheses on the left side of the -mapping symbol $\mapsto$ and pairs, +mapping symbol \(\mapsto\) and pairs, which represent bound attributes, stay on the right side, in double-square brackets. Eq.~\ref{eq:book2} may be written as \begin{equation}\label{eq:book2-compact} @@ -112,14 +112,14 @@ \subsection{Abstraction} \subsection{Application} \begin{definition}\label{def:application} -If $x$ is an abstract object and $y$ is an object - where $\hat{y}\subseteq\hat{x}$, - then an \textbf{application} of $y$ to $x$ is - a \textbf{copy} of $x$, a new object that consists of pairs $(a\in\hat{x},v)$ such that - $v=y.a$ if $x.a=\varnothing$ and $v=x.a$ otherwise. +If \(x\) is an abstract object and \(y\) is an object + where \(\hat{y}\subseteq\hat{x}\), + then an \textbf{application} of \(y\) to \(x\) is + a \textbf{copy} of \(x\), a new object that consists of pairs \((a\in\hat{x},v)\) such that + \(v=y.a\) if \(x.a=\varnothing\) and \(v=x.a\) otherwise. \end{definition} -Application makes some free attributes of $x$ bound---by binding objects to them. +Application makes some free attributes of \(x\) bound---by binding objects to them. The produced object has exactly the same set of attributes, but some of them, which were free before, become bound. @@ -134,8 +134,8 @@ \subsection{Application} Arrow notation may also be used to denote object copying, where the names of the attributes, which remain free, stay in the brackets -on the left side of the mapping symbol $\mapsto$, -while objects $P$ provided as arguments stay on the right side, +on the left side of the mapping symbol \(\mapsto\), +while objects \(P\) provided as arguments stay on the right side, in the brackets. For example, the object at \lref{point-copy} may be written as \begin{equation}\label{eq:point} \begin{split} @@ -172,7 +172,7 @@ \subsection{Application} as in Eq.~\ref{eq:book2-compact}, to the contrary of object application, which is denoted by round brackets, as in Eq.~\ref{eq:point}. Object abstraction is a special case of object formation. -The following expression is a formation of the object $x$: +The following expression is a formation of the object \(x\): \begin{equation*} x \mapsto [[ y -> t ]]. \end{equation*} @@ -180,8 +180,8 @@ \subsection{Application} \subsection{Parent and Home} \begin{definition}\label{def:parent} -If $x$ is an object, then $x.\rho$ is its \textbf{parent}, -which is the object that created $x$. +If \(x\) is an object, then \(x.\rho\) is its \textbf{parent}, +which is the object that created \(x\). \end{definition} An object may be created either by @@ -205,8 +205,8 @@ \subsection{Parent and Home} \end{equation} \begin{definition}\label{def:home} -If $x$ is an object, then $x.\sigma$ is its \textbf{home} object, which -is the $\rho$ of the abstract object $x$ is a copy of. +If \(x\) is an object, then \(x.\sigma\) is its \textbf{home} object, which +is the \(\rho\) of the abstract object \(x\) is a copy of. \end{definition} For example: @@ -223,12 +223,12 @@ \subsection{Parent and Home} \subsection{Decoration}\label{sec:decoration} \begin{definition}\label{def:decorator} -If $x$ and $y$ are objects and $x.\varphi = y$, then - $\forall a (x.a = y.a)$ if $a \not\in \hat{x}$; - this means that $x$ is \textbf{decorating} $y$. +If \(x\) and \(y\) are objects and \(x.\varphi = y\), then + \(\forall a (x.a = y.a)\) if \(a \not\in \hat{x}\); + this means that \(x\) is \textbf{decorating} \(y\). \end{definition} -Here, $\varphi$ is a special identifier denoting the object, +Here, \(\varphi\) is a special identifier denoting the object, known as a \emph{decoratee}, being decorated within the scope of the decorator. @@ -265,8 +265,8 @@ \subsection{Decoration}\label{sec:decoration} \end{equation} Because of decoration, the expression -$\rho.\varphi.\ff{distance}$ in Eq.~\ref{eq:c-empty} is semantically equivalent to a shorter expression -$\rho.\ff{distance}$ in Eq.~\ref{eq:c-fin}. +\(\rho.\varphi.\ff{distance}\) in Eq.~\ref{eq:c-empty} is semantically equivalent to a shorter expression +\(\rho.\ff{distance}\) in Eq.~\ref{eq:c-fin}. The following expression makes a new object \ff{is}, which represents a sequence of object applications ending with a copy of \ff{lte}: @@ -296,9 +296,9 @@ \subsection{Decoration}\label{sec:decoration} \subsection{Atoms} \begin{definition}\label{def:atom} -If $\lambda s.M$ is a function of one argument $s$ returning an object, -then it is an abstract object called an \textbf{atom}, $M$ is its $\lambda$-term, -and $s$ is its free attribute. +If \(\lambda s.M\) is a function of one argument \(s\) returning an object, +then it is an abstract object called an \textbf{atom}, \(M\) is its \(\lambda\)-term, +and \(s\) is its free attribute. \end{definition} For example, the atom at \lref{sum-def} would be represented as @@ -309,22 +309,22 @@ \subsection{Atoms} \end{equation} where the function calculates an arithmetic sum of all items in the tuple \ff{x} and returns the result as a data. The argument of -the function is a vector $s$ where the first element is the object under +the function is a vector \(s\) where the first element is the object under consideration, the second element is its parent object, the third element -is the parent of the parent, and so on. Thus, $s[0]$ is the object -\ff{sum} itself, while $s[0].\ff{x}$ is its inner object \ff{x}, -and $s[0].\ff{x}.\ff{get}(0)$ is the first element of it, if it is a tuple. +is the parent of the parent, and so on. Thus, \(s[0]\) is the object +\ff{sum} itself, while \(s[0].\ff{x}\) is its inner object \ff{x}, +and \(s[0].\ff{x}.\ff{get}(0)\) is the first element of it, if it is a tuple. It is expected that the tuple has an attribute \ff{size} representing the total number of elements in the tuple. -Atoms may have their $\lambda$-terms defined outside of \phic{} formal scope. +Atoms may have their \(\lambda\)-terms defined outside of \phic{} formal scope. For example, the object at \lref{stdout} would be denoted as \begin{equation}\label{def:stdout} \ff{stdout}(\ff{text}) \mapsto \lambda s.M_\texttt{stdout}, \end{equation} -where $M_\texttt{stdout}$ is a $\lambda$-term defined externally. +where \(M_\texttt{stdout}\) is a \(\lambda\)-term defined externally. -In atoms, $\lambda$-terms are bound to $\lambda$ attribute. +In atoms, \(\lambda\)-terms are bound to \(\lambda\) attribute. Thus, a more formal form of the Eq.~\ref{def:stdout} is: \begin{equation*} \ff{stdout} \mapsto \llbracket \ff{text} \mapsto \varnothing, \lambda \mapsto M_\text{stdout} \rrbracket. @@ -334,7 +334,7 @@ \subsection{Locators} \begin{definition}\label{def:locator} Object \textbf{locator} is a unique dot-separated not-empty -collection of identifiers prepended by either $\xi$, $\rho$, $\sigma$, or $\Phi$. +collection of identifiers prepended by either \(\xi\), \(\rho\), \(\sigma\), or \(\Phi\). \end{definition} Locators are used to avoid ambiguity when referencing objects. @@ -353,10 +353,10 @@ \subsection{Locators} & \rrbracket, \end{split} \end{equation} -where $\xi$ denotes the current abstract object -and $\Phi$ refers to the anonymous closed ``root'' object. +where \(\xi\) denotes the current abstract object +and \(\Phi\) refers to the anonymous closed ``root'' object. Defining an object in a global scope -means binding it to the object $\Phi$, unless it is an anonymous +means binding it to the object \(\Phi\), unless it is an anonymous object, as the one at \lrefs{succ}{succ-end}. The most precise and complete formula for the object in the @@ -384,16 +384,16 @@ \subsection{Constant} \newcommand\cmapsto{\mapstochar\relbar\mathrel{\mkern-8mu}\mapsto} \begin{definition}\label{def:identity} -If $x \mapsto \llbracket y \cmapsto z \rrbracket$ is an object -then $y$ is a \emph{constant} attribute, meaning that -the result of dataization of $x.y$ always equals to itself. +If \(x \mapsto \llbracket y \cmapsto z \rrbracket\) is an object +then \(y\) is a \emph{constant} attribute, meaning that +the result of dataization of \(x.y\) always equals to itself. \end{definition} \subsection{Identity} \begin{definition}\label{def:constant} -If $x$ is an object then $x.\nu$ is a positive integer data object -with a unique identity of $x$ in the entire runtime scope. +If \(x\) is an object then \(x.\nu\) is a positive integer data object +with a unique identity of \(x\) in the entire runtime scope. \end{definition} For example, without any other objects in scope it is safe diff --git a/paper/sections/complexity.tex b/paper/sections/complexity.tex index 6cba974eab..1089f7f2e2 100644 --- a/paper/sections/complexity.tex +++ b/paper/sections/complexity.tex @@ -44,10 +44,10 @@ of the design patterns listed above are possible and may be utilized by programmers in their code, letting them write code with higher complexity. To the contrary, they -are not permitted in \eo{} by design: +are not permitted in \eolang{} by design: \begin{itemize} -\solution{return-null,accept-null} There are no NULLs in~\eo{} +\solution{return-null,accept-null} There are no NULLs in~\eolang{} \solution{utility,factory,singleton} There are no static methods \solution{inheritance} There is no inheritance \solution{mutable,setters} There are no mutable objects @@ -60,7 +60,7 @@ \solution{formatting} The syntax explicitly defines style \end{itemize} -Thus, since in \eo{} all patterns listed above -are not permitted by the language design, \eo{} programs +Thus, since in \eolang{} all patterns listed above +are not permitted by the language design, \eolang{} programs will have lower complexity while being written by the same group of programmers. diff --git a/paper/sections/features.tex b/paper/sections/features.tex index df86cfcb66..285a48abfa 100644 --- a/paper/sections/features.tex +++ b/paper/sections/features.tex @@ -5,36 +5,36 @@ #2% }.\;}} -There are a few features that distinguish \eo{} and \phic{} +There are a few features that distinguish \eolang{} and \phic{} from other existing OO languages and object theories, while some of them are similar to what other languages have to offer. The Section is not intended to present the features formally, which was done earlier in -Sections~\ref{sec:calculus} and~\ref{sec:syntax}, but to compare \eo{} with other +Sections~\ref{sec:calculus} and~\ref{sec:syntax}, but to compare \eolang{} with other programming languages and informally identify similarities. \feature{no-classes}{No Classes} % -\eo{} is similar to other delegation-based languages like Self~\citep{ungar1987self}, +\eolang{} is similar to other delegation-based languages like Self~\citep{ungar1987self}, where objects are not created by a class as in class-based languages like C++ or Java, but from another object, inheriting properties from the original. However, while in such languages, according to~\citet{fisher1995delegation}, ``an object may be created, and then have new methods added or existing methods redefined,'' -in \eo{} such object alteration is not allowed. +in \eolang{} such object alteration is not allowed. \feature{no-types}{No Types} % -Even though there are no types in \eo{}, compatibility +Even though there are no types in \eolang{}, compatibility between objects may be inferred in compile-time and validated strictly, which other \nospell{typeless} languages such as Python, Julia~\citep{bezanson2012julia}, Lua~\citep{ierusalimschy2016lua}, or Erlang~\citep{erlang2020manual} can't guarantee. -Also, there is no type casting or reflection on types in \eo{}. +Also, there is no type casting or reflection on types in \eolang{}. \feature{no-inheritance}{No Inheritance} % -It is impossible to inherit attributes from another object in \eo{}. +It is impossible to inherit attributes from another object in \eolang{}. The only two possible ways to re-use functionality are either via object composition or decorators. There are OO languages without implementation inheritance, for example Go~\citep{donovankernighan2015go}, @@ -44,15 +44,15 @@ \feature{no-methods}{No Methods} % -An object in \eo{} is a composition of other objects and atoms: +An object in \eolang{} is a composition of other objects and atoms: there are no methods or functions similar to Java or C++ ones. Execution control is given to a program when atoms' attributes are referred to. -Atoms are implemented by \eo{} runtime similar to Java native objects. +Atoms are implemented by \eolang{} runtime similar to Java native objects. To our knowledge, there are no other OO languages without methods. \feature{no-ctors}{No Constructors} % -Unlike Java or C++, \eo{} doesn't allow programmers to alter +Unlike Java or C++, \eolang{} doesn't allow programmers to alter the process of object construction or suggest alternative paths of object instantiation via additional constructions. Instead, all arguments are assigned to attributes ``as is'' and can't be modified. @@ -60,36 +60,36 @@ \feature{no-static}{No Static Entities} % Unlike Java and C\#, -\eo{} objects may consist only of other objects, represented +\eolang{} objects may consist only of other objects, represented by attributes, while class methods, also known as static methods, as well as -static literals, and static blocks---don't exist in \eo{}. +static literals, and static blocks---don't exist in \eolang{}. Considering modern programming languages, Go has no static methods either, but only objects and ``\nospell{structs}''~\citep{schmager2010gohotdraw}. \feature{no-primitives}{No Primitive Data Types} % -There are no primitive data types in \eo{}, which +There are no primitive data types in \eolang{}, which exist in Java and C++, for example. As in Ruby, Smalltalk~\citep*{goldbergrobson1983smalltalk}, Squeak, Self, and Pharo, integers, floating point numbers, boolean -values, and strings are objects in \eo{}: +values, and strings are objects in \eolang{}: ``everything is an object'' is the key design principle, which, according to~\citet[p.66]{west2004object}, is an ``obviously necessary prerequisite to object thinking.'' \feature{no-operators}{No Operators} % -There are no operators like \ff{+} or \ff{/} in \eo{}. Instead, +There are no operators like \ff{+} or \ff{/} in \eolang{}. Instead, numeric objects have built-in atoms that represent math operations. The same is true for all other manipulations with objects: they are provided only by their encapsulated objects, not by external language constructs, as in -Java or C\#. Here \eo{} is similar to Ruby, Smalltalk and Eiffel, +Java or C\#. Here \eolang{} is similar to Ruby, Smalltalk and Eiffel, where operators are syntax sugar, while implementation is encapsulated in the objects. \feature{no-null}{No NULL References} % -Unlike C++ and Java, there is no concept of NULL in \eo{}, which +Unlike C++ and Java, there is no concept of NULL in \eolang{}, which was called a ``billion dollar mistake'' by~\citet{hoare2009null} and is one of the key threats for design consistency~\citep{eo1}. Haskell, Rust, OCaml, Standard ML, and Swift also don't have NULL references. @@ -97,7 +97,7 @@ \feature{no-empty}{No Empty Objects} % Unlike Java, C++ and all other OO languages, -empty objects with no attributes are forbidden in \eo{} in order +empty objects with no attributes are forbidden in \eolang{} in order to guarantee the presence of object composition and enable separation of concerns~\citep{dijkstra1982role}: larger objects must always encapsulate smaller ones. @@ -105,7 +105,7 @@ \feature{no-private}{No Private Attributes} % Similar to Python~\citep{lutz2013learning} and Smalltalk~\citep{hunt1997smalltalk}, -\eo{} makes all object attributes publicly visible. +\eolang{} makes all object attributes publicly visible. There are no protected ones, because there is no implementation inheritance, which is considered harmful~\citep{hunt2000}. There are no private attributes either, because information @@ -114,7 +114,7 @@ \feature{no-global}{No Global Scope} % -All objects in \eo{} are assigned to some attributes. Objects constructed +All objects in \eolang{} are assigned to some attributes. Objects constructed in the global scope of visibility are assigned to attributes of the $\Phi$ object of the highest level of abstraction. Newspeak and Eiffel are two programming languages that does not have global scope as well. @@ -122,7 +122,7 @@ \feature{no-mutability}{No Mutability} % Similar to Erlang~\citep{armstrong2010erlang}, -there are only immutable objects in \eo{}, meaning that their attributes may +there are only immutable objects in \eolang{}, meaning that their attributes may not be changed after the object is constructed or copied. Java, C\#, and C++, have modifiers like \ff{final}, \ff{readonly}, or \ff{const} to make attributes immutable, which @@ -130,7 +130,7 @@ always expose the same functionality, the former may represent mutable entities, being known as read-only references~\citep{birka2004practical}. For example, an attribute \ff{r} may have an object \ff{random.pseudo} -assigned to it, which is a random number generator. \eo{} won't allow +assigned to it, which is a random number generator. \eolang{} won't allow assigning another object to the attribute \ff{r}. However, every time the attribute is dataized, its value will be different. % @@ -144,26 +144,26 @@ % In most OO languages exception handling~\citep{goodenough1975exception}: happens through an imperative error-throwing statement. -Instead, \eo{} has a declarative mechanism for it, which +Instead, \eolang{} has a declarative mechanism for it, which is similar to Null Object design pattern~\citep{martin1997pattern}: returning an abstract object causes program execution to stop once the returned object is dealt with. \feature{no-functions}{No Functions} % -There are no lambda objects or functions in \eo{}, which exist in Java~8+, for example. -However, objects in \eo{} have ``bodies,'' which make it possible to interpret +There are no lambda objects or functions in \eolang{}, which exist in Java~8+, for example. +However, objects in \eolang{} have ``bodies,'' which make it possible to interpret objects as functions. -Strictly speaking, if objects in \eo{} would only have bodies and no other attributes, +Strictly speaking, if objects in \eolang{} would only have bodies and no other attributes, they would be functions. It is legit to -say that \eo{} extends lambda calculus, but in a different way +say that \eolang{} extends lambda calculus, but in a different way comparing to previous attempts made by~\citet{mitchell1993lambda} and \citet{di1998lambda}: -methods and attributes in \eo{} are not new concepts, but lower-level +methods and attributes in \eolang{} are not new concepts, but lower-level objects. \feature{no-mixins}{No mixins} % -There are no ``traits'' or ``mixins'' in~\eo{}, which exist in Ruby and PHP to enable +There are no ``traits'' or ``mixins'' in~\eolang{}, which exist in Ruby and PHP to enable code reuse from other objects without inheritance and composition. diff --git a/paper/sections/four.tex b/paper/sections/four.tex index 82777a1f6b..6b7d98e62e 100644 --- a/paper/sections/four.tex +++ b/paper/sections/four.tex @@ -155,7 +155,7 @@ \subsection{Polymorphism} the comformance between objects is derived and ``strongly'' checked in compile time. In the example above, it would not be possible to compile the code that adds elements to the set \ff{emps}, if any -of them lacks the attribute \ff{print}. Since in \eo{}, +of them lacks the attribute \ff{print}. Since in \eolang{}, there is no reflection on types or any other mechanisms of alternative object instantiation, it is always known where objects are constructed or copied and what is the structure of them. @@ -195,13 +195,13 @@ \subsection{Encapsulation} Instead, all attributes of all objects in \phic{} are visible to any other object. -In \eo{} the primary goal of encapsulation is achieved differently. +In \eolang{} the primary goal of encapsulation is achieved differently. The goal is to reduce coupling between objects: the less they know about each other the thinner the the connection between them, which is one of the virtues of software design, according to~\citet{yourdon1979structured}. -In \eo{} the tightness of coupling between objects should be controlled +In \eolang{} the tightness of coupling between objects should be controlled during the build, similar to how the threshold of test code coverage is usually controlled. At compile-time the compiler collects the information about the relationships between objects and calculates the coupling depth of each connection. diff --git a/paper/sections/intro.tex b/paper/sections/intro.tex index 87195375a2..b3bf6c6c2d 100644 --- a/paper/sections/intro.tex +++ b/paper/sections/intro.tex @@ -98,7 +98,7 @@ \subsection{High Complexity} \subsection{Solution Proposed} -\eo{}\footnote{\url{https://www.eolang.org}} +\eolang{}\footnote{\url{https://www.eolang.org}} was created in order to eliminate the problem of complexity of OOP code, providing \begin{inparaenum}[1)] @@ -110,9 +110,9 @@ \subsection{Solution Proposed} through abstraction, application, and decoration. The calculus introduces a formal apparatus for manipulations with objects. -\eo{}, the proposed programming language, fully implements +\eolang{}, the proposed programming language, fully implements all elements of the calculus and enables implementation of an object model on any computational platform. -Being an OO programming language, \eo{} enables four key principles of OOP: +Being an OO programming language, \eolang{} enables four key principles of OOP: abstraction, inheritance, polymorphism, and encapsulation. diff --git a/paper/sections/pragmatics.tex b/paper/sections/pragmatics.tex index 42cb038311..423b28540a 100644 --- a/paper/sections/pragmatics.tex +++ b/paper/sections/pragmatics.tex @@ -1,21 +1,21 @@ -First, the source code of \eo{} is parsed by ANTLR4-powered +First, the source code of \eolang{} is parsed by ANTLR4-powered parser and an intermediate representation is built in XML, as was demonstrated in the Section~\ref{sec:xml}. -The output format is called \XMIR{}. +The output format is called \xmir{}. One \ff{.eo} file with -the source code in \eo{} produces one \XMIR{} file with \ff{.xml} extension. +the source code in \eolang{} produces one \xmir{} file with \ff{.xml} extension. -\XMIR{} is then refined via a \emph{pipeline} of XSLT stylesheets. -For example, \XMIR{} at \ref{ln:xml-circle}--\ref{ln:xml-circle-end} contains a +\xmir{} is then refined via a \emph{pipeline} of XSLT stylesheets. +For example, \xmir{} at \ref{ln:xml-circle}--\ref{ln:xml-circle-end} contains a reference to the object \ff{r} at the line no.\ref{ln:xml-circle-r}. An XSL transformation adds an attribute \ff{ref} to the XML element \ff{}, referring it to the line inside XML document, where the object \ff{r} is defined: \begin{ffcode} - |$\label{ln:xml-circle2-r}$| + |\(\label{ln:xml-circle2-r}\)| - + 2 3.14 @@ -23,14 +23,14 @@ \end{ffcode} There are over two dozens XSL transformations in the pipeline, which -are applied to the \XMIR{} in a specific order. New transformations can +are applied to the \xmir{} in a specific order. New transformations can be added to the pipeline for example in order to detect inconsistencies -in \XMIR{}, enforce new semantic rules, or optimize object structures. +in \xmir{}, enforce new semantic rules, or optimize object structures. -Then, \XMIR{} can be translated to machine code, bytecode, C++ source code, +Then, \xmir{} can be translated to machine code, bytecode, C++ source code, or any other target platform language. We implemented a translator to Java source code, which represents -\XMIR{} objects as Java classes and attributes as pairs in encapsulated +\xmir{} objects as Java classes and attributes as pairs in encapsulated \ff{java.util.HashMap} instances. Then, Java source code is compiled to bytecode by OpenJDK Java compiler. diff --git a/paper/sections/syntax.tex b/paper/sections/syntax.tex index 1e1b45f4a3..ba412173be 100644 --- a/paper/sections/syntax.tex +++ b/paper/sections/syntax.tex @@ -1,9 +1,9 @@ -Fig.~\ref{fig:bnf} demonstrates the entire syntax of \eo{} language in BNF. -Similar to Python~\citep{lutz2013learning}, indentation in \eo{} is part of the syntax: +Fig.~\ref{fig:bnf} demonstrates the entire syntax of \eolang{} language in BNF. +Similar to Python~\citep{lutz2013learning}, indentation in \eolang{} is part of the syntax: the scope of a code block is determined by its horizontal position in relation to other blocks, which is also known as ``off-side rule''~\citep{landin1966next}. -There are no keywords in \eo{} but only a few special symbols +There are no keywords in \eolang{} but only a few special symbols denoting grammar constructs: \ff{>} for the attributes naming, \ff{.} for the dot notation, @@ -17,7 +17,7 @@ \ff{\^{}} for referring to the parent object, and \ff{\$} for referring to the current object. -Attributes, which are the only identifiers that exist in \eo{}, may have +Attributes, which are the only identifiers that exist in \eolang{}, may have any Unicode symbols in their names, as long as they start with a small English letter and don't contain spaces, line breaks, or special symbols mentioned above: \ff{test-File} and @@ -81,7 +81,7 @@ \T{float} \df \RE{[+-]?\textbackslash{}d+(\textbackslash{}.\textbackslash{}d+)?} \opt{ \RE{e(+|-)?\textbackslash{}d+} } \\ \end{tabbing} \end{multicols} -\figcap{The full syntax of \eo{} in BNF. +\figcap{The full syntax of \eolang{} in BNF. \lex{eol} is a line ending that preserves the indentation of the previous line. \lex{tab} is a right-shift of the indentation, while \lex{untab} is a left-shift. \lex{any} is any symbol excluding \lex{eol}, \V{.}, and \V{␣}. @@ -96,7 +96,7 @@ \subsection{Identity, State, and Behavior} the object plus the current values of each of these properties. Behavior is how an object acts and reacts, in terms of its state changes and message passing. Identity is that property of an object which distinguishes it from all other objects.'' -The syntax of \eo{} makes a difference between these three categories. +The syntax of \eolang{} makes a difference between these three categories. This is a declaration of an abstract object \ff{book}, which has a single \emph{identity} attribute \ff{isbn}: @@ -237,9 +237,9 @@ \subsection{Indentation} [x] (x.plus 1 > succ) (x.minus 1 > prev) \end{ffcode} -\subsection{\eo{} to XML}\label{sec:xml} +\subsection{\eolang{} to XML}\label{sec:xml} -Due the nesting nature of \eo{}, its program can be transformed +Due the nesting nature of \eolang{}, its program can be transformed to an XML document. The abstract object \ff{vector} would produce this XML tree of elements and attributes: @@ -520,7 +520,7 @@ \subsection{Anonymous Abstract Objects} \subsection{Constants} -\eo{} is a declarative language with lazy evaluations. This means +\eolang{} is a declarative language with lazy evaluations. This means that this code would read the input stream two times: \begin{ffcode} @@ -616,7 +616,7 @@ \subsection{Metas and License} \subsection{Atoms} -Some objects in \eo{} programs may need to be platform specific +Some objects in \eolang{} programs may need to be platform specific and can't be composed from other existing objects---they are called \emph{atoms}. For example, the object \ff{app} uses the object \ff{stdout}, @@ -631,7 +631,7 @@ \subsection{Atoms} \end{ffcode} The \ff{/bool} suffix informs the compiler that this object must -not be compiled from \eo{} to the target language. The object +not be compiled from \eolang{} to the target language. The object with this suffix already exists in the target language and most probably could be found in the library specified by the \ff{rt} meta. The exact library to import has to be selected by the compiler. @@ -642,7 +642,7 @@ \subsection{Atoms} object, which \ff{stdout} decorates. The name may be replaced by a question mark, if uncertain about the object being decorated. -Atoms in \eo{} are similar to ``native'' methods in Java and ``\nospell{extern}'' methods in C\#: this mechanism is also known as foreign function interface (FFI). +Atoms in \eolang{} are similar to ``native'' methods in Java and ``\nospell{extern}'' methods in C\#: this mechanism is also known as foreign function interface (FFI). \subsection{Home Object} diff --git a/paper/sections/xmir.tex b/paper/sections/xmir.tex index 3b0d7e85f4..70a33ade04 100644 --- a/paper/sections/xmir.tex +++ b/paper/sections/xmir.tex @@ -1,4 +1,4 @@ -Consider this sample \eo{} snippet: +Consider this sample \eolang{} snippet: \begin{ffcode} [x y...] > app @@ -16,14 +16,14 @@ 42 |$\label{ln:xml-data}$| + line="2" name="n">42 |\(\label{ln:xml-data}\)| - |$\label{ln:xml-minus}$| - |$\label{ln:method-start}$| - |$\label{ln:method-end}$| + |\(\label{ln:xml-minus}\)| + |\(\label{ln:method-start}\)| + |\(\label{ln:method-end}\)| - |$\label{ln:xml-minus-end}$| + |\(\label{ln:xml-minus-end}\)| \end{ffcode} @@ -46,12 +46,12 @@ goes away): \begin{ffcode} - |$\label{ln:new-minus}$| - |$\label{ln:xml-neg}$| + |\(\label{ln:new-minus}\)| + |\(\label{ln:xml-neg}\)| - |$\label{ln:xml-neg-end}$| + |\(\label{ln:xml-neg-end}\)| - |$\label{ln:new-minus-end}$| + |\(\label{ln:new-minus-end}\)| \end{ffcode} The semantics of the element \ff{.minus} at~\lref{xml-minus} @@ -59,7 +59,7 @@ notation for child-parent relationships. The XML element at~\lrefs{xml-neg}{xml-neg-end} means \ff{neg. n} or \ff{n.neg}. The leading dot at the attribute \ff{base} means that the first -child of this XML element is the \eo{} parent of it. +child of this XML element is the \eolang{} parent of it. Similarly, the XML element at ~\lrefs{new-minus}{new-minus-end} means \ff{minus. (neg. n) t}, or \ff{(neg. n).minus t}, or \ff{n.neg.minus t}. From 8b740d0e594fcfda36f6985180637125f922dea1 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 17:02:35 +0300 Subject: [PATCH 23/80] #2903: more --- paper/Makefile | 10 +- paper/eolang-paper.tex | 4 +- paper/sections/acks.tex | 2 +- paper/sections/complexity.tex | 2 +- paper/sections/features.tex | 2 +- paper/sections/overview.tex | 6 +- paper/sections/related.tex | 2 +- paper/sections/semantics.tex | 504 +++++++++++++++++----------------- paper/sections/syntax.tex | 72 ++--- 9 files changed, 302 insertions(+), 302 deletions(-) diff --git a/paper/Makefile b/paper/Makefile index e3483afd98..e62c3cc486 100644 --- a/paper/Makefile +++ b/paper/Makefile @@ -27,7 +27,7 @@ TLROOT=$$(kpsewhich -var-value TEXMFDIST) PACKAGES=ffcode to-be-determined href-ul minted REPO=objectionary/eo -gsed=$(if $(shell which gsed),gsed,sed) +gsed=\((if \)(shell which gsed),gsed,sed) zip: *.tex sections/*.tex rm -rf package @@ -36,12 +36,12 @@ zip: *.tex sections/*.tex cp ../eolang-paper.tex . cp ../phigure.sty . cp ../main.bib . - for p in $(PACKAGES); do cp $(TLROOT)/tex/latex/$${p}/$${p}.sty .; done + for p in \((PACKAGES); do cp \)(TLROOT)/tex/latex/$\({p}/\)${p}.sty .; done cp -r ../sections . - version=$$(curl --silent -H "Accept: application/vnd.github.v3+json" https://api.github.com/repos/$(REPO)/releases/latest | jq -r '.tag_name') + version=$\((curl --silent -H "Accept: application/vnd.github.v3+json" https://api.github.com/repos/\)(REPO)/releases/latest | jq -r '.tag_name') echo "Version is: $${version}" - ${gsed} -i "s|0\.0\.0|$${version}|g" eolang-paper.tex - ${gsed} -i "s|REPOSITORY|$(REPO)|g" eolang-paper.tex + \({gsed} -i "s|0\.0\.0|\)${version}|g" eolang-paper.tex + \({gsed} -i "s|REPOSITORY|\)(REPO)|g" eolang-paper.tex pdflatex -shell-escape -halt-on-error eolang-paper.tex > /dev/null biber eolang-paper pdflatex -halt-on-error eolang-paper.tex > /dev/null diff --git a/paper/eolang-paper.tex b/paper/eolang-paper.tex index bbd0897150..290d8f945c 100644 --- a/paper/eolang-paper.tex +++ b/paper/eolang-paper.tex @@ -79,7 +79,7 @@ \setlength{\footskip}{13.0pt} \acmBooktitle{untitled} -\title{EOLANG and \texorpdfstring{$\varphi$}{phi}-calculus} +\title{EOLANG and \texorpdfstring{\(\varphi\)}{phi}-calculus} \subtitle{% Ver: \texorpdfstring{ @@ -108,7 +108,7 @@ the rendered version is \href{https://github.com/REPOSITORY/releases/tag/0.0.0}{\ff{0.0.0}}.}. However, despite its industrial and academic popularity, OOP is still missing -a formal apparatus similar to $\lambda$-calculus, which functional +a formal apparatus similar to \(\lambda\)-calculus, which functional programming is based on. There were a number of attempts to formalize OOP, but none of them managed to cover all the features available in modern OO programming languages, such as C++ or Java. diff --git a/paper/sections/acks.tex b/paper/sections/acks.tex index 93f76b0869..a9fb42097f 100644 --- a/paper/sections/acks.tex +++ b/paper/sections/acks.tex @@ -8,7 +8,7 @@ \nospell{Ali-Sultan Ki-giz\-ba\-ev}, \nospell{Nikolai Ku\-da\-sov}, \nospell{Alexander Legalov}, - \nospell{Tymur $\lambda$ysenko}, + \nospell{Tymur \(\lambda\)ysenko}, \nospell{Alexandr Naumchev}, \nospell{Alonso A. Ortega}, \nospell{John Page}, diff --git a/paper/sections/complexity.tex b/paper/sections/complexity.tex index 1089f7f2e2..9bc4fd2108 100644 --- a/paper/sections/complexity.tex +++ b/paper/sections/complexity.tex @@ -16,7 +16,7 @@ , % \fi% P\ref{ptn:\r}% - } $\to$ + } \(\to\) } \begin{itemize} diff --git a/paper/sections/features.tex b/paper/sections/features.tex index 285a48abfa..e944cd391a 100644 --- a/paper/sections/features.tex +++ b/paper/sections/features.tex @@ -116,7 +116,7 @@ % All objects in \eolang{} are assigned to some attributes. Objects constructed in the global scope of visibility are assigned to attributes of the -$\Phi$ object of the highest level of abstraction. +\(\Phi\) object of the highest level of abstraction. Newspeak and Eiffel are two programming languages that does not have global scope as well. \feature{no-mutability}{No Mutability} diff --git a/paper/sections/overview.tex b/paper/sections/overview.tex index 30a9ad9390..e2216d116b 100644 --- a/paper/sections/overview.tex +++ b/paper/sections/overview.tex @@ -17,14 +17,14 @@ attributes are specified with arguments. \item An object may \emph{decorate} another object by binding it -to the $\varphi$ attribute of itself. A decorator has its +to the \(\varphi\) attribute of itself. A decorator has its own attributes and bound attributes of its decoratee. -\item A special attribute $\Delta$ may be bound to \emph{data}, +\item A special attribute \(\Delta\) may be bound to \emph{data}, which is a computation platform dependable entity not decomposable any further. \emph{Dataization} is a process of retrieving data from an object, -by taking what the $\Delta$ attribute is bound to. +by taking what the \(\Delta\) attribute is bound to. The dataization of an object at the highest level of composition leads to the execution of a program. \end{itemize} diff --git a/paper/sections/related.tex b/paper/sections/related.tex index a4526c5608..22a1c13db8 100644 --- a/paper/sections/related.tex +++ b/paper/sections/related.tex @@ -5,7 +5,7 @@ by~\citet{gordon1998concurrent} to support concurrency and synchronisation, and by~\citet{jeffrey1999distributed} to support distributed programming. -Earlier, \citet{honda1991object} combined OOP and $\pi$-calculus in order to +Earlier, \citet{honda1991object} combined OOP and \(\pi\)-calculus in order to introduce object calculus for asynchronous communication, which was further referenced by~\citet{jones1993pi} in their work on object-based design notation. diff --git a/paper/sections/semantics.tex b/paper/sections/semantics.tex index 89d5c68fe0..cccbbae6a0 100644 --- a/paper/sections/semantics.tex +++ b/paper/sections/semantics.tex @@ -15,50 +15,50 @@ \subsection{Object Graph}\label{ssec:graph} \begin{figure}[t!] \begin{phigure} - \node[object] (v0) {$\Phi$}; - \node[object] (v2) [below right=0.5cm and 1.8cm of v0] {$v_2$}; + \node[object] (v0) {\(\Phi\)}; + \node[object] (v2) [below right=0.5cm and 1.8cm of v0] {\(v_2\)}; \draw (v0) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v2) node [attr] {\ff{book2}}; - \node[atom] (v1) [below left of=v0] {$v_1$} node[lambda] at (v1.south east) {$M_1$}; + \node[atom] (v1) [below left of=v0] {\(v_1\)} node[lambda] at (v1.south east) {\(M_1\)}; \draw (v0) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (v1) node [attr] {\ff{memory}}; - \draw[ref] (v2) -- (v1) node [attr] {\ff{price}} node [locator] {$\Phi.\ff{memory}$}; - \node[object] (v4) [below left=1.5cm and 0.5cm of v2] {$v_4$}; + \draw[ref] (v2) -- (v1) node [attr] {\ff{price}} node [locator] {\(\Phi.\ff{memory}\)}; + \node[object] (v4) [below left=1.5cm and 0.5cm of v2] {\(v_4\)}; \draw (v2) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (v4) node [attr] {\ff{title}}; - \node[empty] (v3) [below right=1cm and 1cm of v2] {$v_3$}; + \node[empty] (v3) [below right=1cm and 1cm of v2] {\(v_3\)}; \draw (v2) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v3) node [attr] {\ff{isbn}}; - \node[data] (d4) [below left=0.5cm and 1.5cm of v4] {$d_4$}; - \draw (v4) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (d4) node [attr] {$\Delta$}; + \node[data] (d4) [below left=0.5cm and 1.5cm of v4] {\(d_4\)}; + \draw (v4) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (d4) node [attr] {\(\Delta\)}; \node [anchor=south east] at (current bounding box.south east) { \begin{minipage}{15em}\raggedleft - $d_{4} \to \ff{"Object Thinking"}$ + \(d_{4} \to \ff{"Object Thinking"}\) \end{minipage}}; \end{phigure} \figcap{The object graph with a few objects from Eq.~\ref{eq:book2}, where -$d_4$ is \ff{"Object Thinking"} data and $M_1$ is a lambda expression defined +\(d_4\) is \ff{"Object Thinking"} data and \(M_1\) is a lambda expression defined in the runtime.} \label{fig:book2} \end{figure} The vertice at the top of the graph is the ``root'' object (see Def.~\ref{def:locator}), where all other objects that are not anonymous (see Def.~\ref{def:parent}) are bound to. -The vertice $v_2$ is the abstract object \ff{book2}. The name of the object within the -scope of $\Phi$ is the label on the edge from $\Phi$ to $v_2$. The labeled edge -between $v_2$ and $v_3$ makes the object $v_3$ an attribute of $v_2$ with the -identifier \ff{isbn}. Even though the object $v_3$ is $\varnothing$, the graph +The vertice \(v_2\) is the abstract object \ff{book2}. The name of the object within the +scope of \(\Phi\) is the label on the edge from \(\Phi\) to \(v_2\). The labeled edge +between \(v_2\) and \(v_3\) makes the object \(v_3\) an attribute of \(v_2\) with the +identifier \ff{isbn}. Even though the object \(v_3\) is \(\varnothing\), the graph depicts it as any other object. -The rectangle attached to the vertice $v_1$ makes it an atom (see Def.~\ref{def:atom}) -and $M_1$, the content of the rectangle, is its $\lambda$-term. Atoms -are depicted with double-lined circles. The data $d_4$ -attached to the vertice $v_4$ by the named edge $\Delta$ +The rectangle attached to the vertice \(v_1\) makes it an atom (see Def.~\ref{def:atom}) +and \(M_1\), the content of the rectangle, is its \(\lambda\)-term. Atoms +are depicted with double-lined circles. The data \(d_4\) +attached to the vertice \(v_4\) by the named edge \(\Delta\) is the text \ff{"Object Thinking"}. There are six graphical elements that may be present on an object graph: A \emph{circle} with a name inside it is an object. A \emph{named edge} from a circle to another circle is an attribute of the departing object. -A \emph{snake} edge is the $\rho$ attribute. +A \emph{snake} edge is the \(\rho\) attribute. A \emph{dotted} edge connects a copy with the origin. A \emph{double-bordered} circle is an atom. -A \emph{rectangle} attached to a circle contains the $\lambda$-term of the atom. +A \emph{rectangle} attached to a circle contains the \(\lambda\)-term of the atom. \subsection{SODG} @@ -74,102 +74,102 @@ \subsection{SODG} \makeatother \begin{tabbing} \hspace*{2.6cm}\= \kill -$\ff{ADD}(v_1)$ +\(\ff{ADD}(v_1)\) \> - \tabfill{Adds a new vertice $v_1$ to the graph:} + \tabfill{Adds a new vertice \(v_1\) to the graph:} \\ \> \begin{phigure} - \node[object] (v1) {$v_1$}; + \node[object] (v1) {\(v_1\)}; \end{phigure} \\ -$\ff{BIND}(e_1, v_1, v_2, a)$ +\(\ff{BIND}(e_1, v_1, v_2, a)\) \> - \tabfill{Adds a solid uni-directed edge $e_1$ labeled as $a$ from an existing vertice $v_1$ to an existing vertice $v_2$, - making a snake edge if $a$ equals to $\rho$ and adding a reverse snake edge otherwise:} + \tabfill{Adds a solid uni-directed edge \(e_1\) labeled as \(a\) from an existing vertice \(v_1\) to an existing vertice \(v_2\), + making a snake edge if \(a\) equals to \(\rho\) and adding a reverse snake edge otherwise:} \\ \> \begin{phigure} - \node[object] (v1) {$v_1$}; - \node[object, right of=v1] (v2) {$v_2$}; - \draw (v1) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v2) node [attr] {$a$} node [edge-name] {$e_1$}; + \node[object] (v1) {\(v_1\)}; + \node[object, right of=v1] (v2) {\(v_2\)}; + \draw (v1) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v2) node [attr] {\(a\)} node [edge-name] {\(e_1\)}; \end{phigure} \\ -$\ff{DOT}(e_1, m, v_3, e_2)$ +\(\ff{DOT}(e_1, m, v_3, e_2)\) \> - \tabfill{Deletes the edge $e_1$ going from $v_1$ to $v_2$, - adding a new atom vertice $v_3$, - connecting $v_1$ to $v_3$ with an edge $e_2$ labeled the same way as $e_1$, - connecting $v_3$ and $v_2$ with an edge labeled as \ff{t}, + \tabfill{Deletes the edge \(e_1\) going from \(v_1\) to \(v_2\), + adding a new atom vertice \(v_3\), + connecting \(v_1\) to \(v_3\) with an edge \(e_2\) labeled the same way as \(e_1\), + connecting \(v_3\) and \(v_2\) with an edge labeled as \ff{t}, and - attaching a rectangle with a special lambda expression to $v_3$:} + attaching a rectangle with a special lambda expression to \(v_3\):} \\ \> \begin{phigure} - \node[object] (v1) {$v_1$}; - \node[object, right=0.8cm of v1] (v2) {$v_2$}; - \draw (v1) -- (v2) node [attr] {$a$} node [edge-name] {$e_1$}; - \node[object, right=1cm of v2] (v1d) {$v_1$}; + \node[object] (v1) {\(v_1\)}; + \node[object, right=0.8cm of v1] (v2) {\(v_2\)}; + \draw (v1) -- (v2) node [attr] {\(a\)} node [edge-name] {\(e_1\)}; + \node[object, right=1cm of v2] (v1d) {\(v_1\)}; \node[transforms, right=0.3cm of v2] {}; - \node[object, right=0.5cm of v1d] (v2d) {$v_2$}; - \node[atom, below=0.8cm of v1d] (v3) {$v_3$} - node[lambda] at (v3.south east) {$\mathbb{R}(\xi.\ff{t}, m, s)$}; - \draw (v1d) -- (v3) node [attr] {$a$} node [edge-name] {$e_2$}; + \node[object, right=0.5cm of v1d] (v2d) {\(v_2\)}; + \node[atom, below=0.8cm of v1d] (v3) {\(v_3\)} + node[lambda] at (v3.south east) {\(\mathbb{R}(\xi.\ff{t}, m, s)\)}; + \draw (v1d) -- (v3) node [attr] {\(a\)} node [edge-name] {\(e_2\)}; \draw (v3) -- (v2d) node [attr] {\ff{t}}; \end{phigure} \\ -$\ff{COPY}(e_1, v_3, e_2)$ +\(\ff{COPY}(e_1, v_3, e_2)\) \> - \tabfill{Reconnects the edge $e_1$ going from $v_1$ to $v_2$, - adding a new vertice $v_3$, - connecting $v_1$ and $v_3$ with edge $e_1$, - and connecting $v_3$ and $v_2$ with a new dotted edge $e_2$:} + \tabfill{Reconnects the edge \(e_1\) going from \(v_1\) to \(v_2\), + adding a new vertice \(v_3\), + connecting \(v_1\) and \(v_3\) with edge \(e_1\), + and connecting \(v_3\) and \(v_2\) with a new dotted edge \(e_2\):} \\ \> \begin{phigure} - \node[object] (v1) {$v_1$}; - \node[object, right=0.8cm of v1] (v2) {$v_2$}; - \draw (v1) -- (v2) node [attr] {$a$} node [edge-name] {$e_1$}; - \node[object, right=1cm of v2] (v1d) {$v_1$}; + \node[object] (v1) {\(v_1\)}; + \node[object, right=0.8cm of v1] (v2) {\(v_2\)}; + \draw (v1) -- (v2) node [attr] {\(a\)} node [edge-name] {\(e_1\)}; + \node[object, right=1cm of v2] (v1d) {\(v_1\)}; \node[transforms, right=0.3cm of v2] {}; - \node[object, right=0.7cm of v1d] (v2d) {$v_2$}; - \node[object, below right=0.8cm and 0.2cm of v1d] (v3) {$v_3$}; - \draw (v1d) -- (v3) node [attr] {$a$} node [edge-name] {$e_1$}; - \draw[parent] (v3) -- (v2d) node [edge-name] {$e_2$}; + \node[object, right=0.7cm of v1d] (v2d) {\(v_2\)}; + \node[object, below right=0.8cm and 0.2cm of v1d] (v3) {\(v_3\)}; + \draw (v1d) -- (v3) node [attr] {\(a\)} node [edge-name] {\(e_1\)}; + \draw[parent] (v3) -- (v2d) node [edge-name] {\(e_2\)}; \end{phigure} \\ -$\ff{ATOM}(v_1, M_1)$ +\(\ff{ATOM}(v_1, M_1)\) \> - \tabfill{Attaches a rectangle to an existing vertice $v_1$ with a lambda expression $M_1$ inside - and adds the second border to $v_1$:} + \tabfill{Attaches a rectangle to an existing vertice \(v_1\) with a lambda expression \(M_1\) inside + and adds the second border to \(v_1\):} \\ \> \begin{phigure} - \node[object] (v1) {$v_1$}; + \node[object] (v1) {\(v_1\)}; \node[transforms, right=0.3cm of v1] {}; - \node[atom, right=1cm of v1] (v1d) {$v_1$}; - \node[lambda] at (v1d.south east) {$M_1$}; + \node[atom, right=1cm of v1] (v1d) {\(v_1\)}; + \node[lambda] at (v1d.south east) {\(M_1\)}; \end{phigure} \\ -$\ff{DATA}(v_1, \Gamma)$ +\(\ff{DATA}(v_1, \Gamma)\) \> - \tabfill{Changes the shape of an existing vertice $v_1$ to a polygon and sets its data to $\Gamma$:} + \tabfill{Changes the shape of an existing vertice \(v_1\) to a polygon and sets its data to \(\Gamma\):} \\ \> \begin{phigure} - \node[object] (v1) {$v_1$}; + \node[object] (v1) {\(v_1\)}; \node[transforms, right=0.3cm of v1] {}; - \node[data, right=1cm of v1] (v1d) {$\Gamma$}; + \node[data, right=1cm of v1] (v1d) {\(\Gamma\)}; \end{phigure} \\ -$\ff{REF}(e_1, v_1, k, a)$ +\(\ff{REF}(e_1, v_1, k, a)\) \> - \tabfill{Starting from the vertice $v_1$, - finds a vertice $v_2$ by the locator $k$ - and links them with an edge $e_1$ named as $a$ with a supplementary label $k$ - (omitting the circle around the vertice $v_2$ is a visual - trick that helps avoid a long arrow, which would need to be drawn from $v_1$ to the - found $v_2$ otherwise):} + \tabfill{Starting from the vertice \(v_1\), + finds a vertice \(v_2\) by the locator \(k\) + and links them with an edge \(e_1\) named as \(a\) with a supplementary label \(k\) + (omitting the circle around the vertice \(v_2\) is a visual + trick that helps avoid a long arrow, which would need to be drawn from \(v_1\) to the + found \(v_2\) otherwise):} \\ \> \begin{phigure} - \node[object] (v1) {$v_1$}; - \node[dup, right of=v1] (v2) {$v_2$}; - \draw[ref] (v1) -- (v2) node [attr] {$a$} node [locator] {$k$} node [edge-name] {$e_1$}; + \node[object] (v1) {\(v_1\)}; + \node[dup, right of=v1] (v2) {\(v_2\)}; + \draw[ref] (v1) -- (v2) node [attr] {\(a\)} node [locator] {\(k\)} node [edge-name] {\(e_1\)}; \end{phigure} \\ \end{tabbing} @@ -181,19 +181,19 @@ \subsection{SODG} \begin{twocols} \begin{ffcode} -ADD(|$\Phi$|) -ADD(|$v_1$|); -ATOM(|$v_1$|, |$M_1$|); -BIND(|$\Phi$|, |$v_1$|, memory); -ADD(|$v_2$|); -BIND(|$\Phi$|, |$v_2$|, book2); -ADD(|$v_3$|); -BIND(|$v_2$|, |$v_3$|, isbn); -ADD(|$v_4$|); -BIND(|$v_2$|, |$v_4$|, title); -REF(e, |$v_2$|, |$\Phi$|.memory, price); -ADD(|$d_4$|); -BIND(|$v_4$|, |$d_4$|, |$\Delta$|); +ADD(|\(\Phi\)|) +ADD(|\(v_1\)|); +ATOM(|\(v_1\)|, |\(M_1\)|); +BIND(|\(\Phi\)|, |\(v_1\)|, memory); +ADD(|\(v_2\)|); +BIND(|\(\Phi\)|, |\(v_2\)|, book2); +ADD(|\(v_3\)|); +BIND(|\(v_2\)|, |\(v_3\)|, isbn); +ADD(|\(v_4\)|); +BIND(|\(v_2\)|, |\(v_4\)|, title); +REF(e, |\(v_2\)|, |\(\Phi\)|.memory, price); +ADD(|\(d_4\)|); +BIND(|\(v_4\)|, |\(d_4\)|, |\(\Delta\)|); \end{ffcode} \end{twocols} @@ -213,13 +213,13 @@ \subsection{Transformation Rules} \jrule{abstract} \end{equation*} -The $v|E$ notation at the premise part of the rule -means ``$E$ stands while the focus is at $v$,'' where -$E$ is an expression and $v$ is an element of the graph, for example a vertice or an edge. +The \(v|E\) notation at the premise part of the rule +means ``\(E\) stands while the focus is at \(v\),'' where +\(E\) is an expression and \(v\) is an element of the graph, for example a vertice or an edge. The hierarchical vertice indexing notation is used in order to avoid duplication of indexes. Thus, the index of the vertice -$v_{i\rr x\rr 1}$ is unique on the graph. The symbol ``$\rr$'' is used +\(v_{i\rr x\rr 1}\) is unique on the graph. The symbol ``\(\rr\)'' is used as a delimiter between parts of the index. We decided to use this symbol instead of a more traditional dot because the semantic of the dot is already occupied by the dot notation in \phic{}. @@ -230,9 +230,9 @@ \subsection{Transformation Rules} in order to avoid duplication. Consider for example the abstract object bound to the attribute \ff{is-inside} in Eq.~\ref{eq:c-empty}. -The premise $v_5|E$ will stand when the focus is at the vertice representing the object \ff{circle}, -where $v_5$ would be the vertice of it (the numbers -$5$ and $12$ don't mean anything and are just placeholders): +The premise \(v_5|E\) will stand when the focus is at the vertice representing the object \ff{circle}, +where \(v_5\) would be the vertice of it (the numbers +\(5\) and \(12\) don't mean anything and are just placeholders): \begin{equation*} \dfrac {\quad v_5 | \ohat{x}{\ff{is-inside}}(\ohat{a_1}{\ff{p}}) \mapsto \llbracket \ohat{E}{\varphi \mapsto \dots} \rrbracket} @@ -246,17 +246,17 @@ \subsection{Transformation Rules} on an object graph: \begin{center}\begin{phigure} - \node[object] (v5) {$v_5$}; + \node[object] (v5) {\(v_5\)}; \node[transforms, right=0.3cm of v5] {}; - \node[object, right=1cm of v5] (v5d) {$v_5$}; - \node[object, below right=0.6cm and 1.5cm of v5d] (v12) {$v_{12}$}; + \node[object, right=1cm of v5] (v5d) {\(v_5\)}; + \node[object, below right=0.6cm and 1.5cm of v5d] (v12) {\(v_{12}\)}; \draw (v5d) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v12) node [attr] {\ff{is-inside}}; - \node[object, below left=1cm of v12] (v13) {$v_{13}$}; + \node[object, below left=1cm of v12] (v13) {\(v_{13}\)}; \draw (v12) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v13) node [attr] {\ff{p}}; \end{phigure}\end{center} -The $E$ part of the premise is the internals of the abstract object \ff{is-inside}. -It will be processed by one of the rules, while looking at $v_{12}$. +The \(E\) part of the premise is the internals of the abstract object \ff{is-inside}. +It will be processed by one of the rules, while looking at \(v_{12}\). \rrule{comma} explains how a comma-separated series of expressions break into individual rules (since the expression inside \ff{is-inside} is the only one, this rule is not applicable): @@ -276,21 +276,21 @@ \subsection{Transformation Rules} {\ff{REF}(e_{i\rr a}, v_i,x,a) \quad v_i|x \quad e_{i\rr a}|E} \jrule{attribute} \end{equation*} -The notation ``$x \; E$'' in the premise of \rrule{attribute} splits the expression +The notation ``\(x \; E\)'' in the premise of \rrule{attribute} splits the expression under consideration into two parts: the ``head'' of a single identifier -$x$ and the ``tail'' of the expression as $E$. -In the conclusion part of the rule a vertice is found using the locator $x$ +\(x\) and the ``tail'' of the expression as \(E\). +In the conclusion part of the rule a vertice is found using the locator \(x\) and then a new edge is added, starting from the current vertice and arriving -to the vertice found. Strictly, $x$ must be a single identifier. However, +to the vertice found. Strictly, \(x\) must be a single identifier. However, in a more relaxed mode it is possible to have a longer locator as the head -of the expression. For example, the expression $\rho.\rho.\ff{p}$ can be split -strictly on $\rho$ as the head and $\rho.\ff{p}$ as the tail; but it -also can be split on $\rho.\rho$ as the head and $\ff{p}$ as the tail. Longer +of the expression. For example, the expression \(\rho.\rho.\ff{p}\) can be split +strictly on \(\rho\) as the head and \(\rho.\ff{p}\) as the tail; but it +also can be split on \(\rho.\rho\) as the head and \(\ff{p}\) as the tail. Longer locators in the head part of the expression are only allowed if the vertice they refer to already exists on the graph. -\rrule{attribute} also processes $x$ in the conclusion part, +\rrule{attribute} also processes \(x\) in the conclusion part, providing other rules the opportunity to deal with it. -In particular, \rrule{data} may process $x$ if it is data. +In particular, \rrule{data} may process \(x\) if it is data. The tranformation of the internals of \ff{is-inside} with \rrule{attribute} would look like the following: @@ -299,25 +299,25 @@ \subsection{Transformation Rules} {v_{12} | \ohat{a}{\varphi} \mapsto \ohat{x}{\rho} \; \ohat{E}{.\ff{distance}(\ff{p}).\ff{lte}(\ff{radius})}} {\ff{REF}(e_{14}, v_{12},v_{5},\varphi) \quad e_{14}|.\ff{distance}(\ff{p}).\ff{lte}(\ff{radius})} \end{equation*} -Here $\rho$ represents the $x$ part of the premise and the expression -that starts with a dot represents the $E$ part. At the conclusion, -$x$ is being replaced with $v_5$, because $\rho$ from the vertice $v_{12}$ points -to it: it is the parent object of $v_{12}$. The edge $e_{14}$ created by the \ff{REF} +Here \(\rho\) represents the \(x\) part of the premise and the expression +that starts with a dot represents the \(E\) part. At the conclusion, +\(x\) is being replaced with \(v_5\), because \(\rho\) from the vertice \(v_{12}\) points +to it: it is the parent object of \(v_{12}\). The edge \(e_{14}\) created by the \ff{REF} is used in the expression that finishes the conclusion, triggering the processing -of the tail part of the formula: the head is the $\rho$, while the tail +of the tail part of the formula: the head is the \(\rho\), while the tail is the dot and everything that goes after it. Visually, the execution of \rrule{attribute} would produce the following -changes on the object graph (the vertice $v_{13}$ is not shown for the sake of brevity): +changes on the object graph (the vertice \(v_{13}\) is not shown for the sake of brevity): \begin{center}\begin{phigure} - \node[object] (v5) {$v_5$}; - \node[object, below right=1cm and 1.1cm of v5] (v12) {$v_{12}$}; + \node[object] (v5) {\(v_5\)}; + \node[object, below right=1cm and 1.1cm of v5] (v12) {\(v_{12}\)}; \draw (v5) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v12) node [attr] {\ff{is-inside}}; \node[transforms, right=1.4cm of v5] {}; - \node[object, right=2.4cm of v5] (v5d) {$v_5$}; - \node[object, below right=1cm and 1.1cm of v5d] (v12d) {$v_{12}$}; + \node[object, right=2.4cm of v5] (v5d) {\(v_5\)}; + \node[object, below right=1cm and 1.1cm of v5d] (v12d) {\(v_{12}\)}; \draw (v5d) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v12d) node [attr] {\ff{is-inside}}; - \draw (v12d) edge [bend right=50] node [attr] {$\varphi$} node [edge-name] {$e_{14}$} (v5d); + \draw (v12d) edge [bend right=50] node [attr] {\(\varphi\)} node [edge-name] {\(e_{14}\)} (v5d); \end{phigure}\end{center} The dot notation is resolved by \rrule{dot}, which unlike previously @@ -328,7 +328,7 @@ \subsection{Transformation Rules} {\ff{DOT}(e_i, x, v_{i\rr x}, e_{i\rr x\rr 1}) \quad e_{i\rr x\rr 1}|E} \jrule{dot} \end{equation*} -Here $x$ is the identifier that goes after the dot and $E$ is everything +Here \(x\) is the identifier that goes after the dot and \(E\) is everything else, the tail of the expression. In this example, the instance of the rule would look like this: \begin{equation*} @@ -340,17 +340,17 @@ \subsection{Transformation Rules} modifications on the object graph: \begin{center}\begin{phigure} - \node[object] (v5) {$v_5$}; - \node[object, below right=1cm and 1.1cm of v5] (v12) {$v_{12}$}; + \node[object] (v5) {\(v_5\)}; + \node[object, below right=1cm and 1.1cm of v5] (v12) {\(v_{12}\)}; \draw (v5) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v12) node [attr] {\ff{is-inside}}; - \draw (v12) edge [bend right=50] node [attr] {$\varphi$} node [edge-name] {$e_{14}$} (v5); + \draw (v12) edge [bend right=50] node [attr] {\(\varphi\)} node [edge-name] {\(e_{14}\)} (v5); \node[transforms, right=1.3cm of v5] {}; - \node[object,right=2cm of v5] (v5d) {$v_5$}; - \node[object, below right=1cm and 1.1cm of v5d] (v12d) {$v_{12}$}; + \node[object,right=2cm of v5] (v5d) {\(v_5\)}; + \node[object, below right=1cm and 1.1cm of v5d] (v12d) {\(v_{12}\)}; \draw (v5d) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v12d) node [attr] {\ff{is-inside}}; - \node[atom, above right=1cm and 0cm of v12d] (v15) {$v_{15}$} - node[lambda] at (v15.south east) {$\mathbb{R}(\xi.\ff{t}, \ff{distance}, s)$}; - \draw (v12d) -- (v15) node [attr] {$\varphi$} node [edge-name] {$e_{16}$}; + \node[atom, above right=1cm and 0cm of v12d] (v15) {\(v_{15}\)} + node[lambda] at (v15.south east) {\(\mathbb{R}(\xi.\ff{t}, \ff{distance}, s)\)}; + \draw (v12d) -- (v15) node [attr] {\(\varphi\)} node [edge-name] {\(e_{16}\)}; \draw (v15) -- (v5d) node [attr] {\ff{t}}; \end{phigure}\end{center} @@ -373,22 +373,22 @@ \subsection{Transformation Rules} Visually, this rule would produce the following modifications on the graph: \begin{center}\begin{phigure} - \node[object] (v12) {$v_{12}$}; - \node[atom, above right=1cm and 0cm of v12] (v15) {$v_{15}$} - node[lambda] at (v15.south east) {$M_{15}$}; - \draw (v12) -- (v15) node [attr] {$\varphi$} node [edge-name] {$e_{16}$}; + \node[object] (v12) {\(v_{12}\)}; + \node[atom, above right=1cm and 0cm of v12] (v15) {\(v_{15}\)} + node[lambda] at (v15.south east) {\(M_{15}\)}; + \draw (v12) -- (v15) node [attr] {\(\varphi\)} node [edge-name] {\(e_{16}\)}; \node[transforms, right=1cm of v15] {}; - \node[object, right=2cm of v12] (v12d) {$v_{12}$}; - \node[atom, above right=1cm and 0cm of v12d] (v15d) {$v_{15}$} - node[lambda] at (v15d.south east) {$M_{15}$}; - \draw (v12) -- (v15) node [attr] {$\varphi$} node [edge-name] {$e_{16}$}; - \node[object, above right=0cm and 1.5cm of v12d] (v17) {$v_{17}$}; - \draw (v12d) -- (v17) node [attr] {$\varphi$} node [edge-name] {$e_{16}$}; - \draw[parent] (v17) edge [bend right=30] node [edge-name] {$e_{18}$} (v15d); + \node[object, right=2cm of v12] (v12d) {\(v_{12}\)}; + \node[atom, above right=1cm and 0cm of v12d] (v15d) {\(v_{15}\)} + node[lambda] at (v15d.south east) {\(M_{15}\)}; + \draw (v12) -- (v15) node [attr] {\(\varphi\)} node [edge-name] {\(e_{16}\)}; + \node[object, above right=0cm and 1.5cm of v12d] (v17) {\(v_{17}\)}; + \draw (v12d) -- (v17) node [attr] {\(\varphi\)} node [edge-name] {\(e_{16}\)}; + \draw[parent] (v17) edge [bend right=30] node [edge-name] {\(e_{18}\)} (v15d); \end{phigure}\end{center} The last rule deals with data, such as integers, string literals, and so on -(together referred to as $\Gamma$): +(together referred to as \(\Gamma\)): \begin{equation*} \dfrac {v_i | \Gamma} @@ -408,13 +408,13 @@ \subsection{Transformation Rules} for Eq.~\ref{def:stdout}: \begin{center}\begin{phigure} - \node[object] (phi) {$\Phi$}; - \node[object, below right=1cm of phi] (v1) {$v_{1}$}; + \node[object] (phi) {\(\Phi\)}; + \node[object, below right=1cm of phi] (v1) {\(v_{1}\)}; \draw (phi) -- (v1) node [attr] {\ff{stdout}}; \node[transforms, right=1cm of phi] {}; - \node[object, right=2cm of phi] (phi-d) {$\Phi$}; - \node[atom, below right=1cm of phi-d] (v1d) {$v_{1}$} - node[lambda] at (v1d.south east) {$M_\text{stdout}$}; + \node[object, right=2cm of phi] (phi-d) {\(\Phi\)}; + \node[atom, below right=1cm of phi-d] (v1d) {\(v_{1}\)} + node[lambda] at (v1d.south east) {\(M_\text{stdout}\)}; \draw (phi-d) -- (v1d) node [attr] {\ff{stdout}}; \end{phigure}\end{center} @@ -433,194 +433,194 @@ \subsection{Dataization} it knows how to calculate it. Once being asked to turn itself into data it will ask all its three inner object the same question: ``What data you represent?'' They are integers and will return the -data they have attached to their attributes $\Delta$. Then, the object -\ff{sum}, using its $\lambda$-term, will calculate the arithmetic +data they have attached to their attributes \(\Delta\). Then, the object +\ff{sum}, using its \(\lambda\)-term, will calculate the arithmetic sum of the numbers returned by its inner objects. Visually, the object \ff{sum} from \lref{sum-instance} may be represented by the following object graph: \begin{center}\begin{phigure} - \node[object] (v0) {$\Phi$}; - \node[atom, below right=1cm of v0] (v1) {$v_{1}$} - node[lambda] at (v1.south east) {$\sum a_i$}; + \node[object] (v0) {\(\Phi\)}; + \node[atom, below right=1cm of v0] (v1) {\(v_{1}\)} + node[lambda] at (v1.south east) {\(\sum a_i\)}; \draw (v0) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v1) node [attr] {\ff{sum}}; - \node[object, above right=1.2cm and 2.8cm of v1] (v2) {$v_{2}$}; + \node[object, above right=1.2cm and 2.8cm of v1] (v2) {\(v_{2}\)}; \draw[parent] (v2) edge [bend right=30] (v1); - \node[object, below left=1cm of v2] (v3) {$v_{3}$}; - \draw (v2) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (v3) node [attr] {$a_1$}; + \node[object, below left=1cm of v2] (v3) {\(v_{3}\)}; + \draw (v2) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (v3) node [attr] {\(a_1\)}; \node[data, below=0.7cm of v3] (d3) {\ff{8}}; - \draw (v3) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (d3) node [attr] {$\Delta$}; - \node[object, below=1cm of v2] (v4) {$v_{4}$}; - \draw (v2) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v4) node [attr] {$a_2$}; + \draw (v3) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (d3) node [attr] {\(\Delta\)}; + \node[object, below=1cm of v2] (v4) {\(v_{4}\)}; + \draw (v2) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v4) node [attr] {\(a_2\)}; \node[data, below=0.7cm of v4] (d4) {\ff{13}}; - \draw (v4) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (d4) node [attr] {$\Delta$}; - \node[object, below right=1cm of v2] (v5) {$v_{5}$}; - \draw (v2) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v5) node [attr] {$a_3$}; + \draw (v4) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (d4) node [attr] {\(\Delta\)}; + \node[object, below right=1cm of v2] (v5) {\(v_{5}\)}; + \draw (v2) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v5) node [attr] {\(a_3\)}; \node[data, below=0.7cm of v5] (d5) {\ff{-9}}; - \draw (v5) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (d5) node [attr] {$\Delta$}; + \draw (v5) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (d5) node [attr] {\(\Delta\)}; \end{phigure}\end{center} -The dataization of $v_2$, which is an anonymous copy of \ff{sum} with -three arguments $v_3$, $v_4$, and $v_5$, would produce an arithmetic -sum of three integers calculated by the $\lambda$-term of $v_1$. +The dataization of \(v_2\), which is an anonymous copy of \ff{sum} with +three arguments \(v_3\), \(v_4\), and \(v_5\), would produce an arithmetic +sum of three integers calculated by the \(\lambda\)-term of \(v_1\). We suggest the following recursive object discovery -algorithm, which finds a vertice in a graph by its locator $k$ and -returns a vertice connected to it as an attribute $a$: +algorithm, which finds a vertice in a graph by its locator \(k\) and +returns a vertice connected to it as an attribute \(a\): \begin{twocols} \begin{algo} -\kw{function} $\mathbb{R}(k,a,S)$ \\ - \tab $v \gets k$ \\ - \tab \kw{if} $k$ is a locator with a dot inside \\ - \tab\tab $a' \gets$ after the last dot in $k$ \\ - \tab\tab $k' \gets$ before $a'$ in $k$ \\ - \tab\tab $v \gets$ $\mathbb{R}(k', a', S)$ \\ +\kw{function} \(\mathbb{R}(k,a,S)\) \\ + \tab \(v \gets k\) \\ + \tab \kw{if} \(k\) is a locator with a dot inside \\ + \tab\tab \(a' \gets\) after the last dot in \(k\) \\ + \tab\tab \(k' \gets\) before \(a'\) in \(k\) \\ + \tab\tab \(v \gets\) \(\mathbb{R}(k', a', S)\) \\ \tab \kw{end if} \\ - \tab \kw{if} $v = \xi$ \kw{then} $v \gets S[0]$ \\ - \tab \kw{if} $v = \rho$ \kw{then} $v \gets S[1]$ \\ - \tab \kw{if} $v$ has $a$-edge to $\tau$ \kw{then} \kw{return} $\tau$ \\ - \tab \kw{if} $v$ has $\varphi$-edge to $\tau$ \kw{then} \kw{return} $\mathbb{R}(\tau, a, \tau + S)$ \\ - \tab \kw{if} $v$ has a dotted edge to $\tau$ \kw{then} \kw{return} $\mathbb{R}(\tau, \xi.a, \tau + S)$ \\ - \tab \kw{if} $v$ has $M$ \kw{then} \kw{return} $\mathbb{R}((\lambda s.M \; v + S), a, S)$ \\ - \tab \kw{return} $\perp$ \\ + \tab \kw{if} \(v = \xi\) \kw{then} \(v \gets S[0]\) \\ + \tab \kw{if} \(v = \rho\) \kw{then} \(v \gets S[1]\) \\ + \tab \kw{if} \(v\) has \(a\)-edge to \(\tau\) \kw{then} \kw{return} \(\tau\) \\ + \tab \kw{if} \(v\) has \(\varphi\)-edge to \(\tau\) \kw{then} \kw{return} \(\mathbb{R}(\tau, a, \tau + S)\) \\ + \tab \kw{if} \(v\) has a dotted edge to \(\tau\) \kw{then} \kw{return} \(\mathbb{R}(\tau, \xi.a, \tau + S)\) \\ + \tab \kw{if} \(v\) has \(M\) \kw{then} \kw{return} \(\mathbb{R}((\lambda s.M \; v + S), a, S)\) \\ + \tab \kw{return} \(\perp\) \\ \kw{end} \end{algo} \end{twocols} -Here, $S$ is a vector of vertices, while $v+S$ produces a new vector -where $v$ stays at the first position and all other elements of $S$ follow. -The notation $S[i]$ denotes the $i$-th element of the vector, while +Here, \(S\) is a vector of vertices, while \(v+S\) produces a new vector +where \(v\) stays at the first position and all other elements of \(S\) follow. +The notation \(S[i]\) denotes the \(i\)-th element of the vector, while counting starts with zero. -The notation $(\lambda s.M \; v + S)$ means creating a function from -the $\lambda$-term $M$ with one parameter $s$ and then calculating -it with the argument $v + S$. +The notation \((\lambda s.M \; v + S)\) means creating a function from +the \(\lambda\)-term \(M\) with one parameter \(s\) and then calculating +it with the argument \(v + S\). It is expected that the function returns a locator of a vertice or the vertice itself, where the locator can be derived as -the shortest path from $\Phi$ to the given vertice. -The vector $s$, provided to the -function as its parameter, is used in $M$ when it is necessary -to use $\mathbb{R}$ in order to find some object. +the shortest path from \(\Phi\) to the given vertice. +The vector \(s\), provided to the +function as its parameter, is used in \(M\) when it is necessary +to use \(\mathbb{R}\) in order to find some object. If a function returns data, which doesn't have a locator, a new vertice -$v_i$ is created implicitly with the locator $\Phi.v_i$, and -a single attribute $\Delta$ connected to the data returned, where -$i$ is the next available index in the graph. +\(v_i\) is created implicitly with the locator \(\Phi.v_i\), and +a single attribute \(\Delta\) connected to the data returned, where +\(i\) is the next available index in the graph. For example, $\mathbb{R}(\Phi.\ff{c}.\ff{center}.\ff{y}, \Delta, \varnothing)$ being executed on the graph presented at the -Fig.~\ref{fig:is} would return the vertice $d_{21}$, which is $+9$. +Fig.~\ref{fig:is} would return the vertice \(d_{21}\), which is \(+9\). We also define a dataization function, which turns an object into data: \begin{algo} -\kw{function} $\mathbb{D}(k)$ \\ - \tab \kw{return} $\mathbb{R}(k, \Delta, \varnothing)$ \\ +\kw{function} \(\mathbb{D}(k)\) \\ + \tab \kw{return} \(\mathbb{R}(k, \Delta, \varnothing)\) \\ \kw{end} \end{algo} -The execution of the function $\mathbb{D}(x)$, where $x$ is the +The execution of the function \(\mathbb{D}(x)\), where \(x\) is the ``program'' object, leads to the execution of the entire program. -Program terminates with an error message when $\mathbb{D}(x)$ is $\perp$. +Program terminates with an error message when \(\mathbb{D}(x)\) is \(\perp\). \begin{figure*} \resizebox{.75\textwidth}{!}{ \begin{phigure} - \node[object] (v0) {$\Phi$}; - \node[object] (v1) [right of=v0] {$v_1$}; + \node[object] (v0) {\(\Phi\)}; + \node[object] (v1) [right of=v0] {\(v_1\)}; \draw (v0) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v1) node [attr] {\ff{circle}}; - \node[object] (v2) [below of=v1] {$v_2$}; + \node[object] (v2) [below of=v1] {\(v_2\)}; \draw (v1) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v2) node [attr] {\ff{center}}; - \node[object] (v3) [below left of=v1] {$v_3$}; + \node[object] (v3) [below left of=v1] {\(v_3\)}; \draw (v1) -- pic[sloped,rho,auto,swap]{parallel arrow={-0.3,-0.15}} (v3) node [attr] {\ff{radius}}; - \node[object] (v4) [below right of=v1] {$v_4$}; + \node[object] (v4) [below right of=v1] {\(v_4\)}; \draw (v1) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v4) node [attr] {\ff{is-inside}}; - \node[object] (v6) [below right=1cm of v4] {$v_6$}; + \node[object] (v6) [below right=1cm of v4] {\(v_6\)}; \draw (v4) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v6) node [attr] {\ff{p}}; - \node[dup] (v2d1) [right=2.1cm of v1] {$v_2$}; - \draw[ref] (v1) -- (v2d1) node [attr] {$\varphi$} node [locator] {$\xi.\ff{center}$}; - \node[atom] (v5) [above right=0.5cm and 3cm of v4] {$v_5$} - node[lambda] at (v5.south east) {$M_5$}; - \node[dup] (v4d1) [above left=0.5cm of v5] {$v_4$}; + \node[dup] (v2d1) [right=2.1cm of v1] {\(v_2\)}; + \draw[ref] (v1) -- (v2d1) node [attr] {\(\varphi\)} node [locator] {\(\xi.\ff{center}\)}; + \node[atom] (v5) [above right=0.5cm and 3cm of v4] {\(v_5\)} + node[lambda] at (v5.south east) {\(M_5\)}; + \node[dup] (v4d1) [above left=0.5cm of v5] {\(v_4\)}; \draw[rho] (v5) -- (v4d1); - \node[object] (v25) [below=0.6cm of v5] {$v_{25}$}; + \node[object] (v25) [below=0.6cm of v5] {\(v_{25}\)}; \draw[parent] (v25) -- (v5); - \draw (v4) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v25) node [attr] {$\varphi$}; - \node[dup] (v3d1) [below=1.5cm of v25] {$v_3$}; - \draw[ref] (v25) -- (v3d1) node [attr] {\ff{other}} node [locator] {$\rho.\rho.\ff{radius}$}; - \node[atom] (v7) [right=2cm of v5] {$v_7$} - node[lambda] at (v7.south east) {$M_7$}; - \node[dup] (v5d1) [above left=0.5cm of v7] {$v_5$}; + \draw (v4) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v25) node [attr] {\(\varphi\)}; + \node[dup] (v3d1) [below=1.5cm of v25] {\(v_3\)}; + \draw[ref] (v25) -- (v3d1) node [attr] {\ff{other}} node [locator] {\(\rho.\rho.\ff{radius}\)}; + \node[atom] (v7) [right=2cm of v5] {\(v_7\)} + node[lambda] at (v7.south east) {\(M_7\)}; + \node[dup] (v5d1) [above left=0.5cm of v7] {\(v_5\)}; \draw[rho] (v7) -- (v5d1); - \node[object] (v24) [below=0.6cm of v7] {$v_{24}$}; + \node[object] (v24) [below=0.6cm of v7] {\(v_{24}\)}; \draw[parent] (v24) -- (v7); \draw (v5) edge[bend left=30] node [attr] {\ff{t}} pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v24); - \node[dup] (v6d1) [below=1cm of v24] {$v_6$}; - \draw[ref] (v24) -- (v6d1) node [attr] {\ff{to}} node [locator] {$\rho.\rho.\ff{p}$}; - \node[dup] (v2d1) [right=1.8cm of v7] {$v_2$}; - \draw[ref] (v7) -- (v2d1) node [attr] {\ff{t}} node [locator] {$\rho.\rho.\rho.\varphi$}; + \node[dup] (v6d1) [below=1cm of v24] {\(v_6\)}; + \draw[ref] (v24) -- (v6d1) node [attr] {\ff{to}} node [locator] {\(\rho.\rho.\ff{p}\)}; + \node[dup] (v2d1) [right=1.8cm of v7] {\(v_2\)}; + \draw[ref] (v7) -- (v2d1) node [attr] {\ff{t}} node [locator] {\(\rho.\rho.\rho.\varphi\)}; - \node[object] (v15) [below=0.6cm of v2] {$v_{15}$}; - \node[dup] (v0d1) [left=1cm of v15] {$\Phi$}; + \node[object] (v15) [below=0.6cm of v2] {\(v_{15}\)}; + \node[dup] (v0d1) [left=1cm of v15] {\(\Phi\)}; \draw (v0d1) -- (v15) node [attr] {\ff{point}}; - \node[object] (v16) [below left=1cm of v15] {$v_{16}$}; + \node[object] (v16) [below left=1cm of v15] {\(v_{16}\)}; \draw (v15) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (v16) node [attr] {\ff{x}}; - \node[object] (v17) [below right=1cm of v15] {$v_{17}$}; + \node[object] (v17) [below right=1cm of v15] {\(v_{17}\)}; \draw (v15) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v17) node [attr] {\ff{y}}; - \node[atom] (v14) [below=2cm of v15] {$v_{14}$} node[lambda] at (v14.south east) {$M_{14}$}; + \node[atom] (v14) [below=2cm of v15] {\(v_{14}\)} node[lambda] at (v14.south east) {\(M_{14}\)}; \draw (v15) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v14) node [attr] {\ff{distance}}; - \node[object] (v18) [left=1cm of v14] {$v_{18}$}; + \node[object] (v18) [left=1cm of v14] {\(v_{18}\)}; \draw (v14) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (v18) node [attr] {\ff{to}}; - \node[object] (v10) [below right=1cm and 5cm of v15] {$v_{10}$}; - \node[dup] (v0d2) [left=1cm of v10] {$\Phi$}; + \node[object] (v10) [below right=1cm and 5cm of v15] {\(v_{10}\)}; + \node[dup] (v0d2) [left=1cm of v10] {\(\Phi\)}; \draw (v0d2) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v10) node [attr] {\ff{c}}; - \node[dup] (v1d1) [above right=0.8cm of v10] {$v_{1}$}; + \node[dup] (v1d1) [above right=0.8cm of v10] {\(v_{1}\)}; \draw[parent] (v10) -- (v1d1); - \node[object] (v19) [below left=1.5cm of v10] {$v_{19}$}; + \node[object] (v19) [below left=1.5cm of v10] {\(v_{19}\)}; \draw (v10) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (v19) node [attr] {\ff{radius}}; \node[data] (d19) [below left=1cm of v19] {\texttt{+40}}; - \draw (v19) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (d19) node [attr] {$\Delta$}; - \node[object] (v11) [below right=2cm and 0.5cm of v10] {$v_{11}$}; + \draw (v19) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (d19) node [attr] {\(\Delta\)}; + \node[object] (v11) [below right=2cm and 0.5cm of v10] {\(v_{11}\)}; \draw (v10) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v11) node [attr] {\ff{center}}; - \node[dup] (v15d1) [left=1cm of v11] {$v_{15}$}; + \node[dup] (v15d1) [left=1cm of v11] {\(v_{15}\)}; \draw[parent] (v11) -- (v15d1); - \node[object] (v20) [below left=1cm of v11] {$v_{20}$}; + \node[object] (v20) [below left=1cm of v11] {\(v_{20}\)}; \draw (v11) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (v20) node [attr] {\ff{x}}; \node[data] (d20) [below=1cm of v20] {\texttt{-3}}; - \draw (v20) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (d20) node [attr] {$\Delta$}; - \node[object] (v21) [below right=1cm of v11] {$v_{21}$}; + \draw (v20) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (d20) node [attr] {\(\Delta\)}; + \node[object] (v21) [below right=1cm of v11] {\(v_{21}\)}; \draw (v11) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v21) node [attr] {\ff{y}}; \node[data] (d21) [below=1cm of v21] {\texttt{+9}}; - \draw (v21) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (d21) node [attr] {$\Delta$}; + \draw (v21) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (d21) node [attr] {\(\Delta\)}; - \node[object] (v12) [above right=0.2cm and 4cm of v10] {$v_{12}$}; - \node[dup] (v0d3) [left=1cm of v12] {$\Phi$}; + \node[object] (v12) [above right=0.2cm and 4cm of v10] {\(v_{12}\)}; + \node[dup] (v0d3) [left=1cm of v12] {\(\Phi\)}; \draw (v0d3) -- (v12) node [attr] {\ff{is}}; - \node[dup] (v1d2) [above left=0.8cm of v12] {$v_{1}$}; + \node[dup] (v1d2) [above left=0.8cm of v12] {\(v_{1}\)}; \draw[parent] (v12) -- (v1d2); - \node[dup] (v10d2) [right=1cm of v12] {$v_{10}$}; + \node[dup] (v10d2) [right=1cm of v12] {\(v_{10}\)}; \draw[rho] (v12) -- (v10d2); - \node[object] (v13) [below right=1cm and 0.5cm of v12] {$v_{13}$}; + \node[object] (v13) [below right=1cm and 0.5cm of v12] {\(v_{13}\)}; \draw (v12) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v13) node [attr] {\ff{p}}; - \node[dup] (v15d2) [left=1cm of v13] {$v_{15}$}; + \node[dup] (v15d2) [left=1cm of v13] {\(v_{15}\)}; \draw[parent] (v13) -- (v15d2); - \node[object] (v22) [below left=1cm of v13] {$v_{22}$}; + \node[object] (v22) [below left=1cm of v13] {\(v_{22}\)}; \draw (v13) -- pic[sloped,rho]{parallel arrow={-0.3,-0.15}} (v22) node [attr] {\ff{x}}; \node[data] (d22) [below=1cm of v22] {\texttt{+1}}; - \draw (v22) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (d22) node [attr] {$\Delta$}; - \node[object] (v23) [below right=1cm of v13] {$v_{23}$}; + \draw (v22) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (d22) node [attr] {\(\Delta\)}; + \node[object] (v23) [below right=1cm of v13] {\(v_{23}\)}; \draw (v13) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (v23) node [attr] {\ff{y}}; \node[data] (d23) [below=1cm of v23] {\texttt{+7}}; - \draw (v23) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (d23) node [attr] {$\Delta$}; + \draw (v23) -- pic[sloped,rho]{parallel arrow={0.3,-0.15}} (d23) node [attr] {\(\Delta\)}; \node [anchor=south west] at (current bounding box.south west) { \begin{minipage}{25em}\raggedright - $M_{14} \to \sqrt{\begin{matrix*}[l](\mathbb{R}(\xi.\ff{to}.\ff{x}, \Delta, s)-\mathbb{R}(\rho.\ff{x}, \Delta, s))^2 + \\ + (\mathbb{R}(\xi.\ff{to}.\ff{y}, \Delta, s)-\mathbb{R}(\rho.\ff{y}, \Delta, s))^2\end{matrix*}}$ \\ - $M_5 \to \mathbb{R}(\xi.\ff{t}, \ff{lte}, s)$ \\ - $M_7 \to \mathbb{R}(\xi.\ff{t}, \ff{distance}, s)$ \\ + \(M_{14} \to \sqrt{\begin{matrix*}[l](\mathbb{R}(\xi.\ff{to}.\ff{x}, \Delta, s)-\mathbb{R}(\rho.\ff{x}, \Delta, s))^2 + \\ + (\mathbb{R}(\xi.\ff{to}.\ff{y}, \Delta, s)-\mathbb{R}(\rho.\ff{y}, \Delta, s))^2\end{matrix*}}\) \\ + \(M_5 \to \mathbb{R}(\xi.\ff{t}, \ff{lte}, s)\) \\ + \(M_7 \to \mathbb{R}(\xi.\ff{t}, \ff{distance}, s)\) \\ \end{minipage}}; \end{phigure}} \figcap{The graph of the object \ff{is} from Eq.~\ref{eq:is}.} diff --git a/paper/sections/syntax.tex b/paper/sections/syntax.tex index ba412173be..4cd1dd5f96 100644 --- a/paper/sections/syntax.tex +++ b/paper/sections/syntax.tex @@ -102,7 +102,7 @@ \subsection{Identity, State, and Behavior} which has a single \emph{identity} attribute \ff{isbn}: \begin{ffcode} -[isbn] > book |$\label{ln:book}$| +[isbn] > book |\(\label{ln:book}\)| \end{ffcode} To make a new object with a specific ISBN, the \ff{book} @@ -119,9 +119,9 @@ \subsection{Identity, State, and Behavior} look like: \begin{ffcode} -[isbn] > book2 |$\label{ln:book2}$| +[isbn] > book2 |\(\label{ln:book2}\)| "Object Thinking" > title - memory 0 > price |$\label{ln:book2-end}$| + memory 0 > price |\(\label{ln:book2-end}\)| \end{ffcode} The attribute \ff{title} is a constant, while the \ff{price} @@ -136,11 +136,11 @@ \subsection{Identity, State, and Behavior} abstract object \ff{set-price}: \begin{ffcode} -[isbn] > book3 |$\label{ln:book3}$| +[isbn] > book3 |\(\label{ln:book3}\)| "Object Thinking" > title memory 0 > price [p] > set-price - ^.price.write p > @ |$\label{ln:book3-end}$| + ^.price.write p > @ |\(\label{ln:book3-end}\)| \end{ffcode} The price of the book may be changed with this one-liner: @@ -158,12 +158,12 @@ \subsection{Indentation} second line and the \ff{>} symbol, while two spaces will break the syntax): {\lstset{showspaces=true}\begin{ffcode} -# This is a vector in 2D space |$\label{ln:comment}$| -[dx dy] > vector |$\label{ln:vector}$| - sqrt. > length |$\label{ln:length}$| +# This is a vector in 2D space |\(\label{ln:comment}\)| +[dx dy] > vector |\(\label{ln:vector}\)| + sqrt. > length |\(\label{ln:length}\)| plus. dx.times dx - dy.timex dy |$\label{ln:length-end}$| |$\label{ln:vector-end}$| + dy.timex dy |\(\label{ln:length-end}\)| |\(\label{ln:vector-end}\)| \end{ffcode} } @@ -190,10 +190,10 @@ \subsection{Indentation} inverse notation, but it will look less readable: \begin{ffcode} -dx.times dx |$\label{ln:dx-pow}$| +dx.times dx |\(\label{ln:dx-pow}\)| .plus - dy.timex dy |$\label{ln:dx-pow-2}$| -.sqrt > length |$\label{ln:dx-pow-3}$| + dy.timex dy |\(\label{ln:dx-pow-2}\)| +.sqrt > length |\(\label{ln:dx-pow-3}\)| \end{ffcode} Here, \lref{dx-pow} is the application of the object \ff{dx.times} with @@ -223,11 +223,11 @@ \subsection{Indentation} in a \emph{vertical} mode, where indentation will be required: \begin{ffcode} -[x] |$\label{ln:succ}$| +[x] |\(\label{ln:succ}\)| x.plus > succ 1 x.minus > prev - 1 |$\label{ln:succ-end}$| + 1 |\(\label{ln:succ-end}\)| \end{ffcode} This abstract object can also be written in a horizontal mode, @@ -283,13 +283,13 @@ \subsection{Data Objects and Tuples} data format explained in Sec.~\ref{sec:xmir}): \begin{ffcode} - |$\label{ln:xml-circle}$| + |\(\label{ln:xml-circle}\)| - |$\label{ln:xml-circle-r}$| + |\(\label{ln:xml-circle-r}\)| 3.14 - |$\label{ln:xml-circle-end}$| + |\(\label{ln:xml-circle-end}\)| \end{ffcode} Each object, if it is not abstract, has a ``base'' attribute in XML, @@ -327,11 +327,11 @@ \subsection{Data Objects and Tuples} which looks similar to object copying: \begin{ffcode} -* "Lucy" "Jeff" 3.14 |$\label{ln:tuple-1}$| -* > a |$\label{ln:tuple-2a}$| +* "Lucy" "Jeff" 3.14 |\(\label{ln:tuple-1}\)| +* > a |\(\label{ln:tuple-2a}\)| (* "a") - TRUE |$\label{ln:tuple-2b}$| -* > b |$\label{ln:tuple-3}$| + TRUE |\(\label{ln:tuple-2b}\)| +* > b |\(\label{ln:tuple-3}\)| \end{ffcode} The code at \lref{tuple-1} makes a tuple of three elements: two strings @@ -346,8 +346,8 @@ \subsection{Varargs} will be packaged in a tuple by the compiler, for example: \begin{ffcode} -[x...] > sum |$\label{ln:sum-def}$| -sum 8 13 -9 |$\label{ln:sum-instance}$| +[x...] > sum |\(\label{ln:sum-def}\)| +sum 8 13 -9 |\(\label{ln:sum-instance}\)| \end{ffcode} Here, at the first line the abstract object \ff{sum} is defined @@ -370,7 +370,7 @@ \subsection{Scope Brackets} Brackets can be used to group object arguments in horizontal mode: \begin{ffcode} -sum (div 45 5) 10 |$\label{ln:sum}$| +sum (div 45 5) 10 |\(\label{ln:sum}\)| \end{ffcode} The \ff{(div 45 5)} is a copy of the abstract object \ff{div} @@ -393,7 +393,7 @@ \subsection{Inner Objects} # A point on a 2D canvas [x y] > point [to] > distance - length. > len |$\label{ln:vector-length}$| + length. > len |\(\label{ln:vector-length}\)| vector to.x.minus (^.x) to.y.minus (^.y) @@ -407,7 +407,7 @@ \subsection{Inner Objects} a special attribute denoted by the \ff{\^{}} symbol: \begin{ffcode} -distance. |$\label{ln:point-copy}$| +distance. |\(\label{ln:point-copy}\)| point 5:x -3:y @@ -427,12 +427,12 @@ \subsection{Decorators} An object may extend another object by \emph{decorating} it: \begin{ffcode} -[center radius] > circle |$\label{ln:circle}$| - center > @ |$\label{ln:circle-phi}$| +[center radius] > circle |\(\label{ln:circle}\)| + center > @ |\(\label{ln:circle-phi}\)| [p] > is-inside lte. > @ - ^.@.distance $.p |$\label{ln:circle-phi-2}$| - ^.radius |$\label{ln:circle-end}$| + ^.@.distance \(.p |\)\label{ln:circle-phi-2}$| + ^.radius |\(\label{ln:circle-end}\)| \end{ffcode} The object \ff{circle} has a special attribute \ff{@} @@ -464,10 +464,10 @@ \subsection{Decorators} taken from the current object (denoted by the \ff{\$} symbol). The object \ff{circle} may be used like this, to understand whether -the $(0,0)$ point is inside the circle at $(-3,9)$ with the radius $40$: +the \((0,0)\) point is inside the circle at \((-3,9)\) with the radius \(40\): \begin{ffcode} -circle (point -3 9) 40 > c |$\label{ln:circle-c}$| +circle (point -3 9) 40 > c |\(\label{ln:circle-c}\)| c.is-inside (point 0 0) > i \end{ffcode} @@ -627,7 +627,7 @@ \subsection{Atoms} +rt jvm org.eolang:eo-runtime:0.7.0 +rt ruby eolang:0.1.0 -[text] > stdout /bool |$\label{ln:stdout}$| +[text] > stdout /bool |\(\label{ln:stdout}\)| \end{ffcode} The \ff{/bool} suffix informs the compiler that this object must @@ -651,11 +651,11 @@ \subsection{Home Object} how object \ff{tuple.map} is implemented in Objectionary: \begin{ffcode} -[] > list |$\label{ln:list-parent}$| - [f] > mapi /list |$\label{ln:list-map}$| +[] > list |\(\label{ln:list-parent}\)| + [f] > mapi /list |\(\label{ln:list-map}\)| [f] > map ^.mapi > @ - [x i] |$\label{ln:map-inner}$| + [x i] |\(\label{ln:map-inner}\)| &.f x > @ \end{ffcode} From 35b98bdea5e9c1425af38316e5ec544e4ea720ed Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 17:05:00 +0300 Subject: [PATCH 24/80] #2903: simplified --- paper/sections/semantics.tex | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/paper/sections/semantics.tex b/paper/sections/semantics.tex index cccbbae6a0..dbc5273b2a 100644 --- a/paper/sections/semantics.tex +++ b/paper/sections/semantics.tex @@ -509,8 +509,8 @@ \subsection{Dataization} a single attribute \(\Delta\) connected to the data returned, where \(i\) is the next available index in the graph. -For example, $\mathbb{R}(\Phi.\ff{c}.\ff{center}.\ff{y}, -\Delta, \varnothing)$ being executed on the graph presented at the +For example, \(\mathbb{R}(\Phi.\ff{c}.\ff{center}.\ff{y},\Delta, \varnothing)\) +being executed on the graph presented at the Fig.~\ref{fig:is} would return the vertice \(d_{21}\), which is \(+9\). We also define a dataization function, which turns an object into data: From ac2f657c958fdbb765384fd5fc5a9a6681ddcd2f Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 17:23:46 +0300 Subject: [PATCH 25/80] #2903: bnf removed --- paper/eolang-paper.tex | 2 +- paper/sections/acks.tex | 4 ++- paper/sections/calculus.tex | 6 ++-- paper/sections/intro.tex | 6 ++-- paper/sections/overview.tex | 16 ++++----- paper/sections/syntax.tex | 66 ++----------------------------------- 6 files changed, 21 insertions(+), 79 deletions(-) diff --git a/paper/eolang-paper.tex b/paper/eolang-paper.tex index 290d8f945c..39764f3c33 100644 --- a/paper/eolang-paper.tex +++ b/paper/eolang-paper.tex @@ -125,7 +125,7 @@ \section{Introduction} \input{sections/overview} The rest of the paper is dedicated to the discussion of the -syntax of the language we created based on the calculus, +syntax of the language that we created based on the calculus, the calculus itself, its semantics, and pragmatics. In order to make it easier to understand, we start the discussion with the syntax of the language, while the calculus diff --git a/paper/sections/acks.tex b/paper/sections/acks.tex index a9fb42097f..d678a088aa 100644 --- a/paper/sections/acks.tex +++ b/paper/sections/acks.tex @@ -20,9 +20,11 @@ \nospell{Sergei Skliar}, \nospell{Stian Soiland-Reyes}, \nospell{Viacheslav Tradunskyi}, + \nospell{Maxim Trunnikov}, \nospell{Ilya Trub}, \nospell{César Soto Valero}, + \nospell{David West}, and - \nospell{David West} + \nospell{Vladimir Zakharov} for their contribution to the development of \eolang{} and \phic{}. diff --git a/paper/sections/calculus.tex b/paper/sections/calculus.tex index 926d2926c7..f4d85188be 100644 --- a/paper/sections/calculus.tex +++ b/paper/sections/calculus.tex @@ -54,21 +54,21 @@ \subsection{Attributes} \begin{definition}\label{def:attribute} In an object \(x\), \(a\) is a free \textbf{attribute} with the \textbf{name} \(a\) -iff \((a, \varnothing) \in x\); it is a bound attribute +iff \((a, \varnothing) \in x\); it is an attached attribute with the \textbf{value} \(v\) iff \(\exists (a, v)\in x\) and \(v\not=\varnothing\); \end{definition} In Eq.~\ref{eq:book2}, identifiers \ff{isbn}, \ff{title}, and \ff{price} are the attributes of the object \ff{book2}. -The attribute \ff{isbn} is free, while the other two are bound. +The attribute \ff{isbn} is free, while the other two are attached. \begin{definition}\label{def:dot} If \(x\) is an object and \(\exists (a, v) \in x\), then \(v\) may be referenced as \(x.a\); this referencing mechanism is called \textbf{dot notation}. \end{definition} -Both free and bound attributes of an object are accessible using +Both void and attached attributes of an object are accessible using the dot notation. There is no such thing as visibility restriction in \phic{}: all attributes are visible to all objects outside of the one they belong to. diff --git a/paper/sections/intro.tex b/paper/sections/intro.tex index b3bf6c6c2d..47c09ee8f0 100644 --- a/paper/sections/intro.tex +++ b/paper/sections/intro.tex @@ -10,8 +10,8 @@ \subsection{Lack of Formal Model} -The term OOP was coined by~\citet{kay97keynote} in 1966~\citep{kaymaster68} -and since then was never introduced formally. +The term OOP was coined by~\citet{kay97keynote} in 1966 +and since then was never introduced formally~\citep{kaymaster68}. Back in 1982, \citet{rentsch1982object} predicted: ``Everyone will be in a favor of OOP. Every manufacturer will promote his products as supporting it. Every manager will pay lip service to it. Every programmer will practice @@ -107,7 +107,7 @@ \subsection{Solution Proposed} \end{inparaenum} The proposed \phic{} represents an object model through data and objects, while operations with them are possible -through abstraction, application, and decoration. The calculus +through formation, application, and decoration. The calculus introduces a formal apparatus for manipulations with objects. \eolang{}, the proposed programming language, fully implements diff --git a/paper/sections/overview.tex b/paper/sections/overview.tex index e2216d116b..31dd3c5783 100644 --- a/paper/sections/overview.tex +++ b/paper/sections/overview.tex @@ -7,24 +7,24 @@ is an \emph{atom} if its implementation is provided by the runtime. \item An object is \emph{abstract} if at least one of its attributes -is \emph{free}---isn't \emph{bound} to any object. An object +is \emph{void}---isn't \emph{attached} to any object. An object is \emph{closed} otherwise. -\emph{Abstraction} is the process of creating an abstract object. -\emph{Application} is the process of making a \emph{copy} of an abstract -object, specifying some or all of its free attributes with +\emph{Formation} is the process of creating a objects. +\emph{Application} is the process of making a \emph{copy} of existing +object, specifying some or all of its void attributes with objects known as \emph{arguments}. Application may lead to the -creation of a closed object, or an abstract one, if not all free +creation of a closed object, or an abstract one, if not all void attributes are specified with arguments. \item An object may \emph{decorate} another object by binding it to the \(\varphi\) attribute of itself. A decorator has its -own attributes and bound attributes of its decoratee. +own attributes and attached attributes of its decoratee. -\item A special attribute \(\Delta\) may be bound to \emph{data}, +\item A special attribute \(\Delta\) may be attached to \emph{data}, which is a computation platform dependable entity not decomposable any further. \emph{Dataization} is a process of retrieving data from an object, -by taking what the \(\Delta\) attribute is bound to. +by taking what the \(\Delta\) attribute is attached to. The dataization of an object at the highest level of composition leads to the execution of a program. \end{itemize} diff --git a/paper/sections/syntax.tex b/paper/sections/syntax.tex index 4cd1dd5f96..d7874de33e 100644 --- a/paper/sections/syntax.tex +++ b/paper/sections/syntax.tex @@ -1,4 +1,5 @@ -Fig.~\ref{fig:bnf} demonstrates the entire syntax of \eolang{} language in BNF. +The entire syntax of \eolang{} language in BNF is available on the first page of the +\texttt{objectionary/eo} Github repository\footnote{\url{https://github.com/objectionary/eo}}. Similar to Python~\citep{lutz2013learning}, indentation in \eolang{} is part of the syntax: the scope of a code block is determined by its horizontal position in relation to other blocks, which is also known as ``off-side rule''~\citep{landin1966next}. @@ -28,67 +29,6 @@ Identifiers are case-sentitive: \ff{car} and \ff{Car} are two different identifiers. Java-notation is used for numbers and strings. -\newcommand\sntx[1]{{\sffamily #1}} -\begin{figure*} -\raggedright -\small -\setlength\columnsep{24pt} -\newcommand\T[1]{\sntx{#1}} -\newcommand\V[1]{{\ttfamily `#1'}} -\newcommand\RE[1]{{\ttfamily \textcolor{gray}{/}#1\textcolor{gray}{/}}} -\newcommand\alt{ \textcolor{gray}{|} } -\newcommand\grp[1]{\textcolor{gray}{(} #1 \textcolor{gray}{)}} -\newcommand\opt[1]{\textcolor{gray}{[} #1 \textcolor{gray}{]}} -\newcommand\few[1]{\textcolor{gray}{\{} #1 \textcolor{gray}{\}}} -\newcommand\lex[1]{{\scshape\textcolor{darkgray}{#1}}} -\newcommand\df{\>{\ttfamily\textcolor{gray}{::=} }} -\begin{multicols}{2} -\begin{tabbing} -\hspace*{1.6cm}\= \kill - -\T{program} \df \opt{\T{license}} \opt{\T{metas}} \T{objects} \\ -\T{objects} \df \T{object} \lex{eol} \few{\T{object} \lex{eol}} \\ -\T{license} \df \few{\T{comment}} \lex{eol} \\ -\T{metas} \df \few{\T{meta}} \lex{eol} \\ -\T{comment} \df \V{\#} \few{\lex{any}} \lex{eol} \\ -\T{meta} \df \V{+} \T{name} \opt{\V{␣} \lex{any} \few{\lex{any}}} \lex{eol} \\ -\T{name} \df \RE{[a-z]} \few{\lex{any}} \\ -\T{object} \df \grp{ \T{foreign} \alt \T{local} } \\ -\T{foreign} \df \T{abstraction} \V{␣/} \T{name} \alt \V{?} \\ -\T{local} \df \grp{ \T{abstraction} \alt \T{application} } \T{details} \\ -\T{details} \df \opt{\T{tail}} \few{\T{vtail}} \\ -\T{tail} \df \lex{eol} \lex{tab} \few{\T{object} \lex{eol}} \lex{untab} \\ -\T{vtail} \df \lex{eol} \T{ref} \opt{\T{htail}} \opt{\T{suffix}} \opt{\T{tail}} \\ -\T{abstraction} \df \T{attributes} \opt{ \T{suffix} } \\ -\T{attributes} \df \V{[} \T{attribute} \few{\V{␣} \T{attribute}} \V{]} \\ -\T{attribute} \df \V{@} \alt \T{name} \opt{\V{...}} \\ -\T{suffix} \df \V{␣} \V{>} \V{␣} \grp{\V{@} \alt \T{name}} \opt{\V{!}} \\ -\T{ref} \df \V{.} \grp{ \T{name} \alt \V{\^{}} \alt \V{@} \alt \V{<} } \\ -\T{application} \df \T{head} \opt{\T{htail}} \\ -\T{htail} \df \T{application} \T{ref} \\ - \> \alt \V{(} \T{application} \V{)} \\ - \> \alt \T{application} \V{:} \T{name} \\ - \> \alt \T{application} \T{suffix} \\ - \> \alt \T{application} \V{␣} \T{application} \\ -\T{head} \df \opt{\V{...}} \grp{ \T{name} \opt{\V{'}} \alt \T{data} \alt \V{@} \alt \V{\$} \alt \V{\&} \\ - \> \alt \V{\^{}} \alt \V{*} \alt \T{name} \V{.} \alt \V{Q} \alt \V{QQ} } \\ -\T{data} \df \T{bytes} \alt \T{bool} \alt \T{string} \alt \T{integer} \alt \T{float} \\ -\T{bytes} \df \T{byte} \few{\V{-} \T{byte}} \alt \V{-{}-} \\ -\T{bool} \df \V{TRUE} \alt \V{FALSE} \\ -\T{byte} \df \RE{[\textbackslash{}dA-F][\textbackslash{}dA-F]} \\ -\T{string} \df \RE{"[\^{}"]*"} \\ -\T{integer} \df \RE{[+-]?\textbackslash{}d+|0x[a-f\textbackslash{}d]+} \\ -\T{float} \df \RE{[+-]?\textbackslash{}d+(\textbackslash{}.\textbackslash{}d+)?} \opt{ \RE{e(+|-)?\textbackslash{}d+} } \\ -\end{tabbing} -\end{multicols} -\figcap{The full syntax of \eolang{} in BNF. - \lex{eol} is a line ending that preserves the indentation of the previous line. - \lex{tab} is a right-shift of the indentation, while \lex{untab} is a left-shift. - \lex{any} is any symbol excluding \lex{eol}, \V{.}, and \V{␣}. - The texts between forward slashes are Perl-style regular expressions.} -\label{fig:bnf} -\end{figure*} - \subsection{Identity, State, and Behavior} According to~\citet{grady2007object}, an object in OOP has state, behavior, and identity: @@ -300,7 +240,7 @@ \subsection{Data Objects and Tuples} is to use a numeric literal like \ff{3.14}. The abstract objects which can't be used directly and can only be -created by the compiler through \sntx{data}---are called \emph{data}. +created by the compiler through "data" syntax construct---are called \emph{data}. The examples of some possible data are in the Tab.~\ref{tab:types}. \begin{table} From 05efd23d7c045a85286091475ef3c36b9ae19640 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 18:51:19 +0300 Subject: [PATCH 26/80] #2903: syntax polished --- paper/eolang-paper.tex | 1 + paper/sections/calculus.tex | 22 ++--- paper/sections/pragmatics.tex | 4 +- paper/sections/semantics.tex | 26 +++--- paper/sections/syntax.tex | 168 ++++++++++++++-------------------- paper/sections/xmir.tex | 22 ++--- 6 files changed, 107 insertions(+), 136 deletions(-) diff --git a/paper/eolang-paper.tex b/paper/eolang-paper.tex index 39764f3c33..e4a4186eeb 100644 --- a/paper/eolang-paper.tex +++ b/paper/eolang-paper.tex @@ -34,6 +34,7 @@ \usepackage{csquotes} \usepackage[novert]{ffcode} % for fixed-fonts \usepackage{phigure} % local, in this directory +\usepackage{cleveref} % for \cref \usepackage{CJKutf8} % for chinese font \usepackage{paralist} % for inlined lists \usepackage{cancel} % to enable \cancel command diff --git a/paper/sections/calculus.tex b/paper/sections/calculus.tex index f4d85188be..d015d16f5d 100644 --- a/paper/sections/calculus.tex +++ b/paper/sections/calculus.tex @@ -52,7 +52,7 @@ \subsection{Objects and Data} \subsection{Attributes} \begin{definition}\label{def:attribute} -In an object \(x\), \(a\) is a free \textbf{attribute} +In an object \(x\), \(a\) is a void \textbf{attribute} with the \textbf{name} \(a\) iff \((a, \varnothing) \in x\); it is an attached attribute with the \textbf{value} \(v\) @@ -61,7 +61,7 @@ \subsection{Attributes} In Eq.~\ref{eq:book2}, identifiers \ff{isbn}, \ff{title}, and \ff{price} are the attributes of the object \ff{book2}. -The attribute \ff{isbn} is free, while the other two are attached. +The attribute \ff{isbn} is void, while the other two are attached. \begin{definition}\label{def:dot} If \(x\) is an object and \(\exists (a, v) \in x\), then \(v\) may be referenced as \(x.a\); @@ -90,7 +90,7 @@ \subsection{Attributes} \subsection{Abstraction} \begin{definition}\label{def:abstraction} -An object \(x\) is \textbf{abstract} iff at least one of its attributes is free, +An object \(x\) is \textbf{abstract} iff at least one of its attributes is void, i.e. \(\exists (a, \varnothing)\in x\); the process of creating such an object is called \textbf{abstraction}. \end{definition} @@ -98,7 +98,7 @@ \subsection{Abstraction} An alternative ``arrow notation'' may be used to denote an object \(x\) in a more compact way, where free attributes stay in the parentheses on the left side of the mapping symbol \(\mapsto\) and pairs, -which represent bound attributes, stay on the right side, in double-square brackets. +which represent attached attributes, stay on the right side, in double-square brackets. Eq.~\ref{eq:book2} may be written as \begin{equation}\label{eq:book2-compact} \begin{split} @@ -119,17 +119,17 @@ \subsection{Application} \(v=y.a\) if \(x.a=\varnothing\) and \(v=x.a\) otherwise. \end{definition} -Application makes some free attributes of \(x\) bound---by binding objects to them. +Application makes some free attributes of \(x\) attached---by binding objects to them. The produced object has exactly the same set of attributes, but some of them, -which were free before, become bound. +which were free before, become attached. -It is not expected that all free attributes turn into bound ones during application. +It is not expected that all free attributes turn into attached ones during application. Some of them may remain free, which will lead to creating a new abstract object. To the contrary, if all free attributes are substituted with \emph{arguments} during copying, a newly created object will be \emph{closed}. -Once set, bound attributes may not be reset. +Once set, attached attributes may not be reset. This may be interpreted as \emph{immutability} property of objects. Arrow notation may also be used to denote object copying, @@ -152,8 +152,8 @@ \subsection{Application} \end{equation} An application without arguments is a copy of an object. For example, -in these expressions the attribute \ff{p1} is bound to the same object -as the attribute \ff{p}, while the attribute \ff{p2} is bound to a new +in these expressions the attribute \ff{p1} is attached to the same object +as the attribute \ff{p}, while the attribute \ff{p2} is attached to a new object, a copy of \ff{p}: \begin{equation*} \begin{split} @@ -324,7 +324,7 @@ \subsection{Atoms} \end{equation} where \(M_\texttt{stdout}\) is a \(\lambda\)-term defined externally. -In atoms, \(\lambda\)-terms are bound to \(\lambda\) attribute. +In atoms, \(\lambda\)-terms are attached to \(\lambda\) attribute. Thus, a more formal form of the Eq.~\ref{def:stdout} is: \begin{equation*} \ff{stdout} \mapsto \llbracket \ff{text} \mapsto \varnothing, \lambda \mapsto M_\text{stdout} \rrbracket. diff --git a/paper/sections/pragmatics.tex b/paper/sections/pragmatics.tex index 423b28540a..e7523c0e59 100644 --- a/paper/sections/pragmatics.tex +++ b/paper/sections/pragmatics.tex @@ -13,9 +13,9 @@ \begin{ffcode} - |\(\label{ln:xml-circle2-r}\)| + (*@\label{ln:xml-circle2-r}@*) - + 2 3.14 diff --git a/paper/sections/semantics.tex b/paper/sections/semantics.tex index dbc5273b2a..89ca3a1fdb 100644 --- a/paper/sections/semantics.tex +++ b/paper/sections/semantics.tex @@ -181,19 +181,19 @@ \subsection{SODG} \begin{twocols} \begin{ffcode} -ADD(|\(\Phi\)|) -ADD(|\(v_1\)|); -ATOM(|\(v_1\)|, |\(M_1\)|); -BIND(|\(\Phi\)|, |\(v_1\)|, memory); -ADD(|\(v_2\)|); -BIND(|\(\Phi\)|, |\(v_2\)|, book2); -ADD(|\(v_3\)|); -BIND(|\(v_2\)|, |\(v_3\)|, isbn); -ADD(|\(v_4\)|); -BIND(|\(v_2\)|, |\(v_4\)|, title); -REF(e, |\(v_2\)|, |\(\Phi\)|.memory, price); -ADD(|\(d_4\)|); -BIND(|\(v_4\)|, |\(d_4\)|, |\(\Delta\)|); +ADD((*@\(\Phi\)@*)) +ADD((*@\(v_1@\)*)); +ATOM((*@\(v_1\)@*), (*@\(M_1\)@*)); +BIND((*@\(\Phi\)@*), (*@\(v_1\)@*), memory); +ADD((*@\(v_2\)@*)); +BIND((*@\(\Phi\)@*), (*@\(v_2\)@*), book2); +ADD((*@\(v_3\)@*)); +BIND((*@\(v_2\)@*), (*@\(v_3\)@*), isbn); +ADD((*@\(v_4\)@*)); +BIND((*@\(v_2\)@*), (*@\(v_4\)@*), title); +REF(e, (*@\(v_2\)@*), (*@\(\Phi\)@*).memory, price); +ADD((*@\(d_4\)@*)); +BIND((*@\(v_4\)@*), (*@\(d_4\)@*), (*@\(\Delta\)@*)); \end{ffcode} \end{twocols} diff --git a/paper/sections/syntax.tex b/paper/sections/syntax.tex index d7874de33e..9cc6e60adf 100644 --- a/paper/sections/syntax.tex +++ b/paper/sections/syntax.tex @@ -8,14 +8,16 @@ denoting grammar constructs: \ff{>} for the attributes naming, \ff{.} for the dot notation, - \ff{[]} for the specification of parameters of abstract objects, + \ff{[]} for the specification of parameters of formations, \ff{()} for scope limitations, \ff{!} for turning objects into constants, \ff{:} for naming arguments, \ff{"} (double quotes) for string literals, \ff{@} for the \nospell{decoratee}, \ff{'} (apostroph) for explicit copying, + \ff{<} for object identity, \ff{\^{}} for referring to the parent object, + \ff{\&{}} for referring to the home object, and \ff{\$} for referring to the current object. Attributes, which are the only identifiers that exist in \eolang{}, may have @@ -38,14 +40,14 @@ \subsection{Identity, State, and Behavior} Identity is that property of an object which distinguishes it from all other objects.'' The syntax of \eolang{} makes a difference between these three categories. -This is a declaration of an abstract object \ff{book}, +This is a formation of a new object \ff{book}, which has a single \emph{identity} attribute \ff{isbn}: \begin{ffcode} -[isbn] > book |\(\label{ln:book}\)| +[isbn] > book (*@\label{ln:book}@*) \end{ffcode} -To make a new object with a specific ISBN, the \ff{book} +To make another object with a specific ISBN, the \ff{book} has to be \emph{copied}, with the \emph{data} as an argument: \begin{ffcode} @@ -55,32 +57,32 @@ \subsection{Identity, State, and Behavior} Here, \ff{b1} is a new object created. Its only attribute is accessible as \ff{b1.isbn}. -A similar abstract object, but with two new \emph{state} attributes, would +A similar \emph{abstract} object, but with two new \emph{state} attributes, would look like: \begin{ffcode} -[isbn] > book2 |\(\label{ln:book2}\)| +[isbn] > book2 (*@\label{ln:book2}@*) "Object Thinking" > title - memory 0 > price |\(\label{ln:book2-end}\)| + memory 0 > price (*@\label{ln:book2-end}@*) \end{ffcode} The attribute \ff{title} is a constant, while the \ff{price} represents a mutable chunk of bytes in computing memory. They both are accessible similar to the \ff{isbn}, via \ff{book2.title} and \ff{book2.price}. It is legal to access them in the abstract -object, since they are bound to objects. However, accessing \ff{book2.isbn} -will lead to an error, since the attribute \ff{isbn} is free +object, since they are attached to objects. However, accessing \ff{book2.isbn} +will lead to an error, since the attribute \ff{isbn} is \emph{void} in the abstract object \ff{book2}. A \emph{behavior} may be added to an object with a new \emph{inner} abstract object \ff{set-price}: \begin{ffcode} -[isbn] > book3 |\(\label{ln:book3}\)| +[isbn] > book3 (*@\label{ln:book3}@*) "Object Thinking" > title memory 0 > price [p] > set-price - ^.price.write p > @ |\(\label{ln:book3-end}\)| + ^.price.write p > @ (*@\label{ln:book3-end}@*) \end{ffcode} The price of the book may be changed with this one-liner: @@ -98,21 +100,21 @@ \subsection{Indentation} second line and the \ff{>} symbol, while two spaces will break the syntax): {\lstset{showspaces=true}\begin{ffcode} -# This is a vector in 2D space |\(\label{ln:comment}\)| -[dx dy] > vector |\(\label{ln:vector}\)| - sqrt. > length |\(\label{ln:length}\)| +# This is a vector in 2D space (*@\label{ln:comment}@*) +[dx dy] > vector (*@\label{ln:vector}@*) + sqrt. > length (*@\label{ln:length}@*) plus. dx.times dx - dy.timex dy |\(\label{ln:length-end}\)| |\(\label{ln:vector-end}\)| + dy.timex dy (*@\label{ln:length-end}@*) (*@\label{ln:vector-end}@*) \end{ffcode} } The code at \lref{comment} is a \emph{comment}. -Two \emph{free attributes} \ff{dx} and \ff{dy} +Two \emph{void attributes} \ff{dx} and \ff{dy} are listed in square brackets at \lref{vector}. The \emph{name} of the object goes after the \ff{>} symbol. The code at \lref{length} defines -a \emph{bound attribute} \ff{length}. Anywhere when an object +an \emph{attached attribute} \ff{length}. Anywhere when an object has to get a name, the \ff{>} symbol can be added after the object. The declaration of the attribute \ff{length} at \lrefs{length}{length-end} @@ -130,10 +132,10 @@ \subsection{Indentation} inverse notation, but it will look less readable: \begin{ffcode} -dx.times dx |\(\label{ln:dx-pow}\)| +dx.times dx (*@\label{ln:dx-pow}@*) .plus - dy.timex dy |\(\label{ln:dx-pow-2}\)| -.sqrt > length |\(\label{ln:dx-pow-3}\)| + dy.timex dy (*@\label{ln:dx-pow-2}@*) +.sqrt > length (*@\label{ln:dx-pow-3}@*) \end{ffcode} Here, \lref{dx-pow} is the application of the object \ff{dx.times} with @@ -146,11 +148,11 @@ \subsection{Indentation} Indentation is used for two purposes: either to define attributes of an abstract object or to specify arguments for object application, also known as making a \emph{copy}. -A definition of an abstract object starts with a list of free attributes -in square brackets on one line, followed by a list of bound attributes +A definition of an abstract object starts with a list of void attributes +in square brackets on one line, followed by a list of attached attributes each in its own line. For example, this is an abstract \emph{anonymous} object (it doesn't have a name) -with one free attribute \ff{x} and two bound attributes \ff{succ} and \ff{prev}: +with one void attribute \ff{x} and two attached attributes \ff{succ} and \ff{prev}: \begin{ffcode} [x] @@ -163,11 +165,11 @@ \subsection{Indentation} in a \emph{vertical} mode, where indentation will be required: \begin{ffcode} -[x] |\(\label{ln:succ}\)| +[x] (*@\label{ln:succ}@*) x.plus > succ 1 x.minus > prev - 1 |\(\label{ln:succ-end}\)| + 1 (*@\label{ln:succ-end}@*) \end{ffcode} This abstract object can also be written in a horizontal mode, @@ -179,7 +181,7 @@ \subsection{Indentation} \subsection{\eolang{} to XML}\label{sec:xml} -Due the nesting nature of \eolang{}, its program can be transformed +Due to the nesting nature of \eolang{}, its program can be transformed to an XML document. The abstract object \ff{vector} would produce this XML tree of elements and attributes: @@ -204,8 +206,8 @@ \subsection{\eolang{} to XML}\label{sec:xml} Each object is represented by an \ff{} XML element with a few optional attributes, such as \ff{name} and \ff{base}. Each -attribute is either a named reference to an object (if the attribute is bound, -such as \ff{length}), or a name without a reference (if it is free, +attribute is either a named reference to an object (if the attribute is attached, +such as \ff{length}), or a name without a reference (if it is void, such as \ff{dx} and \ff{dy}). \subsection{Data Objects and Tuples} @@ -223,25 +225,20 @@ \subsection{Data Objects and Tuples} data format explained in Sec.~\ref{sec:xmir}): \begin{ffcode} - |\(\label{ln:xml-circle}\)| + (*@\label{ln:xml-circle}@*) - |\(\label{ln:xml-circle-r}\)| - 3.14 + (*@\label{ln:xml-circle-r}@*) + + 40-09-1E-B8-51-EB-85-1F + - |\(\label{ln:xml-circle-end}\)| + (*@\label{ln:xml-circle-end}@*) \end{ffcode} -Each object, if it is not abstract, has a ``base'' attribute in XML, -which contains that name of an abstract object to be copied. The -object \ff{float} is abstract, but its name -can't be used directly in a program, similar to how \ff{r} or \ff{times} -are used. The only way to make a copy of the abstract object \ff{float} -is to use a numeric literal like \ff{3.14}. - -The abstract objects which can't be used directly and can only be -created by the compiler through "data" syntax construct---are called \emph{data}. -The examples of some possible data are in the Tab.~\ref{tab:types}. +Each object, if it is not a formation, has a ``base'' attribute in XML, +which contains that name of a formation to be copied. +The examples of some possible \emph{data objects} are in~\cref{tab:types}. \begin{table} \begin{tabularx}{\columnwidth}{l|X|r} @@ -267,11 +264,11 @@ \subsection{Data Objects and Tuples} which looks similar to object copying: \begin{ffcode} -* "Lucy" "Jeff" 3.14 |\(\label{ln:tuple-1}\)| -* > a |\(\label{ln:tuple-2a}\)| +* "Lucy" "Jeff" 3.14 (*@\label{ln:tuple-1}@*) +* > a (*@\label{ln:tuple-2a}@*) (* "a") - TRUE |\(\label{ln:tuple-2b}\)| -* > b |\(\label{ln:tuple-3}\)| + TRUE (*@\label{ln:tuple-2b}@*) +* > b (*@\label{ln:tuple-3}@*) \end{ffcode} The code at \lref{tuple-1} makes a tuple of three elements: two strings @@ -279,38 +276,12 @@ \subsection{Data Objects and Tuples} tuple as its first element and \ff{TRUE} as the second item. The code at \lref{tuple-3} is an empty tuple with the name \ff{b}. -\subsection{Varargs} - -The last free attribute in an abstract object may be a \emph{vararg}, -meaning that any number or zero arguments may be provided. All of them -will be packaged in a tuple by the compiler, for example: - -\begin{ffcode} -[x...] > sum |\(\label{ln:sum-def}\)| -sum 8 13 -9 |\(\label{ln:sum-instance}\)| -\end{ffcode} - -Here, at the first line the abstract object \ff{sum} is defined -with a free vararg attribute \ff{x}. At the second line a copy of the -abstract object is made with three arguments. The internals of -the \ff{sum} will see \ff{x} as an \ff{tuple} with three -elements inside. - -It is possible to provide a tuple as a parameter for vararg attribute -(both variants are semantically equivalent): - -\begin{ffcode} -* 42 7 > a -sum ...a -sum 42 7 -\end{ffcode} - \subsection{Scope Brackets} Brackets can be used to group object arguments in horizontal mode: \begin{ffcode} -sum (div 45 5) 10 |\(\label{ln:sum}\)| +sum (div 45 5) 10 (*@\label{ln:sum}@*) \end{ffcode} The \ff{(div 45 5)} is a copy of the abstract object \ff{div} @@ -333,21 +304,21 @@ \subsection{Inner Objects} # A point on a 2D canvas [x y] > point [to] > distance - length. > len |\(\label{ln:vector-length}\)| + length. > len (*@\label{ln:vector-length}@*) vector to.x.minus (^.x) to.y.minus (^.y) \end{ffcode} -The object \ff{point} has two free attributes \ff{x} and \ff{y} -and the attribute \ff{distance}, which is bound to an abstract -object with one free attribute \ff{to} and one bound attribute \ff{len}. +The object \ff{point} has two void attributes \ff{x} and \ff{y} +and the attribute \ff{distance}, which is attached to an abstract +object with one void attribute \ff{to} and one attached attribute \ff{len}. The \emph{inner} abstract object \ff{distance} may only be copied with a reference to its \emph{parent} object \ff{point}, via a special attribute denoted by the \ff{\^{}} symbol: \begin{ffcode} -distance. |\(\label{ln:point-copy}\)| +distance. (*@\label{ln:point-copy}@*) point 5:x -3:y @@ -357,9 +328,9 @@ \subsection{Inner Objects} \end{ffcode} The parent object is \ff{(point 5 -3)}, while the object \ff{(point 13 3.9)} -is the argument for the free attribute \ff{to} of the object \ff{distance}. +is the argument for the void attribute \ff{to} of the object \ff{distance}. Suffixes \ff{:x}, \ff{:y}, and \ff{:to} are optional and may be used -to denote the exact name of the free attribute to be bound to the +to denote the exact name of the void attribute to be attached to the provided argument. \subsection{Decorators} @@ -367,12 +338,12 @@ \subsection{Decorators} An object may extend another object by \emph{decorating} it: \begin{ffcode} -[center radius] > circle |\(\label{ln:circle}\)| - center > @ |\(\label{ln:circle-phi}\)| +[center radius] > circle (*@\label{ln:circle}@*) + center > @ (*@\label{ln:circle-phi}@*) [p] > is-inside lte. > @ ^.@.distance \(.p |\)\label{ln:circle-phi-2}$| - ^.radius |\(\label{ln:circle-end}\)| + ^.radius (*@\label{ln:circle-end}@*) \end{ffcode} The object \ff{circle} has a special attribute \ff{@} @@ -407,20 +378,20 @@ \subsection{Decorators} the \((0,0)\) point is inside the circle at \((-3,9)\) with the radius \(40\): \begin{ffcode} -circle (point -3 9) 40 > c |\(\label{ln:circle-c}\)| +circle (point -3 9) 40 > c (*@\label{ln:circle-c}@*) c.is-inside (point 0 0) > i \end{ffcode} Here, \ff{i} will be a copy of \ff{bool} behaving like \ff{TRUE} because \ff{lte} decorates \ff{bool}. -It is also possible to make decoratee free, similar to other free -attributes, specifying it in the list of free attributes in +It is also possible to make decoratee void, similar to other void +attributes, specifying it in the list of void attributes in square brackets. -\subsection{Anonymous Abstract Objects} +\subsection{Anonymous Formations} -An abstract object may be used as an argument of another object while +A formation may be used as an argument of another object while making a copy of it, for example: \begin{ffcode} @@ -431,14 +402,13 @@ \subsection{Anonymous Abstract Objects} \end{ffcode} Here the object \ff{walk} is copied with a single argument: -the one-item tuple, which is an -abstract object with a single free attribute \ff{f}. The \ff{walk} -will use this abstract object, which doesn't have a name, in order +the one-item tuple, which is a formation with a single void attribute \ff{f}. The \ff{walk} +will use this formation, which doesn't have a name, in order to filter out files while traversing the tree of directories. It will -make a copy of the abstract object and then treat it as a boolean +make a copy of the formation and then treat it as a boolean value in order to make a decision about each file. -The syntax may be simplified and the abstract object may be inlined +The syntax may be simplified and the formation may be inlined (the tuple is also inlined): \begin{ffcode} @@ -446,7 +416,7 @@ \subsection{Anonymous Abstract Objects} * ([f] (f.is-dir > @)) \end{ffcode} -An anonymous abstract object may have multiple attributes: +An anonymous formation may have multiple attributes: \begin{ffcode} [x] (x.plus 1 > succ) (x.minus 1 > prev) @@ -549,7 +519,7 @@ \subsection{Metas and License} +package org.example +alias org.eolang.io.stdout -[args...] > app +[args] > app stdout > @ "Hello, world!\n" \end{ffcode} @@ -567,7 +537,7 @@ \subsection{Atoms} +rt jvm org.eolang:eo-runtime:0.7.0 +rt ruby eolang:0.1.0 -[text] > stdout /bool |\(\label{ln:stdout}\)| +[text] > stdout /bool (*@\label{ln:stdout}@*) \end{ffcode} The \ff{/bool} suffix informs the compiler that this object must @@ -591,11 +561,11 @@ \subsection{Home Object} how object \ff{tuple.map} is implemented in Objectionary: \begin{ffcode} -[] > list |\(\label{ln:list-parent}\)| - [f] > mapi /list |\(\label{ln:list-map}\)| +[] > list (*@\label{ln:list-parent}@*) + [f] > mapi /list (*@\label{ln:list-map}@*) [f] > map ^.mapi > @ - [x i] |\(\label{ln:map-inner}\)| + [x i] (*@\label{ln:map-inner}@*) &.f x > @ \end{ffcode} diff --git a/paper/sections/xmir.tex b/paper/sections/xmir.tex index 70a33ade04..221fd16223 100644 --- a/paper/sections/xmir.tex +++ b/paper/sections/xmir.tex @@ -1,7 +1,7 @@ Consider this sample \eolang{} snippet: \begin{ffcode} -[x y...] > app +[x y] > app 42 > n! [t] > read minus. @@ -14,16 +14,16 @@ \begin{ffcode} - + 42 |\(\label{ln:xml-data}\)| + line="2" name="n">42 (*@\label{ln:xml-data}@*) - |\(\label{ln:xml-minus}\)| - |\(\label{ln:method-start}\)| - |\(\label{ln:method-end}\)| + (*@\label{ln:xml-minus}@*) + (*@\label{ln:method-start}@*) + (*@\label{ln:method-end}@*) - |\(\label{ln:xml-minus-end}\)| + (*@\label{ln:xml-minus-end}@*) \end{ffcode} @@ -46,12 +46,12 @@ goes away): \begin{ffcode} - |\(\label{ln:new-minus}\)| - |\(\label{ln:xml-neg}\)| + (*@\label{ln:new-minus}@*) + (*@\label{ln:xml-neg}@*) - |\(\label{ln:xml-neg-end}\)| + (*@\label{ln:xml-neg-end}@*) - |\(\label{ln:new-minus-end}\)| + (*@\label{ln:new-minus-end}@*) \end{ffcode} The semantics of the element \ff{.minus} at~\lref{xml-minus} From 85b71cf1edb3466c1ad3780d528a59246e081c71 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 18:56:18 +0300 Subject: [PATCH 27/80] #2903: void --- paper/sections/calculus.tex | 20 ++++++++++---------- paper/sections/semantics.tex | 4 ++-- 2 files changed, 12 insertions(+), 12 deletions(-) diff --git a/paper/sections/calculus.tex b/paper/sections/calculus.tex index d015d16f5d..ee3296647f 100644 --- a/paper/sections/calculus.tex +++ b/paper/sections/calculus.tex @@ -1,7 +1,7 @@ The proposed \phic{} is based on set theory~\citep{jech2013set} and lambda calculus, representing objects as sets of pairs and their internals as \(\lambda\)-terms. The rest of the section contains formal definitions of -data, objects, attributes, abstraction, application, decoration, and dataization. +data, objects, attributes, formation, application, decoration, and dataization. \subsection{Objects and Data} @@ -10,7 +10,7 @@ \subsection{Objects and Data} \(a_i\) is an identifier, all \(a_i\) are different, and \(v_i\) is an object. \end{definition} -An identifier is either \(\varphi\), \(\rho\), \(\nu\), or, by convention, a text without +An identifier is either \(\varphi\), \(\rho\), \(\sigma\), \(\nu\), or, by convention, a text without spaces starting with a small-case English letter in typewriter font. The object at \lref{book} may be represented as @@ -96,7 +96,7 @@ \subsection{Abstraction} \end{definition} An alternative ``arrow notation'' may be used to denote an object \(x\) in a more -compact way, where free attributes stay in the parentheses on the left side of the +compact way, where void attributes stay in the parentheses on the left side of the mapping symbol \(\mapsto\) and pairs, which represent attached attributes, stay on the right side, in double-square brackets. Eq.~\ref{eq:book2} may be written as @@ -119,21 +119,21 @@ \subsection{Application} \(v=y.a\) if \(x.a=\varnothing\) and \(v=x.a\) otherwise. \end{definition} -Application makes some free attributes of \(x\) attached---by binding objects to them. +Application makes some void attributes of \(x\) attached---by binding objects to them. The produced object has exactly the same set of attributes, but some of them, -which were free before, become attached. +which were void before, become attached. -It is not expected that all free attributes turn into attached ones during application. -Some of them may remain free, which will lead +It is not expected that all void attributes turn into attached ones during application. +Some of them may remain void, which will lead to creating a new abstract object. To the contrary, -if all free attributes are substituted with \emph{arguments} during copying, +if all void attributes are substituted with \emph{arguments} during copying, a newly created object will be \emph{closed}. Once set, attached attributes may not be reset. This may be interpreted as \emph{immutability} property of objects. Arrow notation may also be used to denote object copying, -where the names of the attributes, which remain free, stay in the brackets +where the names of the attributes, which remain void, stay in the brackets on the left side of the mapping symbol \(\mapsto\), while objects \(P\) provided as arguments stay on the right side, in the brackets. For example, the object at \lref{point-copy} may be written as @@ -298,7 +298,7 @@ \subsection{Atoms} \begin{definition}\label{def:atom} If \(\lambda s.M\) is a function of one argument \(s\) returning an object, then it is an abstract object called an \textbf{atom}, \(M\) is its \(\lambda\)-term, -and \(s\) is its free attribute. +and \(s\) is its void attribute. \end{definition} For example, the atom at \lref{sum-def} would be represented as diff --git a/paper/sections/semantics.tex b/paper/sections/semantics.tex index 89ca3a1fdb..a007b4bcfa 100644 --- a/paper/sections/semantics.tex +++ b/paper/sections/semantics.tex @@ -39,7 +39,7 @@ \subsection{Object Graph}\label{ssec:graph} \end{figure} The vertice at the top of the graph is the ``root'' object (see Def.~\ref{def:locator}), -where all other objects that are not anonymous (see Def.~\ref{def:parent}) are bound to. +where all other objects that are not anonymous (see Def.~\ref{def:parent}) are attached to. The vertice \(v_2\) is the abstract object \ff{book2}. The name of the object within the scope of \(\Phi\) is the label on the edge from \(\Phi\) to \(v_2\). The labeled edge between \(v_2\) and \(v_3\) makes the object \(v_3\) an attribute of \(v_2\) with the @@ -229,7 +229,7 @@ \subsection{Transformation Rules} be used to denote vertices and edges, being incremented sequentially in order to avoid duplication. -Consider for example the abstract object bound to the attribute \ff{is-inside} in Eq.~\ref{eq:c-empty}. +Consider for example the abstract object attached to the attribute \ff{is-inside} in Eq.~\ref{eq:c-empty}. The premise \(v_5|E\) will stand when the focus is at the vertice representing the object \ff{circle}, where \(v_5\) would be the vertice of it (the numbers \(5\) and \(12\) don't mean anything and are just placeholders): From e76f744596b483848e1627e2fe58b6d0ab28a40d Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 18:59:59 +0300 Subject: [PATCH 28/80] #2903: formation --- paper/sections/calculus.tex | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/paper/sections/calculus.tex b/paper/sections/calculus.tex index ee3296647f..3bd75b14fa 100644 --- a/paper/sections/calculus.tex +++ b/paper/sections/calculus.tex @@ -87,12 +87,11 @@ \subsection{Attributes} For example, the scope of the object at Eq.~\ref{eq:book2} consists of three identifiers: \ff{isbn}, \ff{title}, and \ff{price}. -\subsection{Abstraction} +\subsection{Formation} \begin{definition}\label{def:abstraction} An object \(x\) is \textbf{abstract} iff at least one of its attributes is void, -i.e. \(\exists (a, \varnothing)\in x\); -the process of creating such an object is called \textbf{abstraction}. +i.e. \(\exists (a, \varnothing)\in x\). \end{definition} An alternative ``arrow notation'' may be used to denote an object \(x\) in a more @@ -163,6 +162,8 @@ \subsection{Application} \end{split} \end{equation*} +\subsection{Formation} + \begin{definition}\label{def:formation} The process of creating an object that is not a copy of another object is called \textbf{formation}. From 5278156ed7cf636f776134e313b8499bd1690092 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 19:09:38 +0300 Subject: [PATCH 29/80] #2903: cleveref --- paper/DEPENDS.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/paper/DEPENDS.txt b/paper/DEPENDS.txt index 7c62f3f2d9..619a06023b 100644 --- a/paper/DEPENDS.txt +++ b/paper/DEPENDS.txt @@ -48,3 +48,4 @@ hard trimspaces hard upquote hard wrapfig hard xstring +hard cleveref \ No newline at end of file From cbee41901a6d512970a76432f3053ba53de73b71 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 19:17:34 +0300 Subject: [PATCH 30/80] #2903: cref --- paper/eolang-paper.tex | 2 +- paper/sections/calculus.tex | 84 ++++------------------------------- paper/sections/features.tex | 2 +- paper/sections/pragmatics.tex | 10 ++--- paper/sections/semantics.tex | 28 ++++++------ paper/sections/syntax.tex | 2 +- paper/sections/xmir.tex | 2 - 7 files changed, 31 insertions(+), 99 deletions(-) diff --git a/paper/eolang-paper.tex b/paper/eolang-paper.tex index e4a4186eeb..ba9d179fa4 100644 --- a/paper/eolang-paper.tex +++ b/paper/eolang-paper.tex @@ -34,7 +34,7 @@ \usepackage{csquotes} \usepackage[novert]{ffcode} % for fixed-fonts \usepackage{phigure} % local, in this directory -\usepackage{cleveref} % for \cref +\usepackage[capitalize]{cleveref} % for \cref \usepackage{CJKutf8} % for chinese font \usepackage{paralist} % for inlined lists \usepackage{cancel} % to enable \cancel command diff --git a/paper/sections/calculus.tex b/paper/sections/calculus.tex index 3bd75b14fa..17c1a26bce 100644 --- a/paper/sections/calculus.tex +++ b/paper/sections/calculus.tex @@ -22,7 +22,7 @@ \subsection{Objects and Data} \end{split} \end{equation} where \ff{isbn} is an identifier and \(\varnothing\) is an empty -set, which is a proper object, according to the Def.~\ref{def:object}. +set, which is a proper object, according to~\cref{def:object}. \begin{definition}\label{def:data} An object may have properties of \textbf{data}, @@ -59,7 +59,7 @@ \subsection{Attributes} iff \(\exists (a, v)\in x\) and \(v\not=\varnothing\); \end{definition} -In Eq.~\ref{eq:book2}, identifiers \ff{isbn}, \ff{title}, and \ff{price} +In \cref{eq:book2}, identifiers \ff{isbn}, \ff{title}, and \ff{price} are the attributes of the object \ff{book2}. The attribute \ff{isbn} is void, while the other two are attached. @@ -84,7 +84,7 @@ \subsection{Attributes} the \textbf{arity} of \(x\). \end{definition} -For example, the scope of the object at Eq.~\ref{eq:book2} consists of three identifiers: +For example, the scope of the object at~\cref{eq:book2} consists of three identifiers: \ff{isbn}, \ff{title}, and \ff{price}. \subsection{Formation} @@ -98,7 +98,7 @@ \subsection{Formation} compact way, where void attributes stay in the parentheses on the left side of the mapping symbol \(\mapsto\) and pairs, which represent attached attributes, stay on the right side, in double-square brackets. -Eq.~\ref{eq:book2} may be written as +\Cref{eq:book2} may be written as \begin{equation}\label{eq:book2-compact} \begin{split} & \ff{book2}(\ff{isbn}) \mapsto \llbracket \br @@ -170,8 +170,8 @@ \subsection{Formation} \end{definition} Syntactically, object formation is denoted by double square brackets, -as in Eq.~\ref{eq:book2-compact}, to the contrary of object application, -which is denoted by round brackets, as in Eq.~\ref{eq:point}. +as in \cref{eq:book2-compact}, to the contrary of object application, +which is denoted by round brackets, as in \cref{eq:point}. Object abstraction is a special case of object formation. The following expression is a formation of the object \(x\): \begin{equation*} @@ -266,8 +266,8 @@ \subsection{Decoration}\label{sec:decoration} \end{equation} Because of decoration, the expression -\(\rho.\varphi.\ff{distance}\) in Eq.~\ref{eq:c-empty} is semantically equivalent to a shorter expression -\(\rho.\ff{distance}\) in Eq.~\ref{eq:c-fin}. +\(\rho.\varphi.\ff{distance}\) in \cref{eq:c-empty} is semantically equivalent to a shorter expression +\(\rho.\ff{distance}\) in \cref{eq:c-fin}. The following expression makes a new object \ff{is}, which represents a sequence of object applications ending with a copy of \ff{lte}: @@ -302,22 +302,6 @@ \subsection{Atoms} and \(s\) is its void attribute. \end{definition} -For example, the atom at \lref{sum-def} would be represented as -\begin{equation} -\begin{split} -& \ff{sum}(\ff{x}) \mapsto \lambda s . \sum\limits_{i=0}^{s[0].\ff{x}.\ff{size} - 1} s[0].\ff{x}.\ff{get}(i), -\end{split} -\end{equation} -where the function calculates an arithmetic sum of all items -in the tuple \ff{x} and returns the result as a data. The argument of -the function is a vector \(s\) where the first element is the object under -consideration, the second element is its parent object, the third element -is the parent of the parent, and so on. Thus, \(s[0]\) is the object -\ff{sum} itself, while \(s[0].\ff{x}\) is its inner object \ff{x}, -and \(s[0].\ff{x}.\ff{get}(0)\) is the first element of it, if it is a tuple. -It is expected that the tuple has an attribute \ff{size} representing -the total number of elements in the tuple. - Atoms may have their \(\lambda\)-terms defined outside of \phic{} formal scope. For example, the object at \lref{stdout} would be denoted as \begin{equation}\label{def:stdout} @@ -326,61 +310,11 @@ \subsection{Atoms} where \(M_\texttt{stdout}\) is a \(\lambda\)-term defined externally. In atoms, \(\lambda\)-terms are attached to \(\lambda\) attribute. -Thus, a more formal form of the Eq.~\ref{def:stdout} is: +Thus, a more formal form of the \cref{def:stdout} is: \begin{equation*} \ff{stdout} \mapsto \llbracket \ff{text} \mapsto \varnothing, \lambda \mapsto M_\text{stdout} \rrbracket. \end{equation*} -\subsection{Locators} - -\begin{definition}\label{def:locator} -Object \textbf{locator} is a unique dot-separated not-empty -collection of identifiers prepended by either \(\xi\), \(\rho\), \(\sigma\), or \(\Phi\). -\end{definition} - -Locators are used to avoid ambiguity when referencing objects. -For example, Eq.~\ref{eq:c-fin} may be refined as -\begin{equation} -\begin{split} -& \ff{c} \mapsto \llbracket \br -& \quad \ff{center} \mapsto \Phi.\ff{point}(\Phi.\ff{-3}, \Phi.\ff{9}), \br -& \quad \ff{radius} \mapsto \Phi.\ff{40}, \br -& \quad \varphi \mapsto \xi.\ff{center}, \br -& \quad \ff{is-inside}(\ff{p}) \mapsto \llbracket \br -& \quad \quad \varphi \mapsto \rho.\ff{distance}(\xi.\ff{p}).\ff{lte}( \br -& \quad \quad \quad \rho.\ff{radius} \br -& \quad \quad ) \br -& \quad \rrbracket \br -& \rrbracket, -\end{split} -\end{equation} -where \(\xi\) denotes the current abstract object -and \(\Phi\) refers to the anonymous closed ``root'' object. -Defining an object in a global scope -means binding it to the object \(\Phi\), unless it is an anonymous -object, as the one at \lrefs{succ}{succ-end}. - -The most precise and complete formula for the object in the -Eq.~\ref{eq:c-fin2} would also include attribute names for -the object application: -\begin{equation} -\begin{split} -& \ff{c} \mapsto \llbracket \br -& \quad \ff{center} \mapsto \Phi.\ff{point}( \br -& \quad \quad \ff{x} \mapsto \Phi.\ff{-3}, \br -& \quad \quad \ff{y} \mapsto \Phi.\ff{9} \br -& \quad ), \br -& \quad \ff{radius} \mapsto \Phi.\ff{40}, \br -& \quad \varphi \mapsto \xi.\ff{center}, \br -& \quad \ff{is-inside}(\ff{p}) \mapsto \llbracket \br -& \quad \quad \varphi \mapsto \xi.\rho.\ff{distance}(\ff{to} \mapsto \xi.\ff{p}).\ff{lte}( \br -& \quad \quad \quad \ff{other} \mapsto \xi.\rho.\ff{radius} \br -& \quad \quad ) \br -& \quad \rrbracket \br -& \rrbracket. -\end{split} -\end{equation} - \subsection{Constant} \newcommand\cmapsto{\mapstochar\relbar\mathrel{\mkern-8mu}\mapsto} diff --git a/paper/sections/features.tex b/paper/sections/features.tex index e944cd391a..35e6fb9293 100644 --- a/paper/sections/features.tex +++ b/paper/sections/features.tex @@ -9,7 +9,7 @@ from other existing OO languages and object theories, while some of them are similar to what other languages have to offer. The Section is not intended to present the features formally, which was done earlier in -Sections~\ref{sec:calculus} and~\ref{sec:syntax}, but to compare \eolang{} with other +\cref{sec:calculus,sec:syntax}, but to compare \eolang{} with other programming languages and informally identify similarities. \feature{no-classes}{No Classes} diff --git a/paper/sections/pragmatics.tex b/paper/sections/pragmatics.tex index e7523c0e59..c8482375f1 100644 --- a/paper/sections/pragmatics.tex +++ b/paper/sections/pragmatics.tex @@ -1,21 +1,21 @@ First, the source code of \eolang{} is parsed by ANTLR4-powered parser and an intermediate representation is built in XML, -as was demonstrated in the Section~\ref{sec:xml}. +as was demonstrated in \cref{sec:xml}. The output format is called \xmir{}. One \ff{.eo} file with the source code in \eolang{} produces one \xmir{} file with \ff{.xml} extension. \xmir{} is then refined via a \emph{pipeline} of XSLT stylesheets. -For example, \xmir{} at \ref{ln:xml-circle}--\ref{ln:xml-circle-end} contains a -reference to the object \ff{r} at the line no.\ref{ln:xml-circle-r}. +For example, \xmir{} at \lrefs{xml-circle}{xml-circle-end} contains a +reference to the object \ff{r} at \lref{xml-circle-r}. An XSL transformation adds an attribute \ff{ref} to the XML element \ff{}, referring it to the line inside XML document, where the object \ff{r} is defined: \begin{ffcode} - (*@\label{ln:xml-circle2-r}@*) + (*@\label{ln:xml-circle2-r}@*) - + 2 3.14 diff --git a/paper/sections/semantics.tex b/paper/sections/semantics.tex index a007b4bcfa..fccbaece8f 100644 --- a/paper/sections/semantics.tex +++ b/paper/sections/semantics.tex @@ -10,8 +10,8 @@ \subsection{Object Graph}\label{ssec:graph} Consider the object from \lrefs{book2}{book2-end}, -which is also represented by the expression in Eq.~\ref{eq:book}. -Fig.~\ref{fig:book2} represents it as a graph. +which is also represented by the expression in \cref{eq:book}. +\Cref{fig:book2} represents it as a graph. \begin{figure}[t!] \begin{phigure} @@ -32,21 +32,21 @@ \subsection{Object Graph}\label{ssec:graph} \(d_{4} \to \ff{"Object Thinking"}\) \end{minipage}}; \end{phigure} -\figcap{The object graph with a few objects from Eq.~\ref{eq:book2}, where +\figcap{The object graph with a few objects from \cref{eq:book2}, where \(d_4\) is \ff{"Object Thinking"} data and \(M_1\) is a lambda expression defined in the runtime.} \label{fig:book2} \end{figure} -The vertice at the top of the graph is the ``root'' object (see Def.~\ref{def:locator}), -where all other objects that are not anonymous (see Def.~\ref{def:parent}) are attached to. +The vertice at the top of the graph is the ``root'' object (see \cref{def:locator}), +where all other objects that are not anonymous (see \cref{def:parent}) are attached to. The vertice \(v_2\) is the abstract object \ff{book2}. The name of the object within the scope of \(\Phi\) is the label on the edge from \(\Phi\) to \(v_2\). The labeled edge between \(v_2\) and \(v_3\) makes the object \(v_3\) an attribute of \(v_2\) with the identifier \ff{isbn}. Even though the object \(v_3\) is \(\varnothing\), the graph depicts it as any other object. -The rectangle attached to the vertice \(v_1\) makes it an atom (see Def.~\ref{def:atom}) +The rectangle attached to the vertice \(v_1\) makes it an atom (see \cref{def:atom}) and \(M_1\), the content of the rectangle, is its \(\lambda\)-term. Atoms are depicted with double-lined circles. The data \(d_4\) attached to the vertice \(v_4\) by the named edge \(\Delta\) @@ -176,7 +176,7 @@ \subsection{SODG} All SODGs are idempotent, meaning that they have no additional effect if they are called more than once with the same input parameters. -The object graph at Fig.~\ref{fig:book2} may be generated with the +The object graph at \cref{fig:book2} may be generated with the following ordered sequence of SODGs: \begin{twocols} @@ -229,7 +229,7 @@ \subsection{Transformation Rules} be used to denote vertices and edges, being incremented sequentially in order to avoid duplication. -Consider for example the abstract object attached to the attribute \ff{is-inside} in Eq.~\ref{eq:c-empty}. +Consider for example the abstract object attached to the attribute \ff{is-inside} in \cref{eq:c-empty}. The premise \(v_5|E\) will stand when the focus is at the vertice representing the object \ff{circle}, where \(v_5\) would be the vertice of it (the numbers \(5\) and \(12\) don't mean anything and are just placeholders): @@ -405,7 +405,7 @@ \subsection{Transformation Rules} \jrule{lambda} \end{equation*} Visually, the rule would produce the following modifications on the graph -for Eq.~\ref{def:stdout}: +for \cref{def:stdout}: \begin{center}\begin{phigure} \node[object] (phi) {\(\Phi\)}; @@ -418,9 +418,9 @@ \subsection{Transformation Rules} \draw (phi-d) -- (v1d) node [attr] {\ff{stdout}}; \end{phigure}\end{center} -In order to demonstrate a larger example, Fig.~\ref{fig:is} shows +In order to demonstrate a larger example, \cref{fig:is} shows an object graph, which the described rules -would generate by transforming the object \ff{is} from Eq.~\ref{eq:is}. +would generate by transforming the object \ff{is} from \cref{eq:is}. \subsection{Dataization} @@ -510,8 +510,8 @@ \subsection{Dataization} \(i\) is the next available index in the graph. For example, \(\mathbb{R}(\Phi.\ff{c}.\ff{center}.\ff{y},\Delta, \varnothing)\) -being executed on the graph presented at the -Fig.~\ref{fig:is} would return the vertice \(d_{21}\), which is \(+9\). +being executed on the graph presented at +\cref{fig:is} would return the vertice \(d_{21}\), which is \(+9\). We also define a dataization function, which turns an object into data: @@ -623,7 +623,7 @@ \subsection{Dataization} \(M_7 \to \mathbb{R}(\xi.\ff{t}, \ff{distance}, s)\) \\ \end{minipage}}; \end{phigure}} -\figcap{The graph of the object \ff{is} from Eq.~\ref{eq:is}.} +\figcap{The graph of the object \ff{is} from \cref{eq:is}.} \label{fig:is} \end{figure*} diff --git a/paper/sections/syntax.tex b/paper/sections/syntax.tex index 9cc6e60adf..03cb76b4d3 100644 --- a/paper/sections/syntax.tex +++ b/paper/sections/syntax.tex @@ -222,7 +222,7 @@ \subsection{Data Objects and Tuples} \end{ffcode} This syntax would be translated to XMIR (XML based -data format explained in Sec.~\ref{sec:xmir}): +data format explained in \cref{sec:xmir}): \begin{ffcode} (*@\label{ln:xml-circle}@*) diff --git a/paper/sections/xmir.tex b/paper/sections/xmir.tex index 221fd16223..e74e4dba39 100644 --- a/paper/sections/xmir.tex +++ b/paper/sections/xmir.tex @@ -66,6 +66,4 @@ The attribute \ff{data} is used when the object is data. In this case, the data itself is in the text of the object, as in~\lref{xml-data}. -The attribute \ff{vararg} denotes a vararg attribute. - The attribute \ff{const} denotes a constant. From dc902507b02198147a40fd9b7f9b07760976fab5 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 19:20:22 +0300 Subject: [PATCH 31/80] #2903: trimclip --- paper/DEPENDS.txt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/paper/DEPENDS.txt b/paper/DEPENDS.txt index 619a06023b..de4c063c34 100644 --- a/paper/DEPENDS.txt +++ b/paper/DEPENDS.txt @@ -48,4 +48,5 @@ hard trimspaces hard upquote hard wrapfig hard xstring -hard cleveref \ No newline at end of file +hard cleveref +hard trimclip \ No newline at end of file From 5a5738b4d6a43021b24f8fb9e3595a4e02566518 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 19:22:38 +0300 Subject: [PATCH 32/80] ignore --- .github/workflows/shellcheck.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/shellcheck.yml b/.github/workflows/shellcheck.yml index 856fc00c4f..ad721aa9d9 100644 --- a/.github/workflows/shellcheck.yml +++ b/.github/workflows/shellcheck.yml @@ -4,9 +4,11 @@ on: push: branches: - master + paths-ignore: [ 'paper/**', 'sandbox/**' ] pull_request: branches: - master + paths-ignore: [ 'paper/**', 'sandbox/**' ] concurrency: group: shellcheck-${{ github.ref }} cancel-in-progress: true From 1b47da882de56f7d53a66f31449ba8f5b916ccce Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 20:05:39 +0300 Subject: [PATCH 33/80] #2903: adjustbox --- paper/DEPENDS.txt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/paper/DEPENDS.txt b/paper/DEPENDS.txt index de4c063c34..45a5d60eed 100644 --- a/paper/DEPENDS.txt +++ b/paper/DEPENDS.txt @@ -49,4 +49,5 @@ hard upquote hard wrapfig hard xstring hard cleveref -hard trimclip \ No newline at end of file +hard trimclip +hard adjustbox \ No newline at end of file From 383489fb3bf0c9a0b7e02e1991215b3531a6f45a Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 20:29:51 +0300 Subject: [PATCH 34/80] #2903: off --- paper/DEPENDS.txt | 1 - 1 file changed, 1 deletion(-) diff --git a/paper/DEPENDS.txt b/paper/DEPENDS.txt index 45a5d60eed..940a7176cf 100644 --- a/paper/DEPENDS.txt +++ b/paper/DEPENDS.txt @@ -49,5 +49,4 @@ hard upquote hard wrapfig hard xstring hard cleveref -hard trimclip hard adjustbox \ No newline at end of file From d2ceeffeda6e9067f26737eddcdef7ecfe294afd Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 29 Feb 2024 21:15:10 +0300 Subject: [PATCH 35/80] #2903: semantics removed --- paper/eolang-paper.tex | 6 +++--- paper/sections/features.tex | 8 ++++---- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/paper/eolang-paper.tex b/paper/eolang-paper.tex index ba9d179fa4..d85e86d481 100644 --- a/paper/eolang-paper.tex +++ b/paper/eolang-paper.tex @@ -145,9 +145,9 @@ \section{Calculus} \label{sec:calculus} \input{sections/calculus} -\section{Semantics} -\label{sec:semantics} -\input{sections/semantics} +% \section{Semantics} +% \label{sec:semantics} +% \input{sections/semantics} \section{Pragmatics} \label{sec:pragmatics} diff --git a/paper/sections/features.tex b/paper/sections/features.tex index 35e6fb9293..458426a14d 100644 --- a/paper/sections/features.tex +++ b/paper/sections/features.tex @@ -55,7 +55,7 @@ Unlike Java or C++, \eolang{} doesn't allow programmers to alter the process of object construction or suggest alternative paths of object instantiation via additional constructions. -Instead, all arguments are assigned to attributes ``as is'' and can't be modified. +Instead, all arguments are attached to attributes ``as is'' and can't be modified. \feature{no-static}{No Static Entities} % @@ -114,8 +114,8 @@ \feature{no-global}{No Global Scope} % -All objects in \eolang{} are assigned to some attributes. Objects constructed -in the global scope of visibility are assigned to attributes of the +All objects in \eolang{} are attached to some attributes. Objects constructed +in the global scope of visibility are attached to attributes of the \(\Phi\) object of the highest level of abstraction. Newspeak and Eiffel are two programming languages that does not have global scope as well. @@ -130,7 +130,7 @@ always expose the same functionality, the former may represent mutable entities, being known as read-only references~\citep{birka2004practical}. For example, an attribute \ff{r} may have an object \ff{random.pseudo} -assigned to it, which is a random number generator. \eolang{} won't allow +attached to it, which is a random number generator. \eolang{} won't allow assigning another object to the attribute \ff{r}. However, every time the attribute is dataized, its value will be different. % From 0a5eec06ff3ede5828301941db5dfa6e7e736c53 Mon Sep 17 00:00:00 2001 From: maxonfjvipon Date: Thu, 29 Feb 2024 21:32:29 +0300 Subject: [PATCH 36/80] fix(#2873): fix 1 byte printing --- .../org/eolang/maven/print/samples/bytes.yaml | 6 +++++ .../print/samples/compares-bool-to-bytes.yaml | 26 +++++++++++++++++++ .../org/eolang/parser/xmir-to-eo-reversed.xsl | 4 +++ .../org/eolang/parser/xmir-to-eo.xsl | 4 +++ 4 files changed, 40 insertions(+) create mode 100644 eo-maven-plugin/src/test/resources/org/eolang/maven/print/samples/compares-bool-to-bytes.yaml diff --git a/eo-maven-plugin/src/test/resources/org/eolang/maven/print/samples/bytes.yaml b/eo-maven-plugin/src/test/resources/org/eolang/maven/print/samples/bytes.yaml index ae2963e4de..c736db83d2 100644 --- a/eo-maven-plugin/src/test/resources/org/eolang/maven/print/samples/bytes.yaml +++ b/eo-maven-plugin/src/test/resources/org/eolang/maven/print/samples/bytes.yaml @@ -1,5 +1,7 @@ origin: | EA-EA-EA-EA > xs + + 01- > one "hello" > ys @@ -10,6 +12,8 @@ origin: | straight: | EA-EA-EA-EA > xs + 01- > one + "hello" > ys TRUE > b1 @@ -19,6 +23,8 @@ straight: | reversed: | EA-EA-EA-EA > xs + 01- > one + "hello" > ys TRUE > b1 diff --git a/eo-maven-plugin/src/test/resources/org/eolang/maven/print/samples/compares-bool-to-bytes.yaml b/eo-maven-plugin/src/test/resources/org/eolang/maven/print/samples/compares-bool-to-bytes.yaml new file mode 100644 index 0000000000..770de12bb1 --- /dev/null +++ b/eo-maven-plugin/src/test/resources/org/eolang/maven/print/samples/compares-bool-to-bytes.yaml @@ -0,0 +1,26 @@ +origin: | + # Test. + [] > compares-bool-to-bytes + and. > @ + TRUE.eq 01- + FALSE.eq 00- +straight: | + # This is the default 64+ symbols comment in front of named abstract object. + [] > compares-bool-to-bytes + TRUE + .eq + 01- + .and > @ + FALSE + .eq + 00- +reversed: | + # This is the default 64+ symbols comment in front of named abstract object. + [] > compares-bool-to-bytes + and. > @ + eq. + TRUE + 01- + eq. + FALSE + 00- diff --git a/eo-parser/src/main/resources/org/eolang/parser/xmir-to-eo-reversed.xsl b/eo-parser/src/main/resources/org/eolang/parser/xmir-to-eo-reversed.xsl index e99b8bbca4..65bc2f72d8 100644 --- a/eo-parser/src/main/resources/org/eolang/parser/xmir-to-eo-reversed.xsl +++ b/eo-parser/src/main/resources/org/eolang/parser/xmir-to-eo-reversed.xsl @@ -158,6 +158,10 @@ SOFTWARE. -- + + + - + diff --git a/eo-parser/src/main/resources/org/eolang/parser/xmir-to-eo.xsl b/eo-parser/src/main/resources/org/eolang/parser/xmir-to-eo.xsl index a460c30952..c55a65e433 100644 --- a/eo-parser/src/main/resources/org/eolang/parser/xmir-to-eo.xsl +++ b/eo-parser/src/main/resources/org/eolang/parser/xmir-to-eo.xsl @@ -174,6 +174,10 @@ SOFTWARE. -- + + + - + From 685c10e0db78c34e5e30c7fa46f6b97ddf13338e Mon Sep 17 00:00:00 2001 From: rultor <8086956+rultor@users.noreply.github.com> Date: Thu, 29 Feb 2024 20:04:21 +0000 Subject: [PATCH 37/80] new version in README --- eo-maven-plugin/README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/eo-maven-plugin/README.md b/eo-maven-plugin/README.md index f3da683d73..2e329700a5 100644 --- a/eo-maven-plugin/README.md +++ b/eo-maven-plugin/README.md @@ -35,7 +35,7 @@ create a file `pom.xml` with this content (it's just a sample): org.eolang eo-maven-plugin - 0.35.3 + 0.35.4 @@ -156,7 +156,7 @@ execution within `eo-maven-plugin/pom.xml`: ... maven-invoker-plugin - 0.35.3 + 0.35.4 true true From 70f5a6bbe1337864f88cda6422fd68d1ec64b799 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 06:53:31 +0300 Subject: [PATCH 38/80] #2903: minor --- paper/eolang-paper.tex | 12 ++++++------ paper/sections/four.tex | 8 ++++++-- 2 files changed, 12 insertions(+), 8 deletions(-) diff --git a/paper/eolang-paper.tex b/paper/eolang-paper.tex index d85e86d481..3d55eaa0bb 100644 --- a/paper/eolang-paper.tex +++ b/paper/eolang-paper.tex @@ -149,13 +149,13 @@ \section{Calculus} % \label{sec:semantics} % \input{sections/semantics} -\section{Pragmatics} -\label{sec:pragmatics} -\input{sections/pragmatics} +% \section{Pragmatics} +% \label{sec:pragmatics} +% \input{sections/pragmatics} -\section{XMIR} -\label{sec:xmir} -\input{sections/xmir} +% \section{XMIR} +% \label{sec:xmir} +% \input{sections/xmir} \section{Key Features} \label{sec:features} diff --git a/paper/sections/four.tex b/paper/sections/four.tex index 6b7d98e62e..e52be2e667 100644 --- a/paper/sections/four.tex +++ b/paper/sections/four.tex @@ -1,6 +1,6 @@ In order to answer the question, whether the proposed object calculus is sufficient -to express any object model, we are going to demonstrate +to express any object model, in this Section we demonstrate how four fundamental principles of OOP are realized by \phic{}: encapsulation, abstraction, inheritance, and polymorphism. @@ -17,10 +17,14 @@ \subsection{Abstraction} `knife' used to carve our domain into discrete objects.'' In \phic{} objects are the elements the problem domain -is decomposed into, which goes along the claim of~\citet[p.24]{west2004object}: +is decomposed into. +This goes along the claim of~\citet[p.24]{west2004object}: ``objects, as abstractions of entities in the real world, represent a particularly dense and cohesive clustering of information.'' +% Mention that dynamic dispatch, as the main property of abstraction, +% exists in EO. + \subsection{Inheritance} Inheritance, according to~\citet{grady2007object}, is From f4b24bcd4093f4b29d0c7711ba89f66cecfd9e7e Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:02:56 +0300 Subject: [PATCH 39/80] #2903: natbib --- paper/DEPENDS.txt | 1 - paper/aspell.en.pws | 3 ++- paper/eolang-paper.tex | 12 ++++++++---- paper/sections/syntax.tex | 5 ++--- 4 files changed, 12 insertions(+), 9 deletions(-) diff --git a/paper/DEPENDS.txt b/paper/DEPENDS.txt index 940a7176cf..acc95de8de 100644 --- a/paper/DEPENDS.txt +++ b/paper/DEPENDS.txt @@ -3,7 +3,6 @@ hard algorithmicx hard algpseudocodex hard anyfontsize hard babel-russian -hard biblatex hard biber hard cancel hard catchfile diff --git a/paper/aspell.en.pws b/paper/aspell.en.pws index d8e09d0122..cb34b101d3 100644 --- a/paper/aspell.en.pws +++ b/paper/aspell.en.pws @@ -56,4 +56,5 @@ GOTO unary decoratee cmtt -attr \ No newline at end of file +attr +acmart \ No newline at end of file diff --git a/paper/eolang-paper.tex b/paper/eolang-paper.tex index 3d55eaa0bb..5941075c63 100644 --- a/paper/eolang-paper.tex +++ b/paper/eolang-paper.tex @@ -20,12 +20,11 @@ % OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE % SOFTWARE. -\documentclass[sigplan,nonacm,natbib=false]{acmart} +\documentclass[sigplan,nonacm]{acmart} \settopmatter{printfolios=false,printccs=false,printacmref=false} \usepackage[utf8]{inputenc} -\usepackage[maxnames=1,minnames=1,maxbibnames=100,natbib=true,citestyle=authoryear,bibstyle=authoryear,doi=false,url=false,isbn=false,isbn=false,backend=biber]{biblatex} -\addbibresource{main.bib} \usepackage[T2A,T1]{fontenc} +\usepackage{natbib} % for \citep and \citet \usepackage{stmaryrd} % for arrows, like \mapstochar \let\Bbbk\relax\usepackage{amssymb} % for special symbols \usepackage{amsmath} @@ -50,6 +49,9 @@ \usepackage{pgffor} % to enable \foreach \usepackage{mathtools} % for matrix* environment +\usepackage{silence} + \WarningFilter{acmart}{\vspace should only be used to provide space above/below} + \tolerance=1500 \raggedbottom \setlength\headheight{21pt} @@ -176,7 +178,9 @@ \section{Related Work} \section{Acknowledgments} \input{sections/acks} -\printbibliography +\raggedright +\bibliographystyle{ACM-Reference-Format} +\bibliography{main} \clearpage diff --git a/paper/sections/syntax.tex b/paper/sections/syntax.tex index 03cb76b4d3..39ef7979e7 100644 --- a/paper/sections/syntax.tex +++ b/paper/sections/syntax.tex @@ -221,8 +221,7 @@ \subsection{Data Objects and Tuples} r.times 3.14 > circumference \end{ffcode} -This syntax would be translated to XMIR (XML based -data format explained in \cref{sec:xmir}): +This syntax would be translated to XMIR (XML based data format): \begin{ffcode} (*@\label{ln:xml-circle}@*) @@ -342,7 +341,7 @@ \subsection{Decorators} center > @ (*@\label{ln:circle-phi}@*) [p] > is-inside lte. > @ - ^.@.distance \(.p |\)\label{ln:circle-phi-2}$| + ^.@.distance $.p (*@\label{ln:circle-phi-2}@*) ^.radius (*@\label{ln:circle-end}@*) \end{ffcode} From 10a56daffea94d5c46295509d7d7ffb5ea661c7a Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:05:07 +0300 Subject: [PATCH 40/80] #2903: makefile back --- paper/Makefile | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/paper/Makefile b/paper/Makefile index e62c3cc486..0e6437c60f 100644 --- a/paper/Makefile +++ b/paper/Makefile @@ -27,7 +27,7 @@ TLROOT=$$(kpsewhich -var-value TEXMFDIST) PACKAGES=ffcode to-be-determined href-ul minted REPO=objectionary/eo -gsed=\((if \)(shell which gsed),gsed,sed) +gsed=$(if $(shell which gsed),gsed,sed) zip: *.tex sections/*.tex rm -rf package @@ -36,12 +36,12 @@ zip: *.tex sections/*.tex cp ../eolang-paper.tex . cp ../phigure.sty . cp ../main.bib . - for p in \((PACKAGES); do cp \)(TLROOT)/tex/latex/$\({p}/\)${p}.sty .; done + for p in $(PACKAGES); do cp $(TLROOT)/tex/latex/$${p}/$${p}.sty .; done cp -r ../sections . - version=$\((curl --silent -H "Accept: application/vnd.github.v3+json" https://api.github.com/repos/\)(REPO)/releases/latest | jq -r '.tag_name') + version=$$(curl --silent -H "Accept: application/vnd.github.v3+json" https://api.github.com/repos/$(REPO)/releases/latest | jq -r '.tag_name') echo "Version is: $${version}" - \({gsed} -i "s|0\.0\.0|\)${version}|g" eolang-paper.tex - \({gsed} -i "s|REPOSITORY|\)(REPO)|g" eolang-paper.tex + ${gsed} -i "s|0\.0\.0|$${version}|g" eolang-paper.tex + ${gsed} -i "s|REPOSITORY|$(REPO)|g" eolang-paper.tex pdflatex -shell-escape -halt-on-error eolang-paper.tex > /dev/null biber eolang-paper pdflatex -halt-on-error eolang-paper.tex > /dev/null @@ -53,4 +53,5 @@ zip: *.tex sections/*.tex clean: git clean -dfX + clean -dfX From db44b388f43ef4549fc0051528e93fdeead09b43 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:05:16 +0300 Subject: [PATCH 41/80] #2903: typo --- paper/Makefile | 1 - 1 file changed, 1 deletion(-) diff --git a/paper/Makefile b/paper/Makefile index 0e6437c60f..e3483afd98 100644 --- a/paper/Makefile +++ b/paper/Makefile @@ -53,5 +53,4 @@ zip: *.tex sections/*.tex clean: git clean -dfX - clean -dfX From a149d53834d90c7341934fd16ef8b235eaede884 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:06:09 +0300 Subject: [PATCH 42/80] #2903: bibtex --- paper/Makefile | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/paper/Makefile b/paper/Makefile index e3483afd98..480c7a3ef3 100644 --- a/paper/Makefile +++ b/paper/Makefile @@ -22,6 +22,7 @@ .SHELLFLAGS = -e -x -c .ONESHELL: +.PHONY: clean TLROOT=$$(kpsewhich -var-value TEXMFDIST) PACKAGES=ffcode to-be-determined href-ul minted @@ -43,7 +44,7 @@ zip: *.tex sections/*.tex ${gsed} -i "s|0\.0\.0|$${version}|g" eolang-paper.tex ${gsed} -i "s|REPOSITORY|$(REPO)|g" eolang-paper.tex pdflatex -shell-escape -halt-on-error eolang-paper.tex > /dev/null - biber eolang-paper + bibtex eolang-paper pdflatex -halt-on-error eolang-paper.tex > /dev/null pdflatex -halt-on-error eolang-paper.tex > /dev/null rm -rf *.aux *.bcf *.blg *.fdb_latexmk *.fls *.log *.run.xml *.out *.exc From 7a3fb44fbe83cc4e27a566a2340ffc69de16480e Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:06:43 +0300 Subject: [PATCH 43/80] #2903: shell bash --- paper/Makefile | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/paper/Makefile b/paper/Makefile index 480c7a3ef3..800a4d8d06 100644 --- a/paper/Makefile +++ b/paper/Makefile @@ -20,9 +20,10 @@ # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE # SOFTWARE. -.SHELLFLAGS = -e -x -c +.SHELLFLAGS=-e -x -c .ONESHELL: .PHONY: clean +SHELL=bash TLROOT=$$(kpsewhich -var-value TEXMFDIST) PACKAGES=ffcode to-be-determined href-ul minted From 406aad9004c4ad2b76b272326f5897e14a55ad8c Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:07:59 +0300 Subject: [PATCH 44/80] #2903: ubuntu --- .github/workflows/latexmk.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/latexmk.yml b/.github/workflows/latexmk.yml index 5592eed7a6..44660dc755 100644 --- a/.github/workflows/latexmk.yml +++ b/.github/workflows/latexmk.yml @@ -11,7 +11,7 @@ concurrency: cancel-in-progress: true jobs: latexmk: - runs-on: ubuntu-latest + runs-on: ubuntu-22.04 steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 - uses: yegor256/latexmk-action@0.10.9 From 02c64151b03a2a8f236a8c7e4bd1713dda9f9a81 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:08:15 +0300 Subject: [PATCH 45/80] #2903: ubuntu --- .github/workflows/shellcheck.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/shellcheck.yml b/.github/workflows/shellcheck.yml index 856fc00c4f..a9df4f7e59 100644 --- a/.github/workflows/shellcheck.yml +++ b/.github/workflows/shellcheck.yml @@ -13,7 +13,7 @@ concurrency: jobs: shellcheck: name: Shellcheck - runs-on: ubuntu-latest + runs-on: ubuntu-22.04 steps: - uses: actions/checkout@v4 - name: Run ShellCheck From 8debc25fa6b9497156695ad2b4b8c442ee65a9e3 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:08:22 +0300 Subject: [PATCH 46/80] #2903: simplified --- .github/workflows/shellcheck.yml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/.github/workflows/shellcheck.yml b/.github/workflows/shellcheck.yml index a9df4f7e59..046e0cc281 100644 --- a/.github/workflows/shellcheck.yml +++ b/.github/workflows/shellcheck.yml @@ -16,5 +16,4 @@ jobs: runs-on: ubuntu-22.04 steps: - uses: actions/checkout@v4 - - name: Run ShellCheck - uses: ludeeus/action-shellcheck@master + - uses: ludeeus/action-shellcheck@master From ec49504003c9e107d51ade2c7a56cf002c6fb106 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:09:21 +0300 Subject: [PATCH 47/80] #2903: bibcop --- paper/eolang-paper.tex | 1 + 1 file changed, 1 insertion(+) diff --git a/paper/eolang-paper.tex b/paper/eolang-paper.tex index 5941075c63..e2a776ff26 100644 --- a/paper/eolang-paper.tex +++ b/paper/eolang-paper.tex @@ -39,6 +39,7 @@ \usepackage{cancel} % to enable \cancel command \usepackage{anyfontsize} % To get rid of font not found warnings \usepackage{eolang} % for EO sources and formulas +\usepackage{bibcop} % for checking quality of the .bib file \usepackage{tabularx} % for special tables \usepackage{to-be-determined} % for \tbd command \usepackage{href-ul} % for nicely underscored links From 650a189034df35958d5b09b9d69eedbd687cd1de Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:09:37 +0300 Subject: [PATCH 48/80] #2903: more --- paper/eolang-paper.tex | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/paper/eolang-paper.tex b/paper/eolang-paper.tex index e2a776ff26..f614fef14e 100644 --- a/paper/eolang-paper.tex +++ b/paper/eolang-paper.tex @@ -179,9 +179,9 @@ \section{Related Work} \section{Acknowledgments} \input{sections/acks} -\raggedright +{\raggedright \bibliographystyle{ACM-Reference-Format} -\bibliography{main} +\bibliography{main}} \clearpage From ffc671d5c131619ea977941c405a471018efd499 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:20:54 +0300 Subject: [PATCH 49/80] #2903: bibcop --- paper/DEPENDS.txt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/paper/DEPENDS.txt b/paper/DEPENDS.txt index acc95de8de..264fc0669e 100644 --- a/paper/DEPENDS.txt +++ b/paper/DEPENDS.txt @@ -48,4 +48,5 @@ hard upquote hard wrapfig hard xstring hard cleveref -hard adjustbox \ No newline at end of file +hard adjustbox +hard bibcop \ No newline at end of file From afdb1cba2f696e56697db8fe62fd2f73a24e1275 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 07:30:01 +0300 Subject: [PATCH 50/80] #2903: silence --- paper/DEPENDS.txt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/paper/DEPENDS.txt b/paper/DEPENDS.txt index 264fc0669e..aecf3fc238 100644 --- a/paper/DEPENDS.txt +++ b/paper/DEPENDS.txt @@ -49,4 +49,5 @@ hard wrapfig hard xstring hard cleveref hard adjustbox -hard bibcop \ No newline at end of file +hard bibcop +hard silence \ No newline at end of file From 21803cdfa7bc5a4c21e2a8cbeb7668be3da85c76 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 09:39:08 +0300 Subject: [PATCH 51/80] new eo sty --- paper/eolang.sty | 916 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 916 insertions(+) create mode 100644 paper/eolang.sty diff --git a/paper/eolang.sty b/paper/eolang.sty new file mode 100644 index 0000000000..a5ad5ad52f --- /dev/null +++ b/paper/eolang.sty @@ -0,0 +1,916 @@ +%% +%% This is file `eolang.sty', +%% generated with the docstrip utility. +%% +%% The original source files were: +%% +%% eolang.dtx (with options: `package') +%% (The MIT License) +%% +%% Copyright (c) 2021-2024 Yegor Bugayenko +%% +%% 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 NONINFRINGEMENT. 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. + + + +\NeedsTeXFormat{LaTeX2e} +\ProvidesPackage{eolang} +[0000-00-00 0.0.0 Formulas and Graphs for EO Programming Language] + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +\RequirePackage{stmaryrd} +\RequirePackage{amsmath} +\let\Bbbk\relax\RequirePackage{amssymb} +\RequirePackage{fancyvrb} +\ifdefined\eolang@noshell\else\RequirePackage{iexec}\fi + +\RequirePackage{pgfopts} +\RequirePackage{ifluatex} +\RequirePackage{ifxetex} +\pgfkeys{ + /eolang/.cd, + tmpdir/.store in=\eolang@tmpdir, + tmpdir/.default=_eolang\ifxetex-xe\else\ifluatex-lua\fi\fi, + nocomments/.store in=\eolang@nocomments, + anonymous/.store in=\eolang@anonymous, + noshell/.store in=\eolang@noshell, + tmpdir +} +\ProcessPgfPackageOptions{/eolang} + +\makeatletter +\ifdefined\eolang@noshell\else\RequirePackage{shellesc}\fi +\IfFileExists + {\eolang@tmpdir/\jobname} + {\message{eolang: Temporary directory "\eolang@tmpdir/\jobname" + already exists^^J}} + { + \ifdefined\eolang@noshell + \message{eolang: Temporary directory "\eolang@tmpdir/\jobname" + is not created, because of the "noshell" package option, + most probably the compilation will fail later^^J} + \else + \ifnum\ShellEscapeStatus=1 + \iexec[null]{mkdir -p "\eolang@tmpdir/\jobname"} + \else + \message{eolang: Temporary directory "\eolang@tmpdir/\jobname" + is not created, because -shell-escape is not set, and + it doesn't exist, most probably the compilation + will fail later^^J} + \fi + \fi + } +\makeatother + +\makeatletter\newcounter{eolang@lineno}\makeatother + +\RequirePackage{pdftexcmds} +\makeatletter +\newcommand\eolang@mdfive[1]{\pdf@filemdfivesum{#1}} +\makeatother + +\makeatletter +\ifdefined\eolang@noshell + \message{eolang: Perl script is not going to be created, + at "\eolang@tmpdir/\jobname-phi.pl" because of the "noshell" + package option^^J} +\else +\openin 15=\eolang@tmpdir/\jobname-phi.pl +\ifeof 15 +\message{eolang: Perl script is going to be created, + because it is absent at "\eolang@tmpdir/\jobname-phi.pl", + but if -shell-escape is not set, the compilation will + most likely fail now^^J} +\begin{VerbatimOut}{\eolang@tmpdir/\jobname-phi.pl} +$macro = $ARGV[0]; +open(my $fh, '<', $ARGV[1]); +my $tex; { local $/; $tex = <$fh>; } +print "% This file is auto-generated by 0.0.0\n"; +print '% There are ', length($tex), + ' chars in the input: ', $ARGV[1], "\n"; +print '% ---', "\n"; +if (index($tex, "\t") > 0) { + print "TABS are prohibited!"; + exit 1; +} +my @lines = split (/\n/g, $tex); +foreach my $t (@lines) { + print '% ', $t, "\n"; +} +print '% ---', "\n"; +$tex =~ s/(?= 0) { + $macro =~ s/equation/align/g; + $align = 1; + print '% The "align" is used because of && seen in the text' . "\n"; +} +if ($macro ne 'phiq') { + if (not $splitting) { + $tex =~ s/\\\\\n/\n\n/g; + $tex =~ s/\\\n\s*//g; + } + $tex =~ s/\n*(\\label\{[^\}]+\})\n*/\1/g; + $tex =~ s/\n{3,}/\n\n/g; +} +my @texts = (); +sub trep { + my ($s) = @_; + my $open = 0; + my $p = 0; + for (; $p < length($s); $p++) { + $c = substr($s, $p, 1); + if ($c eq '}') { + if ($open eq 0) { + last; + } + $open--; + } + if ($c eq '{') { + $open++; + } + } + push(@texts, substr($s, 0, $p)); + return '{TEXT' . (0+@texts - 1) . '}' . substr($s, $p + 1); +} +$tex =~ s/\\text\{(.+)/trep("$1")/ge; +if (not $splitting) { + $tex =~ s/(?/\1\\Delta{}..>/g; +$tex =~ s/([^\\{a-z0-9]|^)L>/\1\\lambda{}..>/g; +$tex =~ s/"([^"]+)"/|"\1"|/g; +$tex =~ s/(^|(?<=[\s)(\]\[,.>\/]))([a-zA-Z][a-z0-9]+)(?=[\s)(\]\[,.-]|$)/|\2|/g; +$tex =~ s/([^_^]|^)([0-9]+|\*)\/(\\?[a-z]+|\|[a-z]+\|) + (->|\.\.>|~>|:=|!->)/\1\\alpha_{\2}\\vert{}\3\\space{}\4/xg; +$tex =~ s/([^_^]|^)([0-9]+|\*) + (->|\.\.>|~>|:=|!->)/\1\\alpha_{\2}\\space{}\3/xg; +if ($macro ne 'phiq') { + if (not $splitting) { + $tex =~ s/\\begin\{split\}\n/\\begin{split}&/g; + $tex =~ s/\n\s*\\end\{split\}/\\end{split}/g; + $tex =~ s/\n\n/\\\\&/g; + $tex =~ s/\n/\\phiEOL{}\n&/g; + $tex =~ s/\\\\$//g; + $tex =~ s/\\\\/\\\\\n/g; + $tex =~ s/([^&\s])\s{2}([^\s])/\1 \2/g; + $tex =~ s/\s{2}/ \\quad{}/g; + $tex = '&' . $tex; + } + my $lead = '[^\s]+\s(?:->|:=|=|==)\s'; + my @leads = $tex =~ /&${lead}/g; + my @eols = $tex =~ /&/g; + if (0+@leads == 0+@eols && 0+@eols > 1) { + $tex =~ s/&(${lead})/\1&~/g; + $gathered = 0; + print '% The "gathered" is NOT used because all ' . + (0+@eols) . ' lines are ' . (0+@leads) . " leads\n"; + } +} +if ($macro ne 'phiq') { + sub strip_tabs { + my ($env, $tex) = @_; + $tex =~ s/&//g; + return "\\begin{$env}" . $tex . "\\end{$env}"; + } + foreach my $e (('matrix', 'cases')) { + $tex =~ s/\\begin\{(\Q$e\E\*?)\}(.+)\\end\{\Q$e\E\*?\}/strip_tabs($1, $2)/sge; + } +} +$tex =~ s/\$/\\xi{}/g; +$tex =~ s/(?(])([0-9A-F]{2}(?:-[0-9A-F]{2})+| + [0-9]+(?:\.[0-9]+)?)(?!\{)/\1|\2|/xg; +$tex =~ s/TRUE/|TRUE|/g; +$tex =~ s/FALSE/|FALSE|/g; +$tex =~ s/\?/\\varnothing{}/g; +$tex =~ s/@/\\varphi{}/g; +$tex =~ s/-([a-z]+)>/\\mathrel{\\phiSlot{\1}}/g; +$tex =~ s/!->/\\mathbin{\\phiConst}/g; +$tex =~ s/->/\\mathbin{\\mapsto}/g; +$tex =~ s/~>/\\mathbin{\\phiWave}/g; +$tex =~ s/:=/\\mathrel{\\vDash}/g; +$tex =~ s/==/\\mathrel{\\equiv}/g; +$tex =~ s/\.\.>/\\mathbin{\\phiDotted}/g; +$tex =~ s/<>/\\rangle/g; +$tex =~ s/\|{2,}/|/g; +$tex =~ s/\|([^\|]+)\|/\\textnormal{\\texttt{\1}}{}/g; +$tex =~ s/\{TEXT(\d+)\}/'\\text{' . @texts[$1] . '}';/ge; +if ($macro eq 'phiq') { + print '\(' if ($tex ne ''); +} else { + print '\begin{', $macro, "}\n"; + if (not($align)) { + if ($gathered) { + print '\begin{gathered}' . "\n"; + } elsif (not $splitting) { + print '\begin{split}' . "\n"; + } + } +} +if ($gathered and not($align)) { + $tex =~ s/^&//g; + $tex =~ s/\n&/\n/g; +} +print $tex; +if ($macro eq 'phiq') { + print '\)' if ($tex ne ''); +} else { + if (not($align)) { + if ($gathered) { + print "\n" . '\end{gathered}'; + } elsif (not $splitting) { + print "\n" . '\end{split}'; + } + } + print "\n" . '\end{' . $macro . '}'; +} +print '\endinput'; +\end{VerbatimOut} +\message{eolang: File with Perl script + '\eolang@tmpdir/\jobname-phi.pl' saved^^J} +\else + \message{eolang: Perl script already exists at + "\eolang@tmpdir/\jobname-phi.pl"^^J} +\fi +\closein 15 +\fi +\makeatother + +\makeatletter +\newcommand\phiSaveTo[1]{\def\eolang@phiSaveTo{#1}} +\makeatother + +\makeatletter +\newcommand\eolang@ifabsent[2]{% + \IfFileExists + {#1} + {% + \message{eolang: File "#1" already exists ^^J}% + \input{#1}} + {% + \ifdefined\eolang@noshell% + \message{eolang: Shell processing is disabled^^J}% + \else% + \ifnum\ShellEscapeStatus=1\else% + \message{eolang: The -shell-escape command line + option is not provided, most probably compilation + will fail now:^^J}% + \fi% + #2% + \fi% + }% +} +\makeatother + +\makeatletter\newcommand\eolang@process[1]{ + \def\hash{\eolang@mdfive + {\eolang@tmpdir/\jobname/phiquation.tex}-\the\inputlineno}% + \eolang@ifabsent + {\eolang@tmpdir/\jobname/\hash-phiquation-post.tex} + {% + \iexec[null]{cp "\eolang@tmpdir/\jobname/phiquation.tex" + "\eolang@tmpdir/\jobname/\hash-phiquation.tex"}% + \message{Start parsing 'phi' at line no. \the\inputlineno^^J} + \iexec[trace,stdout=\eolang@tmpdir/\jobname/\hash-phiquation-post.tex]{ + perl "\eolang@tmpdir/\jobname-phi.pl" + '#1' + "\eolang@tmpdir/\jobname/\hash-phiquation.tex" + \ifdefined\eolang@nocomments | perl -pe 's/\%.*(\\n|$)//g'\fi + \ifdefined\eolang@phiSaveTo > \eolang@phiSaveTo\fi}% + }% + \setcounter{FancyVerbLine}{\value{eolang@lineno}}% + \def\eolang@phiSaveTo{\relax}% +} +\newenvironment{phiquation*}% +{\catcode`\|=12 \VerbatimEnvironment% +\setcounter{eolang@lineno}{\value{FancyVerbLine}}% +\begin{VerbatimOut} + {\eolang@tmpdir/\jobname/phiquation.tex}} +{\end{VerbatimOut}\eolang@process{equation*}} +\newenvironment{phiquation}% +{\catcode`\|=12 \VerbatimEnvironment% +\setcounter{eolang@lineno}{\value{FancyVerbLine}}% +\begin{VerbatimOut} + {\eolang@tmpdir/\jobname/phiquation.tex}} +{\end{VerbatimOut}\eolang@process{equation}} +\makeatother + +\RequirePackage{xstring} +\makeatletter\newcommand\phiq[1]{% + \StrSubstitute{\detokenize{#1}}{'}{'"'"'}[\clean]% + \def\hash{\pdf@mdfivesum{\clean}-\the\inputlineno}% + \ifdefined\eolang@nodollar\else\catcode`\$=3 \fi% + \eolang@ifabsent + {\eolang@tmpdir/\jobname/\hash-phiq-post.tex} + {% + \iexec[log,trace,quiet,stdout=\eolang@tmpdir/\jobname/phiq.tex]{ + /bin/echo '\clean'}% + \iexec[quiet,null]{cp "\eolang@tmpdir/\jobname/phiq.tex" + "\eolang@tmpdir/\jobname/\hash-phiq.tex"}% + \iexec[trace,stdout=\eolang@tmpdir/\jobname/\hash-phiq-post.tex]{ + perl \eolang@tmpdir/\jobname-phi.pl 'phiq' + "\eolang@tmpdir/\jobname/\hash-phiq.tex" + \ifdefined\eolang@nocomments | perl -pe 's/\%.*(\\n|$)//g' \fi}% + \message{eolang: Parsed `phiq' at line no. \the\inputlineno^^J}% + }% + \ifdefined\eolang@nodollar\else\catcode`\$\active\fi% +}\makeatother + +\ifdefined\eolang@nodollar\else + \begingroup + \catcode`\$=\active + \protected\gdef$#1${\phiq{#1}} + \endgroup + \AtBeginDocument{\catcode`\$=\active} +\fi + +\makeatletter +\ifdefined\eolang@noshell +\message{eolang: Perl script is not going to be created + at "\eolang@tmpdir/\jobname-sodg.pl", because of the + "noshell" package option^^J} +\else +\openin 15=\eolang@tmpdir/\jobname-sodg.pl +\ifeof 15 +\message{eolang: Perl script is going to be created, + because it is absent at "\eolang@tmpdir/\jobname-sodg.pl", + but if -shell-escape is not set, the compilation will + most likely fail now^^J} +\begin{VerbatimOut}{\eolang@tmpdir/\jobname-sodg.pl} +sub num { + my ($i) = @_; + $i =~ s/(\+|-)\./\10./g; + return $i; +} +sub fmt { + my ($tex) = @_; + $tex =~ s/\|([^\|]+)\|/\\textnormal{\\texttt{\1}}/g; + return $tex; +} +sub toem { + my ($cm) = @_; + return $cm * 2.8; +} +sub vertex { + my ($v) = @_; + if (index($v, 'v0') == 0) { + return '\Phi'; + } else { + $v =~ s/^v/v_{/g; + $v =~ s/[^0-9]$//g; + return $v . '}'; + } +} +sub tailor { + my ($t, $m) = @_; + $t =~ s/<([A-Z]?${m}[A-Z]?):([^>]+)>/\2/g; + $t =~ s/<[A-Z]+:[^>]+>//g; + return $t; +} +open(my $fh, '<', $ARGV[0]); +my $tex; { local $/; $tex = <$fh>; } +if (index($tex, "\t") > 0) { + print "TABS are prohibited!"; + exit 1; +} +print '% This file is auto-generated', "\n%\n"; +print '% --- there are ', length($tex), + ' chars in the input (', $ARGV[0], "):\n"; +foreach my $t (split (/\n/g, $tex)) { + print '% ', $t, "\n"; +} +print "% ---\n"; +$tex =~ s/\\\\/\n/g; +$tex =~ s/\\\n//g; +$tex =~ s/(\\[a-zA-Z]+)\s+/\1/g; +$tex =~ s/\n{2,}/\n/g; +my @cmds = split(/\n/g, $tex); +print '% --- before processing:' . "\n"; +foreach my $t (split (/\n/g, $tex)) { + print '% ', $t, "\n"; +} +print '% ---'; +print ' (' . (0+@cmds) . " lines)\n"; +print '\begin{phicture}', "\n"; +for (my $c = 0; $c < 0+@cmds; $c++) { + my $cmd = $cmds[$c]; + $cmd =~ s/^\s+//g; + $cmd =~ s/(?') >= 0) { + my $draw = '\draw['; + if (exists $opts{'pi'}) { + $draw = $draw . ''; + if (not exists $opts{'a'}) { + $opts{'a'} = '\pi'; + } + } + if (exists $opts{'rho'} and not(exists $opts{'bend'})) { + $draw = $draw . ''; + } + $draw = $draw . ',' . $opts{'style'} . ']'; + my ($from, $to) = split (/->/, $head); + $draw = $draw . " (${from}) "; + if (exists $opts{'bend'}) { + $draw = $draw . 'edge ['; + if (exists $opts{'rho'}) { + $draw = $draw . ''; + } + $draw = $draw . ']'; + } else { + $draw = $draw . '--'; + } + if (exists $opts{'a'}) { + my $a = $opts{'a'}; + if (index($a, '$') == -1) { + $a = '$' . fmt($a) . '$'; + } else { + $a = fmt($a); + } + $draw = $draw . ''; + } + if (exists $opts{'break'}) { + $draw = $draw . ''; + } + $draw = $draw . " ()"; + if (exists $opts{'break'}) { + print tailor($draw, 'F') . ";\n"; + print ' \node[outer sep=' . toem(0.1) . 'em,inner sep=0em] ' . + 'at (break) (break-v) {$' . vertex($to) . + '$};' . "\n"; + print ' ' . tailor($draw, 'B'); + } else { + print tailor($draw, 'M'); + } + } elsif (index($head, '=>') >= 0) { + my ($from, $to) = split (/=+>/, $head); + my $size = () = $head =~ /=/g; + if ($from eq '') { + print '\node [phi-arrow, left=' . toem($size * 0.6) . 'em of ' . + $to . '.center]'; + } elsif ($to eq '') { + print '\node [phi-arrow, right=' . toem($size * 0.6) . 'em of ' . + $from . '.center]'; + } else { + print '\node [phi-arrow] at ($(' . + $from . ')!0.5!(' . $to . ')$)'; + } + print '{}'; + } elsif (index($head, '!') >= 0) { + my ($v, $marker) = split (/!+/, $head); + my $size = () = $head =~ /!/g; + print '\node [phi-marker, left=' . + toem($size * 0.6) . 'em of ' . + $v . '.center]{' . fmt($marker) . '}'; + } elsif (index($head, '+') >= 0) { + my ($v, $suffix) = split (/\+/, $head); + my @friends = ($v); + foreach my $c (@cmds) { + $e = $c; + $e =~ s/^\s+//g; + my $h = $e; + $h = substr($e, 0, index($e, ' ')) if index($e, ' ') >= 0; + foreach my $f (@friends) { + my $add = ''; + if (index($h, $f . '->') >= 0) { + $add = substr($h, index($h, '->') + 2); + } + if ($h =~ /->\Q${f}\E$/) { + $add = substr($h, 0, index($h, '->')); + } + if (index($e, ' xy:' . $f . ',') >= 0) { + $add = $h; + } + if (index($add, '+') == -1 + and $add ne '' + and not(grep(/^\Q${add}\E$/, @friends))) { + push(@friends, $add); + } + } + } + my @extra = (); + foreach my $e (@cmds) { + $m = $e; + if ($m =~ /^\s*\Q${v}\E\s/) { + next; + } + if ($m =~ /^\s*[^\s]+\+/ and not($m =~ /^\s*\Q${head}\E\s/)) { + next; + } + foreach my $f (@friends) { + my $h = $f; + $h =~ s/[a-z]$//g; + if ($m =~ s/^(\s*)\Q${f}\E\+\Q${suffix}\E\s?/\1${h}${suffix} /g) { + last; + } + $m =~ s/^(\s*)\Q${f}\E\s/\1${h}${suffix} /g; + $m =~ s/^(\s*)\Q${f}\E->/\1${h}${suffix}->/g; + $m =~ s/\sxy:\Q${f}\E,/ xy:${h}${suffix},/g; + $m =~ s/->\Q${f}\E\s/->${h}${suffix} /g; + } + if ($m ne $e) { + push(@extra, ' ' . $m); + } + } + splice(@extra, 0, 0, @extra[-1]); + splice(@extra, -1, 1); + splice(@extra, 0, 0, '% clone of ' . $v . ' (' . $head . + '), friends: [' . join(', ', @friends) . '] in ' . + (0+@cmds) . ' lines'); + splice(@cmds, $c, 1, @extra); + print '% cloned ' . $v . ' at line no.' . $c . + ' (+' . (0+@extra) . ' lines -> ' . + (0+@cmds) . ' lines total)'; + } elsif ($head =~ /^v[0-9]+[a-z]?$/) { + print '\node['; + if (exists $opts{'xy'}) { + my ($v, $right, $down) = split(/,/, $opts{'xy'}); + my $loc = ''; + if ($down > 0) { + $loc = 'below '; + } elsif ($down < 0) { + $loc = 'above '; + } + if ($right > 0) { + $loc = $loc . 'right'; + } elsif ($right < 0) { + $loc = $loc . 'left'; + } + print ',' . $loc . '='; + print toem(abs(num($down))) . 'em and ' . + toem(abs(num($right))) . 'em of ' . $v . '.center'; + } + if (exists $opts{'data'}) { + print ',phi-data'; + if ($opts{'data'} ne '') { + my $d = $opts{'data'}; + if (index($d, '|') == -1) { + $d = '$\Delta\phiDotted\text{' . + '\textnormal{\texttt{' . fmt($d) . '}}}$'; + } else { + $d = fmt($d); + } + $opts{'box'} = $d; + } + } elsif (exists $opts{'atom'}) { + print ',phi-atom'; + if ($opts{'atom'} ne '') { + my $a = $opts{'atom'}; + if (index($a, '$') == -1) { + $a = '$\lambda\phiDotted{}' . fmt($a) . '$'; + } else { + $a = fmt($a); + } + $opts{'box'} = $a; + } + } else { + print ',phi-object'; + } + if (exists $opts{'edgeless'}) { + print ',draw=none'; + } + print ',' . $opts{'style'} . ']'; + print ' (' . $head . ')'; + print ' {'; + if (exists $opts{'tag'}) { + my $t = $opts{'tag'}; + if (index($t, '$') == -1) { + $t = '$' . $t . '$'; + } else { + $t = fmt($t); + } + print $t; + } else { + print '$' . vertex($head) . '$'; + } + print '}'; + if (exists $opts{'box'}) { + print ' node[phi-box] at ('; + print $head, '.south east) {'; + print $opts{'box'}, '}'; + } + } + print ";\n"; +} +print '\end{phicture}%', "\n"; +print "% --- after processing:\n%"; +foreach my $c (@cmds) { + print '% ', $c, "\n"; +} +print '% --- (' . (0+@cmds) . " lines)\n"; +print '\endinput'; +\end{VerbatimOut} +\message{eolang: File with Perl script + '\eolang@tmpdir/\jobname-sodg.pl' saved^^J} +\else + \message{eolang: Perl script already exists at + "\eolang@tmpdir/\jobname-sodg.pl"^^J} +\fi +\closein 15 +\fi +\makeatother + +\setcounter{FancyVerbLine}{0} + +\RequirePackage{tikz} + \usetikzlibrary{arrows} + \usetikzlibrary{shapes} + \usetikzlibrary{decorations} + \usetikzlibrary{decorations.pathmorphing} + \usetikzlibrary{decorations.pathreplacing} + \usetikzlibrary{positioning} + \usetikzlibrary{calc} + \usetikzlibrary{math} + \usetikzlibrary{arrows.meta} + +\newenvironment{phicture}% + {\noindent\begin{tikzpicture}[ + ->,>=stealth',node distance=0,line width=.08em, + pics/parallel arrow/.style={ + code={\draw[-latex,phi-rho] (##1) -- (-##1);}}]}% + {\end{tikzpicture}} +\tikzstyle{phi-arrow} = [fill=white!80!black, single arrow, + minimum height=0.05em, minimum width=0.05em, + single arrow head extend=2mm] +\tikzstyle{phi-marker} = [inner sep=0pt, minimum height=1.4em, + minimum width=1.4em, font={\small\color{white}\ttfamily}, + fill=gray] +\tikzstyle{phi-thing} = [inner sep=0pt,minimum height=2.4em, + draw,font={\small}] +\tikzstyle{phi-object} = [phi-thing,circle] +\tikzstyle{phi-data} = [phi-thing,regular polygon, + regular polygon sides=8] +\tikzstyle{phi-empty} = [phi-object] +\tikzset{% + phi-rho/.style={ + postaction={% + decoration={ + show path construction, + curveto code={ + \tikzmath{ + coordinate \I, \F, \v; + \I = (\tikzinputsegmentfirst); + \F = (\tikzinputsegmentlast); + \v = ($(\I) -(\F)$); + real \d, \a, \r, \t; + \d = 0.8; + \t = atan2(\vy, \vx); + if \vx<0 then { \a = 90; } else { \a = -90; }; + { + \draw[arrows={-latex}, decorate, + decoration={% + snake, amplitude=.4mm, + segment length=2mm, + post length=1mm + }] + ($(\F)!.5!(\I) +(\t: -\d em) +(\t +\a: 1ex)$) + -- ++(\t: 2*\d em); + }; + } + }, + lineto code={ + \tikzmath{ + coordinate \I, \F, \v; + \I = (\tikzinputsegmentfirst); + \F = (\tikzinputsegmentlast); + \v = ($(\I) -(\F)$); + real \d, \a, \r, \t; + \d = 0.8; + \t = atan2(\vy, \vx); + if \vx<0 then { \a = 90; } else { \a = -90; }; + { + \draw[arrows={-latex}, decorate, + decoration={% + snake, amplitude=.4mm, + segment length=2mm, + post length=1mm}] + ($(\F)!.5!(\I) +(\t: -\d em) +(\t +\a: 1ex)$) + -- ++(\t: 2*\d em); + }; + } + } + }, + decorate + } + } +} +\tikzstyle{phi-pi} = [draw,dotted] +\tikzstyle{phi-atom} = [phi-object,double] +\tikzstyle{phi-box} = [xshift=-5pt,yshift=3pt,draw,fill=white, + rectangle,line width=.04em,minimum width=1.2em,anchor=north west, + font={\scriptsize}] +\tikzstyle{phi-attr} = [midway,sloped,inner sep=0pt, + above=2pt,sloped/.append style={transform shape}, + font={\scriptsize},color=black] + +\makeatletter +\newcommand\sodgSaveTo[1]{\def\eolang@sodgSaveTo{#1}} +\makeatother + +\makeatletter\newenvironment{sodg}% +{\catcode`\|=12 \VerbatimEnvironment% +\setcounter{eolang@lineno}{\value{FancyVerbLine}}% +\begin{VerbatimOut} + {\eolang@tmpdir/\jobname/sodg.tex}} +{\end{VerbatimOut}% + \def\hash{\eolang@mdfive + {\eolang@tmpdir/\jobname/sodg.tex}-\the\inputlineno}% + \catcode`\$=3 % + \eolang@ifabsent + {\eolang@tmpdir/\jobname/\hash-sodg-post.tex} + {% + \iexec[null]{cp "\eolang@tmpdir/\jobname/sodg.tex" + "\eolang@tmpdir/\jobname/\hash-sodg.tex"}% + \message{eolang: Start parsing `sodg' at line no. \the\inputlineno^^J} + \iexec[trace,stdout=\eolang@tmpdir/\jobname/\hash-sodg-post.tex]{ + perl "\eolang@tmpdir/\jobname-sodg.pl" + "\eolang@tmpdir/\jobname/\hash-sodg.tex" + \ifdefined\eolang@nocomments | perl -pe 's/\%.*(\\n|$)//g'\fi + \ifdefined\eolang@sodgSaveTo > \eolang@sodgSaveTo\fi}% + } + \catcode`\$\active% + \setcounter{FancyVerbLine}{\value{eolang@lineno}}% + \def\eolang@sodgSaveTo{\relax}% +}\makeatother + +\RequirePackage{hyperref} +\pdfstringdefDisableCommands{ + \def\({}% + \def\){}% + \def\alpha{alpha}% + \def\varphi{phi}% +} +\makeatletter +\NewExpandableDocumentCommand{\eoAnon}{O{ANONYMIZED}m}{% + \ifdefined\eolang@anonymous% + \textcolor{orange}{#1}% + \else% + #2% + \fi% +}\makeatother + +\newcommand\eolang{% + \eoAnon[XYZ]{{\sffamily EO}}} + +\newcommand\phic{% + \eoAnon[\(\alpha\)-cal\-cu\-lus]{\(\varphi\)-cal\-cu\-lus}} + +\newcommand\xmir{% + \eoAnon[XML\(^+\)]{XMIR}} + +\newcommand\phiConst{% + \mathrel{\hspace{.15em}}% + \mapstochar\mathrel{\hspace{-.15em}}\mapsto} + +\newcommand\phiWave{% + \mapstochar\mathrel{\mspace{0.45mu}}\leadsto} + +\newcommand\phiSlot[1]{% + \xrightarrow{\text{\sffamily\scshape #1}}} + +\makeatletter +\newcommand{\phiOset}[2]{% + \mathrel{\mathop{#2}\limits^{ + \vbox to 0ex{\kern-2\ex@ + \hbox{$\scriptscriptstyle#1$}\vss}}}} +\newcommand{\phiUset}[2]{% + \mathrel{\mathop{#2}\limits_{ + \vbox to 0ex{\kern-6.3\ex@ + \hbox{$\scriptscriptstyle#1$}\vss}}}} +\makeatother + +\newcommand\phiMany[3]{% + \phiOset{#3}{\phiUset{#2}{#1}}} + +\newcommand\phiEOL{\\[-4pt]} + +\RequirePackage{trimclip} +\RequirePackage{amsfonts} +\makeatletter +\newcommand{\phiDotted}{% + \mapstochar\mathrel{\mathpalette\phiDotted@\relax}} +\newcommand{\phiDotted@}[2]{% + \begingroup% + \settowidth{\dimen\z@}{$\m@th#1\rightarrow$}% + \settoheight{\dimen\tw@}{$\m@th#1\rightarrow$}% + \sbox\z@{% + \makebox[\dimen\z@][s]{% + \clipbox{0 0 {0.4\width} 0}% + {\resizebox{\dimen\z@}{\height}% + {$\m@th#1\dashrightarrow$}}% + \hss% + \clipbox{{0.69\width} {-0.1\height} 0 + {-\height}}{$\m@th#1\rightarrow$}% + }% + }% + \ht\z@=\dimen\tw@ \dp\z@=\z@% + \box\z@% + \endgroup% +} +\makeatother + + + +\endinput +%% +%% End of file `eolang.sty'. From edc4c7b0de917ce46db48a54f6bcf335f7d20bca Mon Sep 17 00:00:00 2001 From: maxonfjvipon Date: Fri, 1 Mar 2024 12:01:46 +0300 Subject: [PATCH 52/80] fix(#2806): removed mixing notations in vmethod --- .../src/main/antlr4/org/eolang/parser/Eo.g4 | 24 ++------------- .../java/org/eolang/parser/XeEoListener.java | 30 ------------------- .../packs/syntax/hmethod-after-vmethod.yaml | 11 ------- .../parser/typos/hmethod-after-vmethod.yaml | 4 +++ .../typos/vmethod-after-happlication.yaml | 4 +++ .../parser/typos/vmethod-after-hmethod.yaml | 4 +++ .../src/test/eo/org/eolang/ram-tests.eo | 3 +- 7 files changed, 17 insertions(+), 63 deletions(-) delete mode 100644 eo-parser/src/test/resources/org/eolang/parser/packs/syntax/hmethod-after-vmethod.yaml create mode 100644 eo-parser/src/test/resources/org/eolang/parser/typos/hmethod-after-vmethod.yaml create mode 100644 eo-parser/src/test/resources/org/eolang/parser/typos/vmethod-after-happlication.yaml create mode 100644 eo-parser/src/test/resources/org/eolang/parser/typos/vmethod-after-hmethod.yaml diff --git a/eo-parser/src/main/antlr4/org/eolang/parser/Eo.g4 b/eo-parser/src/main/antlr4/org/eolang/parser/Eo.g4 index b6059e31ee..d20f84d6c7 100644 --- a/eo-parser/src/main/antlr4/org/eolang/parser/Eo.g4 +++ b/eo-parser/src/main/antlr4/org/eolang/parser/Eo.g4 @@ -420,22 +420,13 @@ vmethodOptional // So in order to avoid it this block was described in more detail // Head of vertical method can be: // 1. vertical method -// 2. horizontal method -// 3. vertical application -// 4. horizontal application. The same logic as with a vertical application -// 5. just an object reference +// 2. vertical application +// 3. just an object reference // Ends on the next line vmethodHead : vmethodHead methodTailOptional vmethodHeadApplicationTail | vmethodHeadVapplication - | vmethodHeadCurrent EOL - ; - -// Head of vertical method that ends on the current line -vmethodHeadCurrent - : vmethodHeadHapplication - | vmethodHeadHmethodExtended - | justNamed + | justNamed EOL ; methodTailOptional @@ -448,10 +439,6 @@ vmethodHeadApplicationTail | happlicationTail oname? EOL ; -vmethodHeadHmethodExtended - : hmethodOptional oname? - ; - // Vertical application as head of vertical method // Ends on the next line vmethodHeadVapplication @@ -459,11 +446,6 @@ vmethodHeadVapplication | reversed oname? vapplicationArgsReversed ; -vmethodHeadHapplication - : (applicable | hmethodExtended) happlicationTail oname? - | happlicationReversed oname? - ; - // Tail of method methodTail : DOT finisherCopied diff --git a/eo-parser/src/main/java/org/eolang/parser/XeEoListener.java b/eo-parser/src/main/java/org/eolang/parser/XeEoListener.java index 321e2cbe76..21a0f0fe12 100644 --- a/eo-parser/src/main/java/org/eolang/parser/XeEoListener.java +++ b/eo-parser/src/main/java/org/eolang/parser/XeEoListener.java @@ -963,16 +963,6 @@ public void exitVmethodHead(final EoParser.VmethodHeadContext ctx) { // Nothing here } - @Override - public void enterVmethodHeadCurrent(final EoParser.VmethodHeadCurrentContext ctx) { - // Nothing here - } - - @Override - public void exitVmethodHeadCurrent(final EoParser.VmethodHeadCurrentContext ctx) { - // Nothing here - } - @Override public void enterMethodTailOptional(final EoParser.MethodTailOptionalContext ctx) { // Nothing here @@ -993,16 +983,6 @@ public void exitVmethodHeadApplicationTail(final EoParser.VmethodHeadApplication // Nothing here } - @Override - public void enterVmethodHeadHmethodExtended(final EoParser.VmethodHeadHmethodExtendedContext ctx) { - // Nothing here - } - - @Override - public void exitVmethodHeadHmethodExtended(final EoParser.VmethodHeadHmethodExtendedContext ctx) { - // Nothing here - } - @Override public void enterVmethodHeadVapplication(final EoParser.VmethodHeadVapplicationContext ctx) { // Nothing here @@ -1013,16 +993,6 @@ public void exitVmethodHeadVapplication(final EoParser.VmethodHeadVapplicationCo // Nothing here } - @Override - public void enterVmethodHeadHapplication(final EoParser.VmethodHeadHapplicationContext ctx) { - // Nothing here - } - - @Override - public void exitVmethodHeadHapplication(final EoParser.VmethodHeadHapplicationContext ctx) { - // Nothing here - } - @Override public void enterMethodTail(final EoParser.MethodTailContext ctx) { // Nothing here diff --git a/eo-parser/src/test/resources/org/eolang/parser/packs/syntax/hmethod-after-vmethod.yaml b/eo-parser/src/test/resources/org/eolang/parser/packs/syntax/hmethod-after-vmethod.yaml deleted file mode 100644 index 6149ab3eba..0000000000 --- a/eo-parser/src/test/resources/org/eolang/parser/packs/syntax/hmethod-after-vmethod.yaml +++ /dev/null @@ -1,11 +0,0 @@ -# @todo #2736:30min Enable the test when it's possible. Such syntax is invalid - we can't use -# horizontal method after vertical method. If we decide that we allow such syntax we should add -# "vmethod" to "hmethodHeadExtended" rule and resolve left recursion violation. Don't forget -# to remove the puzzle -xsls: [] -skip: true -tests: - - //errors[count(error)=0] -eo: | - a - .b.c \ No newline at end of file diff --git a/eo-parser/src/test/resources/org/eolang/parser/typos/hmethod-after-vmethod.yaml b/eo-parser/src/test/resources/org/eolang/parser/typos/hmethod-after-vmethod.yaml new file mode 100644 index 0000000000..7e5c03d58a --- /dev/null +++ b/eo-parser/src/test/resources/org/eolang/parser/typos/hmethod-after-vmethod.yaml @@ -0,0 +1,4 @@ +line: 2 +eo: | + a + .b.c \ No newline at end of file diff --git a/eo-parser/src/test/resources/org/eolang/parser/typos/vmethod-after-happlication.yaml b/eo-parser/src/test/resources/org/eolang/parser/typos/vmethod-after-happlication.yaml new file mode 100644 index 0000000000..5082580001 --- /dev/null +++ b/eo-parser/src/test/resources/org/eolang/parser/typos/vmethod-after-happlication.yaml @@ -0,0 +1,4 @@ +line: 2 +eo: | + x y + .z \ No newline at end of file diff --git a/eo-parser/src/test/resources/org/eolang/parser/typos/vmethod-after-hmethod.yaml b/eo-parser/src/test/resources/org/eolang/parser/typos/vmethod-after-hmethod.yaml new file mode 100644 index 0000000000..0c6250bad7 --- /dev/null +++ b/eo-parser/src/test/resources/org/eolang/parser/typos/vmethod-after-hmethod.yaml @@ -0,0 +1,4 @@ +line: 2 +eo: | + x.y + .z \ No newline at end of file diff --git a/eo-runtime/src/test/eo/org/eolang/ram-tests.eo b/eo-runtime/src/test/eo/org/eolang/ram-tests.eo index 0208d3bf13..1ef671185b 100644 --- a/eo-runtime/src/test/eo/org/eolang/ram-tests.eo +++ b/eo-runtime/src/test/eo/org/eolang/ram-tests.eo @@ -92,7 +92,8 @@ write. r.slice 200 13 > s "Hello, world!".as-bytes - s.slice 0 5 + s + .slice 0 5 .slice 0 4 .slice 0 1 eq. > @ From 091526f6433fc5d7c2f1f000d05a49f56e981382 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 13:00:38 +0300 Subject: [PATCH 53/80] new iexec --- paper/iexec.sty | 220 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 220 insertions(+) create mode 100644 paper/iexec.sty diff --git a/paper/iexec.sty b/paper/iexec.sty new file mode 100644 index 0000000000..ac97f3f68d --- /dev/null +++ b/paper/iexec.sty @@ -0,0 +1,220 @@ +%% +%% This is file `iexec.sty', +%% generated with the docstrip utility. +%% +%% The original source files were: +%% +%% iexec.dtx (with options: `package') +%% (The MIT License) +%% +%% Copyright (c) 2021-2024 Yegor Bugayenko +%% +%% 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 NONINFRINGEMENT. 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. + + + +\NeedsTeXFormat{LaTeX2e} +\ProvidesPackage{iexec} +[0000-00-00 0.0.0 Inputable Shell Executions] + + + + + + + + + + + + + + + + + + + +\RequirePackage{shellesc} + +\RequirePackage{pgfopts} +\pgfkeys{ + /iexec/.cd, + trace/.store in=\iexec@trace, +} +\ProcessPgfPackageOptions{/iexec} + +\RequirePackage{pgfkeys} +\makeatletter\pgfkeys{ + /iexec/.is family, + /iexec, + exit/.store in = \iexec@exit, + exit/.default = iexec.ret, + stdout/.store in = \iexec@stdout, + stdout/.default = iexec.tmp, + stderr/.store in = \iexec@stderr, + trace/.store in = \iexec@traceit, + append/.store in = \iexec@append, + log/.store in = \iexec@log, + null/.store in = \iexec@null, + unskip/.store in = \iexec@unskip, + quiet/.store in = \iexec@quiet, + ignore/.store in = \iexec@ignore, + maybe/.store in = \iexec@maybe, + stdout,exit +}\makeatother + +\RequirePackage{expl3} +\makeatletter\ExplSyntaxOn +\NewDocumentCommand{\iexec@typeout}{m}{ + \iexec_typeout_file:n { #1 }} +\ior_new:N \g_iexec_typeout_ior +\cs_new_protected:Nn \iexec_typeout_file:n +{ + \ior_open:Nn \g_iexec_typeout_ior { #1 } + \ior_str_map_inline:Nn \g_iexec_typeout_ior + {\iow_term:n { ##1 }} + \ior_close:N \g_iexec_typeout_ior +} +\ExplSyntaxOff\makeatother + +\makeatletter +\newread\iexec@exitfile +\newcommand\iexec[2][]{% + \begingroup% + \pgfqkeys{/iexec}{#1}% + \ifnum\ShellEscapeStatus=1% + \begingroup% + \ifdefined\iexec@log% + \message{^^J}% + \fi% + \let\%\@percentchar% + \let\\\@backslashchar% + \let\{\@charlb% + \let\}\@charrb% + \def\iexec@cmd{(#2) + \ifdefined\iexec@append>\fi> + \ifdefined\iexec@null/dev/null\else\iexec@stdout\fi + \space\ifdefined\iexec@stderr2>\iexec@stderr\else2>&1\fi; + /bin/echo -n \string$?\% >\iexec@exit}% + \ShellEscape{\iexec@cmd}% + \ifdefined\iexec@log% + \message{iexec: [\iexec@cmd]^^J}% + \fi% + \endgroup% + \immediate\openin\iexec@exitfile=\iexec@exit% + \read\iexec@exitfile to \iexec@code% + \immediate\closein\iexec@exitfile% + \ifdefined\iexec@null\else% + \IfFileExists + {\iexec@stdout} + {} + {\PackageError{iexec}{The "\iexec@stdout" file is absent + after processing, looks like some internal error}{}}% + \ifdefined\iexec@log% + \message{iexec: This is the content of '\iexec@stdout':^^J}% + \IfFileExists + {\iexec@stdout} + {\iexec@typeout{\iexec@stdout}} + {\PackageError{iexec}{The "\iexec@stdout" file is absent + after processing, looks like some internal error}{}}% + \message{^^J}% + \else% + \ifnum\iexec@code=0\else% + \ifdefined\iexec@ignore\else% + \message{iexec: See the content of '\iexec@stdout' + after failure:^^J}% + \iexec@typeout{\iexec@stdout}% + \message{^^J}% + \fi% + \fi% + \fi% + \fi% + \ifnum\iexec@code=0\else% + \ifdefined\iexec@ignore% + \ifdefined\iexec@log% + \message{iexec: Execution failure ignored, + the exit code was \iexec@code^^J}% + \fi% + \else% + \PackageError{iexec}{Execution failure, + the exit code was \iexec@code}{}% + \fi% + \fi% + \ifdefined\iexec@null\else% + \ifdefined\iexec@quiet% + \ifdefined\iexec@log% + \message{iexec: Due to 'quiet' option we didn't read + the content of '\iexec@stdout' + \ifdefined\pdffilesize (\pdffilesize{\iexec@stdout} + bytes)\fi^^J}% + \fi% + \else% + \ifdefined\iexec@log% + \message{iexec: We are going to include the content of + '\iexec@stdout'\ifdefined\pdffilesize (\pdffilesize + {\iexec@stdout} bytes)\fi...^^J}% + \fi% + \input{\iexec@stdout}% + \ifdefined\iexec@unskip\unskip\fi% + \message{iexec: The content of '\iexec@stdout' + was included into the document^^J}% + \fi\fi% + \ifdefined\iexec@null\else% + \ifdefined\iexec@trace% + \ifdefined\iexec@log% + \message{iexec: Due to package option 'trace', + the files '\iexec@stdout' and `\iexec@exit` were + not deleted^^J}% + \fi% + \else% + \ifdefined\iexec@traceit% + \ifdefined\iexec@log% + \message{iexec: Due to 'trace' package option, + the files '\iexec@stdout' and '\iexec@exit' + were not deleted^^J}% + \fi% + \else% + \ShellEscape{rm \iexec@stdout}% + \ifdefined\iexec@log% + \message{iexec: The file '\iexec@stdout' was deleted^^J}% + \fi% + \ShellEscape{rm \iexec@exit}% + \ifdefined\iexec@log% + \message{iexec: The file '\iexec@exit' was deleted^^J}% + \fi% + \fi% + \fi\fi% + \else% + \ifdefined\iexec@maybe% + \message{iexec: The execution skipped because -shell-escape + is not set and 'maybe' option is provided^^J}% + \else% + \PackageError{iexec}{You must run TeX processor with + --shell-escape option}{}% + \fi% + \fi% + \endgroup% +}\makeatother + + + +\endinput +%% +%% End of file `iexec.sty'. From 53db4532dca258228bb680428ff11a1cd6c4f33e Mon Sep 17 00:00:00 2001 From: rultor <8086956+rultor@users.noreply.github.com> Date: Fri, 1 Mar 2024 10:34:23 +0000 Subject: [PATCH 54/80] new version in README --- eo-maven-plugin/README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/eo-maven-plugin/README.md b/eo-maven-plugin/README.md index 2e329700a5..0c82fa6e30 100644 --- a/eo-maven-plugin/README.md +++ b/eo-maven-plugin/README.md @@ -35,7 +35,7 @@ create a file `pom.xml` with this content (it's just a sample): org.eolang eo-maven-plugin - 0.35.4 + 0.35.5 @@ -156,7 +156,7 @@ execution within `eo-maven-plugin/pom.xml`: ... maven-invoker-plugin - 0.35.4 + 0.35.5 true true From 3abf3c0efe1f4cdbbddb4e15a02a4936e4b76319 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 13:38:11 +0300 Subject: [PATCH 55/80] package --- paper/Makefile | 2 +- paper/iexec.sty | 220 ------------------------------------------------ 2 files changed, 1 insertion(+), 221 deletions(-) delete mode 100644 paper/iexec.sty diff --git a/paper/Makefile b/paper/Makefile index 800a4d8d06..9bb7d1e742 100644 --- a/paper/Makefile +++ b/paper/Makefile @@ -26,7 +26,7 @@ SHELL=bash TLROOT=$$(kpsewhich -var-value TEXMFDIST) -PACKAGES=ffcode to-be-determined href-ul minted +PACKAGES=ffcode to-be-determined href-ul iexec eolang REPO=objectionary/eo gsed=$(if $(shell which gsed),gsed,sed) diff --git a/paper/iexec.sty b/paper/iexec.sty deleted file mode 100644 index ac97f3f68d..0000000000 --- a/paper/iexec.sty +++ /dev/null @@ -1,220 +0,0 @@ -%% -%% This is file `iexec.sty', -%% generated with the docstrip utility. -%% -%% The original source files were: -%% -%% iexec.dtx (with options: `package') -%% (The MIT License) -%% -%% Copyright (c) 2021-2024 Yegor Bugayenko -%% -%% 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 NONINFRINGEMENT. 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. - - - -\NeedsTeXFormat{LaTeX2e} -\ProvidesPackage{iexec} -[0000-00-00 0.0.0 Inputable Shell Executions] - - - - - - - - - - - - - - - - - - - -\RequirePackage{shellesc} - -\RequirePackage{pgfopts} -\pgfkeys{ - /iexec/.cd, - trace/.store in=\iexec@trace, -} -\ProcessPgfPackageOptions{/iexec} - -\RequirePackage{pgfkeys} -\makeatletter\pgfkeys{ - /iexec/.is family, - /iexec, - exit/.store in = \iexec@exit, - exit/.default = iexec.ret, - stdout/.store in = \iexec@stdout, - stdout/.default = iexec.tmp, - stderr/.store in = \iexec@stderr, - trace/.store in = \iexec@traceit, - append/.store in = \iexec@append, - log/.store in = \iexec@log, - null/.store in = \iexec@null, - unskip/.store in = \iexec@unskip, - quiet/.store in = \iexec@quiet, - ignore/.store in = \iexec@ignore, - maybe/.store in = \iexec@maybe, - stdout,exit -}\makeatother - -\RequirePackage{expl3} -\makeatletter\ExplSyntaxOn -\NewDocumentCommand{\iexec@typeout}{m}{ - \iexec_typeout_file:n { #1 }} -\ior_new:N \g_iexec_typeout_ior -\cs_new_protected:Nn \iexec_typeout_file:n -{ - \ior_open:Nn \g_iexec_typeout_ior { #1 } - \ior_str_map_inline:Nn \g_iexec_typeout_ior - {\iow_term:n { ##1 }} - \ior_close:N \g_iexec_typeout_ior -} -\ExplSyntaxOff\makeatother - -\makeatletter -\newread\iexec@exitfile -\newcommand\iexec[2][]{% - \begingroup% - \pgfqkeys{/iexec}{#1}% - \ifnum\ShellEscapeStatus=1% - \begingroup% - \ifdefined\iexec@log% - \message{^^J}% - \fi% - \let\%\@percentchar% - \let\\\@backslashchar% - \let\{\@charlb% - \let\}\@charrb% - \def\iexec@cmd{(#2) - \ifdefined\iexec@append>\fi> - \ifdefined\iexec@null/dev/null\else\iexec@stdout\fi - \space\ifdefined\iexec@stderr2>\iexec@stderr\else2>&1\fi; - /bin/echo -n \string$?\% >\iexec@exit}% - \ShellEscape{\iexec@cmd}% - \ifdefined\iexec@log% - \message{iexec: [\iexec@cmd]^^J}% - \fi% - \endgroup% - \immediate\openin\iexec@exitfile=\iexec@exit% - \read\iexec@exitfile to \iexec@code% - \immediate\closein\iexec@exitfile% - \ifdefined\iexec@null\else% - \IfFileExists - {\iexec@stdout} - {} - {\PackageError{iexec}{The "\iexec@stdout" file is absent - after processing, looks like some internal error}{}}% - \ifdefined\iexec@log% - \message{iexec: This is the content of '\iexec@stdout':^^J}% - \IfFileExists - {\iexec@stdout} - {\iexec@typeout{\iexec@stdout}} - {\PackageError{iexec}{The "\iexec@stdout" file is absent - after processing, looks like some internal error}{}}% - \message{^^J}% - \else% - \ifnum\iexec@code=0\else% - \ifdefined\iexec@ignore\else% - \message{iexec: See the content of '\iexec@stdout' - after failure:^^J}% - \iexec@typeout{\iexec@stdout}% - \message{^^J}% - \fi% - \fi% - \fi% - \fi% - \ifnum\iexec@code=0\else% - \ifdefined\iexec@ignore% - \ifdefined\iexec@log% - \message{iexec: Execution failure ignored, - the exit code was \iexec@code^^J}% - \fi% - \else% - \PackageError{iexec}{Execution failure, - the exit code was \iexec@code}{}% - \fi% - \fi% - \ifdefined\iexec@null\else% - \ifdefined\iexec@quiet% - \ifdefined\iexec@log% - \message{iexec: Due to 'quiet' option we didn't read - the content of '\iexec@stdout' - \ifdefined\pdffilesize (\pdffilesize{\iexec@stdout} - bytes)\fi^^J}% - \fi% - \else% - \ifdefined\iexec@log% - \message{iexec: We are going to include the content of - '\iexec@stdout'\ifdefined\pdffilesize (\pdffilesize - {\iexec@stdout} bytes)\fi...^^J}% - \fi% - \input{\iexec@stdout}% - \ifdefined\iexec@unskip\unskip\fi% - \message{iexec: The content of '\iexec@stdout' - was included into the document^^J}% - \fi\fi% - \ifdefined\iexec@null\else% - \ifdefined\iexec@trace% - \ifdefined\iexec@log% - \message{iexec: Due to package option 'trace', - the files '\iexec@stdout' and `\iexec@exit` were - not deleted^^J}% - \fi% - \else% - \ifdefined\iexec@traceit% - \ifdefined\iexec@log% - \message{iexec: Due to 'trace' package option, - the files '\iexec@stdout' and '\iexec@exit' - were not deleted^^J}% - \fi% - \else% - \ShellEscape{rm \iexec@stdout}% - \ifdefined\iexec@log% - \message{iexec: The file '\iexec@stdout' was deleted^^J}% - \fi% - \ShellEscape{rm \iexec@exit}% - \ifdefined\iexec@log% - \message{iexec: The file '\iexec@exit' was deleted^^J}% - \fi% - \fi% - \fi\fi% - \else% - \ifdefined\iexec@maybe% - \message{iexec: The execution skipped because -shell-escape - is not set and 'maybe' option is provided^^J}% - \else% - \PackageError{iexec}{You must run TeX processor with - --shell-escape option}{}% - \fi% - \fi% - \endgroup% -}\makeatother - - - -\endinput -%% -%% End of file `iexec.sty'. From 743219605a1ac121b8170f6caeaf09a423a5edd8 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 13:38:25 +0300 Subject: [PATCH 56/80] rm --- paper/eolang.sty | 916 ----------------------------------------------- 1 file changed, 916 deletions(-) delete mode 100644 paper/eolang.sty diff --git a/paper/eolang.sty b/paper/eolang.sty deleted file mode 100644 index a5ad5ad52f..0000000000 --- a/paper/eolang.sty +++ /dev/null @@ -1,916 +0,0 @@ -%% -%% This is file `eolang.sty', -%% generated with the docstrip utility. -%% -%% The original source files were: -%% -%% eolang.dtx (with options: `package') -%% (The MIT License) -%% -%% Copyright (c) 2021-2024 Yegor Bugayenko -%% -%% 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 NONINFRINGEMENT. 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. - - - -\NeedsTeXFormat{LaTeX2e} -\ProvidesPackage{eolang} -[0000-00-00 0.0.0 Formulas and Graphs for EO Programming Language] - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -\RequirePackage{stmaryrd} -\RequirePackage{amsmath} -\let\Bbbk\relax\RequirePackage{amssymb} -\RequirePackage{fancyvrb} -\ifdefined\eolang@noshell\else\RequirePackage{iexec}\fi - -\RequirePackage{pgfopts} -\RequirePackage{ifluatex} -\RequirePackage{ifxetex} -\pgfkeys{ - /eolang/.cd, - tmpdir/.store in=\eolang@tmpdir, - tmpdir/.default=_eolang\ifxetex-xe\else\ifluatex-lua\fi\fi, - nocomments/.store in=\eolang@nocomments, - anonymous/.store in=\eolang@anonymous, - noshell/.store in=\eolang@noshell, - tmpdir -} -\ProcessPgfPackageOptions{/eolang} - -\makeatletter -\ifdefined\eolang@noshell\else\RequirePackage{shellesc}\fi -\IfFileExists - {\eolang@tmpdir/\jobname} - {\message{eolang: Temporary directory "\eolang@tmpdir/\jobname" - already exists^^J}} - { - \ifdefined\eolang@noshell - \message{eolang: Temporary directory "\eolang@tmpdir/\jobname" - is not created, because of the "noshell" package option, - most probably the compilation will fail later^^J} - \else - \ifnum\ShellEscapeStatus=1 - \iexec[null]{mkdir -p "\eolang@tmpdir/\jobname"} - \else - \message{eolang: Temporary directory "\eolang@tmpdir/\jobname" - is not created, because -shell-escape is not set, and - it doesn't exist, most probably the compilation - will fail later^^J} - \fi - \fi - } -\makeatother - -\makeatletter\newcounter{eolang@lineno}\makeatother - -\RequirePackage{pdftexcmds} -\makeatletter -\newcommand\eolang@mdfive[1]{\pdf@filemdfivesum{#1}} -\makeatother - -\makeatletter -\ifdefined\eolang@noshell - \message{eolang: Perl script is not going to be created, - at "\eolang@tmpdir/\jobname-phi.pl" because of the "noshell" - package option^^J} -\else -\openin 15=\eolang@tmpdir/\jobname-phi.pl -\ifeof 15 -\message{eolang: Perl script is going to be created, - because it is absent at "\eolang@tmpdir/\jobname-phi.pl", - but if -shell-escape is not set, the compilation will - most likely fail now^^J} -\begin{VerbatimOut}{\eolang@tmpdir/\jobname-phi.pl} -$macro = $ARGV[0]; -open(my $fh, '<', $ARGV[1]); -my $tex; { local $/; $tex = <$fh>; } -print "% This file is auto-generated by 0.0.0\n"; -print '% There are ', length($tex), - ' chars in the input: ', $ARGV[1], "\n"; -print '% ---', "\n"; -if (index($tex, "\t") > 0) { - print "TABS are prohibited!"; - exit 1; -} -my @lines = split (/\n/g, $tex); -foreach my $t (@lines) { - print '% ', $t, "\n"; -} -print '% ---', "\n"; -$tex =~ s/(?= 0) { - $macro =~ s/equation/align/g; - $align = 1; - print '% The "align" is used because of && seen in the text' . "\n"; -} -if ($macro ne 'phiq') { - if (not $splitting) { - $tex =~ s/\\\\\n/\n\n/g; - $tex =~ s/\\\n\s*//g; - } - $tex =~ s/\n*(\\label\{[^\}]+\})\n*/\1/g; - $tex =~ s/\n{3,}/\n\n/g; -} -my @texts = (); -sub trep { - my ($s) = @_; - my $open = 0; - my $p = 0; - for (; $p < length($s); $p++) { - $c = substr($s, $p, 1); - if ($c eq '}') { - if ($open eq 0) { - last; - } - $open--; - } - if ($c eq '{') { - $open++; - } - } - push(@texts, substr($s, 0, $p)); - return '{TEXT' . (0+@texts - 1) . '}' . substr($s, $p + 1); -} -$tex =~ s/\\text\{(.+)/trep("$1")/ge; -if (not $splitting) { - $tex =~ s/(?/\1\\Delta{}..>/g; -$tex =~ s/([^\\{a-z0-9]|^)L>/\1\\lambda{}..>/g; -$tex =~ s/"([^"]+)"/|"\1"|/g; -$tex =~ s/(^|(?<=[\s)(\]\[,.>\/]))([a-zA-Z][a-z0-9]+)(?=[\s)(\]\[,.-]|$)/|\2|/g; -$tex =~ s/([^_^]|^)([0-9]+|\*)\/(\\?[a-z]+|\|[a-z]+\|) - (->|\.\.>|~>|:=|!->)/\1\\alpha_{\2}\\vert{}\3\\space{}\4/xg; -$tex =~ s/([^_^]|^)([0-9]+|\*) - (->|\.\.>|~>|:=|!->)/\1\\alpha_{\2}\\space{}\3/xg; -if ($macro ne 'phiq') { - if (not $splitting) { - $tex =~ s/\\begin\{split\}\n/\\begin{split}&/g; - $tex =~ s/\n\s*\\end\{split\}/\\end{split}/g; - $tex =~ s/\n\n/\\\\&/g; - $tex =~ s/\n/\\phiEOL{}\n&/g; - $tex =~ s/\\\\$//g; - $tex =~ s/\\\\/\\\\\n/g; - $tex =~ s/([^&\s])\s{2}([^\s])/\1 \2/g; - $tex =~ s/\s{2}/ \\quad{}/g; - $tex = '&' . $tex; - } - my $lead = '[^\s]+\s(?:->|:=|=|==)\s'; - my @leads = $tex =~ /&${lead}/g; - my @eols = $tex =~ /&/g; - if (0+@leads == 0+@eols && 0+@eols > 1) { - $tex =~ s/&(${lead})/\1&~/g; - $gathered = 0; - print '% The "gathered" is NOT used because all ' . - (0+@eols) . ' lines are ' . (0+@leads) . " leads\n"; - } -} -if ($macro ne 'phiq') { - sub strip_tabs { - my ($env, $tex) = @_; - $tex =~ s/&//g; - return "\\begin{$env}" . $tex . "\\end{$env}"; - } - foreach my $e (('matrix', 'cases')) { - $tex =~ s/\\begin\{(\Q$e\E\*?)\}(.+)\\end\{\Q$e\E\*?\}/strip_tabs($1, $2)/sge; - } -} -$tex =~ s/\$/\\xi{}/g; -$tex =~ s/(?(])([0-9A-F]{2}(?:-[0-9A-F]{2})+| - [0-9]+(?:\.[0-9]+)?)(?!\{)/\1|\2|/xg; -$tex =~ s/TRUE/|TRUE|/g; -$tex =~ s/FALSE/|FALSE|/g; -$tex =~ s/\?/\\varnothing{}/g; -$tex =~ s/@/\\varphi{}/g; -$tex =~ s/-([a-z]+)>/\\mathrel{\\phiSlot{\1}}/g; -$tex =~ s/!->/\\mathbin{\\phiConst}/g; -$tex =~ s/->/\\mathbin{\\mapsto}/g; -$tex =~ s/~>/\\mathbin{\\phiWave}/g; -$tex =~ s/:=/\\mathrel{\\vDash}/g; -$tex =~ s/==/\\mathrel{\\equiv}/g; -$tex =~ s/\.\.>/\\mathbin{\\phiDotted}/g; -$tex =~ s/<>/\\rangle/g; -$tex =~ s/\|{2,}/|/g; -$tex =~ s/\|([^\|]+)\|/\\textnormal{\\texttt{\1}}{}/g; -$tex =~ s/\{TEXT(\d+)\}/'\\text{' . @texts[$1] . '}';/ge; -if ($macro eq 'phiq') { - print '\(' if ($tex ne ''); -} else { - print '\begin{', $macro, "}\n"; - if (not($align)) { - if ($gathered) { - print '\begin{gathered}' . "\n"; - } elsif (not $splitting) { - print '\begin{split}' . "\n"; - } - } -} -if ($gathered and not($align)) { - $tex =~ s/^&//g; - $tex =~ s/\n&/\n/g; -} -print $tex; -if ($macro eq 'phiq') { - print '\)' if ($tex ne ''); -} else { - if (not($align)) { - if ($gathered) { - print "\n" . '\end{gathered}'; - } elsif (not $splitting) { - print "\n" . '\end{split}'; - } - } - print "\n" . '\end{' . $macro . '}'; -} -print '\endinput'; -\end{VerbatimOut} -\message{eolang: File with Perl script - '\eolang@tmpdir/\jobname-phi.pl' saved^^J} -\else - \message{eolang: Perl script already exists at - "\eolang@tmpdir/\jobname-phi.pl"^^J} -\fi -\closein 15 -\fi -\makeatother - -\makeatletter -\newcommand\phiSaveTo[1]{\def\eolang@phiSaveTo{#1}} -\makeatother - -\makeatletter -\newcommand\eolang@ifabsent[2]{% - \IfFileExists - {#1} - {% - \message{eolang: File "#1" already exists ^^J}% - \input{#1}} - {% - \ifdefined\eolang@noshell% - \message{eolang: Shell processing is disabled^^J}% - \else% - \ifnum\ShellEscapeStatus=1\else% - \message{eolang: The -shell-escape command line - option is not provided, most probably compilation - will fail now:^^J}% - \fi% - #2% - \fi% - }% -} -\makeatother - -\makeatletter\newcommand\eolang@process[1]{ - \def\hash{\eolang@mdfive - {\eolang@tmpdir/\jobname/phiquation.tex}-\the\inputlineno}% - \eolang@ifabsent - {\eolang@tmpdir/\jobname/\hash-phiquation-post.tex} - {% - \iexec[null]{cp "\eolang@tmpdir/\jobname/phiquation.tex" - "\eolang@tmpdir/\jobname/\hash-phiquation.tex"}% - \message{Start parsing 'phi' at line no. \the\inputlineno^^J} - \iexec[trace,stdout=\eolang@tmpdir/\jobname/\hash-phiquation-post.tex]{ - perl "\eolang@tmpdir/\jobname-phi.pl" - '#1' - "\eolang@tmpdir/\jobname/\hash-phiquation.tex" - \ifdefined\eolang@nocomments | perl -pe 's/\%.*(\\n|$)//g'\fi - \ifdefined\eolang@phiSaveTo > \eolang@phiSaveTo\fi}% - }% - \setcounter{FancyVerbLine}{\value{eolang@lineno}}% - \def\eolang@phiSaveTo{\relax}% -} -\newenvironment{phiquation*}% -{\catcode`\|=12 \VerbatimEnvironment% -\setcounter{eolang@lineno}{\value{FancyVerbLine}}% -\begin{VerbatimOut} - {\eolang@tmpdir/\jobname/phiquation.tex}} -{\end{VerbatimOut}\eolang@process{equation*}} -\newenvironment{phiquation}% -{\catcode`\|=12 \VerbatimEnvironment% -\setcounter{eolang@lineno}{\value{FancyVerbLine}}% -\begin{VerbatimOut} - {\eolang@tmpdir/\jobname/phiquation.tex}} -{\end{VerbatimOut}\eolang@process{equation}} -\makeatother - -\RequirePackage{xstring} -\makeatletter\newcommand\phiq[1]{% - \StrSubstitute{\detokenize{#1}}{'}{'"'"'}[\clean]% - \def\hash{\pdf@mdfivesum{\clean}-\the\inputlineno}% - \ifdefined\eolang@nodollar\else\catcode`\$=3 \fi% - \eolang@ifabsent - {\eolang@tmpdir/\jobname/\hash-phiq-post.tex} - {% - \iexec[log,trace,quiet,stdout=\eolang@tmpdir/\jobname/phiq.tex]{ - /bin/echo '\clean'}% - \iexec[quiet,null]{cp "\eolang@tmpdir/\jobname/phiq.tex" - "\eolang@tmpdir/\jobname/\hash-phiq.tex"}% - \iexec[trace,stdout=\eolang@tmpdir/\jobname/\hash-phiq-post.tex]{ - perl \eolang@tmpdir/\jobname-phi.pl 'phiq' - "\eolang@tmpdir/\jobname/\hash-phiq.tex" - \ifdefined\eolang@nocomments | perl -pe 's/\%.*(\\n|$)//g' \fi}% - \message{eolang: Parsed `phiq' at line no. \the\inputlineno^^J}% - }% - \ifdefined\eolang@nodollar\else\catcode`\$\active\fi% -}\makeatother - -\ifdefined\eolang@nodollar\else - \begingroup - \catcode`\$=\active - \protected\gdef$#1${\phiq{#1}} - \endgroup - \AtBeginDocument{\catcode`\$=\active} -\fi - -\makeatletter -\ifdefined\eolang@noshell -\message{eolang: Perl script is not going to be created - at "\eolang@tmpdir/\jobname-sodg.pl", because of the - "noshell" package option^^J} -\else -\openin 15=\eolang@tmpdir/\jobname-sodg.pl -\ifeof 15 -\message{eolang: Perl script is going to be created, - because it is absent at "\eolang@tmpdir/\jobname-sodg.pl", - but if -shell-escape is not set, the compilation will - most likely fail now^^J} -\begin{VerbatimOut}{\eolang@tmpdir/\jobname-sodg.pl} -sub num { - my ($i) = @_; - $i =~ s/(\+|-)\./\10./g; - return $i; -} -sub fmt { - my ($tex) = @_; - $tex =~ s/\|([^\|]+)\|/\\textnormal{\\texttt{\1}}/g; - return $tex; -} -sub toem { - my ($cm) = @_; - return $cm * 2.8; -} -sub vertex { - my ($v) = @_; - if (index($v, 'v0') == 0) { - return '\Phi'; - } else { - $v =~ s/^v/v_{/g; - $v =~ s/[^0-9]$//g; - return $v . '}'; - } -} -sub tailor { - my ($t, $m) = @_; - $t =~ s/<([A-Z]?${m}[A-Z]?):([^>]+)>/\2/g; - $t =~ s/<[A-Z]+:[^>]+>//g; - return $t; -} -open(my $fh, '<', $ARGV[0]); -my $tex; { local $/; $tex = <$fh>; } -if (index($tex, "\t") > 0) { - print "TABS are prohibited!"; - exit 1; -} -print '% This file is auto-generated', "\n%\n"; -print '% --- there are ', length($tex), - ' chars in the input (', $ARGV[0], "):\n"; -foreach my $t (split (/\n/g, $tex)) { - print '% ', $t, "\n"; -} -print "% ---\n"; -$tex =~ s/\\\\/\n/g; -$tex =~ s/\\\n//g; -$tex =~ s/(\\[a-zA-Z]+)\s+/\1/g; -$tex =~ s/\n{2,}/\n/g; -my @cmds = split(/\n/g, $tex); -print '% --- before processing:' . "\n"; -foreach my $t (split (/\n/g, $tex)) { - print '% ', $t, "\n"; -} -print '% ---'; -print ' (' . (0+@cmds) . " lines)\n"; -print '\begin{phicture}', "\n"; -for (my $c = 0; $c < 0+@cmds; $c++) { - my $cmd = $cmds[$c]; - $cmd =~ s/^\s+//g; - $cmd =~ s/(?') >= 0) { - my $draw = '\draw['; - if (exists $opts{'pi'}) { - $draw = $draw . ''; - if (not exists $opts{'a'}) { - $opts{'a'} = '\pi'; - } - } - if (exists $opts{'rho'} and not(exists $opts{'bend'})) { - $draw = $draw . ''; - } - $draw = $draw . ',' . $opts{'style'} . ']'; - my ($from, $to) = split (/->/, $head); - $draw = $draw . " (${from}) "; - if (exists $opts{'bend'}) { - $draw = $draw . 'edge ['; - if (exists $opts{'rho'}) { - $draw = $draw . ''; - } - $draw = $draw . ']'; - } else { - $draw = $draw . '--'; - } - if (exists $opts{'a'}) { - my $a = $opts{'a'}; - if (index($a, '$') == -1) { - $a = '$' . fmt($a) . '$'; - } else { - $a = fmt($a); - } - $draw = $draw . ''; - } - if (exists $opts{'break'}) { - $draw = $draw . ''; - } - $draw = $draw . " ()"; - if (exists $opts{'break'}) { - print tailor($draw, 'F') . ";\n"; - print ' \node[outer sep=' . toem(0.1) . 'em,inner sep=0em] ' . - 'at (break) (break-v) {$' . vertex($to) . - '$};' . "\n"; - print ' ' . tailor($draw, 'B'); - } else { - print tailor($draw, 'M'); - } - } elsif (index($head, '=>') >= 0) { - my ($from, $to) = split (/=+>/, $head); - my $size = () = $head =~ /=/g; - if ($from eq '') { - print '\node [phi-arrow, left=' . toem($size * 0.6) . 'em of ' . - $to . '.center]'; - } elsif ($to eq '') { - print '\node [phi-arrow, right=' . toem($size * 0.6) . 'em of ' . - $from . '.center]'; - } else { - print '\node [phi-arrow] at ($(' . - $from . ')!0.5!(' . $to . ')$)'; - } - print '{}'; - } elsif (index($head, '!') >= 0) { - my ($v, $marker) = split (/!+/, $head); - my $size = () = $head =~ /!/g; - print '\node [phi-marker, left=' . - toem($size * 0.6) . 'em of ' . - $v . '.center]{' . fmt($marker) . '}'; - } elsif (index($head, '+') >= 0) { - my ($v, $suffix) = split (/\+/, $head); - my @friends = ($v); - foreach my $c (@cmds) { - $e = $c; - $e =~ s/^\s+//g; - my $h = $e; - $h = substr($e, 0, index($e, ' ')) if index($e, ' ') >= 0; - foreach my $f (@friends) { - my $add = ''; - if (index($h, $f . '->') >= 0) { - $add = substr($h, index($h, '->') + 2); - } - if ($h =~ /->\Q${f}\E$/) { - $add = substr($h, 0, index($h, '->')); - } - if (index($e, ' xy:' . $f . ',') >= 0) { - $add = $h; - } - if (index($add, '+') == -1 - and $add ne '' - and not(grep(/^\Q${add}\E$/, @friends))) { - push(@friends, $add); - } - } - } - my @extra = (); - foreach my $e (@cmds) { - $m = $e; - if ($m =~ /^\s*\Q${v}\E\s/) { - next; - } - if ($m =~ /^\s*[^\s]+\+/ and not($m =~ /^\s*\Q${head}\E\s/)) { - next; - } - foreach my $f (@friends) { - my $h = $f; - $h =~ s/[a-z]$//g; - if ($m =~ s/^(\s*)\Q${f}\E\+\Q${suffix}\E\s?/\1${h}${suffix} /g) { - last; - } - $m =~ s/^(\s*)\Q${f}\E\s/\1${h}${suffix} /g; - $m =~ s/^(\s*)\Q${f}\E->/\1${h}${suffix}->/g; - $m =~ s/\sxy:\Q${f}\E,/ xy:${h}${suffix},/g; - $m =~ s/->\Q${f}\E\s/->${h}${suffix} /g; - } - if ($m ne $e) { - push(@extra, ' ' . $m); - } - } - splice(@extra, 0, 0, @extra[-1]); - splice(@extra, -1, 1); - splice(@extra, 0, 0, '% clone of ' . $v . ' (' . $head . - '), friends: [' . join(', ', @friends) . '] in ' . - (0+@cmds) . ' lines'); - splice(@cmds, $c, 1, @extra); - print '% cloned ' . $v . ' at line no.' . $c . - ' (+' . (0+@extra) . ' lines -> ' . - (0+@cmds) . ' lines total)'; - } elsif ($head =~ /^v[0-9]+[a-z]?$/) { - print '\node['; - if (exists $opts{'xy'}) { - my ($v, $right, $down) = split(/,/, $opts{'xy'}); - my $loc = ''; - if ($down > 0) { - $loc = 'below '; - } elsif ($down < 0) { - $loc = 'above '; - } - if ($right > 0) { - $loc = $loc . 'right'; - } elsif ($right < 0) { - $loc = $loc . 'left'; - } - print ',' . $loc . '='; - print toem(abs(num($down))) . 'em and ' . - toem(abs(num($right))) . 'em of ' . $v . '.center'; - } - if (exists $opts{'data'}) { - print ',phi-data'; - if ($opts{'data'} ne '') { - my $d = $opts{'data'}; - if (index($d, '|') == -1) { - $d = '$\Delta\phiDotted\text{' . - '\textnormal{\texttt{' . fmt($d) . '}}}$'; - } else { - $d = fmt($d); - } - $opts{'box'} = $d; - } - } elsif (exists $opts{'atom'}) { - print ',phi-atom'; - if ($opts{'atom'} ne '') { - my $a = $opts{'atom'}; - if (index($a, '$') == -1) { - $a = '$\lambda\phiDotted{}' . fmt($a) . '$'; - } else { - $a = fmt($a); - } - $opts{'box'} = $a; - } - } else { - print ',phi-object'; - } - if (exists $opts{'edgeless'}) { - print ',draw=none'; - } - print ',' . $opts{'style'} . ']'; - print ' (' . $head . ')'; - print ' {'; - if (exists $opts{'tag'}) { - my $t = $opts{'tag'}; - if (index($t, '$') == -1) { - $t = '$' . $t . '$'; - } else { - $t = fmt($t); - } - print $t; - } else { - print '$' . vertex($head) . '$'; - } - print '}'; - if (exists $opts{'box'}) { - print ' node[phi-box] at ('; - print $head, '.south east) {'; - print $opts{'box'}, '}'; - } - } - print ";\n"; -} -print '\end{phicture}%', "\n"; -print "% --- after processing:\n%"; -foreach my $c (@cmds) { - print '% ', $c, "\n"; -} -print '% --- (' . (0+@cmds) . " lines)\n"; -print '\endinput'; -\end{VerbatimOut} -\message{eolang: File with Perl script - '\eolang@tmpdir/\jobname-sodg.pl' saved^^J} -\else - \message{eolang: Perl script already exists at - "\eolang@tmpdir/\jobname-sodg.pl"^^J} -\fi -\closein 15 -\fi -\makeatother - -\setcounter{FancyVerbLine}{0} - -\RequirePackage{tikz} - \usetikzlibrary{arrows} - \usetikzlibrary{shapes} - \usetikzlibrary{decorations} - \usetikzlibrary{decorations.pathmorphing} - \usetikzlibrary{decorations.pathreplacing} - \usetikzlibrary{positioning} - \usetikzlibrary{calc} - \usetikzlibrary{math} - \usetikzlibrary{arrows.meta} - -\newenvironment{phicture}% - {\noindent\begin{tikzpicture}[ - ->,>=stealth',node distance=0,line width=.08em, - pics/parallel arrow/.style={ - code={\draw[-latex,phi-rho] (##1) -- (-##1);}}]}% - {\end{tikzpicture}} -\tikzstyle{phi-arrow} = [fill=white!80!black, single arrow, - minimum height=0.05em, minimum width=0.05em, - single arrow head extend=2mm] -\tikzstyle{phi-marker} = [inner sep=0pt, minimum height=1.4em, - minimum width=1.4em, font={\small\color{white}\ttfamily}, - fill=gray] -\tikzstyle{phi-thing} = [inner sep=0pt,minimum height=2.4em, - draw,font={\small}] -\tikzstyle{phi-object} = [phi-thing,circle] -\tikzstyle{phi-data} = [phi-thing,regular polygon, - regular polygon sides=8] -\tikzstyle{phi-empty} = [phi-object] -\tikzset{% - phi-rho/.style={ - postaction={% - decoration={ - show path construction, - curveto code={ - \tikzmath{ - coordinate \I, \F, \v; - \I = (\tikzinputsegmentfirst); - \F = (\tikzinputsegmentlast); - \v = ($(\I) -(\F)$); - real \d, \a, \r, \t; - \d = 0.8; - \t = atan2(\vy, \vx); - if \vx<0 then { \a = 90; } else { \a = -90; }; - { - \draw[arrows={-latex}, decorate, - decoration={% - snake, amplitude=.4mm, - segment length=2mm, - post length=1mm - }] - ($(\F)!.5!(\I) +(\t: -\d em) +(\t +\a: 1ex)$) - -- ++(\t: 2*\d em); - }; - } - }, - lineto code={ - \tikzmath{ - coordinate \I, \F, \v; - \I = (\tikzinputsegmentfirst); - \F = (\tikzinputsegmentlast); - \v = ($(\I) -(\F)$); - real \d, \a, \r, \t; - \d = 0.8; - \t = atan2(\vy, \vx); - if \vx<0 then { \a = 90; } else { \a = -90; }; - { - \draw[arrows={-latex}, decorate, - decoration={% - snake, amplitude=.4mm, - segment length=2mm, - post length=1mm}] - ($(\F)!.5!(\I) +(\t: -\d em) +(\t +\a: 1ex)$) - -- ++(\t: 2*\d em); - }; - } - } - }, - decorate - } - } -} -\tikzstyle{phi-pi} = [draw,dotted] -\tikzstyle{phi-atom} = [phi-object,double] -\tikzstyle{phi-box} = [xshift=-5pt,yshift=3pt,draw,fill=white, - rectangle,line width=.04em,minimum width=1.2em,anchor=north west, - font={\scriptsize}] -\tikzstyle{phi-attr} = [midway,sloped,inner sep=0pt, - above=2pt,sloped/.append style={transform shape}, - font={\scriptsize},color=black] - -\makeatletter -\newcommand\sodgSaveTo[1]{\def\eolang@sodgSaveTo{#1}} -\makeatother - -\makeatletter\newenvironment{sodg}% -{\catcode`\|=12 \VerbatimEnvironment% -\setcounter{eolang@lineno}{\value{FancyVerbLine}}% -\begin{VerbatimOut} - {\eolang@tmpdir/\jobname/sodg.tex}} -{\end{VerbatimOut}% - \def\hash{\eolang@mdfive - {\eolang@tmpdir/\jobname/sodg.tex}-\the\inputlineno}% - \catcode`\$=3 % - \eolang@ifabsent - {\eolang@tmpdir/\jobname/\hash-sodg-post.tex} - {% - \iexec[null]{cp "\eolang@tmpdir/\jobname/sodg.tex" - "\eolang@tmpdir/\jobname/\hash-sodg.tex"}% - \message{eolang: Start parsing `sodg' at line no. \the\inputlineno^^J} - \iexec[trace,stdout=\eolang@tmpdir/\jobname/\hash-sodg-post.tex]{ - perl "\eolang@tmpdir/\jobname-sodg.pl" - "\eolang@tmpdir/\jobname/\hash-sodg.tex" - \ifdefined\eolang@nocomments | perl -pe 's/\%.*(\\n|$)//g'\fi - \ifdefined\eolang@sodgSaveTo > \eolang@sodgSaveTo\fi}% - } - \catcode`\$\active% - \setcounter{FancyVerbLine}{\value{eolang@lineno}}% - \def\eolang@sodgSaveTo{\relax}% -}\makeatother - -\RequirePackage{hyperref} -\pdfstringdefDisableCommands{ - \def\({}% - \def\){}% - \def\alpha{alpha}% - \def\varphi{phi}% -} -\makeatletter -\NewExpandableDocumentCommand{\eoAnon}{O{ANONYMIZED}m}{% - \ifdefined\eolang@anonymous% - \textcolor{orange}{#1}% - \else% - #2% - \fi% -}\makeatother - -\newcommand\eolang{% - \eoAnon[XYZ]{{\sffamily EO}}} - -\newcommand\phic{% - \eoAnon[\(\alpha\)-cal\-cu\-lus]{\(\varphi\)-cal\-cu\-lus}} - -\newcommand\xmir{% - \eoAnon[XML\(^+\)]{XMIR}} - -\newcommand\phiConst{% - \mathrel{\hspace{.15em}}% - \mapstochar\mathrel{\hspace{-.15em}}\mapsto} - -\newcommand\phiWave{% - \mapstochar\mathrel{\mspace{0.45mu}}\leadsto} - -\newcommand\phiSlot[1]{% - \xrightarrow{\text{\sffamily\scshape #1}}} - -\makeatletter -\newcommand{\phiOset}[2]{% - \mathrel{\mathop{#2}\limits^{ - \vbox to 0ex{\kern-2\ex@ - \hbox{$\scriptscriptstyle#1$}\vss}}}} -\newcommand{\phiUset}[2]{% - \mathrel{\mathop{#2}\limits_{ - \vbox to 0ex{\kern-6.3\ex@ - \hbox{$\scriptscriptstyle#1$}\vss}}}} -\makeatother - -\newcommand\phiMany[3]{% - \phiOset{#3}{\phiUset{#2}{#1}}} - -\newcommand\phiEOL{\\[-4pt]} - -\RequirePackage{trimclip} -\RequirePackage{amsfonts} -\makeatletter -\newcommand{\phiDotted}{% - \mapstochar\mathrel{\mathpalette\phiDotted@\relax}} -\newcommand{\phiDotted@}[2]{% - \begingroup% - \settowidth{\dimen\z@}{$\m@th#1\rightarrow$}% - \settoheight{\dimen\tw@}{$\m@th#1\rightarrow$}% - \sbox\z@{% - \makebox[\dimen\z@][s]{% - \clipbox{0 0 {0.4\width} 0}% - {\resizebox{\dimen\z@}{\height}% - {$\m@th#1\dashrightarrow$}}% - \hss% - \clipbox{{0.69\width} {-0.1\height} 0 - {-\height}}{$\m@th#1\rightarrow$}% - }% - }% - \ht\z@=\dimen\tw@ \dp\z@=\z@% - \box\z@% - \endgroup% -} -\makeatother - - - -\endinput -%% -%% End of file `eolang.sty'. From b4c854f89d846644d6917feb1e0286f44019a30e Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Fri, 1 Mar 2024 13:40:06 +0300 Subject: [PATCH 57/80] bibcop --- paper/Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/paper/Makefile b/paper/Makefile index 9bb7d1e742..4133a93c9e 100644 --- a/paper/Makefile +++ b/paper/Makefile @@ -26,7 +26,7 @@ SHELL=bash TLROOT=$$(kpsewhich -var-value TEXMFDIST) -PACKAGES=ffcode to-be-determined href-ul iexec eolang +PACKAGES=ffcode to-be-determined href-ul iexec eolang bibcop REPO=objectionary/eo gsed=$(if $(shell which gsed),gsed,sed) From e8ae097586cb34c8a391bd71764a849812281be3 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Fri, 1 Mar 2024 13:58:29 +0000 Subject: [PATCH 58/80] chore(deps): update dependency org.codehaus.groovy:groovy-xml to v3.0.21 --- eo-maven-plugin/pom.xml | 2 +- eo-runtime/pom.xml | 2 +- pom.xml | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/eo-maven-plugin/pom.xml b/eo-maven-plugin/pom.xml index 616bf0b8e0..2491f3e1da 100644 --- a/eo-maven-plugin/pom.xml +++ b/eo-maven-plugin/pom.xml @@ -405,7 +405,7 @@ SOFTWARE. org.codehaus.groovy groovy-xml - 3.0.20 + 3.0.21 diff --git a/eo-runtime/pom.xml b/eo-runtime/pom.xml index 06f84f8406..3a0fdf34f0 100644 --- a/eo-runtime/pom.xml +++ b/eo-runtime/pom.xml @@ -249,7 +249,7 @@ SOFTWARE. org.codehaus.groovy groovy-xml - 3.0.20 + 3.0.21 diff --git a/pom.xml b/pom.xml index dbaffe804e..53e1aa78d4 100644 --- a/pom.xml +++ b/pom.xml @@ -290,7 +290,7 @@ SOFTWARE. org.codehaus.groovy groovy-xml - 3.0.20 + 3.0.21 From f66eeb2eb884f065126ca08b1c72e500436c36cd Mon Sep 17 00:00:00 2001 From: maxonfjvipon Date: Fri, 1 Mar 2024 17:27:50 +0300 Subject: [PATCH 59/80] fix(#2909): extra directives --- .../main/java/org/eolang/maven/UnphiMojo.java | 70 ++++++++++++++++++- .../java/org/eolang/parser/PhiSyntax.java | 18 ++++- .../java/org/eolang/parser/PhiSyntaxTest.java | 16 +++++ 3 files changed, 100 insertions(+), 4 deletions(-) diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java index 3e5d16660e..93ce623cdc 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java @@ -29,19 +29,29 @@ import java.nio.file.Path; import java.nio.file.Paths; import java.util.Arrays; +import java.util.Iterator; import java.util.List; +import java.util.Set; import org.apache.maven.plugins.annotations.LifecyclePhase; import org.apache.maven.plugins.annotations.Mojo; import org.apache.maven.plugins.annotations.Parameter; import org.cactoos.experimental.Threads; +import org.cactoos.iterable.IterableEnvelope; +import org.cactoos.iterable.IterableOf; +import org.cactoos.iterable.Joined; import org.cactoos.iterable.Mapped; import org.cactoos.list.ListOf; import org.cactoos.number.SumOf; +import org.cactoos.set.SetOf; import org.cactoos.text.TextOf; import org.eolang.maven.util.HmBase; import org.eolang.maven.util.Home; import org.eolang.maven.util.Walk; import org.eolang.parser.PhiSyntax; +import org.eolang.parser.XeEoListener; +import org.xembly.Directive; +import org.xembly.Directives; +import org.xembly.Xembler; /** * Read PHI files and parse them to the XMIR. @@ -75,10 +85,18 @@ public final class UnphiMojo extends SafeMojo { ) private File unphiOutputDir; + /** + * Extra metas to add to unphied XMIR. + * @checkstyle MemberNameCheck (10 lines) + */ + @Parameter(property = "eo.unphiMetas") + private Set unphiMetas = new SetOf<>(); + @Override public void exec() { final List errors = new ListOf<>(); final Home home = new HmBase(this.unphiOutputDir); + final Iterable metas = new UnphiMojo.Metas(this.unphiMetas); final int count = new SumOf( new Threads<>( Runtime.getRuntime().availableProcessors(), @@ -93,7 +111,8 @@ public void exec() { ); final XML parsed = new PhiSyntax( phi.getFileName().toString().replace(".phi", ""), - new TextOf(phi) + new TextOf(phi), + metas ).parsed(); home.save(parsed.toString(), xmir); Logger.info( @@ -121,4 +140,53 @@ public void exec() { ); } } + + /** + * Accumulates all metas that should be attached to unphied XMIR. + * +package meta is prohibited since it's converted to special object + * with "λ -> Package" binding. + * @since 0.36.0 + */ + private static class Metas extends IterableEnvelope { + /** + * Package meta. + */ + private static final String PACKAGE = "+package"; + + /** + * Ctor. + * @param metas Metas to append + */ + Metas(final Iterable metas) { + super( + new Joined<>( + new Mapped<>( + meta -> { + final String[] pair = meta.split(" ", 2); + final String head = pair[0].substring(1); + if (head.equals(UnphiMojo.Metas.PACKAGE)) { + throw new IllegalStateException( + "+package meta can't be attached to unphied XMIR" + ); + } + final Directives dirs = new Directives() + .xpath("/program/metas") + .add("head").set(head).up() + .add("tail"); + if (pair.length > 1) { + dirs.set(pair[1].trim()).up(); + for (final String part : pair[1].trim().split(" ")) { + dirs.add("part").set(part).up(); + } + } else { + dirs.up(); + } + return dirs.up(); + }, + metas + ) + ) + ); + } + } } diff --git a/eo-parser/src/main/java/org/eolang/parser/PhiSyntax.java b/eo-parser/src/main/java/org/eolang/parser/PhiSyntax.java index 8311f38ebc..35a2743dd4 100644 --- a/eo-parser/src/main/java/org/eolang/parser/PhiSyntax.java +++ b/eo-parser/src/main/java/org/eolang/parser/PhiSyntax.java @@ -32,6 +32,7 @@ import org.antlr.v4.runtime.tree.ParseTreeWalker; import org.cactoos.Text; import org.cactoos.io.InputStreamOf; +import org.xembly.Directive; import org.xembly.Directives; import org.xembly.Xembler; @@ -50,22 +51,33 @@ public final class PhiSyntax implements Syntax { */ private final Text input; + /** + * Extra directives to append to parsed phi. + */ + private final Iterable extra; + /** * Ctor for the tests. * @param input Input */ PhiSyntax(final String input) { - this("test", () -> input); + this("test", () -> input, new Directives()); } /** * Ctor. * @param nme Name of the program * @param inpt Input + * @param extra Extra directives to append */ - public PhiSyntax(final String nme, final Text inpt) { + public PhiSyntax( + final String nme, + final Text inpt, + final Iterable extra + ) { this.name = nme; this.input = inpt; + this.extra = extra; } @Override @@ -86,7 +98,7 @@ public XML parsed() throws IOException { new ParseTreeWalker().walk(xel, parser.program()); final XML dom = new XMLDocument( new Xembler( - new Directives(xel).append(spy) + new Directives(xel).append(spy).append(extra) ).domQuietly() ); new Schema(dom).check(); diff --git a/eo-parser/src/test/java/org/eolang/parser/PhiSyntaxTest.java b/eo-parser/src/test/java/org/eolang/parser/PhiSyntaxTest.java index 20aec0eae8..c36c7e57a0 100644 --- a/eo-parser/src/test/java/org/eolang/parser/PhiSyntaxTest.java +++ b/eo-parser/src/test/java/org/eolang/parser/PhiSyntaxTest.java @@ -27,6 +27,7 @@ import java.io.IOException; import org.hamcrest.MatcherAssert; import org.junit.jupiter.api.Test; +import org.xembly.Directives; /** * Test cases for {@link PhiSyntax}. @@ -46,4 +47,19 @@ void addsError() throws IOException { ) ); } + + @Test + void addsExtra() throws IOException { + MatcherAssert.assertThat( + "Result XML must contain extra object", + new PhiSyntax( + "test", + () -> "{⟦obj ↦ ⟦⟧⟧}", + new Directives().xpath("/program/objects").add("o").attr("base", "x") + ).parsed(), + XhtmlMatchers.hasXPath( + "//objects/o[@base='x']" + ) + ); + } } From 2ecd9dfe6825e4c912545f61d11236f259f54fa6 Mon Sep 17 00:00:00 2001 From: maxonfjvipon Date: Fri, 1 Mar 2024 17:47:07 +0300 Subject: [PATCH 60/80] fix(#2909): tests --- .../main/java/org/eolang/maven/UnphiMojo.java | 5 ++- .../java/org/eolang/maven/UnphiMojoTest.java | 38 +++++++++++++++++++ .../java/org/eolang/parser/PhiSyntax.java | 2 +- 3 files changed, 42 insertions(+), 3 deletions(-) diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java index 93ce623cdc..3019e74658 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java @@ -151,7 +151,7 @@ private static class Metas extends IterableEnvelope { /** * Package meta. */ - private static final String PACKAGE = "+package"; + private static final String PACKAGE = "package"; /** * Ctor. @@ -166,11 +166,12 @@ private static class Metas extends IterableEnvelope { final String head = pair[0].substring(1); if (head.equals(UnphiMojo.Metas.PACKAGE)) { throw new IllegalStateException( - "+package meta can't be attached to unphied XMIR" + "+package meta is prohibited for attaching to unphied XMIR" ); } final Directives dirs = new Directives() .xpath("/program/metas") + .add("meta") .add("head").set(head).up() .add("tail"); if (pair.length > 1) { diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java index e2bede1666..2d5ba2c682 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java @@ -34,6 +34,7 @@ import java.util.Map; import org.cactoos.io.InputOf; import org.cactoos.list.ListOf; +import org.cactoos.set.SetOf; import org.cactoos.text.TextOf; import org.eolang.jucs.ClasspathSource; import org.eolang.maven.util.HmBase; @@ -85,6 +86,43 @@ void failsIfParsedWithErrors(@TempDir final Path temp) throws IOException { ); } + @Test + void addsMetas(@TempDir final Path temp) throws IOException { + new HmBase(temp).save( + "{⟦std ↦ Φ.org.eolang.io.stdout⟧}", + Paths.get("target/phi/std.phi") + ); + MatcherAssert.assertThat( + "Unphied XMIR must contain metas, added via \"unphiMetas\" parameter", + new XMLDocument( + new FakeMaven(temp) + .with("unphiMetas", new SetOf<>("+tests", "+home https://github.com/objectionary/eo")) + .execute(UnphiMojo.class) + .result() + .get(String.format("target/%s/std.xmir", ParseMojo.DIR)) + ), + XhtmlMatchers.hasXPaths( + "/program/metas/meta[head/text()='tests' and not(tail/text())]", + "/program/metas/meta[head/text()='home' and tail/text()='https://github.com/objectionary/eo']" + ) + ); + } + + @Test + void failsIfPackageMetaIsAdded(@TempDir final Path temp) throws IOException { + new HmBase(temp).save( + "{⟦std ↦ Φ.org.eolang.io.stdout⟧}", + Paths.get("target/phi/std.phi") + ); + Assertions.assertThrows( + IllegalStateException.class, + () -> new FakeMaven(temp) + .with("unphiMetas", new SetOf<>("+package org.eolang")) + .execute(UnphiMojo.class), + "UnphiMojo execution should fail if \"+package\" meta is added" + ); + } + @ParameterizedTest @ClasspathSource(value = "org/eolang/maven/unphi", glob = "**.yaml") void checksUnphiPacks(final String pack, @TempDir final Path temp) throws Exception { diff --git a/eo-parser/src/main/java/org/eolang/parser/PhiSyntax.java b/eo-parser/src/main/java/org/eolang/parser/PhiSyntax.java index 35a2743dd4..c62b372bac 100644 --- a/eo-parser/src/main/java/org/eolang/parser/PhiSyntax.java +++ b/eo-parser/src/main/java/org/eolang/parser/PhiSyntax.java @@ -98,7 +98,7 @@ public XML parsed() throws IOException { new ParseTreeWalker().walk(xel, parser.program()); final XML dom = new XMLDocument( new Xembler( - new Directives(xel).append(spy).append(extra) + new Directives(xel).append(spy).append(this.extra) ).domQuietly() ); new Schema(dom).check(); From 0098d028ea61f57bb07e234de7d63d7a8da998d7 Mon Sep 17 00:00:00 2001 From: volodya-lombrozo Date: Fri, 1 Mar 2024 17:49:13 +0300 Subject: [PATCH 61/80] chore: update jtcop version 1.2.0 --- .../src/test/java/org/eolang/maven/ContainsFiles.java | 6 +++++- eo-runtime/src/test/java/EOorg/EOeolang/EOfailed.java | 6 +++++- pom.xml | 2 +- 3 files changed, 11 insertions(+), 3 deletions(-) diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/ContainsFiles.java b/eo-maven-plugin/src/test/java/org/eolang/maven/ContainsFiles.java index 086a657baf..5eb7b330e7 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/ContainsFiles.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/ContainsFiles.java @@ -35,7 +35,11 @@ * Asserting that path contains a files matching provided globs. * @since 0.31.0 */ -@SuppressWarnings({"JTCOP.RuleAllTestsHaveProductionClass", "JTCOP.RuleCorrectTestName"}) +@SuppressWarnings({ + "JTCOP.RuleAllTestsHaveProductionClass", + "JTCOP.RuleCorrectTestName", + "JTCOP.RuleInheritanceInTests" +}) final class ContainsFiles extends TypeSafeMatcher { /** * Patterns. diff --git a/eo-runtime/src/test/java/EOorg/EOeolang/EOfailed.java b/eo-runtime/src/test/java/EOorg/EOeolang/EOfailed.java index 6e6c362324..a7eff8087c 100644 --- a/eo-runtime/src/test/java/EOorg/EOeolang/EOfailed.java +++ b/eo-runtime/src/test/java/EOorg/EOeolang/EOfailed.java @@ -34,6 +34,10 @@ * * @since 0.29 */ -@SuppressWarnings({"JTCOP.RuleAllTestsHaveProductionClass", "JTCOP.RuleCorrectTestName"}) +@SuppressWarnings({ + "JTCOP.RuleAllTestsHaveProductionClass", + "JTCOP.RuleCorrectTestName", + "JTCOP.RuleInheritanceInTests" +}) final class EOfailed extends PhDefault { } diff --git a/pom.xml b/pom.xml index dbaffe804e..0dd1c738d3 100644 --- a/pom.xml +++ b/pom.xml @@ -379,7 +379,7 @@ SOFTWARE. com.github.volodya-lombrozo jtcop-maven-plugin - 1.1.1 + 1.2.0 true From 56922c580b1c9ad56b313e827847d19997811872 Mon Sep 17 00:00:00 2001 From: maxonfjvipon Date: Fri, 1 Mar 2024 17:50:33 +0300 Subject: [PATCH 62/80] fix(#2909): checkstyle --- .../src/main/java/org/eolang/maven/UnphiMojo.java | 5 +---- .../src/test/java/org/eolang/maven/UnphiMojoTest.java | 7 +++++-- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java index 3019e74658..70df92939e 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/UnphiMojo.java @@ -29,7 +29,6 @@ import java.nio.file.Path; import java.nio.file.Paths; import java.util.Arrays; -import java.util.Iterator; import java.util.List; import java.util.Set; import org.apache.maven.plugins.annotations.LifecyclePhase; @@ -37,7 +36,6 @@ import org.apache.maven.plugins.annotations.Parameter; import org.cactoos.experimental.Threads; import org.cactoos.iterable.IterableEnvelope; -import org.cactoos.iterable.IterableOf; import org.cactoos.iterable.Joined; import org.cactoos.iterable.Mapped; import org.cactoos.list.ListOf; @@ -48,10 +46,8 @@ import org.eolang.maven.util.Home; import org.eolang.maven.util.Walk; import org.eolang.parser.PhiSyntax; -import org.eolang.parser.XeEoListener; import org.xembly.Directive; import org.xembly.Directives; -import org.xembly.Xembler; /** * Read PHI files and parse them to the XMIR. @@ -89,6 +85,7 @@ public final class UnphiMojo extends SafeMojo { * Extra metas to add to unphied XMIR. * @checkstyle MemberNameCheck (10 lines) */ + @SuppressWarnings("PMD.ImmutableField") @Parameter(property = "eo.unphiMetas") private Set unphiMetas = new SetOf<>(); diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java index 2d5ba2c682..5720e74cb7 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java @@ -96,7 +96,10 @@ void addsMetas(@TempDir final Path temp) throws IOException { "Unphied XMIR must contain metas, added via \"unphiMetas\" parameter", new XMLDocument( new FakeMaven(temp) - .with("unphiMetas", new SetOf<>("+tests", "+home https://github.com/objectionary/eo")) + .with( + "unphiMetas", + new SetOf<>("+tests", "+home https://github.com/objectionary/eo") + ) .execute(UnphiMojo.class) .result() .get(String.format("target/%s/std.xmir", ParseMojo.DIR)) @@ -107,7 +110,7 @@ void addsMetas(@TempDir final Path temp) throws IOException { ) ); } - + @Test void failsIfPackageMetaIsAdded(@TempDir final Path temp) throws IOException { new HmBase(temp).save( From 30c0da0453c9421a0f9a08ccdcc8150efc22c3a2 Mon Sep 17 00:00:00 2001 From: volodya-lombrozo Date: Fri, 1 Mar 2024 18:47:35 +0300 Subject: [PATCH 63/80] chore: empty commit to restrart CI pipeline From 8663021b223ada831bbc934691068bd1012527a1 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 2 Mar 2024 19:16:58 +0000 Subject: [PATCH 64/80] chore(deps): update dependency ch.qos.logback:logback-classic to v1.5.2 --- eo-runtime/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eo-runtime/pom.xml b/eo-runtime/pom.xml index 3a0fdf34f0..3f959bb27a 100644 --- a/eo-runtime/pom.xml +++ b/eo-runtime/pom.xml @@ -53,7 +53,7 @@ SOFTWARE. ch.qos.logback logback-classic - 1.5.1 + 1.5.2 test From 02fa132e53fdee6751f3345a7350059d7e8adb32 Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Mon, 4 Mar 2024 15:52:45 +0300 Subject: [PATCH 65/80] #2836: @Execution(ExecutionMode.SAME_THREAD) --- eo-runtime/src/test/java/EOorg/EOeolang/EOcageTest.java | 3 +++ 1 file changed, 3 insertions(+) diff --git a/eo-runtime/src/test/java/EOorg/EOeolang/EOcageTest.java b/eo-runtime/src/test/java/EOorg/EOeolang/EOcageTest.java index e44e790f16..4d4603313c 100644 --- a/eo-runtime/src/test/java/EOorg/EOeolang/EOcageTest.java +++ b/eo-runtime/src/test/java/EOorg/EOeolang/EOcageTest.java @@ -46,6 +46,8 @@ import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Nested; import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.parallel.Execution; +import org.junit.jupiter.api.parallel.ExecutionMode; /** * Test case for {@link EOcage}. @@ -277,6 +279,7 @@ private static void writeTo(final Phi cage, final Phi obj) { * @since 0.1 */ @Nested + @Execution(ExecutionMode.SAME_THREAD) class RecursionTests { /** From df984e26d713ed5acded3844b512e898500b5d4d Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Mon, 4 Mar 2024 13:47:34 +0000 Subject: [PATCH 66/80] chore(deps): update dependency ch.qos.logback:logback-classic to v1.5.3 --- eo-runtime/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eo-runtime/pom.xml b/eo-runtime/pom.xml index 3f959bb27a..944f0ee74d 100644 --- a/eo-runtime/pom.xml +++ b/eo-runtime/pom.xml @@ -53,7 +53,7 @@ SOFTWARE. ch.qos.logback logback-classic - 1.5.2 + 1.5.3 test From 85ce4c3c8c45dba7a1cff611c71d029602224cce Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Tue, 5 Mar 2024 14:56:07 +0300 Subject: [PATCH 67/80] #2863 replace anonymous class by single implementation to reduce code duplicatoin --- .github/workflows/simian.yml | 2 +- .../test/java/org/eolang/DataizedTest.java | 92 ++++++------------- 2 files changed, 29 insertions(+), 65 deletions(-) diff --git a/.github/workflows/simian.yml b/.github/workflows/simian.yml index 2f1afb342c..6c2e2d85e2 100644 --- a/.github/workflows/simian.yml +++ b/.github/workflows/simian.yml @@ -24,4 +24,4 @@ jobs: - run: | wget --quiet http://public.yegor256.com/simian.jar -O /tmp/simian.jar - run: | - java -jar /tmp/simian.jar -threshold=25 -excludes=**/gen -excludes=**/it **/*.java + java -jar /tmp/simian.jar -threshold=16 -excludes=**/gen -excludes=**/it **/*.java diff --git a/eo-runtime/src/test/java/org/eolang/DataizedTest.java b/eo-runtime/src/test/java/org/eolang/DataizedTest.java index 543c129406..c940a9fc94 100644 --- a/eo-runtime/src/test/java/org/eolang/DataizedTest.java +++ b/eo-runtime/src/test/java/org/eolang/DataizedTest.java @@ -48,22 +48,7 @@ void logsCorrectly() { final Level before = log.getLevel(); log.setLevel(Level.ALL); final List logs = new LinkedList<>(); - final Handler hnd = new Handler() { - @Override - public void publish(final LogRecord record) { - logs.add(record); - } - - @Override - public void flush() { - throw new UnsupportedOperationException("#flush()"); - } - - @Override - public void close() throws SecurityException { - throw new UnsupportedOperationException("#close()"); - } - }; + final Handler hnd = new TestHandler(logs); log.addHandler(hnd); new Dataized(new Data.ToPhi(1L), log).take(); log.setLevel(before); @@ -83,22 +68,7 @@ void logsWhenException() { final Level before = log.getLevel(); log.setLevel(Level.ALL); final List logs = new LinkedList<>(); - final Handler hnd = new Handler() { - @Override - public void publish(final LogRecord record) { - logs.add(record); - } - - @Override - public void flush() { - throw new UnsupportedOperationException("#flush()"); - } - - @Override - public void close() throws SecurityException { - throw new UnsupportedOperationException("#close()"); - } - }; + final Handler hnd = new TestHandler(logs); log.addHandler(hnd); final Phi wrong = new PhIncorrect(Phi.Φ); IntStream.range(0, 5).forEach( @@ -125,22 +95,7 @@ void printsShortLogs() throws InterruptedException { final Level before = log.getLevel(); log.setLevel(Level.ALL); final List logs = new LinkedList<>(); - final Handler hnd = new Handler() { - @Override - public void publish(final LogRecord record) { - logs.add(record); - } - - @Override - public void flush() { - throw new UnsupportedOperationException("#flush()"); - } - - @Override - public void close() throws SecurityException { - throw new UnsupportedOperationException("#close()"); - } - }; + final Handler hnd = new TestHandler(logs); log.addHandler(hnd); final Thread thread = new Thread( () -> { @@ -170,22 +125,7 @@ void printsLongLogs() throws InterruptedException { final Level before = log.getLevel(); log.setLevel(Level.ALL); final List logs = new LinkedList<>(); - final Handler hnd = new Handler() { - @Override - public void publish(final LogRecord record) { - logs.add(record); - } - - @Override - public void flush() { - throw new UnsupportedOperationException("#flush()"); - } - - @Override - public void close() throws SecurityException { - throw new UnsupportedOperationException("#close()"); - } - }; + final Handler hnd = new TestHandler(logs); log.addHandler(hnd); final Thread thread = new Thread( () -> { @@ -261,4 +201,28 @@ public static class PhiDec extends PhDefault { } } + private static class TestHandler extends Handler { + final List logs; + + TestHandler(final List logs) { + this.logs = logs; + } + + @Override + public void publish(final LogRecord record) { + logs.add(record); + } + + @Override + public void flush() { + throw new UnsupportedOperationException("#flush()"); + } + + @Override + public void close() throws SecurityException { + throw new UnsupportedOperationException("#close()"); + } + + } + } From 333e32f7b336f0c3a086de488b1f8798acc2482c Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Tue, 5 Mar 2024 15:58:58 +0300 Subject: [PATCH 68/80] #2863 fix qulice warnings --- .../test/java/org/eolang/DataizedTest.java | 29 ++++++++++++++----- 1 file changed, 21 insertions(+), 8 deletions(-) diff --git a/eo-runtime/src/test/java/org/eolang/DataizedTest.java b/eo-runtime/src/test/java/org/eolang/DataizedTest.java index c940a9fc94..65e8d24aab 100644 --- a/eo-runtime/src/test/java/org/eolang/DataizedTest.java +++ b/eo-runtime/src/test/java/org/eolang/DataizedTest.java @@ -48,7 +48,7 @@ void logsCorrectly() { final Level before = log.getLevel(); log.setLevel(Level.ALL); final List logs = new LinkedList<>(); - final Handler hnd = new TestHandler(logs); + final Handler hnd = new Hnd(logs); log.addHandler(hnd); new Dataized(new Data.ToPhi(1L), log).take(); log.setLevel(before); @@ -68,7 +68,7 @@ void logsWhenException() { final Level before = log.getLevel(); log.setLevel(Level.ALL); final List logs = new LinkedList<>(); - final Handler hnd = new TestHandler(logs); + final Handler hnd = new Hnd(logs); log.addHandler(hnd); final Phi wrong = new PhIncorrect(Phi.Φ); IntStream.range(0, 5).forEach( @@ -95,7 +95,7 @@ void printsShortLogs() throws InterruptedException { final Level before = log.getLevel(); log.setLevel(Level.ALL); final List logs = new LinkedList<>(); - final Handler hnd = new TestHandler(logs); + final Handler hnd = new Hnd(logs); log.addHandler(hnd); final Thread thread = new Thread( () -> { @@ -125,7 +125,7 @@ void printsLongLogs() throws InterruptedException { final Level before = log.getLevel(); log.setLevel(Level.ALL); final List logs = new LinkedList<>(); - final Handler hnd = new TestHandler(logs); + final Handler hnd = new Hnd(logs); log.addHandler(hnd); final Thread thread = new Thread( () -> { @@ -201,16 +201,29 @@ public static class PhiDec extends PhDefault { } } - private static class TestHandler extends Handler { - final List logs; + /** + * Handler implementation for tests. + * + * @since 1.0 + */ + private static class Hnd extends Handler { + /** + * Logs. + */ + private final List logs; - TestHandler(final List logs) { + /** + * Ctor. + * + * @param logs Logs + */ + Hnd(final List logs) { this.logs = logs; } @Override public void publish(final LogRecord record) { - logs.add(record); + this.logs.add(record); } @Override From 153aeb969971132b780ec7272affa6516b4e864d Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Tue, 5 Mar 2024 17:32:54 +0300 Subject: [PATCH 69/80] #2863 create additional object for test to reduce code duplication --- .../EOorg/EOeolang/EOio/EOstdoutTest.java | 91 ++++++++++++------- 1 file changed, 59 insertions(+), 32 deletions(-) diff --git a/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java b/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java index 76224ac252..aabd1eb58a 100644 --- a/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java +++ b/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java @@ -32,9 +32,11 @@ import EOorg.EOeolang.EOtuple$EOempty; import java.io.ByteArrayOutputStream; import java.io.PrintStream; +import org.eolang.AtComposite; import org.eolang.Data; import org.eolang.Dataized; import org.eolang.PhCopy; +import org.eolang.PhDefault; import org.eolang.PhMethod; import org.eolang.PhWith; import org.eolang.Phi; @@ -96,27 +98,16 @@ public void doesNotPrintTwiceOnIntComparisonMethods(final String method) { final ByteArrayOutputStream stream = new ByteArrayOutputStream(); final String str = "Hello world"; new Dataized( - new PhWith( + new PrintWithCmp( new PhMethod( new Data.ToPhi(1L), method ), - 0, + new Data.ToPhi(2L), new PhWith( - new EOseq(Phi.Φ), - 0, - new PhWith( - new PhWith( - new EOtuple$EOempty(Phi.Φ).attr("with").get().copy(), - 0, - new PhWith( - new EOstdout(Phi.Φ, new PrintStream(stream)), - "text", - new Data.ToPhi(str) - ) - ).attr("with").get().copy(), - 0, new Data.ToPhi(2L) - ) + new EOstdout(Phi.Φ, new PrintStream(stream)), + "text", + new Data.ToPhi(str) ) ) ).take(); @@ -132,27 +123,16 @@ public void doesNotPrintTwiceOnFloatComparisonMethods(final String method) { final ByteArrayOutputStream stream = new ByteArrayOutputStream(); final String str = "Hello world"; new Dataized( - new PhWith( + new PrintWithCmp( new PhMethod( new Data.ToPhi(1.0), method ), - 0, + new Data.ToPhi(3.0), new PhWith( - new EOseq(Phi.Φ), - 0, - new PhWith( - new PhWith( - new EOtuple$EOempty(Phi.Φ).attr("with").get().copy(), - 0, - new PhWith( - new EOstdout(Phi.Φ, new PrintStream(stream)), - "text", - new Data.ToPhi(str) - ) - ).attr("with").get().copy(), - 0, new Data.ToPhi(3.0) - ) + new EOstdout(Phi.Φ, new PrintStream(stream)), + "text", + new Data.ToPhi(str) ) ) ).take(); @@ -161,4 +141,51 @@ public void doesNotPrintTwiceOnFloatComparisonMethods(final String method) { Matchers.equalTo(str) ); } + + /** + * Handler implementation for tests. + * + * @since 1.0 + */ + private static class PrintWithCmp extends PhDefault { + /** + * Ctor. + * + * @param method Comparison PhMethod ("lt", "gt", "lte", "gte") + * @param value Phi value to be compared + * @param stdout Phi object with printing a string via {@link EOstdout} object + */ + PrintWithCmp(final Phi method, final Phi value, final Phi stdout) { + super(Phi.Φ); + this.add( + "φ", + new AtComposite( + this, + self -> new Data.ToPhi( + new Dataized( + new PhWith( + method, + 0, + new PhWith( + new EOseq(Phi.Φ), + 0, + new PhWith( + new PhWith( + new EOtuple$EOempty(Phi.Φ) + .attr("with") + .get() + .copy(), + 0, + stdout + ).attr("with").get().copy(), + 0, value + ) + ) + ) + ).take() + ) + ) + ); + } + } } From 1a39c4a9319960e4e1afc8f92c91bf9a166abeef Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Tue, 5 Mar 2024 19:19:17 +0000 Subject: [PATCH 70/80] chore(deps): update actions/checkout digest to 8eb1f6a --- .github/workflows/markdown-lint.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/markdown-lint.yml b/.github/workflows/markdown-lint.yml index 6ae0d3bf34..ad013979cb 100644 --- a/.github/workflows/markdown-lint.yml +++ b/.github/workflows/markdown-lint.yml @@ -15,5 +15,5 @@ jobs: markdown-lint: runs-on: ubuntu-22.04 steps: - - uses: actions/checkout@b32f140b0c872d58512e0a66172253c302617b90 + - uses: actions/checkout@8eb1f6a495037164bea451156472f35fdd6bafc0 - uses: articulate/actions-markdownlint@v1 From 0689977a96195ed0ec99070a3c64ea72f29654c9 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 6 Mar 2024 05:39:29 +0000 Subject: [PATCH 71/80] chore(deps): update dependency com.qulice:qulice-maven-plugin to v0.22.1 --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index 42e2021ce0..d25ddbf43e 100644 --- a/pom.xml +++ b/pom.xml @@ -368,7 +368,7 @@ SOFTWARE. com.qulice qulice-maven-plugin - 0.22.0 + 0.22.1 checkstyle:/src/site/resources/.* From 120ec47e5ecd03072e0f4a3242abc138826d5681 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 7 Mar 2024 07:42:17 +0300 Subject: [PATCH 72/80] #2923 shorter line --- src/test/scripts/test-repetition.sh | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/test/scripts/test-repetition.sh b/src/test/scripts/test-repetition.sh index 9afa969c9b..c9c890cad0 100755 --- a/src/test/scripts/test-repetition.sh +++ b/src/test/scripts/test-repetition.sh @@ -24,7 +24,8 @@ do compilation=$1 ;; *) - echo "Invalid option: $1. Please, specify --max, --folder or --compilation options, for example, --max 15 --folder /some/path" + echo "Invalid option: $1. Please, specify --max, --folder or --compilation options, \ +for example, --max 15 --folder /some/path" exit 1 ;; esac From 5ef4e529278adc7bcbdcbe765750a5a801f4421b Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Thu, 7 Mar 2024 14:00:45 +0300 Subject: [PATCH 73/80] #2716: using slow annotation --- eo-maven-plugin/pom.xml | 1 - eo-runtime/src/test/java/org/eolang/SnippetTestCase.java | 2 ++ pom.xml | 1 + 3 files changed, 3 insertions(+), 1 deletion(-) diff --git a/eo-maven-plugin/pom.xml b/eo-maven-plugin/pom.xml index 2491f3e1da..2b8b878f2a 100644 --- a/eo-maven-plugin/pom.xml +++ b/eo-maven-plugin/pom.xml @@ -286,7 +286,6 @@ SOFTWARE. org.apache.maven.plugins maven-surefire-plugin - slow @{argLine} -Xss${stack-size} ${project.basedir}/../eo-runtime diff --git a/eo-runtime/src/test/java/org/eolang/SnippetTestCase.java b/eo-runtime/src/test/java/org/eolang/SnippetTestCase.java index 8a39ab10cd..efa4f11b11 100755 --- a/eo-runtime/src/test/java/org/eolang/SnippetTestCase.java +++ b/eo-runtime/src/test/java/org/eolang/SnippetTestCase.java @@ -40,6 +40,7 @@ import org.hamcrest.MatcherAssert; import org.hamcrest.Matchers; import org.junit.jupiter.api.Assumptions; +import org.junit.jupiter.api.Tag; import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.io.TempDir; import org.junit.jupiter.params.ParameterizedTest; @@ -80,6 +81,7 @@ final class SnippetTestCase { * @throws IOException If fails */ @ParameterizedTest + @Tag("slow") @ExtendWith(WeAreOnline.class) @SuppressWarnings("unchecked") @ClasspathSource(value = "org/eolang/snippets/", glob = "**.yaml") diff --git a/pom.xml b/pom.xml index d25ddbf43e..d00bef8400 100644 --- a/pom.xml +++ b/pom.xml @@ -349,6 +349,7 @@ SOFTWARE. ${project.basedir} + slow junit.jupiter.execution.parallel.enabled = true From ae53efd9603e92cd919d508786c00d73398f9c25 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 7 Mar 2024 15:34:05 +0300 Subject: [PATCH 74/80] qulice back to 0.22 --- .../src/main/java/org/eolang/maven/AssembleMojo.java | 12 ++++++------ .../src/main/java/org/eolang/maven/BinarizeMojo.java | 2 +- .../main/java/org/eolang/maven/BinarizeParse.java | 2 +- .../src/main/java/org/eolang/maven/DemandMojo.java | 2 +- .../src/main/java/org/eolang/maven/OptimizeMojo.java | 2 +- .../src/main/java/org/eolang/maven/PlaceMojo.java | 2 +- .../src/main/java/org/eolang/maven/PullMojo.java | 2 +- .../src/main/java/org/eolang/maven/ResolveMojo.java | 6 +++--- .../src/main/java/org/eolang/maven/SafeMojo.java | 8 ++++---- .../src/main/java/org/eolang/maven/ShakeMojo.java | 2 +- .../src/main/java/org/eolang/maven/UnplaceMojo.java | 4 ++-- .../java/org/eolang/maven/dependencies/DcsFake.java | 5 ++++- .../eolang/maven/objectionary/Objectionaries.java | 2 +- .../org/eolang/maven/objectionary/Objectionary.java | 2 +- .../test/java/org/eolang/maven/AssembleMojoTest.java | 2 +- .../src/test/java/org/eolang/maven/CatalogsTest.java | 2 +- .../test/java/org/eolang/maven/CleanMojoTest.java | 2 +- .../test/java/org/eolang/maven/JavaFilesTest.java | 2 +- .../test/java/org/eolang/maven/LatexMojoTest.java | 2 +- .../test/java/org/eolang/maven/LogFormatTest.java | 2 +- .../src/test/java/org/eolang/maven/PhiMojoTest.java | 2 +- .../test/java/org/eolang/maven/UnphiMojoTest.java | 2 +- .../test/java/org/eolang/maven/VerifyMojoTest.java | 2 +- .../dependencies/DcsEachWithoutTransitiveTest.java | 2 +- .../java/org/eolang/maven/hash/ChCachedTest.java | 2 +- .../java/org/eolang/maven/hash/ChNarrowTest.java | 2 +- .../test/java/org/eolang/maven/hash/ChTextTest.java | 2 +- .../org/eolang/maven/latex/LatexTemplateTest.java | 2 +- .../test/java/org/eolang/maven/name/OnSwapTest.java | 2 +- .../eolang/maven/objectionary/ObjectsIndexTest.java | 2 +- .../maven/objectionary/OyFallbackSwapTest.java | 2 +- .../eolang/maven/objectionary/OyFilesystemTest.java | 2 +- .../org/eolang/maven/objectionary/OyIndexedTest.java | 2 +- .../src/test/java/org/eolang/maven/util/RelTest.java | 2 +- .../main/java/org/eolang/parser/XePhiListener.java | 2 +- .../test/java/org/eolang/parser/PhiSyntaxTest.java | 2 +- .../test/java/org/eolang/parser/StEoLoggedTest.java | 2 +- pom.xml | 2 +- 38 files changed, 52 insertions(+), 49 deletions(-) diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/AssembleMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/AssembleMojo.java index 6af43821d7..bb5e086433 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/AssembleMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/AssembleMojo.java @@ -113,8 +113,8 @@ public final class AssembleMojo extends SafeMojo { /** * Pull again even if the .eo file is already present? - * @checkstyle MemberNameCheck (7 lines) * @since 0.10.0 + * @checkstyle MemberNameCheck (7 lines) */ @Parameter(property = "eo.overWrite", required = true, defaultValue = "false") private boolean overWrite; @@ -122,8 +122,8 @@ public final class AssembleMojo extends SafeMojo { /** * Track optimization steps into intermediate XML files? * - * @checkstyle MemberNameCheck (7 lines) * @since 0.24.0 + * @checkstyle MemberNameCheck (7 lines) */ @SuppressWarnings("PMD.LongVariable") @Parameter(property = "eo.trackOptimizationSteps", required = true, defaultValue = "false") @@ -139,16 +139,16 @@ public final class AssembleMojo extends SafeMojo { /** * Skip artifact with the version 0.0.0. - * @checkstyle MemberNameCheck (7 lines) * @since 0.9.0 + * @checkstyle MemberNameCheck (7 lines) */ @Parameter(property = "eo.skipZeroVersions", required = true, defaultValue = "true") private boolean skipZeroVersions; /** * Shall we discover JAR artifacts for .EO sources? - * @checkstyle MemberNameCheck (7 lines) * @since 0.12.0 + * @checkstyle MemberNameCheck (7 lines) */ @Parameter(property = "eo.discoverSelf", required = true, defaultValue = "false") private boolean discoverSelf; @@ -156,8 +156,8 @@ public final class AssembleMojo extends SafeMojo { /** * Fail resolution process on conflicting dependencies. * - * @checkstyle MemberNameCheck (7 lines) * @since 1.0 + * @checkstyle MemberNameCheck (7 lines) */ @Parameter(property = "eo.ignoreVersionConflicts", required = true, defaultValue = "false") @SuppressWarnings("PMD.LongVariable") @@ -196,9 +196,9 @@ public final class AssembleMojo extends SafeMojo { /** * If set to TRUE, the exception on exit will be printed in details * to the log. + * @since 0.29.0 * @checkstyle MemberNameCheck (7 lines) * @checkstyle VisibilityModifierCheck (10 lines) - * @since 0.29.0 */ @Parameter(property = "eo.unrollExitError") @SuppressWarnings("PMD.ImmutableField") diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeMojo.java index fbed7d6dda..657d7bf5bd 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeMojo.java @@ -39,8 +39,8 @@ /** * Compile binaries. * - * @checkstyle ClassDataAbstractionCouplingCheck (500 lines) * @since 0.1 + * @checkstyle ClassDataAbstractionCouplingCheck (500 lines) */ @Mojo( name = "binarize", diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParse.java b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParse.java index ad73287cd3..7ed4506caa 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParse.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/BinarizeParse.java @@ -50,8 +50,8 @@ /** * Parse rust inserts. * - * @checkstyle ClassDataAbstractionCouplingCheck (500 lines) * @since 0.1 + * @checkstyle ClassDataAbstractionCouplingCheck (500 lines) */ @SuppressWarnings("PMD.LongVariable") public final class BinarizeParse { diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/DemandMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/DemandMojo.java index 51704b53b6..6a94e2a74e 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/DemandMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/DemandMojo.java @@ -44,8 +44,8 @@ public final class DemandMojo extends SafeMojo { /** * List of object names to add. - * @checkstyle MemberNameCheck (7 lines) * @since 0.17.0 + * @checkstyle MemberNameCheck (7 lines) */ @Parameter(required = true) private List objects; 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 6a848c98dc..c725d32227 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 @@ -78,8 +78,8 @@ public final class OptimizeMojo extends SafeMojo { /** * Track optimization steps into intermediate XML files? * - * @checkstyle MemberNameCheck (7 lines) * @since 0.24.0 + * @checkstyle MemberNameCheck (7 lines) */ @SuppressWarnings("PMD.LongVariable") @Parameter(property = "eo.trackOptimizationSteps", required = true, defaultValue = "false") diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/PlaceMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/PlaceMojo.java index 4fd53d2567..18c4fd0f0e 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/PlaceMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/PlaceMojo.java @@ -49,8 +49,8 @@ * Take binary files from where ResolveMojo placed them and * copy to target/classes. * - * @since 0.11 * @see Place catalog + * @since 0.11 */ @Mojo( name = "place", diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/PullMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/PullMojo.java index 5b13eefcb1..2e1fa8bcc8 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/PullMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/PullMojo.java @@ -87,8 +87,8 @@ public final class PullMojo extends SafeMojo { /** * Pull again even if the .eo file is already present? - * @checkstyle MemberNameCheck (7 lines) * @since 0.10.0 + * @checkstyle MemberNameCheck (7 lines) */ @Parameter(property = "eo.overWrite", required = true, defaultValue = "false") private boolean overWrite; diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/ResolveMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/ResolveMojo.java index e1ae7a5638..a4c19b8186 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/ResolveMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/ResolveMojo.java @@ -69,8 +69,8 @@ public final class ResolveMojo extends SafeMojo { /** * Skip artifact with the version 0.0.0. * - * @checkstyle MemberNameCheck (7 lines) * @since 0.9.0 + * @checkstyle MemberNameCheck (7 lines) */ @Parameter(property = "eo.skipZeroVersions", required = true, defaultValue = "true") private boolean skipZeroVersions; @@ -78,8 +78,8 @@ public final class ResolveMojo extends SafeMojo { /** * Shall we discover JAR artifacts for .EO sources? * - * @checkstyle MemberNameCheck (7 lines) * @since 0.12.0 + * @checkstyle MemberNameCheck (7 lines) */ @Parameter(property = "eo.discoverSelf", required = true, defaultValue = "false") private boolean discoverSelf; @@ -87,8 +87,8 @@ public final class ResolveMojo extends SafeMojo { /** * Fail resolution process on conflicting dependencies. * - * @checkstyle MemberNameCheck (7 lines) * @since 1.0 + * @checkstyle MemberNameCheck (7 lines) */ @Parameter(property = "eo.ignoreVersionConflicts", required = true, defaultValue = "false") @SuppressWarnings("PMD.LongVariable") diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/SafeMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/SafeMojo.java index 3d91b3d4ef..6778bb09fd 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/SafeMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/SafeMojo.java @@ -123,9 +123,9 @@ abstract class SafeMojo extends AbstractMojo { /** * The path to a text file where paths of all added * .class (and maybe others) files are placed. + * @since 0.11.0 * @checkstyle MemberNameCheck (7 lines) * @checkstyle VisibilityModifierCheck (10 lines) - * @since 0.11.0 */ @Parameter( property = "eo.placed", @@ -144,9 +144,9 @@ abstract class SafeMojo extends AbstractMojo { /** * The path to a text file where paths of generated java files per EO program. + * @since 0.11.0 * @checkstyle MemberNameCheck (7 lines) * @checkstyle VisibilityModifierCheck (10 lines) - * @since 0.11.0 */ @Parameter( property = "eo.transpiled", @@ -157,8 +157,8 @@ abstract class SafeMojo extends AbstractMojo { /** * Mojo execution timeout in seconds. - * @checkstyle VisibilityModifierCheck (10 lines) * @since 0.28.12 + * @checkstyle VisibilityModifierCheck (10 lines) */ @Parameter(property = "eo.timeout") protected Integer timeout = Integer.MAX_VALUE; @@ -174,9 +174,9 @@ abstract class SafeMojo extends AbstractMojo { /** * If set to TRUE, the exception on exit will be printed in details * to the log. + * @since 0.29.0 * @checkstyle MemberNameCheck (7 lines) * @checkstyle VisibilityModifierCheck (10 lines) - * @since 0.29.0 */ @Parameter(property = "eo.unrollExitError") protected boolean unrollExitError = true; 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 fb829415cc..f82a719a2c 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 @@ -75,8 +75,8 @@ public final class ShakeMojo extends SafeMojo { /** * Track optimization steps into intermediate XML files? * - * @checkstyle MemberNameCheck (7 lines) * @since 0.24.0 + * @checkstyle MemberNameCheck (7 lines) */ @SuppressWarnings("PMD.LongVariable") @Parameter(property = "eo.trackOptimizationSteps", required = true, defaultValue = "false") diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/UnplaceMojo.java b/eo-maven-plugin/src/main/java/org/eolang/maven/UnplaceMojo.java index a903a76624..655539c1c6 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/UnplaceMojo.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/UnplaceMojo.java @@ -58,8 +58,8 @@ public final class UnplaceMojo extends SafeMojo { /** * List of inclusion GLOB filters for unplacing (these files will be removed for sure). - * @since 0.24 * @see Placing and Unplacing in JAR Artifacts + * @since 0.24 * @checkstyle MemberNameCheck (7 lines) */ @Parameter @@ -67,8 +67,8 @@ public final class UnplaceMojo extends SafeMojo { /** * List of inclusion GLOB filters for placing (ONLY these files will stay). - * @since 0.24 * @see Placing and Unplacing in JAR Artifacts + * @since 0.24 * @checkstyle MemberNameCheck (7 lines) */ @Parameter diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/dependencies/DcsFake.java b/eo-maven-plugin/src/main/java/org/eolang/maven/dependencies/DcsFake.java index 434f4243b2..191216a040 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/dependencies/DcsFake.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/dependencies/DcsFake.java @@ -119,11 +119,14 @@ static Dependency runtimeDep() { */ private static Dependency randDep() { final Random rand = new SecureRandom(); + final String scope = new String[] { + "test", "compiled", "runtime", + }[rand.nextInt(3)]; return DcsFake.dep( UUID.randomUUID().toString(), UUID.randomUUID().toString(), String.valueOf(Math.abs(rand.nextInt())), - new String[]{"test", "compiled", "runtime"}[rand.nextInt(3)] + scope ); } diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/objectionary/Objectionaries.java b/eo-maven-plugin/src/main/java/org/eolang/maven/objectionary/Objectionaries.java index e81ca45b09..84f369bdd1 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/objectionary/Objectionaries.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/objectionary/Objectionaries.java @@ -56,7 +56,7 @@ public interface Objectionaries { * * @since 0.29.6 */ - class Fake implements Objectionaries { + final class Fake implements Objectionaries { /** * Default objectionary. */ diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/objectionary/Objectionary.java b/eo-maven-plugin/src/main/java/org/eolang/maven/objectionary/Objectionary.java index d3644d8d8b..05cf003028 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/objectionary/Objectionary.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/objectionary/Objectionary.java @@ -56,8 +56,8 @@ public interface Objectionary { /** * Objectionary with lambda-function Ctor-s for testing. * - * @checkstyle IllegalCatchCheck (150 lines) * @since 0.28.11 + * @checkstyle IllegalCatchCheck (150 lines) */ @SuppressWarnings("PMD.AvoidCatchingGenericException") final class Fake implements Objectionary { diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/AssembleMojoTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/AssembleMojoTest.java index cb95c481d5..e7340993ac 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/AssembleMojoTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/AssembleMojoTest.java @@ -48,6 +48,7 @@ /** * Test case for {@link AssembleMojo}. * + * @since 0.1 * @todo #1602:30min Make up how to get rid of excessive usage of * {@code ParseMojo.DIR}, {@code ResolveMojo.DIR} and so on. It would be nice * to replace them with corresponding classes, or something similar @@ -61,7 +62,6 @@ * from older repositories are not parsed successfully because of the presence of varargs there. * So we need to make 2-3 releases and then refactor the test with more fresh versions. Don't * forget to remove the puzzle. - * @since 0.1 */ @ExtendWith(WeAreOnline.class) final class AssembleMojoTest { diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/CatalogsTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/CatalogsTest.java index 787c10cc51..48b4ffabc1 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/CatalogsTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/CatalogsTest.java @@ -43,7 +43,7 @@ * everything works fine it's important to run the tests many times. * @since 0.29.0 */ -class CatalogsTest { +final class CatalogsTest { /** * Number of cores on the running system. diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/CleanMojoTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/CleanMojoTest.java index ab0bfbb062..ba090dc7d5 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/CleanMojoTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/CleanMojoTest.java @@ -39,7 +39,7 @@ * * @since 0.28.6 */ -class CleanMojoTest { +final class CleanMojoTest { @Test void cleansSuccessfully(@TempDir final Path temp) throws IOException { diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/JavaFilesTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/JavaFilesTest.java index 5a337dac4c..c58a6700e5 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/JavaFilesTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/JavaFilesTest.java @@ -44,7 +44,7 @@ * * @since 0.29 */ -class JavaFilesTest { +final class JavaFilesTest { /** * Parsed eo program from resources. diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/LatexMojoTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/LatexMojoTest.java index 55687881e3..9299154402 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/LatexMojoTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/LatexMojoTest.java @@ -34,7 +34,7 @@ * * @since 0.29 */ -class LatexMojoTest { +final class LatexMojoTest { /** * Generate simple main.tex file from main.xmir file diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/LogFormatTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/LogFormatTest.java index f2e31a6e0f..7dc176c019 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/LogFormatTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/LogFormatTest.java @@ -46,7 +46,7 @@ */ @Execution(ExecutionMode.SAME_THREAD) @SuppressWarnings("JTCOP.RuleAllTestsHaveProductionClass") -class LogFormatTest { +final class LogFormatTest { /** * Expected log message format. diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/PhiMojoTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/PhiMojoTest.java index 430b7d8d13..f5f5784dd6 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/PhiMojoTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/PhiMojoTest.java @@ -39,7 +39,7 @@ * Test cases for {@link PhiMojo}. * @since 0.34.0 */ -class PhiMojoTest { +final class PhiMojoTest { @Test void createsFiles(@TempDir final Path temp) throws Exception { MatcherAssert.assertThat( diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java index 5720e74cb7..853a1ff2da 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/UnphiMojoTest.java @@ -53,7 +53,7 @@ * Test cases for {@link UnphiMojo}. * @since 0.34.0 */ -class UnphiMojoTest { +final class UnphiMojoTest { @Test void createsFile(@TempDir final Path temp) throws Exception { new HmBase(temp).save( diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/VerifyMojoTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/VerifyMojoTest.java index d28755dda2..e795dee98f 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/VerifyMojoTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/VerifyMojoTest.java @@ -57,7 +57,7 @@ * error Assertion since now it is hard to get why it failed. */ @SuppressWarnings({"PMD.AvoidDuplicateLiterals", "PMD.TooManyMethods"}) -class VerifyMojoTest { +final class VerifyMojoTest { @Test void doesNotFailWithNoErrorsAndWarnings(@TempDir final Path temp) { diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/dependencies/DcsEachWithoutTransitiveTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/dependencies/DcsEachWithoutTransitiveTest.java index 0a7c2410a7..22339cc5ee 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/dependencies/DcsEachWithoutTransitiveTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/dependencies/DcsEachWithoutTransitiveTest.java @@ -38,7 +38,7 @@ * * @since 0.30 */ -class DcsEachWithoutTransitiveTest { +final class DcsEachWithoutTransitiveTest { @Test void failsIfHasTransitiveDependencies() { diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChCachedTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChCachedTest.java index b5ea55fc19..68487cd6e3 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChCachedTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChCachedTest.java @@ -33,7 +33,7 @@ * * @since 0.28.11 */ -class ChCachedTest { +final class ChCachedTest { @Test void cachesHashAndInvokesDelegateOnlyOnce() { diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChNarrowTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChNarrowTest.java index 4ba72a2a4a..268fdd9b22 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChNarrowTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChNarrowTest.java @@ -35,7 +35,7 @@ * * @since 0.28.11 */ -class ChNarrowTest { +final class ChNarrowTest { @ParameterizedTest @CsvSource({ diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChTextTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChTextTest.java index 03163d5954..ba4b93e64b 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChTextTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/hash/ChTextTest.java @@ -41,7 +41,7 @@ * * @since 0.28.11 */ -class ChTextTest { +final class ChTextTest { /** * Test file path in temp dir. diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/latex/LatexTemplateTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/latex/LatexTemplateTest.java index ca6b435155..0dbe9ada86 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/latex/LatexTemplateTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/latex/LatexTemplateTest.java @@ -32,7 +32,7 @@ * * @since 0.30 */ -class LatexTemplateTest { +final class LatexTemplateTest { /** * Check the full template. diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/name/OnSwapTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/name/OnSwapTest.java index ade9e17b39..9f893d2403 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/name/OnSwapTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/name/OnSwapTest.java @@ -33,7 +33,7 @@ * * @since 0.29.6 */ -class OnSwapTest { +final class OnSwapTest { /** * First. */ diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/ObjectsIndexTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/ObjectsIndexTest.java index b591de6cc3..ea36242c0b 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/ObjectsIndexTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/ObjectsIndexTest.java @@ -37,7 +37,7 @@ * * @since 0.29 */ -class ObjectsIndexTest { +final class ObjectsIndexTest { @Test void contains() throws Exception { diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyFallbackSwapTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyFallbackSwapTest.java index 48937f07c2..f0dfeb63f4 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyFallbackSwapTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyFallbackSwapTest.java @@ -36,7 +36,7 @@ * Tests for {@link OyFallbackSwap}. * @since 1.0 */ -class OyFallbackSwapTest { +final class OyFallbackSwapTest { @Test void getsWithFallbackNoSwapOy() throws Exception { MatcherAssert.assertThat( diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyFilesystemTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyFilesystemTest.java index 99d7a20e2d..245326567b 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyFilesystemTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyFilesystemTest.java @@ -43,7 +43,7 @@ * * @since 0.30 */ -class OyFilesystemTest { +final class OyFilesystemTest { /** * Object content. diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyIndexedTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyIndexedTest.java index ad55cb46d1..6aeac12edd 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyIndexedTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/objectionary/OyIndexedTest.java @@ -37,7 +37,7 @@ * * @since 0.29 */ -class OyIndexedTest { +final class OyIndexedTest { /** * Object name for stdout. diff --git a/eo-maven-plugin/src/test/java/org/eolang/maven/util/RelTest.java b/eo-maven-plugin/src/test/java/org/eolang/maven/util/RelTest.java index 811a148a5e..5167698604 100644 --- a/eo-maven-plugin/src/test/java/org/eolang/maven/util/RelTest.java +++ b/eo-maven-plugin/src/test/java/org/eolang/maven/util/RelTest.java @@ -37,7 +37,7 @@ * * @since 0.28.11 */ -class RelTest { +final class RelTest { @ParameterizedTest @CsvSource({ diff --git a/eo-parser/src/main/java/org/eolang/parser/XePhiListener.java b/eo-parser/src/main/java/org/eolang/parser/XePhiListener.java index f1faefa355..4d296e2d52 100644 --- a/eo-parser/src/main/java/org/eolang/parser/XePhiListener.java +++ b/eo-parser/src/main/java/org/eolang/parser/XePhiListener.java @@ -43,11 +43,11 @@ /** * The PHI-CALCULUS grammar listener for ANTLR4 walker. * + * @since 0.34.0 * @checkstyle CyclomaticComplexityCheck (500 lines) * @checkstyle ClassFanOutComplexityCheck (500 lines) * @checkstyle MethodCountCheck (1300 lines) * @checkstyle NestedIfDepthCheck (1300 lines) - * @since 0.34.0 */ @SuppressWarnings({ "PMD.TooManyMethods", diff --git a/eo-parser/src/test/java/org/eolang/parser/PhiSyntaxTest.java b/eo-parser/src/test/java/org/eolang/parser/PhiSyntaxTest.java index c36c7e57a0..5739c0925b 100644 --- a/eo-parser/src/test/java/org/eolang/parser/PhiSyntaxTest.java +++ b/eo-parser/src/test/java/org/eolang/parser/PhiSyntaxTest.java @@ -34,7 +34,7 @@ * * @since 0.35.0 */ -class PhiSyntaxTest { +final class PhiSyntaxTest { @Test void addsError() throws IOException { MatcherAssert.assertThat( diff --git a/eo-parser/src/test/java/org/eolang/parser/StEoLoggedTest.java b/eo-parser/src/test/java/org/eolang/parser/StEoLoggedTest.java index 618b833ef4..1bb7fb0b2e 100644 --- a/eo-parser/src/test/java/org/eolang/parser/StEoLoggedTest.java +++ b/eo-parser/src/test/java/org/eolang/parser/StEoLoggedTest.java @@ -41,7 +41,7 @@ * * @since 0.30 */ -class StEoLoggedTest { +final class StEoLoggedTest { @Test void hasTheSameUid() { diff --git a/pom.xml b/pom.xml index d25ddbf43e..42e2021ce0 100644 --- a/pom.xml +++ b/pom.xml @@ -368,7 +368,7 @@ SOFTWARE. com.qulice qulice-maven-plugin - 0.22.1 + 0.22.0 checkstyle:/src/site/resources/.* From e77c5050e55fc7e6ce551a4ea65a3b7b3b5700a6 Mon Sep 17 00:00:00 2001 From: levBagryansky <28lev11@gmail.com> Date: Thu, 7 Mar 2024 16:00:50 +0300 Subject: [PATCH 75/80] #2716: using of slow annotation in eo-runtime too --- eo-maven-plugin/pom.xml | 7 ------- pom.xml | 8 ++++++++ 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/eo-maven-plugin/pom.xml b/eo-maven-plugin/pom.xml index 2b8b878f2a..d36f0136b5 100644 --- a/eo-maven-plugin/pom.xml +++ b/eo-maven-plugin/pom.xml @@ -489,13 +489,6 @@ SOFTWARE. - - org.apache.maven.plugins - maven-surefire-plugin - - nothing-to-exclude - - com.github.volodya-lombrozo jtcop-maven-plugin diff --git a/pom.xml b/pom.xml index a0364eff6f..d8bbebb1c8 100644 --- a/pom.xml +++ b/pom.xml @@ -377,6 +377,14 @@ SOFTWARE. + + org.apache.maven.plugins + maven-surefire-plugin + + + nothing-to-exclude + + com.github.volodya-lombrozo jtcop-maven-plugin From 3be2745e68afcfb14e2e0e2fa678175b1bfe8c76 Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Fri, 8 Mar 2024 21:56:20 +0300 Subject: [PATCH 76/80] #2863 use dirty hacks to reduce code duplication --- .../src/main/java/org/eolang/maven/rust/Names.java | 11 ++--------- eo-runtime/src/main/java/EOorg/EOeolang/EOrust.java | 11 ++--------- 2 files changed, 4 insertions(+), 18 deletions(-) diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/rust/Names.java b/eo-maven-plugin/src/main/java/org/eolang/maven/rust/Names.java index ab362fbdd4..2154266e86 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/rust/Names.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/rust/Names.java @@ -189,20 +189,13 @@ private static ConcurrentHashMap load(final Path src) throws IOE final Object result = map.readObject(); if (result.getClass() != ConcurrentHashMap.class) { throw new ClassCastException( - String.format( - "Object inside %s has wrong class %s", - src, - result.getClass() - ) + String.format("Object inside %s has wrong class %s", src, result.getClass()) ); } return (ConcurrentHashMap) result; } catch (final ClassNotFoundException exc) { throw new IllegalArgumentException( - String.format( - "File %s contains invalid data", - src - ), + String.format("File %s contains invalid data", src), exc ); } diff --git a/eo-runtime/src/main/java/EOorg/EOeolang/EOrust.java b/eo-runtime/src/main/java/EOorg/EOeolang/EOrust.java index bef9fcaa8b..ed9af8e97e 100644 --- a/eo-runtime/src/main/java/EOorg/EOeolang/EOrust.java +++ b/eo-runtime/src/main/java/EOorg/EOeolang/EOrust.java @@ -189,20 +189,13 @@ private static ConcurrentHashMap load(final String src) throws I final Object result = map.readObject(); if (result.getClass() != ConcurrentHashMap.class) { throw new ClassCastException( - String.format( - "Object inside %s has wrong class %s", - src, - result.getClass() - ) + String.format("Object inside %s has wrong class %s", src, result.getClass()) ); } return (ConcurrentHashMap) result; } catch (final ClassNotFoundException exc) { throw new IllegalArgumentException( - String.format( - "File %s contains invalid data", - src - ), + String.format("File %s contains invalid data", src), exc ); } From 1bce14ba96f52da0dccf666eef700f67d4eccc4e Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sun, 10 Mar 2024 04:35:24 +0000 Subject: [PATCH 77/80] chore(deps): update teatimeguest/setup-texlive-action action to v3.1.0 --- .github/workflows/codecov.yml | 2 +- .github/workflows/daily.yml | 2 +- .github/workflows/ebnf.yml | 2 +- .github/workflows/sonar.yml | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/codecov.yml b/.github/workflows/codecov.yml index 2333befe6f..1b912a2d5c 100644 --- a/.github/workflows/codecov.yml +++ b/.github/workflows/codecov.yml @@ -17,7 +17,7 @@ jobs: runs-on: ubuntu-22.04 steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 - - uses: teatimeguest/setup-texlive-action@v3.0.2 + - uses: teatimeguest/setup-texlive-action@v3.1.0 with: update-all-packages: true packages: scheme-basic geometry xcolor naive-ebnf microtype etoolbox diff --git a/.github/workflows/daily.yml b/.github/workflows/daily.yml index 6596237f91..989aafe87f 100644 --- a/.github/workflows/daily.yml +++ b/.github/workflows/daily.yml @@ -8,7 +8,7 @@ jobs: runs-on: ubuntu-22.04 steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 - - uses: teatimeguest/setup-texlive-action@v3.0.2 + - uses: teatimeguest/setup-texlive-action@v3.1.0 with: update-all-packages: true packages: scheme-basic geometry xcolor naive-ebnf microtype etoolbox diff --git a/.github/workflows/ebnf.yml b/.github/workflows/ebnf.yml index b8f48d2d71..965524dfea 100644 --- a/.github/workflows/ebnf.yml +++ b/.github/workflows/ebnf.yml @@ -17,7 +17,7 @@ jobs: - run: | sudo apt-get update sudo apt-get -y install ghostscript imagemagick texlive-extra-utils pdf2svg inkscape - - uses: teatimeguest/setup-texlive-action@v3.0.2 + - uses: teatimeguest/setup-texlive-action@v3.1.0 with: update-all-packages: true packages: scheme-basic geometry xcolor naive-ebnf microtype etoolbox diff --git a/.github/workflows/sonar.yml b/.github/workflows/sonar.yml index 5026cc4dbd..893c965b86 100644 --- a/.github/workflows/sonar.yml +++ b/.github/workflows/sonar.yml @@ -14,7 +14,7 @@ jobs: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 with: fetch-depth: 0 - - uses: teatimeguest/setup-texlive-action@v3.0.2 + - uses: teatimeguest/setup-texlive-action@v3.1.0 with: update-all-packages: true packages: scheme-basic geometry xcolor naive-ebnf microtype etoolbox From 0d5bbfba21c89c00835feda7bf6cfbfff4808553 Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Mon, 11 Mar 2024 11:52:51 +0300 Subject: [PATCH 78/80] #2863 fix documentation --- eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java b/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java index aabd1eb58a..9ce05d69a6 100644 --- a/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java +++ b/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java @@ -143,7 +143,7 @@ public void doesNotPrintTwiceOnFloatComparisonMethods(final String method) { } /** - * Handler implementation for tests. + * PrintWithCmp Phi * * @since 1.0 */ From 80f0434426f48b3c805583ce86d818407c271477 Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Mon, 11 Mar 2024 12:03:18 +0300 Subject: [PATCH 79/80] #2863 fix documentation again --- eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java b/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java index 9ce05d69a6..29068d53f6 100644 --- a/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java +++ b/eo-runtime/src/test/java/EOorg/EOeolang/EOio/EOstdoutTest.java @@ -143,7 +143,7 @@ public void doesNotPrintTwiceOnFloatComparisonMethods(final String method) { } /** - * PrintWithCmp Phi + * PrintWithCmp Phi. * * @since 1.0 */ From 6b317f816313d833a62ab1056f35fa641f9bf68c Mon Sep 17 00:00:00 2001 From: Roman Korostinskiy <70313618+c71n93@users.noreply.github.com> Date: Mon, 11 Mar 2024 16:19:02 +0300 Subject: [PATCH 80/80] #2863 slightly change the messages --- .../src/main/java/org/eolang/maven/rust/Names.java | 11 +++++++++-- eo-runtime/src/main/java/EOorg/EOeolang/EOrust.java | 11 +++++++++-- 2 files changed, 18 insertions(+), 4 deletions(-) diff --git a/eo-maven-plugin/src/main/java/org/eolang/maven/rust/Names.java b/eo-maven-plugin/src/main/java/org/eolang/maven/rust/Names.java index 2154266e86..ab362fbdd4 100644 --- a/eo-maven-plugin/src/main/java/org/eolang/maven/rust/Names.java +++ b/eo-maven-plugin/src/main/java/org/eolang/maven/rust/Names.java @@ -189,13 +189,20 @@ private static ConcurrentHashMap load(final Path src) throws IOE final Object result = map.readObject(); if (result.getClass() != ConcurrentHashMap.class) { throw new ClassCastException( - String.format("Object inside %s has wrong class %s", src, result.getClass()) + String.format( + "Object inside %s has wrong class %s", + src, + result.getClass() + ) ); } return (ConcurrentHashMap) result; } catch (final ClassNotFoundException exc) { throw new IllegalArgumentException( - String.format("File %s contains invalid data", src), + String.format( + "File %s contains invalid data", + src + ), exc ); } diff --git a/eo-runtime/src/main/java/EOorg/EOeolang/EOrust.java b/eo-runtime/src/main/java/EOorg/EOeolang/EOrust.java index ed9af8e97e..0fa4b543f4 100644 --- a/eo-runtime/src/main/java/EOorg/EOeolang/EOrust.java +++ b/eo-runtime/src/main/java/EOorg/EOeolang/EOrust.java @@ -189,13 +189,20 @@ private static ConcurrentHashMap load(final String src) throws I final Object result = map.readObject(); if (result.getClass() != ConcurrentHashMap.class) { throw new ClassCastException( - String.format("Object inside %s has wrong class %s", src, result.getClass()) + String.format( + "Object inside %s has wrong class %s, a ConcurrentHashMap was expected", + src, + result.getClass() + ) ); } return (ConcurrentHashMap) result; } catch (final ClassNotFoundException exc) { throw new IllegalArgumentException( - String.format("File %s contains invalid data", src), + String.format( + "File %s contains invalid data, a ConcurrentHashMap objects was expected", + src + ), exc ); }