diff --git a/.github/workflows/coq-alpine.yml b/.github/workflows/coq-alpine.yml index 55f2341be2..928247d764 100644 --- a/.github/workflows/coq-alpine.yml +++ b/.github/workflows/coq-alpine.yml @@ -51,34 +51,48 @@ jobs: - name: make deps shell: alpine.sh {0} run: make TIMED=1 TIMING=1 -j2 deps - - name: all-except-generated + - name: all-except-generated-and-js-of-ocaml shell: alpine.sh {0} - run: make TIMED=1 TIMING=1 -j2 CAMLEXTRAFLAGS="-ccopt -static" all-except-generated - - name: generated-files - shell: alpine.sh {0} - run: make TIMED=1 TIMING=1 -j2 generated-files - - run: tar -czvf generated-files.tgz fiat-*/ - if: ${{ failure() }} - - name: upload generated files - uses: actions/upload-artifact@v3 - with: - name: generated-files-${{ matrix.alpine }} - path: generated-files.tgz - if: ${{ failure() }} + run: make TIMED=1 TIMING=1 -j2 CAMLEXTRAFLAGS="-ccopt -static" all-except-generated-and-js-of-ocaml - name: install-standalone-unified-ocaml shell: alpine.sh {0} run: make install-standalone-unified-ocaml BINDIR=dist +# - name: install-standalone-js-of-ocaml +# shell: alpine.sh {0} +# run: make install-standalone-js-of-ocaml - name: upload standalone files uses: actions/upload-artifact@v3 with: name: standalone-${{ matrix.alpine }} path: dist/fiat_crypto +# - name: upload standalone js files +# uses: actions/upload-artifact@v3 +# with: +# name: standalone-html-${{ matrix.alpine }} +# path: fiat-html - name: upload OCaml files uses: actions/upload-artifact@v3 with: name: ExtractionOCaml-${{ matrix.alpine }} path: src/ExtractionOCaml if: always () +# - name: upload js_of_ocaml files +# uses: actions/upload-artifact@v3 +# with: +# name: ExtractionJsOfOCaml-${{ matrix.alpine }} +# path: src/ExtractionJsOfOCaml +# if: always () + - name: generated-files + shell: alpine.sh {0} + run: make TIMED=1 TIMING=1 -j2 generated-files + - run: tar -czvf generated-files.tgz fiat-*/ + if: ${{ failure() }} + - name: upload generated files + uses: actions/upload-artifact@v3 + with: + name: generated-files-${{ matrix.alpine }} + path: generated-files.tgz + if: ${{ failure() }} - name: standalone-haskell shell: alpine.sh {0} run: make TIMED=1 TIMING=1 -j1 standalone-haskell GHCFLAGS='+RTS -M7G -RTS' diff --git a/.github/workflows/coq-debian.yml b/.github/workflows/coq-debian.yml index f2cb4315cf..cd6199912b 100644 --- a/.github/workflows/coq-debian.yml +++ b/.github/workflows/coq-debian.yml @@ -43,9 +43,9 @@ jobs: - name: make deps shell: in-debian-chroot.sh {0} run: etc/ci/github-actions-make.sh -j2 deps - - name: all-except-generated + - name: all-except-generated-and-js-of-ocaml shell: in-debian-chroot.sh {0} - run: etc/ci/github-actions-make.sh -j2 all-except-generated + run: etc/ci/github-actions-make.sh -j2 all-except-generated-and-js-of-ocaml - name: generated-files shell: in-debian-chroot.sh {0} run: etc/ci/github-actions-make.sh -j2 generated-files @@ -60,17 +60,34 @@ jobs: - name: install-standalone-unified-ocaml shell: in-debian-chroot.sh {0} run: etc/ci/github-actions-make.sh install-standalone-unified-ocaml BINDIR=dist + - name: standalone-js-of-ocaml + shell: in-debian-chroot.sh {0} + run: etc/ci/github-actions-make.sh -j2 standalone-js-of-ocaml + - name: install-standalone-js-of-ocaml + shell: in-debian-chroot.sh {0} + run: etc/ci/github-actions-make.sh install-standalone-js-of-ocaml - name: upload standalone files uses: actions/upload-artifact@v3 with: name: standalone-${{ matrix.env.DEBIAN }} path: dist/fiat_crypto + - name: upload standalone js files + uses: actions/upload-artifact@v3 + with: + name: standalone-html-${{ matrix.env.DEBIAN }} + path: fiat-html - name: upload OCaml files uses: actions/upload-artifact@v3 with: name: ExtractionOCaml-${{ matrix.env.DEBIAN }} path: src/ExtractionOCaml if: always () + - name: upload js_of_ocaml files + uses: actions/upload-artifact@v3 + with: + name: ExtractionJsOfOCaml-${{ matrix.env.DEBIAN }} + path: src/ExtractionJsOfOCaml + if: always () - name: standalone-haskell shell: in-debian-chroot.sh {0} run: etc/ci/github-actions-make.sh -j1 standalone-haskell GHCFLAGS='+RTS -M7G -RTS' diff --git a/.github/workflows/coq-docker.yml b/.github/workflows/coq-docker.yml index 21427763eb..bcce643140 100644 --- a/.github/workflows/coq-docker.yml +++ b/.github/workflows/coq-docker.yml @@ -56,7 +56,43 @@ jobs: coq_version: ${{ matrix.env.DOCKER_COQ_VERSION }} ocaml_version: ${{ matrix.env.DOCKER_OCAML_VERSION }} export: CI ALLOW_DIFF COQCHKEXTRAFLAGS - custom_script: etc/ci/github-actions-docker-make.sh ${EXTRA_GH_REPORTIFY} -j2 all-except-generated + custom_script: etc/ci/github-actions-docker-make.sh ${EXTRA_GH_REPORTIFY} -j2 all-except-generated-and-js-of-ocaml + - name: standalone-js-of-ocaml + uses: coq-community/docker-coq-action@v1 + with: + coq_version: ${{ matrix.env.DOCKER_COQ_VERSION }} + ocaml_version: ${{ matrix.env.DOCKER_OCAML_VERSION }} + export: CI ALLOW_DIFF COQCHKEXTRAFLAGS + custom_script: | + eval $(opam env) + opam install -y js_of_ocaml + etc/ci/github-actions-docker-make.sh ${EXTRA_GH_REPORTIFY} -j2 standalone-js-of-ocaml + - name: install-standalone-js-of-ocaml + run: make -f Makefile.standalone install-standalone-js-of-ocaml + - name: backup .gitignore + run: mv .gitignore{,.bak} + - name: Deploy js_of_ocaml 🚀 ${{ ( github.ref != 'refs/heads/master' && '(dry run)' ) || '' }} + uses: JamesIves/github-pages-deploy-action@v4.4.3 + with: + branch: gh-pages # The branch the action should deploy to. + folder: fiat-html # The folder the action should deploy. + git-config-email: JasonGross@users.noreply.github.com + target-folder: . + single-commit: true # otherwise the repo will get too big + dry-run: ${{ github.ref != 'refs/heads/master' }} + - name: restore .gitignore + run: mv .gitignore{.bak,} + - name: upload standalone js files + uses: actions/upload-artifact@v3 + with: + name: standalone-html-docker-coq-${{ matrix.env.DOCKER_COQ_VERSION }} + path: fiat-html + - name: upload js_of_ocaml files + uses: actions/upload-artifact@v3 + with: + name: ExtractionJsOfOCaml-${{ matrix.env.COQ_VERSION }} + path: src/ExtractionJsOfOCaml + if: always () - name: generated-files run: etc/ci/github-actions-make.sh ${EXTRA_GH_REPORTIFY} -f Makefile.examples -j2 generated-files if: github.event_name == 'pull_request' || ${{ matrix.env.COQ_VERSION }} != 'master' diff --git a/.github/workflows/coq-macos.yml b/.github/workflows/coq-macos.yml index cef2ba7b9f..0d100a1aa5 100644 --- a/.github/workflows/coq-macos.yml +++ b/.github/workflows/coq-macos.yml @@ -52,6 +52,15 @@ jobs: OPAMYES: "true" OPAMCONFIRMLEVEL: "unsafe-yes" + - name: Install js_of_ocaml + run: | + set -e + eval $(opam env) + opam install js_of_ocaml + env: + OPAMYES: "true" + OPAMCONFIRMLEVEL: "unsafe-yes" + - name: echo build params run: | eval $(opam env) @@ -70,6 +79,11 @@ jobs: eval $(opam env) etc/ci/github-actions-make.sh install-standalone-unified-ocaml BINDIR=dist + - name: install-standalone-js-of-ocaml + run: | + eval $(opam env) + etc/ci/github-actions-make.sh install-standalone-js-of-ocaml + - name: only-test-amd64-files-lite run: | eval $(opam env) @@ -80,11 +94,21 @@ jobs: with: name: ExtractionOCaml path: src/ExtractionOCaml + - name: upload js_of_ocaml files + uses: actions/upload-artifact@v3 + with: + name: ExtractionJsOfOCaml + path: src/ExtractionJsOfOCaml - name: upload standalone files uses: actions/upload-artifact@v3 with: name: standalone-macos path: dist/fiat_crypto + - name: upload standalone js files + uses: actions/upload-artifact@v3 + with: + name: standalone-html-macos + path: fiat-html - name: install run: | eval $(opam env) diff --git a/.github/workflows/coq-windows.yml b/.github/workflows/coq-windows.yml index cc96accd6c..602e681337 100644 --- a/.github/workflows/coq-windows.yml +++ b/.github/workflows/coq-windows.yml @@ -49,6 +49,7 @@ jobs: default: https://github.com/ocaml/opam-repository.git - run: opam depext coq.${{ env.COQ_VERSION }} - run: opam pin add --kind=version coq ${{ env.COQ_VERSION }} + - run: opam install js_of_ocaml - name: Install System Dependencies run: | @@ -76,13 +77,22 @@ jobs: run: | %CYGWIN_ROOT%\bin\bash.exe -l -c 'cd "%cd%"; opam exec -- etc/ci/github-actions-make.sh install-standalone-unified-ocaml BINDIR=dist' shell: cmd + - name: coq run: | %CYGWIN_ROOT%\bin\bash.exe -l -c 'cd "%cd%"; opam exec -- etc/ci/github-actions-make.sh -j1 coq' shell: cmd - - name: all-except-generated + - name: all-except-generated-and-js-of-ocaml + run: | + %CYGWIN_ROOT%\bin\bash.exe -l -c 'cd "%cd%"; opam exec -- etc/ci/github-actions-make.sh -j1 all-except-generated-and-js-of-ocaml' + shell: cmd + - name: standalone-js-of-ocaml + run: | + %CYGWIN_ROOT%\bin\bash.exe -l -c 'cd "%cd%"; opam exec -- etc/ci/github-actions-make.sh -j1 standalone-js-of-ocaml' + shell: cmd + - name: install-standalone-js-of-ocaml run: | - %CYGWIN_ROOT%\bin\bash.exe -l -c 'cd "%cd%"; opam exec -- etc/ci/github-actions-make.sh -j1 all-except-generated' + %CYGWIN_ROOT%\bin\bash.exe -l -c 'cd "%cd%"; opam exec -- etc/ci/github-actions-make.sh install-standalone-js-of-ocaml' shell: cmd - name: c-files lite-generated-files run: | @@ -97,11 +107,21 @@ jobs: with: name: ExtractionOCaml path: src/ExtractionOCaml + - name: upload js_of_ocaml files + uses: actions/upload-artifact@v3 + with: + name: ExtractionJsOfOCaml + path: src/ExtractionJsOfOCaml - name: upload standalone files uses: actions/upload-artifact@v3 with: name: standalone-windows path: dist/fiat_crypto.exe + - name: upload standalone js files + uses: actions/upload-artifact@v3 + with: + name: standalone-html-windows + path: fiat-html - name: install run: | %CYGWIN_ROOT%\bin\bash.exe -l -c 'cd "%cd%"; opam exec -- etc/ci/github-actions-make.sh EXTERNAL_DEPENDENCIES=1 SKIP_COQSCRIPTS_INCLUDE=1 install install-standalone-ocaml' diff --git a/.gitignore b/.gitignore index a571427f68..45de5854d0 100644 --- a/.gitignore +++ b/.gitignore @@ -204,6 +204,10 @@ src/ExtractionOCaml/perf_unsaturated_solinas src/ExtractionOCaml/perf_word_by_word_montgomery src/ExtractionOCaml/*.ml src/ExtractionOCaml/*.mli +src/ExtractionJsOfOCaml/*.ml +src/ExtractionJsOfOCaml/*.mli +src/ExtractionJsOfOCaml/*.js +src/ExtractionJsOfOCaml/*.map src/Rewriter/PerfTesting/Specific/generated/*.v src/Rewriter/PerfTesting/Specific/generated/*.log src/Rewriter/PerfTesting/Specific/generated/*.sh @@ -216,6 +220,8 @@ fiat-amd64/*.status fiat-amd64/*.only-status fiat-amd64/*.description fiat-amd64/*.invocation +fiat-html/fiat_crypto.js +fiat-html/fiat_crypto.map /Makefile.test-amd64-files.mk # Rust diff --git a/Makefile b/Makefile index 8f456d8c3d..59788db508 100644 --- a/Makefile +++ b/Makefile @@ -7,7 +7,7 @@ bedrock2 clean-bedrock2 install-bedrock2 coqutil clean-coqutil install-coqutil \ bedrock2-compiler clean-bedrock2-compiler install-bedrock2-compiler \ rupicola clean-rupicola install-rupicola \ - util all-except-generated all \ + util all-except-generated all all-except-generated-and-js-of-ocaml all-except-js-of-ocaml \ bedrock2-backend \ deps \ nobigmem print-nobigmem \ @@ -53,6 +53,7 @@ endif # coq .vo files that are not compiled using coq_makefile SPECIAL_VOFILES := \ src/ExtractionOCaml/%.vo \ + src/ExtractionJsOfOCaml/%.vo \ src/ExtractionHaskell/%.vo \ src/Rewriter/PerfTesting/Specific/generated/%.vo GREP_EXCLUDE_SPECIAL := grep -v '^\(src/Extraction\(OCaml\|Haskell\)/\|src/Rewriter/PerfTesting/Specific/generated/\)' @@ -69,8 +70,10 @@ PERFTESTING_VO := \ src/Rewriter/PerfTesting/Core.vo \ src/Rewriter/PerfTesting/StandaloneOCamlMain.vo BEDROCK2_FILES_PATTERN := \ + src/ExtractionJsOfOCaml/bedrock2_% \ src/ExtractionOCaml/bedrock2_% \ src/ExtractionHaskell/bedrock2_% \ + src/ExtractionJsOfOCaml/with_bedrock2_% \ src/ExtractionOCaml/with_bedrock2_% \ src/ExtractionHaskell/with_bedrock2_% \ src/Assembly/WithBedrock/% \ @@ -148,8 +151,10 @@ CHECK_OUTPUTS := $(addprefix check-,$(OUTPUT_PREOUTS)) ACCEPT_OUTPUTS := $(addprefix accept-,$(OUTPUT_PREOUTS) fiat-amd64.test) all-except-compiled: coq pre-standalone-extracted check-output -all-except-generated: standalone-ocaml perf-standalone all-except-compiled -all: all-except-generated generated-files copy-to-fiat-rust copy-to-fiat-go +all-except-generated-and-js-of-ocaml: standalone-ocaml perf-standalone all-except-compiled +all-except-generated: all-except-generated-and-js-of-ocaml standalone-js-of-ocaml +all-except-js-of-ocaml: all-except-generated-and-js-of-ocaml generated-files +all: all-except-generated-and-js-of-ocaml standalone-js-of-ocaml generated-files copy-to-fiat-rust copy-to-fiat-go @true coq: $(REGULAR_VOFILES) coq-without-bedrock2: $(REGULAR_EXCEPT_BEDROCK2_VOFILES) @@ -336,9 +341,11 @@ $(BEDROCK2_STANDALONE:%=src/ExtractionOCaml/%.ml): src/Bedrock/Standalone/Standa $(PERF_STANDALONE:%=src/ExtractionOCaml/%.ml): src/Rewriter/PerfTesting/StandaloneOCamlMain.vo $(STANDALONE:%=src/ExtractionHaskell/%.hs): src/StandaloneHaskellMain.vo $(BEDROCK2_STANDALONE:%=src/ExtractionHaskell/%.hs): src/Bedrock/Standalone/StandaloneHaskellMain.vo +$(STANDALONE_JS_OF_OCAML:%=src/ExtractionJsOfOCaml/%.ml): src/StandaloneJsOfOCamlMain.vo +$(BEDROCK2_STANDALONE_JS_OF_OCAML:%=src/ExtractionJsOfOCaml/%.ml): src/Bedrock/Standalone/StandaloneJsOfOCamlMain.vo # $(PERF_STANDALONE:%=src/ExtractionHaskell/%.hs): src/Rewriter/PerfTesting/StandaloneHaskellMain.vo -pre-standalone-extracted: $(STANDALONE_OCAML:%=src/ExtractionOCaml/%.ml) $(STANDALONE_HASKELL:%=src/ExtractionHaskell/%.hs) +pre-standalone-extracted: $(STANDALONE_OCAML:%=src/ExtractionOCaml/%.ml) $(STANDALONE_JS_OF_OCAML:%=src/ExtractionJsOfOCaml/%.ml) $(STANDALONE_HASKELL:%=src/ExtractionHaskell/%.hs) $(STANDALONE_OCAML:%=src/ExtractionOCaml/%.ml) : %.ml : %.v $(SHOW)'COQC $<' @@ -346,7 +353,13 @@ $(STANDALONE_OCAML:%=src/ExtractionOCaml/%.ml) : %.ml : %.v $(HIDE)cat $*.tmp.ml | tr -d '\r' > $@ && rm $*.tmp.ml $(HIDE)cat $*.tmp.mli | tr -d '\r' > $*.mli && rm $*.tmp.mli -$(STANDALONE_HASKELL:%=src/ExtractionHaskell/%.hs) : %.hs : %.v src/haskell.sed +$(STANDALONE_JS_OF_OCAML:%=src/ExtractionJsOfOCaml/%.ml) : %.ml : %.v + $(SHOW)'COQC $<' + $(HIDE)$(TIMER) $(COQC) $(COQDEBUG) $(COQFLAGS) $(COQLIBS) $< + $(HIDE)cat $*.tmp.ml | tr -d '\r' > $@ && rm $*.tmp.ml + $(HIDE)cat $*.tmp.mli | tr -d '\r' > $*.mli && rm $*.tmp.mli + +$(STANDALONE_HASKELL:%=src/ExtractionHaskell/%.hs) : %.hs : %.v src/haskell.sed src/StandaloneHaskellMain.vo $(SHOW)'COQC $< > $@' $(HIDE)$(TIMER) $(COQC) $(COQDEBUG) $(COQFLAGS) $(COQLIBS) $< > $@.tmp $(HIDE)cat $@.tmp | tr -d '\r' | sed -f src/haskell.sed > $@ && rm $@.tmp diff --git a/Makefile.config b/Makefile.config index afed0c3954..825b3b0ffb 100644 --- a/Makefile.config +++ b/Makefile.config @@ -5,6 +5,7 @@ SHOW := $(if $(VERBOSE),@true "",@echo "") HIDE := $(if $(VERBOSE),,@) BINDIR?=/usr/local/bin +JSDIR?=fiat-html # or $(shell opam config var bin) ? MOD_NAME := Crypto @@ -56,8 +57,8 @@ BASE_STANDALONE := $(SEPARATE_BASE_STANDALONE) $(UNIFIED_STANDALONE) BEDROCK2_UNIFIED_STANDALONE := $(addprefix bedrock2_,$(UNIFIED_BASE_STANDALONE)) $(addprefix with_bedrock2_,$(UNIFIED_BASE_STANDALONE)) BEDROCK2_SEPARATE_STANDALONE := $(addprefix bedrock2_,$(SEPARATE_BASE_STANDALONE)) $(addprefix with_bedrock2_,$(SEPARATE_BASE_STANDALONE)) BEDROCK2_STANDALONE := $(BEDROCK2_UNIFIED_STANDALONE) $(BEDROCK2_SEPARATE_STANDALONE) -UNIFIED_STANDALONE := $(UNIFIED_BASE_STANDALONE) $(call if_SKIP_BEDROCK2,,$(BEDROCK2_UNIFIED_STANDALONE) $(WITH_BEDROCK2_UNIFIED_STANDALONE)) -SEPARATE_STANDALONE := $(SEPARATE_BASE_STANDALONE) $(call if_SKIP_BEDROCK2,,$(BEDROCK2_SEPARATE_STANDALONE) $(WITH_BEDROCK2_SEPARATE_STANDALONE)) +UNIFIED_STANDALONE := $(UNIFIED_BASE_STANDALONE) $(call if_SKIP_BEDROCK2,,$(BEDROCK2_UNIFIED_STANDALONE)) +SEPARATE_STANDALONE := $(SEPARATE_BASE_STANDALONE) $(call if_SKIP_BEDROCK2,,$(BEDROCK2_SEPARATE_STANDALONE)) STANDALONE := $(UNIFIED_STANDALONE) $(SEPARATE_STANDALONE) PERF_STANDALONE := perf_unsaturated_solinas perf_word_by_word_montgomery @@ -68,12 +69,16 @@ UNIFIED_STANDALONE_HASKELL := $(UNIFIED_STANDALONE) SEPARATE_STANDALONE_HASKELL := $(SEPARATE_STANDALONE) STANDALONE_HASKELL := $(UNIFIED_STANDALONE_HASKELL) $(SEPARATE_STANDALONE_HASKELL) +STANDALONE_JS_OF_OCAML := $(UNIFIED_STANDALONE) +BEDROCK2_STANDALONE_JS_OF_OCAML := $(BEDROCK2_UNIFIED_STANDALONE) + UNIFIED_OCAML_BINARIES := $(UNIFIED_BASE_STANDALONE:%=src/ExtractionOCaml/%) SEPARATE_OCAML_BINARIES := $(SEPARATE_BASE_STANDALONE:%=src/ExtractionOCaml/%) OCAML_BINARIES := $(UNIFIED_OCAML_BINARIES) $(SEPARATE_OCAML_BINARIES) UNIFIED_HASKELL_BINARIES := $(UNIFIED_BASE_STANDALONE:%=src/ExtractionHaskell/%) SEPARATE_HASKELL_BINARIES := $(SEPARATE_BASE_STANDALONE:%=src/ExtractionHaskell/%) HASKELL_BINARIES := $(UNIFIED_HASKELL_BINARIES) $(SEPARATE_HASKELL_BINARIES) +JS_OF_OCAML_FILES := $(UNIFIED_BASE_STANDALONE:%=src/ExtractionJsOfOCaml/%.js) $(UNIFIED_BASE_STANDALONE:%=src/ExtractionJsOfOCaml/%.map) WITH_BEDROCK2_UNIFIED_OCAML_BINARIES := $(UNIFIED_BASE_STANDALONE:%=src/ExtractionOCaml/with_bedrock2_%) WITH_BEDROCK2_SEPARATE_OCAML_BINARIES := $(SEPARATE_BASE_STANDALONE:%=src/ExtractionOCaml/with_bedrock2_%) @@ -81,3 +86,4 @@ WITH_BEDROCK2_OCAML_BINARIES := $(WITH_BEDROCK2_UNIFIED_OCAML_BINARIES) $(WITH_B WITH_BEDROCK2_UNIFIED_HASKELL_BINARIES := $(UNIFIED_BASE_STANDALONE:%=src/ExtractionHaskell/with_bedrock2_%) WITH_BEDROCK2_SEPARATE_HASKELL_BINARIES := $(SEPARATE_BASE_STANDALONE:%=src/ExtractionHaskell/with_bedrock2_%) WITH_BEDROCK2_HASKELL_BINARIES := $(WITH_BEDROCK2_UNIFIED_HASKELL_BINARIES) $(WITH_BEDROCK2_SEPARATE_HASKELL_BINARIES) +WITH_BEDROCK2_JS_OF_OCAML_FILES := $(UNIFIED_BASE_STANDALONE:%=src/ExtractionJsOfOCaml/with_bedrock2_%.js) $(UNIFIED_BASE_STANDALONE:%=src/ExtractionJsOfOCaml/with_bedrock2_%.map) diff --git a/Makefile.standalone b/Makefile.standalone index 38722b5626..760e470fc1 100644 --- a/Makefile.standalone +++ b/Makefile.standalone @@ -12,6 +12,7 @@ GHCFLAGS?= # -XStrict # in case we didn't include Makefile.coq OCAMLFIND?=ocamlfind OCAMLOPT?="$(OCAMLFIND)" ocamlopt +OCAMLC?="$(OCAMLFIND)" ocamlc OCAMLOPTP?="$(OCAMLFIND)" ocamloptp ifneq ($(WITH_PERF),1) CAMLOPT_PERF ?= $(OCAMLOPT) @@ -21,7 +22,11 @@ CAMLOPT_PERF ?= $(OCAMLOPTP) CAMLOPT_PERF_SHOW:=OCAMLOPTP endif CAMLEXTRAFLAGS ?= +JS_OF_OCAML ?= js_of_ocaml STANDALONE_CAMLFLAGS ?= -package unix -w -20 -g $(CAMLEXTRAFLAGS) +STANDALONE_JS_CAMLFLAGS ?= -package js_of_ocaml $(STANDALONE_CAMLFLAGS) +JS_OF_OCAML_EXTRAFLAGS ?= +JS_OF_OCAML_FLAGS ?= --source-map --no-inline --enable=effects $(JS_OF_OCAML_EXTRAFLAGS) PACKAGE ?= standalone.tar.gz PACKAGE_CMD ?= tar -czvf @@ -41,6 +46,7 @@ ENSURE_STACK_LIMIT := . etc/ensure_stack_limit.sh || true standalone-unified-haskell install-standalone-unified-haskell uninstall-standalone-unified-haskell \ standalone-separate-haskell install-standalone-separate-haskell uninstall-standalone-separate-haskell \ standalone-haskell install-standalone-haskell uninstall-standalone-haskell \ + standalone-js-of-ocaml install-standalone-js-of-ocaml uninstall-standalone-js-of-ocaml \ package-standalone package-standalone-ocaml package-standalone-haskell \ package-standalone-unified package-standalone-unified-ocaml package-standalone-unified-haskell \ package-standalone-separate package-standalone-separate-ocaml package-standalone-separate-haskell \ @@ -58,12 +64,27 @@ $(STANDALONE_OCAML:%=src/ExtractionOCaml/%) : % : %.ml %.cmi $(HIDE)$(ENSURE_STACK_LIMIT); \ $(TIMER) $(CAMLOPT_PERF) $(STANDALONE_CAMLFLAGS) -linkpkg -I src/ExtractionOCaml/ -o $@ $< +$(STANDALONE_JS_OF_OCAML:%=src/ExtractionJsOfOCaml/%.cmi) : %.cmi : %.ml + $(SHOW)'OCAMLC $*.mli' + $(HIDE)$(ENSURE_STACK_LIMIT); \ + $(TIMER) $(OCAMLC) $(STANDALONE_JS_CAMLFLAGS) $*.mli + +$(STANDALONE_JS_OF_OCAML:%=src/ExtractionJsOfOCaml/%.byte) : %.byte : %.ml %.cmi + $(SHOW)'OCAMLC $< -o $@' + $(HIDE)$(ENSURE_STACK_LIMIT); \ + $(TIMER) $(OCAMLC) $(STANDALONE_JS_CAMLFLAGS) -linkpkg -I src/ExtractionJsOfOCaml/ -o $@ $< + +$(STANDALONE_JS_OF_OCAML:%=src/ExtractionJsOfOCaml/%.js) : %.js : %.byte + $(SHOW)'JS_OF_OCAML $<' + $(HIDE)$(ENSURE_STACK_LIMIT); \ + $(TIMER) $(JS_OF_OCAML) $(JS_OF_OCAML_FLAGS) $< + $(STANDALONE_HASKELL:%=src/ExtractionHaskell/%) : % : %.hs $(SHOW)'GHC $< -o $@' $(HIDE)$(TIMER) $(GHC) $(GHCFLAGS) -o $@ $< -standalone: standalone-haskell standalone-ocaml -standalone-unified: standalone-unified-haskell standalone-unified-ocaml +standalone: standalone-haskell standalone-ocaml standalone-js-of-ocaml +standalone-unified: standalone-unified-haskell standalone-unified-ocaml standalone-js-of-ocaml standalone-separate: standalone-separate-haskell standalone-separate-ocaml perf-standalone: $(PERF_STANDALONE:%=src/ExtractionOCaml/%) @@ -73,13 +94,22 @@ standalone-separate-ocaml: $(SEPARATE_STANDALONE_OCAML:%=src/ExtractionOCaml/%) standalone-haskell: standalone-unified-haskell standalone-separate-haskell standalone-unified-haskell: $(UNIFIED_STANDALONE_HASKELL:%=src/ExtractionHaskell/%) standalone-separate-haskell: $(SEPARATE_STANDALONE_HASKELL:%=src/ExtractionHaskell/%) -# FIXME HERE +standalone-js-of-ocaml: $(STANDALONE_JS_OF_OCAML:%=src/ExtractionJsOfOCaml/%.js) + uninstall-standalone-ocaml: FILESTOINSTALL=$(OCAML_BINARIES) uninstall-standalone-unified-ocaml: FILESTOINSTALL=$(UNIFIED_OCAML_BINARIES) uninstall-standalone-separate-ocaml: FILESTOINSTALL=$(SEPARATE_OCAML_BINARIES) uninstall-standalone-haskell: FILESTOINSTALL=$(HASKELL_BINARIES) uninstall-standalone-unified-haskell: FILESTOINSTALL=$(UNIFIED_HASKELL_BINARIES) uninstall-standalone-separate-haskell: FILESTOINSTALL=$(SEPARATE_HASKELL_BINARIES) +uninstall-standalone-js-of-ocaml: FILESTOINSTALL=$(JS_OF_OCAML_FILES) + +install-standalone-ocaml install-standalone-unified-ocaml install-standalone-separate-ocaml install-standalone-haskell install-standalone-unified-haskell install-standalone-separate-haskell: PERMS=0755 +install-standalone-js-of-ocaml: PERMS=0644 +install-standalone-ocaml install-standalone-unified-ocaml install-standalone-separate-ocaml install-standalone-haskell install-standalone-unified-haskell install-standalone-separate-haskell: INSTALLDIR=$(BINDIR) +install-standalone-js-of-ocaml: INSTALLDIR=$(JSDIR) + + ifeq ($(SKIP_BEDROCK2),1) install-standalone-ocaml: FILESTOINSTALL=$(OCAML_BINARIES) @@ -88,15 +118,16 @@ install-standalone-separate-ocaml: FILESTOINSTALL=$(SEPARATE_OCAML_BINARIES) install-standalone-haskell: FILESTOINSTALL=$(HASKELL_BINARIES) install-standalone-unified-haskell: FILESTOINSTALL=$(UNIFIED_HASKELL_BINARIES) install-standalone-separate-haskell: FILESTOINSTALL=$(SEPARATE_HASKELL_BINARIES) +install-standalone-js-of-ocaml: FILESTOINSTALL=$(JS_OF_OCAML_FILES) -install-standalone-ocaml install-standalone-unified-ocaml install-standalone-separate-ocaml install-standalone-haskell install-standalone-unified-haskell install-standalone-separate-haskell: +install-standalone-ocaml install-standalone-unified-ocaml install-standalone-separate-ocaml install-standalone-haskell install-standalone-unified-haskell install-standalone-separate-haskell install-standalone-js-of-ocaml: $(HIDE)code=0; for f in $(FILESTOINSTALL); do\ if ! [ -f "$$f" ]; then >&2 echo $$f does not exist; code=1; fi \ done; exit $$code $(HIDE)for f in $(FILESTOINSTALL); do\ - install -d "$(BINDIR)/" &&\ - install -m 0755 "$$f" "$(BINDIR)/" &&\ - echo INSTALL "$$f" "$(BINDIR)/";\ + install -d "$(INSTALLDIR)/" &&\ + install -m $(PERMS) "$$f" "$(INSTALLDIR)/" &&\ + echo INSTALL "$$f" "$(INSTALLDIR)/";\ done else install-standalone-ocaml: FILESTOINSTALL=$(WITH_BEDROCK2_OCAML_BINARIES) @@ -105,6 +136,7 @@ install-standalone-separate-ocaml: FILESTOINSTALL=$(WITH_BEDROCK2_SEPARATE_OCAML install-standalone-haskell: FILESTOINSTALL=$(WITH_BEDROCK2_HASKELL_BINARIES) install-standalone-unified-haskell: FILESTOINSTALL=$(WITH_BEDROCK2_UNIFIED_HASKELL_BINARIES) install-standalone-separate-haskell: FILESTOINSTALL=$(WITH_BEDROCK2_SEPARATE_HASKELL_BINARIES) +install-standalone-js-of-ocaml: FILESTOINSTALL=$(WITH_BEDROCK2_JS_OF_OCAML_FILES) install-standalone-ocaml install-standalone-unified-ocaml install-standalone-separate-ocaml install-standalone-haskell install-standalone-unified-haskell install-standalone-separate-haskell: $(HIDE)code=0; for f in $(FILESTOINSTALL); do\ @@ -114,15 +146,29 @@ install-standalone-ocaml install-standalone-unified-ocaml install-standalone-sep fdir="$$(dirname "$$f")" &&\ fname="$$(basename "$$f")" &&\ df="$${fname#with_bedrock2_}" &&\ - install -d "$(BINDIR)/" &&\ - install -m 0755 "$$f" "$(BINDIR)/$$df" &&\ - echo INSTALL "$$f" "$(BINDIR)/$$df";\ + install -d "$(INSTALLDIR)/" &&\ + install -m $(PERMS) "$$f" "$(INSTALLDIR)/$$df" &&\ + echo INSTALL "$$f" "$(INSTALLDIR)/$$df";\ + done +install-standalone-js-of-ocaml: + $(HIDE)code=0; for f in $(FILESTOINSTALL); do\ + if ! [ -f "$$f" ]; then >&2 echo $$f does not exist; code=1; fi \ + done; exit $$code + $(HIDE)for f in $(FILESTOINSTALL); do\ + fdir="$$(dirname "$$f")" &&\ + fname="$$(basename "$$f")" &&\ + df="$${fname#with_bedrock2_}" &&\ + install -d "$(INSTALLDIR)/" &&\ + install -m $(PERMS) "$$f" "$(INSTALLDIR)/$$df" &&\ + sed -i.bak -e 's,\(sourceMappingURL=.*\)with_bedrock2_,\1,g; s,\("file":[^"]*"[^"]*\)with_bedrock2_,\1,g' "$(INSTALLDIR)/$$df" &&\ + rm -f "$(INSTALLDIR)/$$df.bak" &&\ + echo 'INSTALL+SED' "$$f" "$(INSTALLDIR)/$$df";\ done endif -uninstall-standalone-ocaml uninstall-standalone-unified-ocaml uninstall-standalone-separate-ocaml uninstall-standalone-haskell uninstall-standalone-unified-haskell uninstall-standalone-separate-haskell: +uninstall-standalone-ocaml uninstall-standalone-unified-ocaml uninstall-standalone-separate-ocaml uninstall-standalone-haskell uninstall-standalone-unified-haskell uninstall-standalone-separate-haskell uninstall-standalone-js-of-ocaml: $(HIDE)for f in $(FILESTOINSTALL); do \ - instf="$(BINDIR)/`basename $$f`" &&\ + instf="$(INSTALLDIR)/`basename $$f`" &&\ rm -f "$$instf" &&\ echo RM "$$instf"; \ done diff --git a/etc/ci/setup-debian-chroot.sh b/etc/ci/setup-debian-chroot.sh index f031dc32ef..de790cb5c2 100755 --- a/etc/ci/setup-debian-chroot.sh +++ b/etc/ci/setup-debian-chroot.sh @@ -11,7 +11,7 @@ sudo apt-get -q -y -o Acquire::Retries=30 install debootstrap sudo debootstrap --variant=minbase "$debian" /chroot http://debian-archive.trafficmanager.net/debian/ || ( cat /tmp/tmp.*/debootstrap/debootstrap.log ; exit 1 ) sudo mount proc /chroot/proc -t proc sudo mount sysfs /chroot/sys -t sysfs -sudo chroot /chroot apt-get -q -y -o Acquire::Retries=30 install sudo git make time jq python3 python-is-python3 ocaml coq libcoq-core-ocaml-dev libfindlib-ocaml-dev ocaml-findlib cabal-install +sudo chroot /chroot apt-get -q -y -o Acquire::Retries=30 install sudo git make time jq python3 python-is-python3 ocaml coq libcoq-core-ocaml-dev libfindlib-ocaml-dev ocaml-findlib cabal-install js-of-ocaml sudo chroot /chroot groupadd -g "$(id -g)" "$(id -g -n)" sudo chroot /chroot useradd -g "$(id -g)" -u "$(id -u)" "$(id -u -n)" printf "%s ALL=(ALL) NOPASSWD: ALL\n" "$(id -u -n)" | sudo tee /chroot/etc/sudoers.d/root diff --git a/fiat-html/copy-button.js b/fiat-html/copy-button.js new file mode 100644 index 0000000000..375d80edd0 --- /dev/null +++ b/fiat-html/copy-button.js @@ -0,0 +1,18 @@ +// JavaScript for copy functionality +document.addEventListener('click', function(e) { + if (e.target.matches('.copy-button')) { + const button = e.target; + const targetId = button.getAttribute('data-target'); + const codeText = document.getElementById(targetId).textContent; + + navigator.clipboard.writeText(codeText).then(() => { + button.textContent = "Copied!"; + button.disabled = true; + + setTimeout(() => { + button.textContent = "Copy"; + button.disabled = false; + }, 3000); // Revert after 3 seconds + }); + } +}); diff --git a/fiat-html/fiat-crypto.html b/fiat-html/fiat-crypto.html new file mode 100644 index 0000000000..819704077c --- /dev/null +++ b/fiat-html/fiat-crypto.html @@ -0,0 +1,71 @@ + + +
+ +
+
+