diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile index 1587a7ddc7..0fa50e46e2 100644 --- a/.devcontainer/Dockerfile +++ b/.devcontainer/Dockerfile @@ -3,8 +3,8 @@ # See here for image contents: https://github.com/microsoft/vscode-dev-containers/tree/v0.245.2/containers/cpp/.devcontainer/base.Dockerfile # [Choice] Debian / Ubuntu version (use Debian 12/11/9, Ubuntu 18.04/21.04 on local arm64/Apple Silicon): debian-12, debian-11, debian-10, debian-9, ubuntu-21.04, ubuntu-20.04, ubuntu-18.04 -ARG VARIANT=debian-12 -FROM mcr.microsoft.com/vscode/devcontainers/cpp:${VARIANT} +ARG VARIANT=ubuntu-22.04 +FROM mcr.microsoft.com/devcontainers/cpp:1-${VARIANT} ARG DEBIAN_FRONTEND=noninteractive ENV TZ=Asian/Shanghai @@ -13,13 +13,11 @@ ENV TZ=Asian/Shanghai RUN apt-get update \ && apt-get upgrade -y \ && apt-get install -y apt-transport-https apt-utils build-essential \ - ca-certificates ccache cmake curl g++-multilib git gnupg \ - libgcc-12-dev lib32gcc-12-dev lsb-release \ + ca-certificates ccache clang curl g++-multilib git gnupg \ + libgcc-12-dev lib32gcc-12-dev llvm lsb-release \ ninja-build ocaml ocamlbuild \ software-properties-common tree tzdata \ - unzip valgrind vim wget zip --no-install-recommends \ - && apt-get clean -y \ - && rm -rf /var/lib/apt/lists/* + unzip valgrind vim wget zip --no-install-recommends # # binaryen @@ -30,19 +28,6 @@ RUN wget -c --progress=dot:giga https://github.com/WebAssembly/binaryen/releases && ln -sf /opt/binaryen-version_${BINARYEN_VER} /opt/binaryen \ && rm binaryen-version_${BINARYEN_VER}-x86_64-linux.tar.gz -# -# CMAKE (https://apt.kitware.com/) -SHELL ["/bin/bash", "-o", "pipefail", "-c"] -# hadolint ignore=DL3008 -ARG CMAKE_VER=3.27.0 -RUN wget https://github.com/Kitware/CMake/releases/download/v${CMAKE_VER}/cmake-${CMAKE_VER}-Linux-x86_64.sh \ - -q -O /tmp/cmake-install.sh \ - && chmod u+x /tmp/cmake-install.sh \ - && mkdir /opt/cmake-${CMAKE_VER} \ - && /tmp/cmake-install.sh --skip-license --prefix=/opt/cmake-${CMAKE_VER} \ - && rm /tmp/cmake-install.sh \ - && ln -s /opt/cmake-${CMAKE_VER}/bin/* /usr/local/bin - # # install emsdk WORKDIR /opt @@ -66,10 +51,10 @@ RUN wget -c --progress=dot:giga https://github.com/WebAssembly/wasi-sdk/releases # #install wabt ARG WABT_VER=1.0.33 -RUN wget -c --progress=dot:giga https://github.com/WebAssembly/wabt/releases/download/${WABT_VER}/wabt-${WABT_VER}-ubuntu.tar.gz -P /opt \ - && tar xf /opt/wabt-${WABT_VER}-ubuntu.tar.gz -C /opt \ +RUN wget -c --progress=dot:giga https://github.com/WebAssembly/wabt/releases/download/${WABT_VER}/wabt-${WABT_VER}-ubuntu-20.04.tar.gz -P /opt \ + && tar xf /opt/wabt-${WABT_VER}-ubuntu-20.04.tar.gz -C /opt \ && ln -sf /opt/wabt-${WABT_VER} /opt/wabt \ - && rm /opt/wabt-${WABT_VER}-ubuntu.tar.gz + && rm /opt/wabt-${WABT_VER}-ubuntu-20.04.tar.gz # # install bazelisk @@ -81,47 +66,23 @@ RUN mkdir /opt/bazelisk \ # # install clang+llvm -ARG LLVM_VER=16 -RUN apt-get purge -y clang-14 llvm-14 && apt-get autoremove -y -WORKDIR /etc/apt/apt.conf.d -RUN touch 99verfiy-peer.conf \ - && echo "Acquire { https::Verify-Peer false }" > 99verfiy-peer.conf - -WORKDIR /tmp -#RUN wget --progress=dot:giga https://apt.llvm.org/llvm.sh \ -# && chmod a+x ./llvm.sh \ -# && ./llvm.sh ${LLVM_VER} all - -# Workaround due to https://github.com/llvm/llvm-project/issues/62475 -# hadolint ignore=DL3008 -RUN set -ex \ - && echo "deb http://apt.llvm.org/bookworm/ llvm-toolchain-bookworm-${LLVM_VER} main" > /etc/apt/sources.list.d/apt.llvm.org.list \ - && wget -qO- https://apt.llvm.org/llvm-snapshot.gpg.key | tee /etc/apt/trusted.gpg.d/apt.llvm.org.asc \ - && apt-get update \ - && apt-get install -y \ - clang-${LLVM_VER} lldb-${LLVM_VER} lld-${LLVM_VER} clangd-${LLVM_VER} clang-tidy-${LLVM_VER} clang-format-${LLVM_VER} clang-tools-${LLVM_VER} \ - llvm-${LLVM_VER}-dev lld-${LLVM_VER} lldb-${LLVM_VER} llvm-${LLVM_VER}-tools libomp-${LLVM_VER}-dev libc++-${LLVM_VER}-dev libc++abi-${LLVM_VER}-dev \ - libclang-common-${LLVM_VER}-dev libclang-${LLVM_VER}-dev libclang-cpp${LLVM_VER}-dev libunwind-${LLVM_VER}-dev \ - libclang-rt-${LLVM_VER}-dev libpolly-${LLVM_VER}-dev --no-install-recommends \ - && apt-get clean -y \ - && rm -rf /var/lib/apt/lists/* - -# -# [Optional] +ARG LLVM_VER=15.0.6 +RUN wget https://github.com/llvm/llvm-project/releases/download/llvmorg-${LLVM_VER}/clang+llvm-${LLVM_VER}-x86_64-linux-gnu-ubuntu-18.04.tar.xz +RUN tar -xvf clang+llvm-${LLVM_VER}-x86_64-linux-gnu-ubuntu-18.04.tar.xz \ + && mv clang+llvm-${LLVM_VER}-x86_64-linux-gnu-ubuntu-18.04 llvm-${LLVM_VER} \ + && rm clang+llvm-${LLVM_VER}-x86_64-linux-gnu-ubuntu-18.04.tar.xz # # Install pip # hadolint ignore=DL3008 RUN apt-get update \ && apt-get install -y --reinstall python3-venv python3-pip --no-install-recommends \ - && apt-get clean -y \ - && rm -rf /var/lib/apt/lists/* + && pip install --no-cache-dir --upgrade pip # # Install required python packages # hadolint ignore=DL3013 -RUN python3 -m pip install --no-cache-dir --break-system-packages --upgrade pip \ - && pip3 install --no-cache-dir --break-system-packages black nose pycparser pylint +RUN pip3 install --no-cache-dir black jupyter nose numpy pycparser pylint # # Install github-cli. It doens't work as a feature of devcontainer.json @@ -136,9 +97,54 @@ RUN wget -qO- https://deb.nodesource.com/setup_20.x | bash - # hadolint ignore=DL3008 RUN apt-get install -y nodejs --no-install-recommends +# +# SGX setup +RUN mkdir -p /opt/intel + +WORKDIR /opt/intel +RUN wget -q https://download.01.org/intel-sgx/sgx-linux/2.21/distro/ubuntu22.04-server/sgx_linux_x64_sdk_2.21.100.1.bin \ + && chmod +x sgx_linux_x64_sdk_2.21.100.1.bin +RUN echo 'yes' | ./sgx_linux_x64_sdk_2.21.100.1.bin +RUN source /opt/intel/sgxsdk/environment + +# RUN echo 'deb [signed-by=/etc/apt/keyrings/intel-sgx-keyring.asc arch=amd64] https://download.01.org/intel-sgx/sgx_repo/ubuntu jammy main' | sudo tee /etc/apt/sources.list.d/intel-sgx.list \ +# && wget https://download.01.org/intel-sgx/sgx_repo/ubuntu/intel-sgx-deb.key \ +# && cat intel-sgx-deb.key | sudo tee /etc/apt/keyrings/intel-sgx-keyring.asc +# RUN sudo apt update \ +# && sudo apt install -y libsgx-launch libsgx-urts libsgx-enclave-common + + +# +# Install Rust +# WORKDIR /tmp +# ENV RUSTUP_HOME=/usr/local/cargo +# ENV CARGO_HOME=/usr/local/cargo +# RUN curl --proto '=https' --tlsv1.2 https://sh.rustup.rs -sSf -o install_rust.sh +# RUN chmod a+x install_rust.sh \ +# && ./install_rust.sh -v -y +# ENV PATH="/usr/local/cargo/bin:${PATH}" + +# +# Install wasm-tools from binary releasing +ARG WASM_TOOLS_VER=1.0.38 +WORKDIR /opt +RUN wget -c --progress=dot:giga https://github.com/bytecodealliance/wasm-tools/releases/download/wasm-tools-${WASM_TOOLS_VER}/wasm-tools-${WASM_TOOLS_VER}-x86_64-linux.tar.gz +RUN tar xzf wasm-tools-${WASM_TOOLS_VER}-x86_64-linux.tar.gz \ + && rm wasm-tools-${WASM_TOOLS_VER}-x86_64-linux.tar.gz \ + && ln -sf /opt/wasm-tools-${WASM_TOOLS_VER}-x86_64-linux/wasm-tools /usr/bin/wasm-tools + +# +# Install wit-bindgen +RUN cargo install --git https://github.com/bytecodealliance/wit-bindgen wit-bindgen-cli + +# +# Install perf +RUN apt update \ + && apt-get install -y linux-tools-generic linux-tools-$(uname -a | awk '{print $3}') \ + # set path ENV PATH="/opt/bazelisk:/usr/lib/llvm-${LLVM_VER}/bin:${PATH}" -ENV CC=/usr/lib/llvm-${LLVM_VER}/bin/clang CXX=/usr/lib/llvm-${LLVM_VER}/bin/clang++ +# ENV CC=/usr/lib/llvm-${LLVM_VER}/bin/clang CXX=/usr/lib/llvm-${LLVM_VER}/bin/clang++ RUN printf "%s\n" "PS1='\n[ \u@wamr-dev-docker \W ]\n$ '" >> /root/.bashrc \ && apt-get autoremove -y \ && apt-get clean -y \ @@ -146,5 +152,4 @@ RUN printf "%s\n" "PS1='\n[ \u@wamr-dev-docker \W ]\n$ '" >> /root/.bashrc \ && rm -rf /tmp/* # set workdir when container run -VOLUME /workspaces WORKDIR /workspaces diff --git a/.devcontainer/Dockerfile-SGX b/.devcontainer/Dockerfile-SGX new file mode 100644 index 0000000000..90a925f8e4 --- /dev/null +++ b/.devcontainer/Dockerfile-SGX @@ -0,0 +1,203 @@ +# Copyright (C) 2019 Intel Corporation. All rights reserved. +# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception + +# See here for image contents: https://github.com/microsoft/vscode-dev-containers/tree/v0.245.2/containers/cpp/.devcontainer/base.Dockerfile +# [Choice] Debian / Ubuntu version (use Debian 12/11/9, Ubuntu 18.04/21.04 on local arm64/Apple Silicon): debian-12, debian-11, debian-10, debian-9, ubuntu-21.04, ubuntu-20.04, ubuntu-18.04 +ARG VARIANT=jammy +FROM mcr.microsoft.com/devcontainers/base:${VARIANT} + +ARG DEBIAN_FRONTEND=noninteractive +ENV TZ=Asian/Shanghai + +# hadolint ignore=DL3008 +RUN apt-get update \ + && apt-get upgrade -y \ + && apt-get install -y apt-transport-https apt-utils build-essential \ + ca-certificates ccache cmake curl g++-multilib git gnupg \ + libgcc-12-dev lib32gcc-12-dev libstdc++-12-dev lsb-release \ + ninja-build ocaml ocamlbuild \ + software-properties-common tree tzdata \ + unzip valgrind vim wget zip --no-install-recommends + +# +# binaryen +ARG BINARYEN_VER=114 +WORKDIR /opt +RUN wget -c --progress=dot:giga https://github.com/WebAssembly/binaryen/releases/download/version_${BINARYEN_VER}/binaryen-version_${BINARYEN_VER}-x86_64-linux.tar.gz \ + && tar xf binaryen-version_${BINARYEN_VER}-x86_64-linux.tar.gz \ + && ln -sf /opt/binaryen-version_${BINARYEN_VER} /opt/binaryen \ + && rm binaryen-version_${BINARYEN_VER}-x86_64-linux.tar.gz + +# +# CMAKE (https://apt.kitware.com/) +SHELL ["/bin/bash", "-o", "pipefail", "-c"] +# hadolint ignore=DL3008 +ARG CMAKE_VER=3.27.0 +RUN wget https://github.com/Kitware/CMake/releases/download/v${CMAKE_VER}/cmake-${CMAKE_VER}-Linux-x86_64.sh \ + -q -O /tmp/cmake-install.sh \ + && chmod u+x /tmp/cmake-install.sh \ + && mkdir /opt/cmake-${CMAKE_VER} \ + && /tmp/cmake-install.sh --skip-license --prefix=/opt/cmake-${CMAKE_VER} \ + && rm /tmp/cmake-install.sh \ + && ln -s /opt/cmake-${CMAKE_VER}/bin/* /usr/local/bin + +# +# install emsdk +WORKDIR /opt +RUN git clone https://github.com/emscripten-core/emsdk.git + +ARG EMSDK_VER=3.1.43 +WORKDIR /opt/emsdk +RUN git pull \ + && ./emsdk install ${EMSDK_VER} \ + && ./emsdk activate ${EMSDK_VER} \ + && echo "source /opt/emsdk/emsdk_env.sh" >> /root/.bashrc + +# +# install wasi-sdk +ARG WASI_SDK_VER=21 +RUN wget -c --progress=dot:giga https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-${WASI_SDK_VER}/wasi-sdk-${WASI_SDK_VER}.0-linux.tar.gz -P /opt \ + && tar xf /opt/wasi-sdk-${WASI_SDK_VER}.0-linux.tar.gz -C /opt \ + && ln -sf /opt/wasi-sdk-${WASI_SDK_VER}.0 /opt/wasi-sdk \ + && rm /opt/wasi-sdk-${WASI_SDK_VER}.0-linux.tar.gz + +# +#install wabt +ARG WABT_VER=1.0.34 +RUN wget -c --progress=dot:giga https://github.com/WebAssembly/wabt/releases/download/${WABT_VER}/wabt-${WABT_VER}-ubuntu-20.04.tar.gz -P /opt \ + && tar xf /opt/wabt-${WABT_VER}-ubuntu-20.04.tar.gz -C /opt \ + && ln -sf /opt/wabt-${WABT_VER} /opt/wabt \ + && rm /opt/wabt-${WABT_VER}-ubuntu-20.04.tar.gz + +# +# install bazelisk +ARG BAZELISK_VER=1.17.0 +RUN mkdir /opt/bazelisk \ + && wget -c --progress=dot:giga https://github.com/bazelbuild/bazelisk/releases/download/v${BAZELISK_VER}/bazelisk-linux-amd64 -P /opt/bazelisk \ + && chmod a+x /opt/bazelisk/bazelisk-linux-amd64 \ + && ln -fs /opt/bazelisk/bazelisk-linux-amd64 /opt/bazelisk/bazel + +# +# install clang+llvm +ARG LLVM_VER=15 +# RUN apt-get purge -y clang-14 llvm-14 && apt-get autoremove -y +# WORKDIR /etc/apt/apt.conf.d +# RUN touch 99verfiy-peer.conf \ +# && echo "Acquire { https::Verify-Peer false }" > 99verfiy-peer.conf +# +# WORKDIR /tmp +# RUN wget --progress=dot:giga https://apt.llvm.org/llvm.sh \ +# && chmod a+x ./llvm.sh \ +# && ./llvm.sh ${LLVM_VER} all + +# Workaround due to https://github.com/llvm/llvm-project/issues/62475 +# hadolint ignore=DL3008nn +# RUN set -ex \ +# && echo "deb http://apt.llvm.org/bookworm/ llvm-toolchain-bookworm-${LLVM_VER} main" > /etc/apt/sources.list.d/apt.llvm.org.list \ +# && wget -qO- https://apt.llvm.org/llvm-snapshot.gpg.key | tee /etc/apt/trusted.gpg.d/apt.llvm.org.asc \ +# && apt-get update \ +# && apt-get install -y \ +# clang-${LLVM_VER} lldb-${LLVM_VER} lld-${LLVM_VER} clangd-${LLVM_VER} clang-tidy-${LLVM_VER} clang-format-${LLVM_VER} clang-tools-${LLVM_VER} \ +# llvm-${LLVM_VER}-dev lld-${LLVM_VER} lldb-${LLVM_VER} llvm-${LLVM_VER}-tools libomp-${LLVM_VER}-dev libc++-${LLVM_VER}-dev libc++abi-${LLVM_VER}-dev \ +# libclang-common-${LLVM_VER}-dev libclang-${LLVM_VER}-dev libclang-cpp${LLVM_VER}-dev libunwind-${LLVM_VER}-dev \ +# libclang-rt-${LLVM_VER}-dev libpolly-${LLVM_VER}-dev --no-install-recommends \ +# && apt-get clean -y \ +# && rm -rf /var/lib/apt/lists/* +# +# +# [Optional] + +RUN apt update \ + && apt install -y llvm-${LLVM_VER} libmlir-${LLVM_VER}-dev \ + libclang-common-${LLVM_VER}-dev libedit-dev libpfm4-dev + +# +# Install pip +# hadolint ignore=DL3008 +RUN apt-get update \ + && apt-get install -y --reinstall python3-venv python3-pip --no-install-recommends \ + && apt-get clean -y \ + && rm -rf /var/lib/apt/lists/* + +# +# Install required python packages +# hadolint ignore=DL3013 +RUN python3 -m pip install --no-cache-dir --upgrade pip \ + && pip3 install --no-cache-dir black jupyter nose numpy pycparser pylint + +# +# Install github-cli. It doens't work as a feature of devcontainer.json +# ARG GH_CLI_VER=2.32.0 +# WORKDIR /tmp +# RUN wget -q https://github.com/cli/cli/releases/download/v${GH_CLI_VER}/gh_${GH_CLI_VER}_linux_amd64.deb \ +# && dpkg -i gh_${GH_CLI_VER}_linux_amd64.deb + +# +# Install NodeJS +# RUN wget -qO- https://deb.nodesource.com/setup_20.x | bash - +# # hadolint ignore=DL3008 +# RUN apt-get install -y nodejs --no-install-recommends + +# +# SGX setup +RUN mkdir -p /opt/intel + +WORKDIR /opt/intel +RUN wget -q https://download.01.org/intel-sgx/sgx-linux/2.21/distro/ubuntu22.04-server/sgx_linux_x64_sdk_2.21.100.1.bin \ + && chmod +x sgx_linux_x64_sdk_2.21.100.1.bin +RUN echo 'yes' | ./sgx_linux_x64_sdk_2.21.100.1.bin +RUN source /opt/intel/sgxsdk/environment + +RUN echo 'deb [arch=amd64] https://download.01.org/intel-sgx/sgx_repo/ubuntu jammy main' | sudo tee /etc/apt/sources.list.d/intel-sgx.list \ + && wget -qO - https://download.01.org/intel-sgx/sgx_repo/ubuntu/intel-sgx-deb.key | apt-key add - + +RUN apt update \ + && apt install -y libsgx-launch libsgx-urts + +# +# Install wasm-tools from binary releasing +ARG WASM_TOOLS_VER=1.201.0 +WORKDIR /opt +RUN wget -c --progress=dot:giga https://github.com/bytecodealliance/wasm-tools/releases/download/v${WASM_TOOLS_VER}/wasm-tools-${WASM_TOOLS_VER}-x86_64-linux.tar.gz +RUN tar xzf wasm-tools-${WASM_TOOLS_VER}-x86_64-linux.tar.gz \ + && rm wasm-tools-${WASM_TOOLS_VER}-x86_64-linux.tar.gz \ + && ln -sf /opt/wasm-tools-${WASM_TOOLS_VER}-x86_64-linux/wasm-tools /usr/bin/wasm-tools + +# +# Install wit-bindgen +ARG WIT_BINDGEN_VER=0.21.0 +WORKDIR /opt +RUN wget -c --progress=dot:giga https://github.com/bytecodealliance/wit-bindgen/releases/download/v${WIT_BINDGEN_VER}/wit-bindgen-${WIT_BINDGEN_VER}-x86_64-linux.tar.gz +RUN tar xzf wit-bindgen-${WIT_BINDGEN_VER}-x86_64-linux.tar.gz \ + && rm wit-bindgen-${WIT_BINDGEN_VER}-x86_64-linux.tar.gz + +# +# Install perf +ARG KERNEL_VER=5.15.0-97 +RUN apt update \ + && apt-get install -y linux-tools-generic linux-tools-${KERNEL_VER}-generic \ + && apt-get install -y linux-headers-${KERNEL_VER} + +# +# Install extra clang tools and lldb +RUN apt update \ + && apt install -y clang-tools-${LLVM_VER} clang-tidy-${LLVM_VER} clang-format-${LLVM_VER} clangd-${LLVM_VER} \ + && apt install -y lldb-${LLVM_VER} python3-lldb-${LLVM_VER} + +# +# Install Ocaml +RUN apt update \ + && apt install -y opam ocaml ocamlbuild + +# set path +ENV PATH="/home/vscode/.opam/default/bin:/opt/bazelisk:/usr/lib/llvm-${LLVM_VER}/bin:${PATH}" +# ENV CC=/usr/lib/llvm-${LLVM_VER}/bin/clang CXX=/usr/lib/llvm-${LLVM_VER}/bin/clang++ +RUN printf "%s\n" "PS1='\n[ \u@wamr-dev-docker \W ]\n$ '" >> /root/.bashrc \ + && apt-get autoremove -y \ + && apt-get clean -y \ + && rm -rf /var/lib/apt/lists/* \ + && rm -rf /tmp/* + +# set workdir when container run +VOLUME /workspaces +WORKDIR /workspaces diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json index 5feb175640..77bf48a11f 100644 --- a/.devcontainer/devcontainer.json +++ b/.devcontainer/devcontainer.json @@ -5,26 +5,24 @@ { "name": "WAMR-Dev", "build": { - "dockerfile": "Dockerfile", + "dockerfile": "Dockerfile-SGX", // Update 'VARIANT' to pick an Debian / Ubuntu OS version: debian-12, debian-11, debian-10, debian-9, ubuntu-21.04, ubuntu-20.04, ubuntu-18.04 // Use Debian 12, Debian 11, Debian 9, Ubuntu 18.04 or Ubuntu 21.04 on local arm64/Apple Silicon "args": { - "BINARYEN_VER": "114", - "BAZELISK_VER": "1.17.0", + "BAZELISK_VER": "1.19.0", + "BINARYEN_VER": "117", "CMAKE_VER": "3.27.0", "EMSDK_VER": "3.1.43", - "GH_CLI_VER": "2.32.0", - "LLVM_VER": "16", - "VARIANT": "debian-12", - "WASI_SDK_VER": "20", - "WABT_VER": "1.0.33" + "GH_CLI_VER": "2.45.0", + "LLVM_VER": "15", + "WABT_VER": "1.0.35", + "WASI_SDK_VER": "22", + "WASM_TOOLS_VER": "1.209.0", + "WIT_BINDGEN_VER": "0.26.0", + "VARIANT": "jammy", } }, - "runArgs": [ - "--cap-add=SYS_PTRACE", - "--security-opt", - "seccomp=unconfined" - ], + "privileged": true, // Configure tool-specific properties. "customizations": { // Configure properties specific to VS Code. @@ -34,17 +32,28 @@ // Add the IDs of extensions you want installed when the container is created. "extensions": [ "dtsvet.vscode-wasm", + "esbenp.prettier-vscode", + "GitHub.copilot", + "GitHub.copilot-chat", + "GitHub.copilot-labs", "llvm-vs-code-extensions.vscode-clangd", + "ms-python.pylint", "ms-python.python", - "ms-python.vscode-pylance", - "ms-vscode.cmake-tools" + "ms-python.black-formatter", + "ms-toolsai.jupyter", + "streetsidesoftware.code-spell-checker", + "vadimcn.vscode-lldb", + "vscodevim.vim", ] } }, // Use 'forwardPorts' to make a list of ports inside the container available locally. // "forwardPorts": [], // Use 'postCreateCommand' to run commands after the container is created. - "postCreateCommand": "curl https://sh.rustup.rs -sSf | bash -s -- -y", + "postCreateCommand": "bash .devcontainer/finalize.sh", // Comment out this line to run as root instead. - "remoteUser": "vscode" + "remoteUser": "vscode", + "mounts": [ + "source=/mnt/workspace/SDF,target=/SDF,type=bind" + ] } \ No newline at end of file diff --git a/.devcontainer/finalize.sh b/.devcontainer/finalize.sh new file mode 100644 index 0000000000..170a86e21b --- /dev/null +++ b/.devcontainer/finalize.sh @@ -0,0 +1,13 @@ +printf "Running 'postCreateCommand' Script\n" + +printf "Installing Rust Targets\n" + +printf "Installing Python Dependencies\n" + +printf "Installing NPM Dependencies\n" + +printf "Installing Ocaml stuff\n" + +opam init --yes --shell-setup +eval $(opam env --switch=default) +opam install --yes dune menhir diff --git a/.github/workflows/codeql.yml b/.github/workflows/codeql.yml index 5a9c12d334..8d8266ed68 100644 --- a/.github/workflows/codeql.yml +++ b/.github/workflows/codeql.yml @@ -43,7 +43,7 @@ jobs: steps: - name: Checkout repository - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: submodules: recursive diff --git a/.github/workflows/compilation_on_nuttx.yml b/.github/workflows/compilation_on_nuttx.yml index 09bdfd324b..588bdcf01d 100644 --- a/.github/workflows/compilation_on_nuttx.yml +++ b/.github/workflows/compilation_on_nuttx.yml @@ -114,7 +114,7 @@ jobs: make -j$(nproc) EXTRAFLAGS=-Werror - name: Checkout Bloaty - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: repository: google/bloaty submodules: recursive diff --git a/.github/workflows/nightly_run.yml b/.github/workflows/nightly_run.yml index 1124df6295..00233c65a4 100644 --- a/.github/workflows/nightly_run.yml +++ b/.github/workflows/nightly_run.yml @@ -324,7 +324,7 @@ jobs: make_options_feature: "-DWAMR_BUILD_MEMORY64=1" steps: - name: checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Install dependencies uses: nick-fields/retry@v2