-
Notifications
You must be signed in to change notification settings - Fork 21
109 lines (87 loc) · 2.71 KB
/
lint.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
# Copyright (c) 2024 Zero ASIC Corporation
# This code is licensed under Apache License 2.0 (see LICENSE for details)
# modified from https://github.com/siliconcompiler/siliconcompiler/blob/main/.github/workflows/lint.yml
name: Lint
on:
pull_request:
workflow_dispatch:
push:
branches:
- main
jobs:
lint_python:
name: Lint Python Code
strategy:
fail-fast: false
matrix:
version:
- {python: "3.11", os: "ubuntu-latest"}
runs-on: ${{ matrix.version.os }}
timeout-minutes: 5
steps:
- name: Check out Git repository
uses: actions/checkout@v4
- name: Set up Python ${{ matrix.version.python }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.version.python }}
- name: Install Requirements
run: python3 -m pip install flake8
- name: Lint with Flake8
run: flake8 --statistics .
lint_verilog:
name: Lint Verilog Code
runs-on: ubuntu-latest
container:
image: ghcr.io/zeroasiccorp/sbtest:latest
timeout-minutes: 5
steps:
- name: Check out Git repository
uses: actions/checkout@v4
# note that "sb_loopback.v" is not included in linting. verible doesn't
# seem to be able to take into account the macro definitions in the port
# list, so linting unfortunately needs to be disabled for that file.
- name: Lint with Verible
run: |
find . \( \
-name "*.v" \
-or -name "*.sv" \
-or -name "*.vh" \
-or -name "*.svh" \
\) -not \( \
-path "./switchboard/deps/*" \
-or -path "./examples/deps/*" \
-or -name "axil_interconnect_wrap_1x2.v" \
-or -name "picorv32.v" \
-or -name "sb_loopback.v" \
\) > files.txt
cat files.txt
verible-verilog-lint \
--rules_config verible_lint.txt \
`cat files.txt`
lint_cc:
name: Lint C/C++ Code Style
runs-on: ubuntu-latest
timeout-minutes: 5
steps:
- name: Install clang-format
run: |
sudo apt-get update
sudo apt-get install -y clang-format-14
- name: Check out Git repository
uses: actions/checkout@v4
- name: Gather files
run: |
find . \( \
-name "*.c" \
-or -name "*.cc" \
-or -name "*.h" \
-or -name "*.hpp" \
\) -not \( \
-path "./switchboard/deps/*" \
-or -path "./examples/deps/*" \
\) > files.txt
cat files.txt
- name: Lint with clang-format
run: |
clang-format-14 --dry-run -Werror `cat files.txt`