Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Dev #18

Merged
merged 99 commits into from
Jun 28, 2024
Merged

Dev #18

Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
99 commits
Select commit Hold shift + click to select a range
3c489c3
Update the duplicate finder
dr8co May 10, 2024
5ee4826
Ignore ide config files
dr8co May 10, 2024
f3e5b42
Improve the performance of the encryption module
dr8co May 10, 2024
4da6d3d
Refactor the file shredder
dr8co May 10, 2024
b6d2bb2
Improve the password manager performance
dr8co May 10, 2024
20a5a21
Update the GitHub flow configuration
dr8co May 17, 2024
67520e5
Configure the colored output options
dr8co May 19, 2024
7d23a5a
Update CMake and CPack configurations
dr8co May 19, 2024
828eaeb
Update the CI
dr8co May 19, 2024
1a53632
Update GitHub workflow configuration
dr8co May 21, 2024
96885bc
Update GitHub workflow configuration
dr8co May 21, 2024
5556b7c
Refactor color printing
dr8co May 26, 2024
cb6c6e8
Bugfix: Fix linker errors due to template instantiation issues
dr8co May 26, 2024
031d09b
Refactor: Update color printing and output formatting
dr8co May 26, 2024
8466504
Update IDE configuration
dr8co May 26, 2024
351c929
Bugfix: failure in encryption/decryption of files
dr8co May 27, 2024
0da0a1f
Delay throwing of errors during hashing
dr8co May 27, 2024
8a85c62
Refactor code for style
dr8co May 28, 2024
081f715
Update the build scripts
dr8co May 30, 2024
2e71db3
Fix a typo in the CMake config
dr8co May 30, 2024
098a2d4
Update GitHub workflow config
dr8co May 30, 2024
80cb5c2
Figure out homebrew directories
dr8co May 30, 2024
eb93665
Disable restarting of services after an update
dr8co May 30, 2024
790a304
Fix Ninja installation
dr8co May 30, 2024
b62034d
Update `Readline` search paths
dr8co May 30, 2024
773fb68
Fix Ninja extraction
dr8co May 30, 2024
512cd40
Fix Ninja extraction
dr8co May 30, 2024
c9d0cc9
Xcode does not support C++ modules yet
dr8co May 30, 2024
92cc0c5
Update Readline search directories
dr8co May 30, 2024
68579fe
Update Readline search directories
dr8co May 30, 2024
4548b97
Update Readline search directories
dr8co May 30, 2024
f486480
Fix issues finding gcrypt
dr8co May 30, 2024
8928469
Check configurations
dr8co May 31, 2024
dc68a7e
Check configurations
dr8co May 31, 2024
22ebabe
Check configurations
dr8co May 31, 2024
f5c0e33
Check configurations
dr8co May 31, 2024
0d8ddf4
Check configurations
dr8co May 31, 2024
37a61b0
Try using libc++
dr8co May 31, 2024
ba1d48d
Try using libc++
dr8co May 31, 2024
6f6e1b9
Try using libc++
dr8co May 31, 2024
9d03aae
Try using libc++
dr8co May 31, 2024
7f8ebce
Try using gcc instead of clang
dr8co May 31, 2024
640ca7a
Running out of patience
dr8co May 31, 2024
13861f5
Running out of patience
dr8co May 31, 2024
90b5f5b
Reconfigure libstdc++
dr8co May 31, 2024
befad4b
Reconfigure libstdc++
dr8co May 31, 2024
c7bd9e7
Reconfigure libstdc++
dr8co May 31, 2024
f90aa5e
Install gcc from source
dr8co May 31, 2024
17208c4
Fix gcc-15 paths
dr8co May 31, 2024
6beacfe
Fix gcc-15 paths
dr8co May 31, 2024
066a5d7
Fix gcc-15 paths
dr8co May 31, 2024
22d8f9b
Revert to gcc 14
dr8co May 31, 2024
19aa746
Try different settings
dr8co May 31, 2024
b4ab72a
Find essential locations
dr8co May 31, 2024
c002424
Clean the GitHub workflow config
dr8co May 31, 2024
78604ca
Refactor code
dr8co Jun 3, 2024
b4ac003
Refactor scripts
dr8co Jun 3, 2024
825d7c0
Refactor CMake config
dr8co Jun 5, 2024
733953e
Refactor CMake config
dr8co Jun 5, 2024
6ef7b80
Refactor build scripts
dr8co Jun 5, 2024
cad180a
Configure Qodana code analysis
dr8co Jun 5, 2024
d025f7f
GitHub actions 'checkout' version update
dr8co Jun 5, 2024
48559ea
Install wget
dr8co Jun 5, 2024
8dbc4e5
Grant write permissions to qodana
dr8co Jun 5, 2024
f84c665
Merge dependency installation steps
dr8co Jun 5, 2024
9e85138
Update gcc path on macOS
dr8co Jun 5, 2024
a4e5d21
Install Qodana dependencies
dr8co Jun 5, 2024
61596a1
Install Qodana dependencies
dr8co Jun 5, 2024
71110cb
Install Qodana dependencies
dr8co Jun 6, 2024
8ff62db
Build gcc-14
dr8co Jun 6, 2024
518746c
Cancel the Qodana action
dr8co Jun 12, 2024
4869059
Separate testing and packaging in GitHub Actions
dr8co Jun 12, 2024
0b5ee89
Remove unused linker command-line argument
dr8co Jun 12, 2024
3648252
Refactor compile and link flags
dr8co Jun 12, 2024
7d79b83
Refactor compile and link flags
dr8co Jun 12, 2024
97d7bab
Refactor GitHub Actions
dr8co Jun 12, 2024
50208c5
Use daanx/isocline in place of readline
dr8co Jun 13, 2024
8c7cd08
Refactor utility functions
dr8co Jun 13, 2024
dfa83d9
Update documentation
dr8co Jun 13, 2024
badf82c
Avoid Readline installation on GitHub Actions
dr8co Jun 13, 2024
0c11911
Dynamically set up gcc and libstdc++ on macOS
dr8co Jun 14, 2024
f8704b5
CI env bug fix
dr8co Jun 14, 2024
5db7950
CI env bug fix
dr8co Jun 14, 2024
69b8f78
CI env bug fix
dr8co Jun 14, 2024
6c66717
Packaging ci env bug fix
dr8co Jun 14, 2024
97892af
Use mimalloc as the main memory allocator
dr8co Jun 16, 2024
863a6ed
Bugfix: overriding malloc
dr8co Jun 16, 2024
69ef495
Handle Ctrl+C/D during input
dr8co Jun 17, 2024
387f11e
Refactor the file deduplicator algorithm
dr8co Jun 24, 2024
60063c2
Refactor CMakeLists.txt
dr8co Jun 25, 2024
b5d9e4e
More mimalloc integration
dr8co Jun 25, 2024
9c36916
Fix compilation errors on macOS
dr8co Jun 27, 2024
6e57ad9
Update documentation
dr8co Jun 27, 2024
f9c927a
Update documentation assets
dr8co Jun 27, 2024
d93c4f7
Make CMake the official build system
dr8co Jun 27, 2024
7814883
Refactor code
dr8co Jun 27, 2024
52d7a4a
Add verification info
dr8co Jun 28, 2024
cc1e59b
Update security info
dr8co Jun 28, 2024
f41889a
Version 3.0.0 release
dr8co Jun 28, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 25 additions & 0 deletions .github/cancelled_workflows/qodana_code_quality.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
name: Qodana
on:
workflow_dispatch:
pull_request:
push:
branches:
- dev
- main

jobs:
qodana:
runs-on: ubuntu-24.04
permissions:
contents: write
pull-requests: write
checks: write
steps:
- uses: actions/checkout@v4
with:
ref: ${{ github.event.pull_request.head.sha }}
fetch-depth: 0
- name: 'Qodana Scan'
uses: JetBrains/[email protected]
env:
QODANA_TOKEN: ${{ secrets.QODANA_TOKEN }}
149 changes: 38 additions & 111 deletions .github/workflows/cmake-multi-platform.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,158 +3,85 @@ name: CMake Build
on:
push:
branches: [ "main", "dev" ]
pull_request:
branches: [ "main" ]

jobs:
build:
runs-on: ${{ matrix.os }}
env:
GCC_MAJOR: 14

strategy:
fail-fast: false

matrix:
os: [ ubuntu-latest, macos-13 ]
build_type: [ Debug, Release ]
os: [ ubuntu-24.04, macos-latest ]
build_type: [ Debug ]
c_compiler: [ clang ]
include:
- os: macos-13
- os: macos-latest
c_compiler: clang
cpp_compiler: clang++
env:
LDFLAGS=: "-L/usr/local/opt/llvm/lib -Wl,-rpath,/usr/local/opt/llvm/lib"
CPPFLAGS: "-I/usr/local/opt/llvm/include I/usr/local/opt/llvm/include/c++/v1"
LD_LIBRARY_PATH: "/usr/local/opt/llvm/lib"
DYLD_LIBRARY_PATH: "/usr/local/opt/llvm/lib"
cpp_compiler: clang++-18

# - os: macos-13
# c_compiler: gcc
# cpp_compiler: g++-13
#
# - os: ubuntu-latest
# c_compiler: gcc
# cpp_compiler: g++-13

- os: ubuntu-latest
- os: ubuntu-24.04
c_compiler: clang
cpp_compiler: clang++-17

# Don't include the following configurations in the matrix
exclude:
- os: macos-13
build_type: Debug
cpp_compiler: clang++-18

steps:
# Install dependencies: cmake, ninja, gcc, libgcrypt, openssl, readline, and libsodium
- name: Install Dependencies
if: matrix.os == 'macos-13'
if: matrix.os == 'macos-latest'
run: |
export HOMEBREW_NO_INSTALLED_DEPENDENTS_CHECK=TRUE
brew update
brew install llvm cmake ninja gcc libgcrypt openssl@3 readline libsodium
echo 'export PATH="/usr/local/opt/llvm/bin:$PATH"' >> ~/.bash_profile
echo 'export PATH="/usr/local/opt/gcc@13/bin:$PATH"' >> ~/.bash_profile
echo 'export PATH="/usr/local/opt/gcc@13/lib/gcc/13:$PATH"' >> ~/.bash_profile

# - name: Install Dependencies
# if: matrix.os == 'ubuntu-latest'
# run: |
# wget -qO- https://apt.llvm.org/llvm-snapshot.gpg.key | sudo tee /etc/apt/trusted.gpg.d/apt.llvm.org.asc
# sudo add-apt-repository -y "deb http://apt.llvm.org/jammy/ llvm-toolchain-jammy-17 main"
# sudo add-apt-repository -y ppa:ubuntu-toolchain-r/ppa
# sudo apt update
# sudo apt install -y cmake ninja-build gcc-13 g++-13 clang-17 lldb-17 lld-17 libc++-17-dev libc++abi-17-dev \
# libomp-17-dev libgcrypt20 openssl libreadline8 libsodium23 libsodium-dev

brew install ninja cmake git gcc@${{ env.GCC_MAJOR }}
brew reinstall llvm
echo 'export PATH="/opt/homebrew/opt/llvm/bin:$PATH"' >> ~/.bash_profile
echo 'export PATH="/opt/homebrew/opt/gcc/bin:$PATH"' >> ~/.bash_profile
echo 'export PATH="/opt/homebrew/opt/gcc/lib/gcc/${{ env.GCC_MAJOR }}:$PATH"' >> ~/.bash_profile
. ~/.bash_profile

- uses: actions/checkout@v4

- name: Set reusable strings
id: strings
shell: bash
working-directory: ${{ github.workspace }}
run: |
echo "build-output-dir=${{ github.workspace }}/build" >> "$GITHUB_OUTPUT"

# Build project
# Set the paths to the GCC include and lib directories on macOS
if [ "${{ matrix.os }}" == "macos-latest" ]; then
echo "gcc-include-dir=$(./scripts/search.sh "/opt/homebrew/Cellar/gcc/${{ env.GCC_MAJOR }}*/include/c++/${{ env.GCC_MAJOR }}")" >> "$GITHUB_OUTPUT"
echo "gcc-sys-include-dir=$(./scripts/search.sh "/opt/homebrew/Cellar/gcc/${{ env.GCC_MAJOR }}*/include/c++/${{ env.GCC_MAJOR }}/*-apple-darwin*")" >> "$GITHUB_OUTPUT"
echo "gcc-lib-dir=$(./scripts/search.sh "/opt/homebrew/Cellar/gcc/${{ env.GCC_MAJOR }}*/lib/gcc/current")" >> "$GITHUB_OUTPUT"
fi

# Build the project
- name: Build PrivacyShield
if: matrix.os == 'ubuntu-latest'
if: matrix.os == 'ubuntu-24.04'
run: |
sudo ./scripts/buildscript.sh
# OS=${{ matrix.os }}
# COMMAND="./scripts/install-blake3.sh ${{ matrix.c_compiler }}"
# if [ "$OS" == "macos-13" ]; then
# $COMMAND
# elif [ "$OS" == "ubuntu-latest" ]; then
# sudo $COMMAND
# fi
#
sudo ./scripts/build.sh

- name: Install Blake3
if: matrix.os == 'macos-13'
if: matrix.os == 'macos-latest'
run: |
./scripts/install-blake3.sh ${{ matrix.c_compiler }}
sudo ./scripts/install-blake3.sh ${{ matrix.c_compiler }}

- name: Configure CMake
if: matrix.os == 'macos-13'
if: matrix.os == 'macos-latest'
run: >
export LDFLAGS="-L/usr/local/opt/gcc@13/lib/gcc/13 -Wl,-rpath,/usr/local/opt/gcc@13/lib/gcc/13";
export CPPFLAGS="-I/usr/local/opt/gcc@13/include/c++/13 -I/usr/local/opt/gcc@13/include/c++/13/x86_64-apple-darwin22";
export LD_LIBRARY_PATH="/usr/local/opt/gcc@13/lib/gcc/13";
export DYLD_LIBRARY_PATH="/usr/local/opt/gcc@13/lib/gcc/13";

cmake -B ${{ steps.strings.outputs.build-output-dir }}
-DCMAKE_CXX_COMPILER=/usr/local/opt/llvm/bin/clang++
-DCMAKE_C_COMPILER=/usr/local/opt/llvm/bin/clang
-DCMAKE_CXX_FLAGS="-I/usr/local/opt/gcc@13/include/c++/13 -I/usr/local/opt/gcc@13/include/c++/13/x86_64-apple-darwin22 -L/usr/local/opt/gcc@13/lib/gcc/13 -Wl,-rpath,/usr/local/opt/gcc@13/lib/gcc/13 -stdlib=libstdc++"
-DCMAKE_CXX_COMPILER=/opt/homebrew/opt/llvm/bin/clang++
-DCMAKE_C_COMPILER=/opt/homebrew/opt/llvm/bin/clang
-DCMAKE_CXX_FLAGS="-stdlib++-isystem ${{ steps.strings.outputs.gcc-include-dir }} -cxx-isystem ${{ steps.strings.outputs.gcc-sys-include-dir }}"
-DCMAKE_EXE_LINKER_FLAGS="-stdlib=libstdc++ -L ${{ steps.strings.outputs.gcc-lib-dir }} -Wl,-rpath,/opt/homebrew/opt/gcc/lib/gcc/current"
-DCMAKE_BUILD_TYPE=${{ matrix.build_type }}
-S ${{ github.workspace }} -G Ninja
# -DCMAKE_CXX_FLAGS="-stdlib=libstdc++ -stdlib++-isystem /opt/homebrew/Cellar/gcc/14.1.0_1/include/c++/14 -cxx-isystem /opt/homebrew/Cellar/gcc/14.1.0_1/include/c++/14/aarch64-apple-darwin23 -L /opt/homebrew/Cellar/gcc/14.1.0_1/lib/gcc/14 -Wl,-rpath,/opt/homebrew/opt/gcc/lib/gcc/current"

- name: Build
if: matrix.os == 'macos-13'
if: matrix.os == 'macos-latest'
run: cmake --build ${{ steps.strings.outputs.build-output-dir }} --config ${{ matrix.build_type }} -j 4
#
# - name: Test
# working-directory: ${{ steps.strings.outputs.build-output-dir }}
# # Execute tests defined by the CMake configuration
# run: ctest --build-config ${{ matrix.build_type }}
#
- name: Package
if: matrix.os == 'macos-13' && matrix.build_type == 'Release'
working-directory: ${{ steps.strings.outputs.build-output-dir }}
run: |
cpack -G DragNDrop

- name: Package
if: matrix.os == 'ubuntu-latest' && matrix.build_type == 'Release'
# Run Tests
- name: Test
working-directory: ${{ steps.strings.outputs.build-output-dir }}
run: |
sudo cpack
sudo chown -R $USER:$USER "${{ github.workspace }}/Packages"

- name: Import GPG Key
if: matrix.build_type == 'Release'
uses: crazy-max/ghaction-import-gpg@v6
with:
gpg_private_key: ${{ secrets.GPG_SIGNING_KEY }}
passphrase: ${{ secrets.GPG_PASS }}
trust_level: 5

- name: Sign Package
if: matrix.build_type == 'Release'
working-directory: ${{ github.workspace }}
run: |
for file in Packages/*; do
gpg --batch --status-file ~/gpg_log.txt --passphrase ${{ secrets.GPG_PASS }} --default-key [email protected] \
--pinentry-mode=loopback --detach-sign "$file" || (cat ~/gpg_log.txt && exit 1)
done
#
# # Upload the built artifacts
- name: Upload Artifacts
if: matrix.build_type == 'Release'
uses: actions/upload-artifact@v4
with:
name: "${{ matrix.os }}-${{ matrix.build_type }}"
path: "${{ github.workspace }}/Packages"
overwrite: true
if-no-files-found: 'warn'

run: ctest -j 4
121 changes: 121 additions & 0 deletions .github/workflows/cpack-multi-platform.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@
name: CPack Multi-Platform

on:
pull_request:
branches: [ "main" ]

jobs:
build_then_package:
runs-on: ${{ matrix.os }}
env:
GCC_MAJOR: 14

strategy:
fail-fast: false

matrix:
os: [ ubuntu-24.04, macos-latest ]
build_type: [ Release ]
c_compiler: [ clang ]
include:
- os: macos-latest
c_compiler: clang
cpp_compiler: clang++-18

- os: ubuntu-24.04
c_compiler: clang
cpp_compiler: clang++-18

steps:
- name: Install Dependencies
if: matrix.os == 'macos-latest'
run: |
export HOMEBREW_NO_INSTALLED_DEPENDENTS_CHECK=TRUE
brew update
brew install ninja cmake git gcc@${{ env.GCC_MAJOR }}
brew reinstall llvm
echo 'export PATH="/opt/homebrew/opt/llvm/bin:$PATH"' >> ~/.bash_profile
echo 'export PATH="/opt/homebrew/opt/gcc/bin:$PATH"' >> ~/.bash_profile
echo 'export PATH="/opt/homebrew/opt/gcc/lib/gcc/${{ env.GCC_MAJOR }}:$PATH"' >> ~/.bash_profile
. ~/.bash_profile

- uses: actions/checkout@v4

- name: Set reusable strings
id: strings
shell: bash
working-directory: ${{ github.workspace }}
run: |
echo "build-output-dir=${{ github.workspace }}/build" >> "$GITHUB_OUTPUT"
# Set the paths to the GCC include and lib directories on macOS
if [ "${{ matrix.os }}" == "macos-latest" ]; then
echo "gcc-include-dir=$(./scripts/search.sh "/opt/homebrew/Cellar/gcc/*/include/c++/${{ env.GCC_MAJOR }}")" >> "$GITHUB_OUTPUT"
echo "gcc-sys-include-dir=$(./scripts/search.sh "/opt/homebrew/Cellar/gcc/*/include/c++/${{ env.GCC_MAJOR }}/*-apple-darwin*")" >> "$GITHUB_OUTPUT"
echo "gcc-lib-dir=$(./scripts/search.sh "/opt/homebrew/Cellar/gcc/${{ env.GCC_MAJOR }}*/lib/gcc/current")" >> "$GITHUB_OUTPUT"
fi

# Build the project
- name: Build PrivacyShield
if: matrix.os == 'ubuntu-24.04'
run: |
sudo ./scripts/build.sh

- name: Install Blake3
if: matrix.os == 'macos-latest'
run: |
sudo ./scripts/install-blake3.sh ${{ matrix.c_compiler }}

- name: Configure CMake
if: matrix.os == 'macos-latest'
run: >
cmake -B ${{ steps.strings.outputs.build-output-dir }}
-DCMAKE_CXX_COMPILER=/opt/homebrew/opt/llvm/bin/clang++
-DCMAKE_C_COMPILER=/opt/homebrew/opt/llvm/bin/clang
-DCMAKE_CXX_FLAGS="-stdlib++-isystem ${{ steps.strings.outputs.gcc-include-dir }} -cxx-isystem ${{ steps.strings.outputs.gcc-sys-include-dir }}"
-DCMAKE_EXE_LINKER_FLAGS="-stdlib=libstdc++ -L ${{ steps.strings.outputs.gcc-lib-dir }} -Wl,-rpath,/opt/homebrew/opt/gcc/lib/gcc/current"
-DCMAKE_BUILD_TYPE=${{ matrix.build_type }}
-S ${{ github.workspace }} -G Ninja

- name: Build
if: matrix.os == 'macos-latest'
run: cmake --build ${{ steps.strings.outputs.build-output-dir }} --config ${{ matrix.build_type }} -j 4

- name: Package
if: matrix.os == 'macos-latest' && matrix.build_type == 'Release'
working-directory: ${{ steps.strings.outputs.build-output-dir }}
run: |
cpack

- name: Package
if: matrix.os == 'ubuntu-24.04' && matrix.build_type == 'Release'
working-directory: ${{ steps.strings.outputs.build-output-dir }}
run: |
sudo cpack
sudo chown -R $USER:$USER "${{ github.workspace }}/Packages"

- name: Import GPG Key
if: matrix.build_type == 'Release'
uses: crazy-max/ghaction-import-gpg@v6
with:
gpg_private_key: ${{ secrets.GPG_SIGNING_KEY }}
passphrase: ${{ secrets.GPG_PASS }}
trust_level: 5

- name: Sign Package
if: matrix.build_type == 'Release'
working-directory: ${{ github.workspace }}
run: |
for file in Packages/*; do
gpg --batch --status-file ~/gpg_log.txt --passphrase ${{ secrets.GPG_PASS }} --default-key [email protected] \
--pinentry-mode=loopback --detach-sign "$file" || (cat ~/gpg_log.txt && exit 1)
done

# Upload the built artifacts
- name: Upload Artifacts
if: matrix.build_type == 'Release'
uses: actions/upload-artifact@v4
with:
name: "${{ matrix.os }}-${{ matrix.build_type }}"
path: "${{ github.workspace }}/Packages"
overwrite: true
if-no-files-found: 'warn'
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@
# .idea/modules
# *.iml
# *.ipr
.idea/**/*copilot*

# CMake
cmake-build-*/
Expand Down
3 changes: 3 additions & 0 deletions .idea/misc.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading
Loading