108 lines
3.6 KiB
YAML
108 lines
3.6 KiB
YAML
# For most projects, this workflow file will not need changing; you simply need
|
|
# to commit it to your repository.
|
|
#
|
|
# You may wish to alter this file to override the set of languages analyzed,
|
|
# or to provide custom queries or build logic.
|
|
#
|
|
# ******** NOTE ********
|
|
# We have attempted to detect the languages in your repository. Please check
|
|
# the `language` matrix defined below to confirm you have the correct set of
|
|
# supported CodeQL languages.
|
|
#
|
|
name: "CodeQL"
|
|
|
|
on:
|
|
push:
|
|
branches: [ main ]
|
|
pull_request:
|
|
# The branches below must be a subset of the branches above
|
|
branches: [ main ]
|
|
schedule:
|
|
- cron: '19 14 * * 2'
|
|
|
|
env:
|
|
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
|
|
BUILD_TYPE: Debug
|
|
EXECUTABLE_OUTPUT_PATH: ./
|
|
|
|
jobs:
|
|
analyze:
|
|
name: Analyze
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
actions: read
|
|
contents: read
|
|
security-events: write
|
|
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
language: [ 'cpp' ]
|
|
# CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python' ]
|
|
# Learn more:
|
|
# https://docs.github.com/en/free-pro-team@latest/github/finding-security-vulnerabilities-and-errors-in-your-code/configuring-code-scanning#changing-the-languages-that-are-analyzed
|
|
|
|
steps:
|
|
- name: Checkout repository
|
|
uses: actions/checkout@v3
|
|
with:
|
|
lfs: 'false'
|
|
submodules: recursive
|
|
|
|
# Initializes the CodeQL tools for scanning.
|
|
- name: Initialize CodeQL
|
|
uses: github/codeql-action/init@v1
|
|
with:
|
|
languages: ${{ matrix.language }}
|
|
# If you wish to specify custom queries, you can do so here or in a config file.
|
|
# By default, queries listed here will override any specified in a config file.
|
|
# Prefix the list here with "+" to use these queries and those in the config file.
|
|
# queries: ./path/to/local/query, your-org/your-repo/queries@main
|
|
|
|
- name: Install Dependence
|
|
run: |
|
|
sudo apt-get update
|
|
sudo apt-get -y install build-essential binutils git autoconf automake gettext texinfo
|
|
sudo apt-get -y install gcc g++ ninja-build
|
|
sudo apt-get -y install libarchive-dev libconfig++-dev libboost-all-dev
|
|
sudo apt-get -y install gpg
|
|
|
|
- name: Build gpg-error (Linux)
|
|
run: |
|
|
cd ${{github.workspace}}/third_party/libgpg-error
|
|
./autogen.sh
|
|
./configure --enable-maintainer-mode && make -j2
|
|
sudo make install
|
|
cd ${{github.workspace}}
|
|
|
|
- name: Build assuan (Linux)
|
|
run: |
|
|
cd ${{github.workspace}}/third_party/libassuan
|
|
./autogen.sh
|
|
./configure --enable-maintainer-mode && make -j2
|
|
sudo make install
|
|
cd ${{github.workspace}}
|
|
|
|
- name: Build GpgME (Linux)
|
|
run: |
|
|
cd ${{github.workspace}}/third_party/gpgme
|
|
./autogen.sh
|
|
./configure --enable-maintainer-mode --enable-languages=cpp && make -j2
|
|
sudo make install
|
|
cd ${{github.workspace}}
|
|
|
|
- name: Install Qt
|
|
uses: jurplel/install-qt-action@v3
|
|
with:
|
|
version: '6.4.3'
|
|
cache: 'true'
|
|
modules: 'qt5compat'
|
|
|
|
- name: Configure CMake && Build GpgFrontend
|
|
run: |
|
|
cmake -G Ninja -B ${{github.workspace}}/build -DCMAKE_BUILD_TYPE=${{env.BUILD_TYPE}} -DGPGFRONTEND_BUILD_TYPE_TEST_UI=ON
|
|
cmake --build ${{github.workspace}}/build --config {{$env.BUILD_TYPE}} -- -v
|
|
|
|
- name: Perform CodeQL Analysis
|
|
uses: github/codeql-action/analyze@v2
|