From ba2cad0b5ce89fb8021113be8cd2db3900cab6f1 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 28 Dec 2023 17:52:39 +0300 Subject: [PATCH 01/10] #3: simple integration test --- .github/workflows/itest.yml | 20 +++++++++++++++++++ .gitignore | 4 ++++ pipeline.sh | 40 +++++++++++++++++++++++++++++++++++++ 3 files changed, 64 insertions(+) create mode 100644 .github/workflows/itest.yml create mode 100755 pipeline.sh diff --git a/.github/workflows/itest.yml b/.github/workflows/itest.yml new file mode 100644 index 000000000..b0512b35c --- /dev/null +++ b/.github/workflows/itest.yml @@ -0,0 +1,20 @@ +name: itest +on: + push: + branches: master + pull_request: + branches: master +jobs: + itest: + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-node@v4 + with: + node-version: 16 + - uses: actions/setup-java@v4 + with: + distribution: 'zulu' + java-version: 20 + - run: npm install -g eolang + - run: ./pipeline.sh \ No newline at end of file diff --git a/.gitignore b/.gitignore index fc587c5eb..8a188c2b8 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,7 @@ +.eoc +before.txt +after.txt +app.eo *.bak eo-phi-normalizer/src/Language/EO/Phi/Syntax/Lex.hs eo-phi-normalizer/src/Language/EO/Phi/Syntax/Par.hs diff --git a/pipeline.sh b/pipeline.sh new file mode 100755 index 000000000..0b026e6e0 --- /dev/null +++ b/pipeline.sh @@ -0,0 +1,40 @@ +#!/bin/bash +set -x +set -e + +EO=0.34.2 + +cat > app.eo < app + QQ.io.stdout > @ + "Hello, world!\n" +EOT + +eoc "--parser=${EO}" clean +eoc "--parser=${EO}" link +eoc "--parser=${EO}" --alone dataize app > before.txt + +eoc "--parser=${EO}" phi + +# Now, you modify/normalize this file: +# .eoc/phi/app.phi + +eoc "--parser=${EO}" unphi + +cp .eoc/unphi/app.xmir .eoc/2-optimize/app.xmir + +eoc "--parser=${EO}" print + +cp .eoc/print/app.eo app.eo + +eoc "--parser=${EO}" clean + +eoc "--parser=${EO}" link +eoc "--parser=${EO}" --alone dataize app > after.txt + +if [ "$(cat before.txt)" == "$(cat after.txt)" ]; then + echo 'SUCCESS' +else + echo 'FAILURE' + exit 1 +fi \ No newline at end of file From 78adce241e4a184888ab47f5af69243321fb93d1 Mon Sep 17 00:00:00 2001 From: Yegor Bugayenko Date: Thu, 28 Dec 2023 17:57:40 +0300 Subject: [PATCH 02/10] #3: typo --- pipeline.sh | 1 - 1 file changed, 1 deletion(-) diff --git a/pipeline.sh b/pipeline.sh index 0b026e6e0..39474f406 100755 --- a/pipeline.sh +++ b/pipeline.sh @@ -28,7 +28,6 @@ eoc "--parser=${EO}" print cp .eoc/print/app.eo app.eo eoc "--parser=${EO}" clean - eoc "--parser=${EO}" link eoc "--parser=${EO}" --alone dataize app > after.txt From 7206f790d041b11720dc01e159188e59f8dc01aa Mon Sep 17 00:00:00 2001 From: Danila Danko Date: Wed, 10 Jan 2024 02:49:35 +0300 Subject: [PATCH 03/10] refactor: pipeline script --- pipeline.sh | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/pipeline.sh b/pipeline.sh index 39474f406..a0697e85d 100755 --- a/pipeline.sh +++ b/pipeline.sh @@ -1,8 +1,10 @@ -#!/bin/bash -set -x -set -e +mkdir -p pipeline +cd pipeline + +shopt -s expand_aliases EO=0.34.2 +alias eo="eoc --parser=${EO}" cat > app.eo < app @@ -10,26 +12,26 @@ cat > app.eo < before.txt +eo clean +eo link +eo --alone dataize app > before.txt -eoc "--parser=${EO}" phi +eo phi # Now, you modify/normalize this file: # .eoc/phi/app.phi -eoc "--parser=${EO}" unphi +eo unphi cp .eoc/unphi/app.xmir .eoc/2-optimize/app.xmir -eoc "--parser=${EO}" print +eo print cp .eoc/print/app.eo app.eo -eoc "--parser=${EO}" clean -eoc "--parser=${EO}" link -eoc "--parser=${EO}" --alone dataize app > after.txt +eo clean +eo link +eo --alone dataize app > after.txt if [ "$(cat before.txt)" == "$(cat after.txt)" ]; then echo 'SUCCESS' From 0b68687be5f3477cbe2983e1114547e6afef728b Mon Sep 17 00:00:00 2001 From: Danila Danko Date: Wed, 10 Jan 2024 03:09:38 +0300 Subject: [PATCH 04/10] feat: run normalizer --- pipeline.sh | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/pipeline.sh b/pipeline.sh index a0697e85d..02f9c942d 100755 --- a/pipeline.sh +++ b/pipeline.sh @@ -19,7 +19,11 @@ eo --alone dataize app > before.txt eo phi # Now, you modify/normalize this file: -# .eoc/phi/app.phi +IO=".eoc/phi/app.phi" +I=".eoc/phi/app.bk.phi" +mv "$IO" "$I" +stack run normalize-phi < "$I" > "$IO" \ + || echo 'Normalizer failed' && exit 1 eo unphi From 8b4bbd4552b3957b6294bd1bf8bdc34fed64aec0 Mon Sep 17 00:00:00 2001 From: Danila Danko Date: Wed, 10 Jan 2024 03:19:45 +0300 Subject: [PATCH 05/10] rm: test action --- .github/workflows/itest.yml | 20 -------------------- 1 file changed, 20 deletions(-) delete mode 100644 .github/workflows/itest.yml diff --git a/.github/workflows/itest.yml b/.github/workflows/itest.yml deleted file mode 100644 index b0512b35c..000000000 --- a/.github/workflows/itest.yml +++ /dev/null @@ -1,20 +0,0 @@ -name: itest -on: - push: - branches: master - pull_request: - branches: master -jobs: - itest: - runs-on: ubuntu-22.04 - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-node@v4 - with: - node-version: 16 - - uses: actions/setup-java@v4 - with: - distribution: 'zulu' - java-version: 20 - - run: npm install -g eolang - - run: ./pipeline.sh \ No newline at end of file From 10bcc1ceb2abebae95e4aa0e620df10adddeaa79 Mon Sep 17 00:00:00 2001 From: Danila Danko Date: Wed, 10 Jan 2024 03:19:54 +0300 Subject: [PATCH 06/10] upd: action --- .github/workflows/ghc.yml | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/.github/workflows/ghc.yml b/.github/workflows/ghc.yml index b53026bda..28c4018b0 100644 --- a/.github/workflows/ghc.yml +++ b/.github/workflows/ghc.yml @@ -27,10 +27,24 @@ jobs: uses: actions/checkout@v4 - name: 🧰 Setup Stack - uses: freckle/stack-action@v4 + # FIXME use freckle/stack-action@v4 when https://github.com/freckle/stack-action/pull/31 is merged + uses: deemp/stack-action with: fast: ${{ github.ref_name != 'master' }} + - uses: actions/setup-node@v4 + with: + node-version: 20 + + - uses: actions/setup-java@v4 + with: + distribution: "zulu" + java-version: 21 + + - run: npm install -g eolang@0.15.1 + + - run: ./pipeline.sh + haddock: needs: [build] if: ${{ github.ref_name == 'master' }} From 8747b44c5cdf949e9c5f10b4e13b9c49c068652b Mon Sep 17 00:00:00 2001 From: Danila Danko Date: Wed, 10 Jan 2024 03:26:10 +0300 Subject: [PATCH 07/10] fix: ref --- .github/workflows/ghc.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ghc.yml b/.github/workflows/ghc.yml index 28c4018b0..2fa57511a 100644 --- a/.github/workflows/ghc.yml +++ b/.github/workflows/ghc.yml @@ -28,7 +28,7 @@ jobs: - name: 🧰 Setup Stack # FIXME use freckle/stack-action@v4 when https://github.com/freckle/stack-action/pull/31 is merged - uses: deemp/stack-action + uses: deemp/stack-action@main with: fast: ${{ github.ref_name != 'master' }} From c5659367d9cbf9e7f78060cd3f8899fd90be5c92 Mon Sep 17 00:00:00 2001 From: Danila Danko Date: Wed, 10 Jan 2024 03:35:07 +0300 Subject: [PATCH 08/10] add: script that runs pipeline --- flake.lock | 38 ++++++++++++++++++++++++++++---- flake.nix | 64 ++++++++++++++++++++++++++++++++++++++++++++++++------ 2 files changed, 91 insertions(+), 11 deletions(-) diff --git a/flake.lock b/flake.lock index 9669d63dd..bb01383d7 100644 --- a/flake.lock +++ b/flake.lock @@ -1,12 +1,28 @@ { "nodes": { + "eoc": { + "flake": false, + "locked": { + "lastModified": 1704732261, + "narHash": "sha256-UOwwOpbVQjVraZebqQbq4BPitCKpwcL6s3ywjAfGCaw=", + "owner": "deemp", + "repo": "eoc", + "rev": "c338c36db124212efbb85f31d12e04e04bcde450", + "type": "github" + }, + "original": { + "owner": "deemp", + "repo": "eoc", + "type": "github" + } + }, "flakes": { "locked": { - "lastModified": 1703248027, - "narHash": "sha256-kq2J/wLaUL3KY/OwgZEAZ7/QZ5alrol9ERBWqxJshiA=", + "lastModified": 1704589266, + "narHash": "sha256-iuqS9ieLQYcTIKT7GHrqBf89yNU6rdYp+ge08ww5zC0=", "owner": "deemp", "repo": "flakes", - "rev": "8b4c8ae507d591ad41e239e70a9c2d226b7eaa45", + "rev": "dcb6e49b7c7df2dd381d204a9316572d7087c373", "type": "github" }, "original": { @@ -15,9 +31,23 @@ "type": "github" } }, + "maven-wrapper-jar": { + "flake": false, + "locked": { + "narHash": "sha256-O6tlCRB5YmX0T0F240jGhiln1jwkKO8XgyCvtHSq40A=", + "type": "file", + "url": "https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar" + }, + "original": { + "type": "file", + "url": "https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar" + } + }, "root": { "inputs": { - "flakes": "flakes" + "eoc": "eoc", + "flakes": "flakes", + "maven-wrapper-jar": "maven-wrapper-jar" } } }, diff --git a/flake.nix b/flake.nix index c4b3fa919..c63ea5751 100644 --- a/flake.nix +++ b/flake.nix @@ -1,10 +1,24 @@ { - inputs.flakes.url = "github:deemp/flakes"; + inputs = { + flakes.url = "github:deemp/flakes"; + eoc = { + url = "github:deemp/eoc"; + flake = false; + }; + # should be synchronized with + # https://github.com/objectionary/eoc/blob/116286a11aa538705c0f2b794abbdbcc6dec33ef/mvnw/.mvn/wrapper/maven-wrapper.properties#L18 + maven-wrapper-jar = { + flake = false; + url = "https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar"; + }; + }; outputs = inputs: inputs.flakes.makeFlake { inputs = { inherit (inputs.flakes.all) - haskell-tools codium drv-tools devshell - flakes-tools nixpkgs formatter workflows lima; + haskell-tools drv-tools devshell + flakes-tools nixpkgs formatter + slimlock; + inherit (inputs) eoc maven-wrapper-jar; }; perSystem = { inputs, system }: let @@ -14,8 +28,9 @@ # --- Imports --- pkgs = inputs.nixpkgs.legacyPackages.${system}; + inherit (pkgs) lib; inherit (inputs.devshell.lib.${system}) mkCommands mkRunCommands mkShell; - inherit (inputs.drv-tools.lib.${system}) withAttrs withMan withDescription mkShellApp man; + inherit (inputs.drv-tools.lib.${system}) mkShellApps; inherit (inputs.flakes-tools.lib.${system}) mkFlakesTools; inherit (inputs.haskell-tools.lib.${system}) toolsGHC; @@ -69,7 +84,7 @@ packages = ps: [ ps.${packageName} ]; }) hls cabal fourmolu justStaticExecutable - ghcid haskellPackages hpack stack; + ghcid ghc haskellPackages hpack stack; # --- Tools --- @@ -80,6 +95,7 @@ fourmolu cabal stack + pkgs.gh # `cabal` already has a `ghc` on its `PATH`, # so you may remove `ghc` from this list. # Then, you can access `ghc` like `cabal exec -- ghc --version`. @@ -93,7 +109,30 @@ # --- Packages --- - packages = { + packages = mkShellApps { + eoc = pkgs.buildNpmPackage rec { + name = ""; + version = "0.15.1"; + src = inputs.eoc; + npmDepsHash = "sha256-j6lfte6RhxRY5cRHcrtIHfZDe0lP1ovEukgHbHsGPb0="; + npmInstallFlags = [ "--omit=dev" ]; + dontNpmBuild = true; + + postPatch = + let path = "mvnw/.mvn/wrapper/maven-wrapper.jar"; in + '' + cp ${inputs.maven-wrapper-jar} ${path} + chmod +x ${path} + ''; + meta = with pkgs.lib; { + description = "EO compiler"; + homepage = "https://github.com/objectionary/eoc"; + license = licenses.mit; + }; + }; + + # + # --- Haskell package --- # This is a static executable with given runtime dependencies. @@ -104,6 +143,17 @@ }; "${packageName}" = haskellPackages."${packageName}"; + + pipeline = { + runtimeInputs = [ stack pkgs.jdk21 packages.eoc pkgs.maven ]; + text = '' + JAVA_HOME="${pkgs.jdk21.home}" + export JAVA_HOME + ${builtins.readFile ./pipeline.sh} + ''; + description = "Run pipeline"; + excludeShellChecks = [ "SC2139" ]; + }; }; # --- Devshells --- @@ -115,7 +165,7 @@ bash.extra = "export LANG=C.utf8"; commands = mkCommands "tools" tools - ++ mkRunCommands "packages" { inherit (packages) default; } + ++ mkRunCommands "packages" { inherit (packages) default pipeline; } ; }; }; From f1325b0520775e5bafece4fa31393dc0ae0a88e6 Mon Sep 17 00:00:00 2001 From: Danila Danko Date: Wed, 10 Jan 2024 04:05:57 +0300 Subject: [PATCH 09/10] fix: error message --- pipeline.sh | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/pipeline.sh b/pipeline.sh index 02f9c942d..ba25d7be7 100755 --- a/pipeline.sh +++ b/pipeline.sh @@ -23,7 +23,16 @@ IO=".eoc/phi/app.phi" I=".eoc/phi/app.bk.phi" mv "$IO" "$I" stack run normalize-phi < "$I" > "$IO" \ - || echo 'Normalizer failed' && exit 1 + || printf "\n\nNormalizer failed" \ + && printf "\n\n* EO Expression\n\n" \ + && cat app.eo \ + && printf "\n\n* Phi Expression\n\n" \ + && cat "$I" \ + && printf "\n\n* Error\n\n" \ + && cat "$IO" \ + && exit 1 + +printf "Normalizer succeeded" eo unphi From a187a84020f8763fa2e5e57e1a98b3ce3f488398 Mon Sep 17 00:00:00 2001 From: Danila Danko Date: Wed, 10 Jan 2024 04:21:59 +0300 Subject: [PATCH 10/10] fix: normalizer logs --- pipeline.sh | 28 ++++++++++++++++++---------- 1 file changed, 18 insertions(+), 10 deletions(-) diff --git a/pipeline.sh b/pipeline.sh index ba25d7be7..04ba4239d 100755 --- a/pipeline.sh +++ b/pipeline.sh @@ -23,16 +23,24 @@ IO=".eoc/phi/app.phi" I=".eoc/phi/app.bk.phi" mv "$IO" "$I" stack run normalize-phi < "$I" > "$IO" \ - || printf "\n\nNormalizer failed" \ - && printf "\n\n* EO Expression\n\n" \ - && cat app.eo \ - && printf "\n\n* Phi Expression\n\n" \ - && cat "$I" \ - && printf "\n\n* Error\n\n" \ - && cat "$IO" \ - && exit 1 - -printf "Normalizer succeeded" + || { + printf "\n\nNormalizer failed" + printf "\n\n* EO expression:\n\n" + cat app.eo + printf "\n\n* Phi expression:\n\n" + cat "$I" + printf "\n\n* Error:\n\n" + cat "$IO" + exit 1 + } + +printf "\n\nNormalizer succeeded!\n\n" +printf "\n\n* Phi expression:\n\n" +cat "$I" +printf "\n\n* Normalized Phi expression:\n\n" +cat "$IO" +printf "\n\n* Diff:\n\n" +diff "$I" "$IO" eo unphi