[WIP] Add syntax check for rust and C\C++ code (#108)
* proof of concept * fix syntax for rust and add auto fix syntax * fix syntax for C * fix bug with files owner * add information to wiki * try to add ci * format code from master * even more format fixes * change docker to docker-compose * Exclude ./target_*/build directories from format check * Run rustfmt only on project files * add ulimit setup for long clang list * merge * fix rustfmt, exclude target Inc directory * sync with master * abspath Co-authored-by: aanper <mail@s3f.ru> Co-authored-by: Vadim Kaushan <admin@disasm.info>
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
FROM ubuntu:18.04
|
||||
|
||||
RUN apt-get update && \
|
||||
ENV PATH /root/.cargo/bin:$PATH
|
||||
|
||||
RUN apt update && \
|
||||
apt install -y --no-install-recommends \
|
||||
make \
|
||||
gcc-arm-none-eabi \
|
||||
@@ -17,10 +19,15 @@ RUN apt-get update && \
|
||||
python \
|
||||
python-pip \
|
||||
libstdc++-arm-none-eabi-newlib \
|
||||
libclang-10-dev && \
|
||||
apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||
libclang-10-dev \
|
||||
clang-format-10 \
|
||||
&& apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||
|
||||
RUN curl https://sh.rustup.rs -sSf | sh -s -- -y --profile=minimal --target thumbv7em-none-eabi thumbv7em-none-eabihf
|
||||
RUN curl https://sh.rustup.rs -sSf | sh -s -- -y --profile=minimal --target thumbv7em-none-eabi thumbv7em-none-eabihf && \
|
||||
rustup component add rustfmt --toolchain stable-x86_64-unknown-linux-gnu
|
||||
|
||||
COPY entrypoint.sh syntax_check.sh /
|
||||
|
||||
RUN chmod +x /syntax_check.sh
|
||||
|
||||
COPY entrypoint.sh /entrypoint.sh
|
||||
ENTRYPOINT ["/entrypoint.sh"]
|
||||
|
43
docker/syntax_check.sh
Executable file
43
docker/syntax_check.sh
Executable file
@@ -0,0 +1,43 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
set -e
|
||||
|
||||
CLANG_FORMAT_BIN="/usr/bin/clang-format-10"
|
||||
PATH="$HOME/.cargo/bin:${PATH}"
|
||||
|
||||
PROJECT_DIR=$(pwd)
|
||||
|
||||
cd $PROJECT_DIR
|
||||
|
||||
echo "RUN C\C++ SYNTAX CHECK"
|
||||
C_FILES=$(find . \
|
||||
-not \( -path './target_*/Middlewares' -prune \) \
|
||||
-not \( -path './target_*/Drivers' -prune \) \
|
||||
-not \( -path './target_*/build' -prune \) \
|
||||
-not \( -path './target_*/Inc' -prune \) \
|
||||
-not \( -path ./lib -prune \) \
|
||||
-name *.c -o -name *.h -o -name *.cpp)
|
||||
|
||||
ulimit -s 65536
|
||||
$CLANG_FORMAT_BIN --verbose -style=file -n --Werror --ferror-limit=0 $C_FILES
|
||||
c_syntax_rc=$?
|
||||
|
||||
echo "RUN RUST SYNTAX CHECK"
|
||||
cd $PROJECT_DIR/core-rs && cargo fmt -- --check
|
||||
rust_syntax_rc=$?
|
||||
|
||||
if [[ $rust_syntax_rc -eq 0 ]] && [[ $c_syntax_rc -eq 0 ]]; then
|
||||
echo "Code looks fine for me!"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
read -p "Do you want fix syntax? (y/n): " confirm && [[ $confirm == [yY] || $confirm == [yY][eE][sS] ]] || exit 1
|
||||
|
||||
cd $PROJECT_DIR/core-rs && cargo fmt --
|
||||
|
||||
cd $PROJECT_DIR
|
||||
|
||||
# We use root in container and clang-format rewriting files. We'll need change owner to original
|
||||
local_user=$(stat -c '%u' .clang-format)
|
||||
$CLANG_FORMAT_BIN -style=file -i $C_FILES
|
||||
chown $local_user $C_FILES
|
Reference in New Issue
Block a user