Compare commits
40 Commits
Author | SHA1 | Date |
---|---|---|
tastytea | 733aad9903 | |
tastytea | 3a8b8c715a | |
tastytea | b19e8b233a | |
tastytea | bc6444747d | |
tastytea | ea9755bf9a | |
tastytea | 774c1685af | |
tastytea | 9067b9dc91 | |
tastytea | 11b88aaf3d | |
tastytea | 231f8ee1bb | |
tastytea | 788d56f98e | |
tastytea | bd33509e7a | |
tastytea | 3711f30f3b | |
tastytea | 69177d5dda | |
tastytea | dc33ae0a54 | |
tastytea | 032dc9f644 | |
tastytea | 1bb26d9c33 | |
tastytea | 3ab52e1b9e | |
tastytea | 58a79b0681 | |
tastytea | fac5bd700a | |
tastytea | 3ed5d3ce0d | |
tastytea | 449651e94f | |
tastytea | 59466c5f9e | |
tastytea | 229c3f6645 | |
tastytea | 2acd37bcce | |
tastytea | ccf31d072e | |
tastytea | daefd245f0 | |
tastytea | 8a5aa60d66 | |
tastytea | 1a99bf1ded | |
tastytea | fd951ed502 | |
tastytea | d9065280ea | |
tastytea | 0fdaad70ee | |
tastytea | 0f13bc8d9b | |
tastytea | 75dc40406c | |
tastytea | 54919796d7 | |
tastytea | 165e9039a7 | |
tastytea | f29e180092 | |
tastytea | 64ab212a1f | |
tastytea | eab650d6dd | |
tastytea | dd83e11338 | |
tastytea | 89eef7247a |
404
.drone.yml
404
.drone.yml
|
@ -1,185 +1,223 @@
|
|||
pipeline:
|
||||
gcc6:
|
||||
image: ubuntu:xenial
|
||||
pull: true
|
||||
environment:
|
||||
- LANG=C.utf8
|
||||
- CXX=g++-6
|
||||
- CXXFLAGS=-pipe -O2
|
||||
commands:
|
||||
- rm /etc/apt/apt.conf.d/docker-clean
|
||||
- echo "deb http://ppa.launchpad.net/ubuntu-toolchain-r/test/ubuntu xenial main" >> /etc/apt/sources.list.d/ubuntu-toolchain-r.list
|
||||
- gpg --keyserver hkp://keyserver.ubuntu.com --recv-keys 0x60c317803a41ba51845e371a1e9377a2ba9ef27f
|
||||
- gpg --armor --export 0x60c317803a41ba51845e371a1e9377a2ba9ef27f | apt-key add -
|
||||
- apt-get update -q
|
||||
- apt-get install -qy g++-6 cmake pkg-config
|
||||
- apt-get install -qy libvsqlitepp-dev libboost-dev libxdg-basedir-dev qt5-default qttools5-dev-tools qttools5-dev libconfig++-dev
|
||||
- apt-get install -qy dpkg-dev rpm file wget
|
||||
- gpg --import /var/autosign_gpg.key
|
||||
- rm -rf build && mkdir -p build && cd build
|
||||
- cmake -DCMAKE_INSTALL_PREFIX=/usr ..
|
||||
- make VERBOSE=1
|
||||
- make install DESTDIR=install
|
||||
- make package
|
||||
- cmake -DWITH_DEB=ON ..
|
||||
- make package
|
||||
- cmake -DWITH_DEB=OFF -DWITH_RPM=ON ..
|
||||
- make package
|
||||
- gpg --verbose --detach-sign *.tar.gz
|
||||
- gpg --verbose --detach-sign *.deb
|
||||
- gpg --verbose --detach-sign *.rpm
|
||||
volumes:
|
||||
- /var/cache/debian-package-cache:/var/cache/apt/archives
|
||||
- /home/tastytea/misc/autosign_gpg.key:/var/autosign_gpg.key
|
||||
kind: pipeline
|
||||
name: build x86_64
|
||||
|
||||
gcc7:
|
||||
image: debian:stretch-slim
|
||||
pull: true
|
||||
when:
|
||||
event: [push, pull_request]
|
||||
environment:
|
||||
- LANG=C.utf8
|
||||
- CXX=g++-7
|
||||
- CXXFLAGS=-pipe -O2
|
||||
commands:
|
||||
- rm /etc/apt/apt.conf.d/docker-clean
|
||||
- apt-get update -q
|
||||
- echo "APT::Default-Release \"stretch\";" >> /etc/apt/apt.conf.d/00default_release
|
||||
- echo "deb http://deb.debian.org/debian stretch-backports main" >> /etc/apt/sources.list.d/backports.list
|
||||
- echo "deb http://ppa.launchpad.net/ubuntu-toolchain-r/test/ubuntu xenial main" >> /etc/apt/sources.list.d/ubuntu-toolchain-r.list
|
||||
- apt-get install -qy gnupg
|
||||
- gpg --keyserver hkp://keyserver.ubuntu.com --recv-keys 0x60c317803a41ba51845e371a1e9377a2ba9ef27f
|
||||
- gpg --armor --export 0x60c317803a41ba51845e371a1e9377a2ba9ef27f | apt-key add -
|
||||
- apt-get update -q
|
||||
- apt-get install -qy -t xenial g++-7
|
||||
- apt-get install -qy cmake pkg-config
|
||||
- apt-get install -qy libvsqlitepp-dev libboost-dev libxdg-basedir-dev qt5-default qttools5-dev-tools qttools5-dev libconfig++-dev
|
||||
- rm -rf build && mkdir -p build && cd build
|
||||
- cmake ..
|
||||
- make VERBOSE=1
|
||||
- make install DESTDIR=install
|
||||
volumes:
|
||||
- /var/cache/debian-package-cache:/var/cache/apt/archives
|
||||
volumes:
|
||||
- name: debian-package-cache
|
||||
host:
|
||||
path: /var/cache/debian-package-cache
|
||||
|
||||
gcc8:
|
||||
image: debian:stretch-slim
|
||||
pull: true
|
||||
when:
|
||||
event: [push, pull_request]
|
||||
environment:
|
||||
- LANG=C.utf8
|
||||
- CXX=g++-8
|
||||
- CXXFLAGS=-pipe -O2
|
||||
commands:
|
||||
- rm /etc/apt/apt.conf.d/docker-clean
|
||||
- apt-get update -q
|
||||
- echo "APT::Default-Release \"stretch\";" >> /etc/apt/apt.conf.d/00default_release
|
||||
- echo "deb http://deb.debian.org/debian stretch-backports main" >> /etc/apt/sources.list.d/backports.list
|
||||
- echo "deb http://ppa.launchpad.net/ubuntu-toolchain-r/test/ubuntu xenial main" >> /etc/apt/sources.list.d/ubuntu-toolchain-r.list
|
||||
- apt-get install -qy gnupg
|
||||
- gpg --keyserver hkp://keyserver.ubuntu.com --recv-keys 0x60c317803a41ba51845e371a1e9377a2ba9ef27f
|
||||
- gpg --armor --export 0x60c317803a41ba51845e371a1e9377a2ba9ef27f | apt-key add -
|
||||
- apt-get update -q
|
||||
- apt-get install -qy -t xenial g++-8
|
||||
- apt-get install -qy cmake pkg-config
|
||||
- apt-get install -qy libvsqlitepp-dev libboost-dev libxdg-basedir-dev qt5-default qttools5-dev-tools qttools5-dev libconfig++-dev
|
||||
- rm -rf build && mkdir -p build && cd build
|
||||
- cmake ..
|
||||
- make VERBOSE=1
|
||||
- make install DESTDIR=install
|
||||
volumes:
|
||||
- /var/cache/debian-package-cache:/var/cache/apt/archives
|
||||
trigger:
|
||||
event:
|
||||
exclude:
|
||||
- tag
|
||||
|
||||
clang3:
|
||||
image: debian:stretch-slim
|
||||
pull: true
|
||||
when:
|
||||
event: [push, pull_request]
|
||||
environment:
|
||||
- LANG=C.utf8
|
||||
- CXX=clang++
|
||||
- CXXFLAGS=-pipe -O2
|
||||
commands:
|
||||
- rm /etc/apt/apt.conf.d/docker-clean
|
||||
- echo "APT::Default-Release \"stretch\";" >> /etc/apt/apt.conf.d/00default_release
|
||||
- echo "deb http://deb.debian.org/debian stretch-backports main" >> /etc/apt/sources.list.d/backports.list
|
||||
- apt-get update -q
|
||||
- apt-get install -qy clang cmake pkg-config
|
||||
- apt-get install -qy libvsqlitepp-dev libboost-dev libxdg-basedir-dev qt5-default qttools5-dev-tools qttools5-dev libconfig++-dev
|
||||
- rm -rf build && mkdir -p build && cd build
|
||||
- cmake ..
|
||||
- make VERBOSE=1
|
||||
- make install DESTDIR=install
|
||||
volumes:
|
||||
- /var/cache/debian-package-cache:/var/cache/apt/archives
|
||||
steps:
|
||||
- name: submodules
|
||||
image: docker:git
|
||||
commands:
|
||||
- git submodule init
|
||||
- git submodule update --recursive
|
||||
|
||||
clang5:
|
||||
image: debian:stretch-slim
|
||||
pull: true
|
||||
when:
|
||||
event: [push, pull_request]
|
||||
environment:
|
||||
- LANG=C.utf8
|
||||
- CXX=clang++-5.0
|
||||
- CXXFLAGS=-pipe -O2
|
||||
commands:
|
||||
- rm /etc/apt/apt.conf.d/docker-clean
|
||||
- echo "APT::Default-Release \"stretch\";" >> /etc/apt/apt.conf.d/00default_release
|
||||
- echo "deb http://deb.debian.org/debian stretch-backports main" >> /etc/apt/sources.list.d/stretch.list
|
||||
- apt-get update -q
|
||||
- apt-get install -qy -t stretch-backports clang-5.0
|
||||
- apt-get install -qy cmake pkg-config
|
||||
- apt-get install -qy libvsqlitepp-dev libboost-dev libxdg-basedir-dev qt5-default qttools5-dev-tools qttools5-dev libconfig++-dev
|
||||
- rm -rf build && mkdir -p build && cd build
|
||||
- cmake ..
|
||||
- make VERBOSE=1
|
||||
- make install DESTDIR=install
|
||||
volumes:
|
||||
- /var/cache/debian-package-cache:/var/cache/apt/archives
|
||||
- name: gcc6
|
||||
image: ubuntu:xenial
|
||||
pull: always
|
||||
environment:
|
||||
CXX: g++-6
|
||||
CXXFLAGS: -pipe -O2
|
||||
commands:
|
||||
- rm /etc/apt/apt.conf.d/docker-clean
|
||||
- echo "deb http://ppa.launchpad.net/ubuntu-toolchain-r/test/ubuntu xenial main" >> /etc/apt/sources.list.d/ubuntu-toolchain-r.list
|
||||
- gpg --keyserver hkp://keyserver.ubuntu.com --recv-keys 0x60c317803a41ba51845e371a1e9377a2ba9ef27f
|
||||
- gpg --armor --export 0x60c317803a41ba51845e371a1e9377a2ba9ef27f | apt-key add -
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get update -q
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy g++-6 cmake pkg-config
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy libvsqlitepp-dev libboost-dev libxdg-basedir-dev qt5-default qttools5-dev-tools qttools5-dev libconfig++-dev asciidoc
|
||||
- rm -rf build && mkdir -p build && cd build
|
||||
- cmake -DCMAKE_INSTALL_PREFIX=/usr ..
|
||||
- make VERBOSE=1
|
||||
- make install DESTDIR=install
|
||||
volumes:
|
||||
- name: debian-package-cache
|
||||
path: /var/cache/apt/archives
|
||||
|
||||
clang6:
|
||||
image: debian:stretch-slim
|
||||
pull: true
|
||||
when:
|
||||
event: [push, pull_request]
|
||||
environment:
|
||||
- LANG=C.utf8
|
||||
- CXX=clang++-6.0
|
||||
- CXXFLAGS=-pipe -O2
|
||||
commands:
|
||||
- rm /etc/apt/apt.conf.d/docker-clean
|
||||
- echo "APT::Default-Release \"stretch\";" >> /etc/apt/apt.conf.d/00default_release
|
||||
- echo "deb http://deb.debian.org/debian stretch-backports main" >> /etc/apt/sources.list.d/stretch.list
|
||||
- apt-get update -q
|
||||
- apt-get install -qy -t stretch-backports clang-6.0
|
||||
- apt-get install -qy cmake pkg-config
|
||||
- apt-get install -qy libvsqlitepp-dev libboost-dev libxdg-basedir-dev qt5-default qttools5-dev-tools qttools5-dev libconfig++-dev
|
||||
- rm -rf build && mkdir -p build && cd build
|
||||
- cmake ..
|
||||
- make VERBOSE=1
|
||||
- make install DESTDIR=install
|
||||
volumes:
|
||||
- /var/cache/debian-package-cache:/var/cache/apt/archives
|
||||
- name: gcc9
|
||||
image: debian:stretch-slim
|
||||
pull: always
|
||||
environment:
|
||||
CXX: g++-9
|
||||
CXXFLAGS: -pipe -O2
|
||||
commands:
|
||||
- rm /etc/apt/apt.conf.d/docker-clean
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get update -q
|
||||
- echo "APT::Default-Release \"stretch\";" >> /etc/apt/apt.conf.d/00default_release
|
||||
- echo "deb http://deb.debian.org/debian stretch-backports main" >> /etc/apt/sources.list.d/backports.list
|
||||
- echo "deb http://ppa.launchpad.net/ubuntu-toolchain-r/test/ubuntu xenial main" >> /etc/apt/sources.list.d/ubuntu-toolchain-r.list
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy gnupg
|
||||
- gpg --keyserver hkp://keyserver.ubuntu.com --recv-keys 0x60c317803a41ba51845e371a1e9377a2ba9ef27f
|
||||
- gpg --armor --export 0x60c317803a41ba51845e371a1e9377a2ba9ef27f | apt-key add -
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get update -q
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy -t xenial g++-9
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy cmake pkg-config
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy libvsqlitepp-dev libboost-dev libxdg-basedir-dev qt5-default qttools5-dev-tools qttools5-dev libconfig++-dev asciidoc
|
||||
- rm -rf build && mkdir -p build && cd build
|
||||
- cmake ..
|
||||
- make VERBOSE=1
|
||||
- make install DESTDIR=install
|
||||
volumes:
|
||||
- name: debian-package-cache
|
||||
path: /var/cache/apt/archives
|
||||
|
||||
prepare_release:
|
||||
image: ubuntu:xenial
|
||||
pull: true
|
||||
when:
|
||||
event: tag
|
||||
commands:
|
||||
- cp -v build/whyblocked-${DRONE_TAG}_x86_64.tar.gz .
|
||||
- cp -v build/whyblocked-${DRONE_TAG}_x86_64.tar.gz.sig .
|
||||
- cp -v build/whyblocked_${DRONE_TAG}-0_amd64.deb .
|
||||
- cp -v build/whyblocked_${DRONE_TAG}-0_amd64.deb.sig .
|
||||
- cp -v build/whyblocked-${DRONE_TAG}-0.x86_64.rpm .
|
||||
- cp -v build/whyblocked-${DRONE_TAG}-0.x86_64.rpm.sig .
|
||||
gitea_release:
|
||||
image: plugins/gitea-release
|
||||
pull: true
|
||||
when:
|
||||
event: tag
|
||||
- name: clang3
|
||||
image: debian:stretch-slim
|
||||
pull: always
|
||||
environment:
|
||||
CXX: clang++
|
||||
CXXFLAGS: -pipe -O2
|
||||
commands:
|
||||
- rm /etc/apt/apt.conf.d/docker-clean
|
||||
- echo "APT::Default-Release \"stretch\";" >> /etc/apt/apt.conf.d/00default_release
|
||||
- echo "deb http://deb.debian.org/debian stretch-backports main" >> /etc/apt/sources.list.d/backports.list
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get update -q
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy clang cmake pkg-config
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy libvsqlitepp-dev libboost-dev libxdg-basedir-dev qt5-default qttools5-dev-tools qttools5-dev libconfig++-dev asciidoc
|
||||
- rm -rf build && mkdir -p build && cd build
|
||||
- cmake ..
|
||||
- make VERBOSE=1
|
||||
- make install DESTDIR=install
|
||||
volumes:
|
||||
- name: debian-package-cache
|
||||
path: /var/cache/apt/archives
|
||||
|
||||
- name: clang6
|
||||
image: debian:stretch-slim
|
||||
pull: always
|
||||
environment:
|
||||
CXX: clang++-6.0
|
||||
CXXFLAGS: -pipe -O2
|
||||
commands:
|
||||
- rm /etc/apt/apt.conf.d/docker-clean
|
||||
- echo "APT::Default-Release \"stretch\";" >> /etc/apt/apt.conf.d/00default_release
|
||||
- echo "deb http://deb.debian.org/debian stretch-backports main" >> /etc/apt/sources.list.d/stretch.list
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get update -q
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy -t stretch-backports clang-6.0
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy cmake pkg-config
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy libvsqlitepp-dev libboost-dev libxdg-basedir-dev qt5-default qttools5-dev-tools qttools5-dev libconfig++-dev asciidoc
|
||||
- rm -rf build && mkdir -p build && cd build
|
||||
- cmake ..
|
||||
- make VERBOSE=1
|
||||
- make install DESTDIR=install
|
||||
volumes:
|
||||
- name: debian-package-cache
|
||||
path: /var/cache/apt/archives
|
||||
|
||||
- name: notify
|
||||
image: drillster/drone-email
|
||||
pull: always
|
||||
settings:
|
||||
host: cryptoparty-celle.de
|
||||
username:
|
||||
from_secret: email_username
|
||||
password:
|
||||
from_secret: email_password
|
||||
from: drone@tzend.de
|
||||
when:
|
||||
status: [ changed, failure ]
|
||||
|
||||
---
|
||||
kind: pipeline
|
||||
name: packages x86_64
|
||||
|
||||
volumes:
|
||||
- name: debian-package-cache
|
||||
host:
|
||||
path: /var/cache/debian-package-cache
|
||||
- name: gpg-key
|
||||
host:
|
||||
path: /var/autosign_gpg.key
|
||||
|
||||
trigger:
|
||||
event:
|
||||
- tag
|
||||
|
||||
steps:
|
||||
- name: submodules
|
||||
image: docker:git
|
||||
commands:
|
||||
- git submodule init
|
||||
- git submodule update --recursive
|
||||
|
||||
- name: gcc6
|
||||
image: ubuntu:xenial
|
||||
pull: always
|
||||
environment:
|
||||
CXX: g++-6
|
||||
CXXFLAGS: -pipe -O2
|
||||
commands:
|
||||
- rm /etc/apt/apt.conf.d/docker-clean
|
||||
- echo "deb http://ppa.launchpad.net/ubuntu-toolchain-r/test/ubuntu xenial main" >> /etc/apt/sources.list.d/ubuntu-toolchain-r.list
|
||||
- gpg --keyserver hkp://keyserver.ubuntu.com --recv-keys 0x60c317803a41ba51845e371a1e9377a2ba9ef27f
|
||||
- gpg --armor --export 0x60c317803a41ba51845e371a1e9377a2ba9ef27f | apt-key add -
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get update -q
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy g++-6 cmake pkg-config
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy libvsqlitepp-dev libboost-dev libxdg-basedir-dev qt5-default qttools5-dev-tools qttools5-dev libconfig++-dev asciidoc
|
||||
- rm -f /var/cache/apt/archives/lock
|
||||
- apt-get install -qy dpkg-dev rpm file wget
|
||||
- gpg --import /var/autosign_gpg.key
|
||||
- rm -rf build && mkdir -p build && cd build
|
||||
- cmake -DCMAKE_INSTALL_PREFIX=/usr ..
|
||||
- make VERBOSE=1
|
||||
- make install DESTDIR=install
|
||||
- make package
|
||||
- cmake -DWITH_DEB=ON ..
|
||||
- make package
|
||||
- cmake -DWITH_DEB=OFF -DWITH_RPM=ON ..
|
||||
- make package
|
||||
- gpg --verbose --detach-sign *.tar.gz
|
||||
- gpg --verbose --detach-sign *.deb
|
||||
- gpg --verbose --detach-sign *.rpm
|
||||
volumes:
|
||||
- name: debian-package-cache
|
||||
path: /var/cache/apt/archives
|
||||
- name: gpg-key
|
||||
path: /var/autosign_gpg.key
|
||||
|
||||
- name: prepare_release
|
||||
image: ubuntu:xenial
|
||||
pull: always
|
||||
commands:
|
||||
- cp -v build/whyblocked-${DRONE_TAG}_x86_64.tar.gz .
|
||||
- cp -v build/whyblocked-${DRONE_TAG}_x86_64.tar.gz.sig .
|
||||
- cp -v build/whyblocked_${DRONE_TAG}-0_amd64.deb .
|
||||
- cp -v build/whyblocked_${DRONE_TAG}-0_amd64.deb.sig .
|
||||
- cp -v build/whyblocked-${DRONE_TAG}-0.x86_64.rpm .
|
||||
- cp -v build/whyblocked-${DRONE_TAG}-0.x86_64.rpm.sig .
|
||||
|
||||
- name: release
|
||||
image: plugins/gitea-release
|
||||
pull: always
|
||||
settings:
|
||||
base_url: https://schlomp.space
|
||||
secrets: [ gitea_token ]
|
||||
api_key:
|
||||
from_secret: gitea_token
|
||||
title: ${DRONE_TAG}
|
||||
prerelease: true
|
||||
files:
|
||||
|
@ -193,11 +231,15 @@ pipeline:
|
|||
- sha256
|
||||
- sha512
|
||||
|
||||
notify:
|
||||
image: drillster/drone-email
|
||||
pull: true
|
||||
- name: notify
|
||||
image: drillster/drone-email
|
||||
pull: always
|
||||
settings:
|
||||
host: cryptoparty-celle.de
|
||||
secrets: [ email_username, email_password ]
|
||||
username:
|
||||
from_secret: email_username
|
||||
password:
|
||||
from_secret: email_password
|
||||
from: drone@tzend.de
|
||||
when:
|
||||
status: [ changed, failure ]
|
||||
when:
|
||||
status: [ changed, failure ]
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
cmake_minimum_required (VERSION 3.2)
|
||||
project (whyblocked
|
||||
VERSION 0.12.2
|
||||
VERSION 0.15.0
|
||||
LANGUAGES CXX
|
||||
)
|
||||
|
||||
|
@ -13,16 +13,15 @@ pkg_check_modules(LIBXDG_BASEDIR REQUIRED libxdg-basedir)
|
|||
# because the sqlite3 in Debian jessie doesn't come with a pkg-config module.
|
||||
pkg_check_modules(SQLITE3 sqlite3)
|
||||
find_package(Qt5Core CONFIG REQUIRED)
|
||||
if(NOT WITHOUT_GUI)
|
||||
find_package(Qt5Widgets CONFIG REQUIRED)
|
||||
pkg_check_modules(LIBCONFIG REQUIRED libconfig++)
|
||||
endif()
|
||||
find_package(Qt5Widgets CONFIG REQUIRED)
|
||||
pkg_check_modules(LIBCONFIG REQUIRED libconfig++)
|
||||
|
||||
set(CMAKE_CXX_STANDARD 14)
|
||||
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||
set(CMAKE_CXX_EXTENSIONS OFF)
|
||||
|
||||
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -Wall -g -Og")
|
||||
set(CMAKE_CXX_FLAGS_DEBUG
|
||||
"${CMAKE_CXX_FLAGS_DEBUG} -Wpedantic -Wall -Wextra -g -Og -fno-omit-frame-pointer")
|
||||
|
||||
set(CMAKE_AUTOMOC ON)
|
||||
set(CMAKE_AUTOUIC ON)
|
||||
|
@ -42,31 +41,46 @@ configure_file (
|
|||
"${PROJECT_BINARY_DIR}/version.hpp"
|
||||
)
|
||||
|
||||
set(COMMON_LIBRARIES
|
||||
${LIBXDG_BASEDIR_LIBRARIES} vsqlitepp stdc++fs)
|
||||
add_executable(${CMAKE_PROJECT_NAME}
|
||||
src/qt/main.cpp src/qt/mainwindow.cpp src/qt/dialog_add.cpp
|
||||
src/whyblocked.cpp src/xdgcfg.cpp)
|
||||
target_link_libraries(${CMAKE_PROJECT_NAME}
|
||||
${LIBXDG_BASEDIR_LIBRARIES} vsqlitepp Qt5::Widgets
|
||||
${LIBCONFIG_LIBRARIES} stdc++fs)
|
||||
set(WITH_MAN "YES" CACHE STRING "WITH_MAN defaults to \"YES\"")
|
||||
add_custom_command(TARGET ${CMAKE_PROJECT_NAME} POST_BUILD
|
||||
WORKING_DIRECTORY "${PROJECT_BINARY_DIR}"
|
||||
COMMAND ${CMAKE_COMMAND} -E create_symlink ${CMAKE_PROJECT_NAME} whyblocked-gui)
|
||||
|
||||
add_executable(whyblocked
|
||||
src/interface_text.cpp src/whyblocked.cpp)
|
||||
target_link_libraries(whyblocked ${COMMON_LIBRARIES} Qt5::Core)
|
||||
install(TARGETS whyblocked DESTINATION ${CMAKE_INSTALL_BINDIR})
|
||||
|
||||
if(NOT WITHOUT_GUI)
|
||||
add_executable(whyblocked-gui
|
||||
src/interface_qt.cpp src/whyblocked.cpp src/xdgcfg.cpp)
|
||||
target_link_libraries(whyblocked-gui
|
||||
${COMMON_LIBRARIES} Qt5::Widgets
|
||||
${LIBCONFIG_LIBRARIES} stdc++fs)
|
||||
|
||||
install(TARGETS whyblocked-gui DESTINATION ${CMAKE_INSTALL_BINDIR})
|
||||
install(FILES de.tastytea.Whyblocked.desktop DESTINATION
|
||||
${CMAKE_INSTALL_DATAROOTDIR}/applications)
|
||||
install(FILES de.tastytea.Whyblocked.appdata.xml DESTINATION
|
||||
${CMAKE_INSTALL_DATAROOTDIR}/metainfo)
|
||||
install(FILES de.tastytea.Whyblocked.svg DESTINATION
|
||||
${CMAKE_INSTALL_DATAROOTDIR}/icons/hicolor/scalable/apps)
|
||||
if(WITH_MAN)
|
||||
add_custom_command(
|
||||
OUTPUT "${PROJECT_BINARY_DIR}/whyblocked.1"
|
||||
WORKING_DIRECTORY "${PROJECT_BINARY_DIR}"
|
||||
DEPENDS "${CMAKE_SOURCE_DIR}/whyblocked.1.adoc"
|
||||
COMMAND ${CMAKE_SOURCE_DIR}/build_manpage.sh
|
||||
ARGS ${PROJECT_VERSION})
|
||||
add_custom_target(run ALL
|
||||
DEPENDS "${PROJECT_BINARY_DIR}/whyblocked.1"
|
||||
)
|
||||
endif()
|
||||
|
||||
if(NOT WITHOUT_TRANSLATIONS)
|
||||
install(TARGETS ${CMAKE_PROJECT_NAME}
|
||||
DESTINATION ${CMAKE_INSTALL_BINDIR})
|
||||
install(FILES "${PROJECT_BINARY_DIR}/whyblocked-gui"
|
||||
DESTINATION "${CMAKE_INSTALL_BINDIR}")
|
||||
install(FILES de.tastytea.Whyblocked.desktop
|
||||
DESTINATION ${CMAKE_INSTALL_DATAROOTDIR}/applications)
|
||||
install(FILES de.tastytea.Whyblocked.appdata.xml
|
||||
DESTINATION ${CMAKE_INSTALL_DATAROOTDIR}/metainfo)
|
||||
install(FILES de.tastytea.Whyblocked.svg
|
||||
DESTINATION ${CMAKE_INSTALL_DATAROOTDIR}/icons/hicolor/scalable/apps)
|
||||
if(WITH_MAN)
|
||||
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/whyblocked.1
|
||||
DESTINATION ${CMAKE_INSTALL_MANDIR}/man1)
|
||||
endif()
|
||||
|
||||
set(WITH_TRANSLATIONS "YES" CACHE STRING "WITH_TRANSLATIONS defaults to \"YES\"")
|
||||
if(WITH_TRANSLATIONS)
|
||||
add_subdirectory(translations)
|
||||
endif()
|
||||
|
||||
|
|
51
README.md
51
README.md
|
@ -1,14 +1,13 @@
|
|||
**Whyblocked** allows you to store the reason why you blocked someone, along with
|
||||
"receipts", URLs to the posts that led you to block them.
|
||||
**Whyblocked** allows you to store the reason why you blocked someone, along
|
||||
with “receipts”, URLs to the posts that led you to block them.
|
||||
|
||||
It has a text- and a Qt-interface and uses an SQLite-database.
|
||||
It has a Qt-interface and uses an SQLite-database.
|
||||
|
||||
![Screenshot Qt interface](https://doc.schlomp.space/whyblocked/whyblocked_screenshot.png)
|
||||
![Screenshot](https://doc.schlomp.space/whyblocked/whyblocked_screenshot.png)
|
||||
|
||||
## Usage
|
||||
|
||||
For the text interface start `whyblocked`, for the Qt interface
|
||||
`whyblocked-gui`. You can also start it from the menu of your desktop
|
||||
Run `whyblocked`. You can also start it from the menu of your desktop
|
||||
environment.
|
||||
|
||||
## Install
|
||||
|
@ -17,9 +16,12 @@ environment.
|
|||
|
||||
Every [release](https://schlomp.space/tastytea/whyblocked/releases) includes
|
||||
a .deb-package, an .rpm-package and a .tar.gz-package with precompiled binaries
|
||||
for x86_64(amd64) ([more info](https://schlomp.space/tastytea/whyblocked/wiki/Binary-Packages)). These are automatically built and not tested. You can install
|
||||
them with `dpkg -i` or `rpm -i`, respectively. The packages are signed with the
|
||||
PGP key [242E5AC4DA587BF9](https://tastytea.de/tastytea_autosign.asc)
|
||||
for x86_64(amd64)
|
||||
([more info](https://schlomp.space/tastytea/whyblocked/wiki/Binary-Packages)).
|
||||
These are automatically built and not tested. You can install them with
|
||||
`apt install ./whyblocked*.deb` or `yum install ./whyblocked*.rpm`,
|
||||
respectively. The packages are signed with the PGP key
|
||||
[242E5AC4DA587BF9](https://tastytea.de/tastytea_autosign.asc)
|
||||
(Fingerprint: `F730 1ADF C9ED 2624 48C4 2B64 242E 5AC4 DA58 7BF9`).
|
||||
|
||||
Gentoo ebuilds are available via my
|
||||
|
@ -29,31 +31,26 @@ Gentoo ebuilds are available via my
|
|||
|
||||
#### Dependencies
|
||||
|
||||
* C++ compiler (tested: [gcc](https://gcc.gnu.org/) 6/7/8,
|
||||
[clang](https://llvm.org/) 3/5/6)
|
||||
* C++ compiler (tested: [gcc](https://gcc.gnu.org/) 6/8/9,
|
||||
[clang](https://llvm.org/) 3/6)
|
||||
* [cmake](https://cmake.org/) (at least 3.2)
|
||||
* [vsqlite++](http://vsqlite.virtuosic-bytes.com/) (tested: 0.3)
|
||||
* [libxdg-basedir](http://repo.or.cz/w/libxdg-basedir.git) (tested: 1.2)
|
||||
* [qtcore](https://www.qt.io/) (tested: 5.11/5.5)
|
||||
* [qtcore](https://www.qt.io/) (tested: 5.12/5.5)
|
||||
* [qtwidgets](https://www.qt.io/) (tested: 5.12/5.5)
|
||||
* [libconfig++](https://github.com/hyperrealm/libconfig) (tested: 1.5)
|
||||
* Optional
|
||||
* GUI: [qtwidgets](https://www.qt.io/) (tested: 5.11/5.5)
|
||||
* GUI: [libconfig++](https://github.com/hyperrealm/libconfig) (tested: 1.5)
|
||||
* Translations: [lupdate & lrelease](http://doc.qt.io/qt-5/linguist-manager.html) (tested: 5.11/5.5)
|
||||
* Translations: [lupdate & lrelease](http://doc.qt.io/qt-5/linguist-manager.html) (tested: 5.12/5.5)
|
||||
* Manpage: [asciidoc](http://asciidoc.org/) (tested: 8.6)
|
||||
|
||||
#### Get sourcecode
|
||||
|
||||
Download the current
|
||||
[release](https://schlomp.space/tastytea/whyblocked/releases) and copy
|
||||
[xdgcfg](https://schlomp.space/tastytea/xdgcfg) into `xdgcfg/`.
|
||||
|
||||
If you clone from git, be sure to `git submodule init` and
|
||||
`git submodule update` afterwards. See the [submodules article in the git book]
|
||||
(https://git-scm.com/book/en/v2/Git-Tools-Submodules#_cloning_submodules) for
|
||||
further info.
|
||||
[release](https://schlomp.space/tastytea/whyblocked/releases).
|
||||
|
||||
#### Compile
|
||||
|
||||
```SH
|
||||
``` zsh
|
||||
mkdir build
|
||||
cd build
|
||||
cmake ..
|
||||
|
@ -63,8 +60,8 @@ make install
|
|||
|
||||
cmake options:
|
||||
* `-DCMAKE_BUILD_TYPE=Debug` for a debug build
|
||||
* `-DWITHOUT_GUI=YES` to not build GUI
|
||||
* `-DWITHOUT_TRANSLATIONS=YES` to not compile translations
|
||||
* `-DWITH_TRANSLATIONS=NO` to not compile translations
|
||||
* `-DWITH_MAN=NO` to not compile the manpage
|
||||
* One of:
|
||||
* `-DWITH_DEB=YES` if you want to be able to generate a deb-package
|
||||
* `-DWITH_RPM=YES` if you want to be able to generate an rpm-package
|
||||
|
@ -92,14 +89,14 @@ Please report them on the
|
|||
|
||||
## Licence & Copyright
|
||||
|
||||
```PLAIN
|
||||
``` plain
|
||||
Copyright © 2018 tastytea <tastytea@tastytea.de>.
|
||||
License GPLv3: GNU GPL version 3 <https://www.gnu.org/licenses/gpl-3.0.html>.
|
||||
This program comes with ABSOLUTELY NO WARRANTY. This is free software,
|
||||
and you are welcome to redistribute it under certain conditions.
|
||||
```
|
||||
|
||||
The icon is derived from the icons `messagebox critical` and `help` of the
|
||||
The icon is derived from the icons *“messagebox critical”* and *“help”* of the
|
||||
[Gartoon icon theme](https://commons.wikimedia.org/wiki/Gartoon_icons). The
|
||||
original authors were Zeus, Patrick Yavitz and La Mula Francis, who released
|
||||
them under the terms of the
|
||||
|
|
|
@ -0,0 +1,10 @@
|
|||
#!/bin/sh
|
||||
|
||||
if [ -n "${1}" ]; then
|
||||
dir="$(dirname ${0})"
|
||||
cp -vf ${dir}/whyblocked.1.adoc .
|
||||
sed -Ei "s/(Revision: +)[0-9]+\.[0-9]\.[0-9]/\1${1}/" whyblocked.1.adoc
|
||||
a2x --doctype manpage --format manpage --no-xmllint whyblocked.1.adoc
|
||||
else
|
||||
echo "usage: ${0} VERSION" >&2
|
||||
fi
|
|
@ -5,7 +5,7 @@ Name=Whyblocked
|
|||
Comment=Reminds you why you blocked someone
|
||||
Comment[de]=Erinnert dich, warum du jemanden blockiertest
|
||||
Icon=de.tastytea.Whyblocked
|
||||
Exec=whyblocked-gui
|
||||
Exec=whyblocked
|
||||
Terminal=false
|
||||
Categories=Utility;
|
||||
Keywords=blocklist;social-network;
|
||||
|
|
|
@ -1,322 +0,0 @@
|
|||
/* This file is part of whyblocked.
|
||||
* Copyright © 2018 tastytea <tastytea@tastytea.de>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation, version 3.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include <iostream>
|
||||
#include <QCoreApplication>
|
||||
#include <QTranslator>
|
||||
#include <QLocale>
|
||||
#include <QLibraryInfo>
|
||||
#include "version.hpp"
|
||||
#include "whyblocked.hpp"
|
||||
#include "interface_text.hpp"
|
||||
|
||||
using std::cout;
|
||||
using std::cerr;
|
||||
using std::cin;
|
||||
|
||||
// Allow cout to output QStrings
|
||||
std::ostream &operator <<(std::ostream &stream, const QString &str)
|
||||
{
|
||||
stream << str.toStdString();
|
||||
return stream;
|
||||
}
|
||||
|
||||
const string Text::get_answer(const QString &question)
|
||||
{
|
||||
string answer;
|
||||
|
||||
cout << question << ": ";
|
||||
std::getline(cin, answer, '\n');
|
||||
|
||||
return answer;
|
||||
}
|
||||
|
||||
const bool Text::askblocked()
|
||||
{
|
||||
while (true)
|
||||
{
|
||||
const string blocked = get_answer(tr("Blocked or silenced?") +
|
||||
" [b/s]");
|
||||
if (blocked[0] == 'b' || blocked[0] == 'B')
|
||||
{
|
||||
return true;
|
||||
}
|
||||
else if (blocked[0] == 's' || blocked[0] == 'S')
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
const void Text::askrecipes(const string &user)
|
||||
{
|
||||
while (true)
|
||||
{
|
||||
const string receipt_yn = get_answer(tr("Add receipt? [y/n]"));
|
||||
if (receipt_yn[0] == tr("y")[0] || receipt_yn[0] == tr("Y")[0])
|
||||
{
|
||||
const string receipt = get_answer(tr("Receipt"));
|
||||
|
||||
if (database::add_receipt(user, receipt))
|
||||
{
|
||||
cout << tr("Receipt added.") << '\n';
|
||||
}
|
||||
}
|
||||
else if (receipt_yn[0] == tr("n")[0] || receipt_yn[0] == tr("N")[0])
|
||||
{
|
||||
break;
|
||||
}
|
||||
else
|
||||
{
|
||||
continue;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
const void Text::add()
|
||||
{
|
||||
const string user = get_answer(tr("User or instance"));
|
||||
int blocked;
|
||||
|
||||
if (askblocked())
|
||||
{
|
||||
blocked = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
blocked = 0;
|
||||
}
|
||||
const string reason = get_answer(tr("Reason"));
|
||||
|
||||
if (database::add_block(user, blocked, reason))
|
||||
{
|
||||
cout << user << " " << tr("added.") << '\n';
|
||||
}
|
||||
|
||||
askrecipes(user);
|
||||
}
|
||||
|
||||
const void Text::edit()
|
||||
{
|
||||
result_details olddata;
|
||||
const string olduser = get_answer(tr("User or instance"));
|
||||
if (database::details(olduser, olddata))
|
||||
{
|
||||
cout << tr("A blank line keeps the former value.") << '\n';
|
||||
string newuser = get_answer(tr("Change user or instance to"));
|
||||
if (newuser.empty())
|
||||
{
|
||||
newuser = olduser;
|
||||
}
|
||||
|
||||
int blocked;
|
||||
if (askblocked())
|
||||
{
|
||||
blocked = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
blocked = 0;
|
||||
}
|
||||
|
||||
cout << tr("Old reason was:") << " " << std::get<1>(olddata) << '\n';
|
||||
string newreason = get_answer(tr("Change reason to"));
|
||||
if (newreason.empty())
|
||||
{
|
||||
newreason = std::get<1>(olddata);
|
||||
}
|
||||
|
||||
std::vector<string> newreceipts;
|
||||
for (const string &oldreceipt : std::get<2>(olddata))
|
||||
{
|
||||
cout << tr("Old receipt was:") << " " << oldreceipt << '\n';
|
||||
string newreceipt = get_answer(tr("Change receipt to"));
|
||||
if (newreceipt.empty())
|
||||
{
|
||||
newreceipt = oldreceipt;
|
||||
}
|
||||
newreceipts.push_back(newreceipt);
|
||||
}
|
||||
|
||||
if (database::remove(olduser))
|
||||
{
|
||||
database::add_block(newuser, blocked, newreason);
|
||||
if (!newreceipts.empty())
|
||||
{
|
||||
for (const string &newreceipt : newreceipts)
|
||||
{
|
||||
database::add_receipt(newuser, newreceipt);
|
||||
}
|
||||
}
|
||||
askrecipes(newuser);
|
||||
}
|
||||
else
|
||||
{
|
||||
cerr << tr("Could not remove") << " " << olduser << ".\n";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
const void Text::remove()
|
||||
{
|
||||
const string user = get_answer(tr("User or instance"));
|
||||
|
||||
if (database::remove(user))
|
||||
{
|
||||
cout << user << " " << tr("removed.") << '\n';
|
||||
}
|
||||
}
|
||||
|
||||
const void Text::view()
|
||||
{
|
||||
result_view result;
|
||||
if (database::view(result))
|
||||
{
|
||||
for (const std::tuple<string, int, string> &line : result)
|
||||
{
|
||||
if (std::get<1>(line) == 1)
|
||||
{
|
||||
cout << tr(" Blocked:") << " ";
|
||||
}
|
||||
else
|
||||
{
|
||||
cout << tr("Silenced:") << " ";
|
||||
}
|
||||
cout << std::get<0>(line) << " " << tr("because:") << " ";
|
||||
cout << std::get<2>(line) << '\n';
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
const void Text::details()
|
||||
{
|
||||
const string user = get_answer(tr("User or instance"));
|
||||
{
|
||||
result_details result;
|
||||
if (database::details(user, result))
|
||||
{
|
||||
cout << user << " " << tr("is") << " ";
|
||||
if (std::get<0>(result) == 1)
|
||||
{
|
||||
cout << tr("blocked, because:") << " ";
|
||||
}
|
||||
else if (std::get<0>(result) == 0)
|
||||
{
|
||||
cout << tr("silenced, because:") << " ";
|
||||
}
|
||||
cout << std::get<1>(result) << '\n';
|
||||
|
||||
if (!std::get<2>(result).empty())
|
||||
{
|
||||
cout << tr("Receipts:") << '\n';
|
||||
for (const string &url : std::get<2>(result))
|
||||
{
|
||||
cout << " " << url << '\n';
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
const void Text::help()
|
||||
{
|
||||
cout << tr(
|
||||
"Type add, edit, remove, view or details. Or just the first letter.")
|
||||
<< '\n';
|
||||
cout << tr(
|
||||
"Type help or h to show this help. Type quit or q to quit the program.")
|
||||
<< '\n';
|
||||
}
|
||||
|
||||
Text::Text(QObject *parent) : QObject(parent)
|
||||
{
|
||||
bool keeprunning = true;
|
||||
|
||||
cout << tr("This is Whyblocked") << " " << global::version << ".\n";
|
||||
help();
|
||||
while (keeprunning)
|
||||
{
|
||||
string answer = get_answer("");
|
||||
switch (answer[0])
|
||||
{
|
||||
case 'a':
|
||||
case 'A':
|
||||
{
|
||||
add();
|
||||
break;
|
||||
}
|
||||
case 'e':
|
||||
case 'E':
|
||||
{
|
||||
edit();
|
||||
break;
|
||||
}
|
||||
case 'r':
|
||||
case 'R':
|
||||
{
|
||||
remove();
|
||||
break;
|
||||
}
|
||||
case 'v':
|
||||
case 'V':
|
||||
{
|
||||
view();
|
||||
break;
|
||||
}
|
||||
case 'd':
|
||||
case 'D':
|
||||
{
|
||||
details();
|
||||
break;
|
||||
}
|
||||
case 'h':
|
||||
case 'H':
|
||||
{
|
||||
help();
|
||||
break;
|
||||
}
|
||||
case 'q':
|
||||
case 'Q':
|
||||
{
|
||||
keeprunning = false;
|
||||
break;
|
||||
}
|
||||
default:
|
||||
{
|
||||
cout << tr("Response not understood.") << '\n';
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
QCoreApplication app(argc, argv);
|
||||
QCoreApplication::setApplicationName("Whyblocked");
|
||||
|
||||
QTranslator qtTranslator;
|
||||
qtTranslator.load("qt_" + QLocale::system().name(),
|
||||
QLibraryInfo::location(QLibraryInfo::TranslationsPath));
|
||||
app.installTranslator(&qtTranslator);
|
||||
QTranslator appTranslator;
|
||||
appTranslator.load("whyblocked_" + QLocale::system().name(),
|
||||
QLibraryInfo::location(QLibraryInfo::TranslationsPath));
|
||||
app.installTranslator(&appTranslator);
|
||||
|
||||
Text t(&app);
|
||||
|
||||
return 0;
|
||||
}
|
|
@ -0,0 +1,112 @@
|
|||
/* This file is part of whyblocked.
|
||||
* Copyright © 2019 tastytea <tastytea@tastytea.de>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation, version 3.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include <QtCore/qmimedata.h>
|
||||
#include "dialog_add.hpp"
|
||||
|
||||
DialogAdd::DialogAdd(Database &database, QMainWindow *parent)
|
||||
: QDialog(parent)
|
||||
, _parent(static_cast<MainWindow*>(parent))
|
||||
, _database(database)
|
||||
{
|
||||
setupUi(this);
|
||||
}
|
||||
|
||||
|
||||
void DialogAdd::set_data(const Database::data &data)
|
||||
{
|
||||
text_user->setText(QString::fromStdString(data.user));
|
||||
radio_blocked->setChecked(data.blocked);
|
||||
radio_silcenced->setChecked(!data.blocked);
|
||||
text_reason->setText(QString::fromStdString(data.reason));
|
||||
for (const string &receipt : data.receipts)
|
||||
{
|
||||
QListWidgetItem *item =
|
||||
new QListWidgetItem(QString::fromStdString(receipt));
|
||||
item->setFlags(item->flags() | Qt::ItemIsEditable);
|
||||
list_receipts->insertItem(list_receipts->count(), item);
|
||||
}
|
||||
}
|
||||
|
||||
const Database::data DialogAdd::get_data() const
|
||||
{
|
||||
std::vector<string> receipts;
|
||||
for (int row = 0; row <= list_receipts->count() - 1; ++row)
|
||||
{
|
||||
receipts.push_back(list_receipts->item(row)->text().toStdString());
|
||||
}
|
||||
|
||||
Database::data data;
|
||||
data.user = text_user->text().toStdString();
|
||||
data.blocked = radio_blocked->isChecked();
|
||||
data.reason = text_reason->text().toStdString();
|
||||
data.receipts = receipts;
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
void DialogAdd::dragEnterEvent(QDragEnterEvent *event)
|
||||
{
|
||||
if (event->mimeData()->hasFormat("text/plain"))
|
||||
{
|
||||
event->acceptProposedAction();
|
||||
}
|
||||
}
|
||||
|
||||
void DialogAdd::dropEvent(QDropEvent *event)
|
||||
{
|
||||
const QString text = event->mimeData()->text();
|
||||
QListWidgetItem *item = new QListWidgetItem(text);
|
||||
item->setFlags(item->flags() | Qt::ItemIsEditable);
|
||||
list_receipts->insertItem(list_receipts->count(), item);
|
||||
}
|
||||
|
||||
void DialogAdd::add_receipt()
|
||||
{
|
||||
QListWidgetItem *item = new QListWidgetItem(tr("Insert receipt here."));
|
||||
item->setFlags(item->flags() | Qt::ItemIsEditable);
|
||||
list_receipts->insertItem(list_receipts->count(), item);
|
||||
list_receipts->editItem(item);
|
||||
}
|
||||
|
||||
void DialogAdd::remove_receipt()
|
||||
{
|
||||
for (auto item :list_receipts->selectedItems())
|
||||
{
|
||||
delete item;
|
||||
}
|
||||
}
|
||||
|
||||
void DialogAdd::accept()
|
||||
{
|
||||
if (property("edit").toBool())
|
||||
{
|
||||
_parent->remove();
|
||||
}
|
||||
Database::data data = get_data();
|
||||
|
||||
if (!data)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
_database.add_user(data);
|
||||
_parent->add_row(QString::fromStdString(data.user),
|
||||
data.blocked,
|
||||
QString::fromStdString(data.reason));
|
||||
|
||||
delete this;
|
||||
}
|
|
@ -1,5 +1,5 @@
|
|||
/* This file is part of whyblocked.
|
||||
* Copyright © 2018 tastytea <tastytea@tastytea.de>
|
||||
* Copyright © 2019 tastytea <tastytea@tastytea.de>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
|
@ -14,31 +14,33 @@
|
|||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef INTERFACE_TEXT_HPP
|
||||
#define INTERFACE_TEXT_HPP
|
||||
#ifndef DIALOG_ADD_HPP
|
||||
#define DIALOG_ADD_HPP
|
||||
|
||||
#include <string>
|
||||
#include <QtCore>
|
||||
#include "mainwindow.hpp"
|
||||
#include "ui_whyblocked_add.h"
|
||||
|
||||
using std::string;
|
||||
|
||||
class Text : public QObject
|
||||
class DialogAdd : public QDialog, private Ui::DialogAdd
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit Text(QObject *parent = nullptr);
|
||||
explicit DialogAdd(Database &database, QMainWindow *parent = nullptr);
|
||||
void set_data(const Database::data &data);
|
||||
|
||||
private:
|
||||
const string get_answer(const QString &question);
|
||||
const bool askblocked();
|
||||
const void askrecipes(const string &user);
|
||||
const void add();
|
||||
const void edit();
|
||||
const void remove();
|
||||
const void view();
|
||||
const void details();
|
||||
const void help();
|
||||
const Database::data get_data() const;
|
||||
void dragEnterEvent(QDragEnterEvent *event);
|
||||
void dropEvent(QDropEvent *event);
|
||||
|
||||
MainWindow *_parent;
|
||||
Database &_database;
|
||||
|
||||
private slots:
|
||||
void add_receipt();
|
||||
void remove_receipt();
|
||||
void accept();
|
||||
|
||||
};
|
||||
|
||||
#endif // INTERFACE_TEXT_HPP
|
||||
#endif // DIALOG_ADD_HPP
|
|
@ -0,0 +1,42 @@
|
|||
/* This file is part of whyblocked.
|
||||
* Copyright © 2019, 2020 tastytea <tastytea@tastytea.de>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation, version 3.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include "mainwindow.hpp"
|
||||
|
||||
#include <QLibraryInfo>
|
||||
#include <QLocale>
|
||||
#include <QTranslator>
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
QApplication app(argc, argv);
|
||||
QCoreApplication::setApplicationName("Whyblocked");
|
||||
|
||||
QTranslator qtTranslator;
|
||||
qtTranslator.load(QLocale(), "qt", "_",
|
||||
QLibraryInfo::location(QLibraryInfo::TranslationsPath));
|
||||
|
||||
app.installTranslator(&qtTranslator);
|
||||
QTranslator appTranslator;
|
||||
appTranslator.load(QLocale(), "whyblocked", "_",
|
||||
QLibraryInfo::location(QLibraryInfo::TranslationsPath));
|
||||
app.installTranslator(&appTranslator);
|
||||
|
||||
MainWindow win;
|
||||
win.show();
|
||||
|
||||
return app.exec();
|
||||
}
|
|
@ -1,5 +1,5 @@
|
|||
/* This file is part of whyblocked.
|
||||
* Copyright © 2018 tastytea <tastytea@tastytea.de>
|
||||
* Copyright © 2018, 2019 tastytea <tastytea@tastytea.de>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
|
@ -16,20 +16,27 @@
|
|||
|
||||
#include <regex>
|
||||
#include <array>
|
||||
#include <locale>
|
||||
#include <codecvt>
|
||||
#include <algorithm>
|
||||
#include <QMessageBox>
|
||||
#include <QTranslator>
|
||||
#include <QLibraryInfo>
|
||||
#include <QtCore/qmimedata.h>
|
||||
#include <libconfig.h++>
|
||||
#include "version.hpp"
|
||||
#include "whyblocked.hpp"
|
||||
#include "interface_qt.hpp"
|
||||
#include "mainwindow.hpp"
|
||||
#include "dialog_add.hpp"
|
||||
|
||||
using std::wstring;
|
||||
|
||||
MainWindow::MainWindow(QMainWindow *parent)
|
||||
: QMainWindow(parent)
|
||||
, _config("whyblocked.cfg")
|
||||
, _headersize({ 250, 125, 125 })
|
||||
, _database()
|
||||
, _dbdata(_database.get_data())
|
||||
{
|
||||
std::locale::global(std::locale(""));
|
||||
|
||||
setupUi(this);
|
||||
|
||||
_model = new QStandardItemModel;
|
||||
|
@ -84,9 +91,21 @@ MainWindow::MainWindow(QMainWindow *parent)
|
|||
const libconfig::Setting &value = root[key.c_str()];
|
||||
_headersize = { value[0], value[1], value[2] };
|
||||
}
|
||||
|
||||
key = "find_in";
|
||||
if (root.exists(key) && root[key.c_str()].isGroup())
|
||||
{
|
||||
const libconfig::Setting &value = root[key.c_str()];
|
||||
check_user->setChecked(value["user"]);
|
||||
check_reason->setChecked(value["reason"]);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
populate_tableview();
|
||||
widget_find->hide();
|
||||
|
||||
reload();
|
||||
|
||||
statusBar()->showMessage(tr("Try dragging an account from your webbrowser "
|
||||
"into this window."));
|
||||
}
|
||||
|
@ -96,7 +115,8 @@ MainWindow::~MainWindow()
|
|||
libconfig::Setting &root = _config.get_cfg().getRoot();
|
||||
// We can't add an element that already exists, so we delete it beforehand.
|
||||
for (const string &key :
|
||||
{ "size", "toolbar_position", "toolbar_visible", "table_headers" })
|
||||
{ "size", "toolbar_position", "toolbar_visible", "table_headers",
|
||||
"find_in" })
|
||||
{
|
||||
if (root.exists(key))
|
||||
{
|
||||
|
@ -142,37 +162,18 @@ MainWindow::~MainWindow()
|
|||
tableview->horizontalHeader()->sectionSize(0);
|
||||
headers.add(libconfig::Setting::TypeInt) =
|
||||
tableview->horizontalHeader()->sectionSize(1);
|
||||
headers.add(libconfig::Setting::TypeInt) =
|
||||
tableview->horizontalHeader()->sectionSize(2);
|
||||
headers.add(libconfig::Setting::TypeInt) = 125;
|
||||
|
||||
libconfig::Setting &find_in = root.add("find_in",
|
||||
libconfig::Setting::TypeGroup);
|
||||
find_in.add("user", libconfig::Setting::TypeBoolean) =
|
||||
check_user->isChecked();
|
||||
find_in.add("reason", libconfig::Setting::TypeBoolean) =
|
||||
check_reason->isChecked();
|
||||
|
||||
_config.write();
|
||||
}
|
||||
|
||||
void MainWindow::populate_tableview()
|
||||
{
|
||||
_model->clear();
|
||||
_model->setHorizontalHeaderLabels(
|
||||
{
|
||||
tr("User/Instance"),
|
||||
tr("Blocked/Silenced"),
|
||||
tr("Reason")
|
||||
});
|
||||
tableview->horizontalHeader()->resizeSection(0, _headersize[0]);
|
||||
tableview->horizontalHeader()->resizeSection(1, _headersize[1]);
|
||||
tableview->horizontalHeader()->resizeSection(2, _headersize[2]);
|
||||
|
||||
result_view result;
|
||||
if (database::view(result))
|
||||
{
|
||||
for (const std::tuple<string, int, string> &line : result)
|
||||
{
|
||||
add_row(QString::fromStdString(std::get<0>(line)),
|
||||
std::get<1>(line),
|
||||
QString::fromStdString(std::get<2>(line)));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void MainWindow::add_row(const QString &user, const int &blocked,
|
||||
const QString &reason)
|
||||
{
|
||||
|
@ -190,54 +191,18 @@ void MainWindow::add_row(const QString &user, const int &blocked,
|
|||
_model->appendRow(items);
|
||||
}
|
||||
|
||||
void MainWindow::add()
|
||||
{
|
||||
DialogAdd *dialog = new DialogAdd(this);
|
||||
dialog->show();
|
||||
}
|
||||
|
||||
void MainWindow::edit()
|
||||
{
|
||||
if (tableview->selectionModel()->selectedRows().count() != 1)
|
||||
{
|
||||
QMessageBox::warning(this, tr("Invalid selection"),
|
||||
tr("Please select only 1 entry to edit."));
|
||||
return;
|
||||
}
|
||||
|
||||
DialogAdd *dialog = new DialogAdd(this);
|
||||
dialog->setWindowTitle(tr("Edit entry"));
|
||||
|
||||
Dialogdata data;
|
||||
QModelIndex index = tableview->selectionModel()->selectedRows().first();
|
||||
data.user = index.sibling(index.row(), 0).data().toString().toStdString();
|
||||
result_details details;
|
||||
database::details(data.user, details);
|
||||
if (std::get<0>(details) == true)
|
||||
{
|
||||
data.blocked = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
data.blocked = 0;
|
||||
}
|
||||
data.reason = std::get<1>(details);
|
||||
data.receipts = std::get<2>(details);
|
||||
|
||||
dialog->set_data(data);
|
||||
dialog->setProperty("edit", true);
|
||||
dialog->show();
|
||||
}
|
||||
|
||||
void MainWindow::remove()
|
||||
{
|
||||
QItemSelectionModel *selection = tableview->selectionModel();
|
||||
if (selection->hasSelection())
|
||||
{
|
||||
for (auto &row : selection->selectedRows())
|
||||
// I use this construct here because the number of selected rows
|
||||
// decrease by 1 each iteration.
|
||||
for (; selection->selectedRows().count() > 0;)
|
||||
{
|
||||
const QModelIndex row = selection->selectedRows().front();
|
||||
const string user = row.data().toString().toStdString();
|
||||
database::remove(user);
|
||||
_database.remove(user);
|
||||
_model->removeRow(row.row());
|
||||
}
|
||||
label_receipts->clear();
|
||||
|
@ -249,43 +214,6 @@ void MainWindow::remove()
|
|||
}
|
||||
}
|
||||
|
||||
void MainWindow::about()
|
||||
{
|
||||
QMessageBox::about(this, tr("About Whyblocked"),
|
||||
tr("<p><b>Whyblocked</b> %1</p>"
|
||||
"<p>Reminds you why you blocked someone.</p>"
|
||||
"<p>Sourcecode: <a href=\"https://schlomp.space/tastytea/whyblocked\">"
|
||||
"https://schlomp.space/tastytea/whyblocked</a></p>"
|
||||
"<p><small>Copyright © 2018 <a href=\"mailto:tastytea@tastytea.de\">tastytea</a>.<br>"
|
||||
"Licence GPLv3: <a href=\"https://www.gnu.org/licenses/gpl-3.0.html\">"
|
||||
"GNU GPL version 3</a>.<br>"
|
||||
"This program comes with ABSOLUTELY NO WARRANTY. This is free software, "
|
||||
"and you are welcome to redistribute it under certain conditions.</small></p>")
|
||||
.arg(global::version));
|
||||
}
|
||||
|
||||
void MainWindow::show_details(QModelIndex index)
|
||||
{
|
||||
const string user = index.sibling(index.row(), 0).data()
|
||||
.toString().toStdString();
|
||||
result_details result;
|
||||
string text = "";
|
||||
|
||||
if (database::details(user, result))
|
||||
{
|
||||
if (!std::get<2>(result).empty())
|
||||
{
|
||||
text += string("<b>") + tr("Receipts:").toStdString() + "</b>";
|
||||
for (const string &url : std::get<2>(result))
|
||||
{
|
||||
text += "<br>" + url;
|
||||
}
|
||||
text = urls_to_hyperlinks(text);
|
||||
}
|
||||
label_receipts->setText(QString::fromStdString((text)));
|
||||
}
|
||||
}
|
||||
|
||||
const string MainWindow::urls_to_hyperlinks(const string &text)
|
||||
{
|
||||
std::regex re_url("((https?|gopher|ftps?)\\://[^ <]*)");
|
||||
|
@ -324,124 +252,148 @@ void MainWindow::dropEvent(QDropEvent *event)
|
|||
}
|
||||
}
|
||||
|
||||
DialogAdd *dialog = new DialogAdd(this);
|
||||
Dialogdata data;
|
||||
DialogAdd *dialog = new DialogAdd(_database, this);
|
||||
Database::data data;
|
||||
data.user = text;
|
||||
data.blocked = true;
|
||||
dialog->set_data(data);
|
||||
dialog->show();
|
||||
}
|
||||
|
||||
DialogAdd::DialogAdd(QMainWindow *parent)
|
||||
: QDialog(parent)
|
||||
, _parent(static_cast<MainWindow*>(parent))
|
||||
void MainWindow::add()
|
||||
{
|
||||
setupUi(this);
|
||||
DialogAdd *dialog = new DialogAdd(_database, this);
|
||||
dialog->show();
|
||||
}
|
||||
|
||||
const Dialogdata DialogAdd::get_data() const
|
||||
void MainWindow::edit()
|
||||
{
|
||||
std::vector<string> receipts;
|
||||
for (int row = 0; row <= list_receipts->count() - 1; ++row)
|
||||
{
|
||||
receipts.push_back(list_receipts->item(row)->text().toStdString());
|
||||
}
|
||||
|
||||
Dialogdata data;
|
||||
data.user = text_user->text().toStdString();
|
||||
data.blocked = radio_blocked->isChecked();
|
||||
data.reason = text_reason->text().toStdString();
|
||||
data.receipts = receipts;
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
const void DialogAdd::set_data(const Dialogdata &data)
|
||||
{
|
||||
text_user->setText(QString::fromStdString(data.user));
|
||||
radio_blocked->setChecked(data.blocked);
|
||||
radio_silcenced->setChecked(!data.blocked);
|
||||
text_reason->setText(QString::fromStdString(data.reason));
|
||||
for (const string &receipt : data.receipts)
|
||||
{
|
||||
QListWidgetItem *item =
|
||||
new QListWidgetItem(QString::fromStdString(receipt));
|
||||
item->setFlags(item->flags() | Qt::ItemIsEditable);
|
||||
list_receipts->insertItem(list_receipts->count(), item);
|
||||
}
|
||||
}
|
||||
|
||||
void DialogAdd::add_receipt()
|
||||
{
|
||||
QListWidgetItem *item = new QListWidgetItem(tr("Insert receipt here."));
|
||||
item->setFlags(item->flags() | Qt::ItemIsEditable);
|
||||
list_receipts->insertItem(list_receipts->count(), item);
|
||||
list_receipts->editItem(item);
|
||||
}
|
||||
|
||||
void DialogAdd::remove_receipt()
|
||||
{
|
||||
for (auto item :list_receipts->selectedItems())
|
||||
{
|
||||
delete item;
|
||||
}
|
||||
}
|
||||
|
||||
void DialogAdd::accept()
|
||||
{
|
||||
if (property("edit").toBool())
|
||||
{
|
||||
_parent->remove();
|
||||
}
|
||||
Dialogdata data = get_data();
|
||||
|
||||
if (data.user.empty())
|
||||
if (tableview->selectionModel()->selectedRows().count() != 1)
|
||||
{
|
||||
QMessageBox::warning(this, tr("Invalid selection"),
|
||||
tr("Please select only 1 entry to edit."));
|
||||
return;
|
||||
}
|
||||
database::add_block(data.user, data.blocked, data.reason);
|
||||
_parent->add_row(QString::fromStdString(data.user),
|
||||
data.blocked,
|
||||
QString::fromStdString(data.reason));
|
||||
for (const string &receipt : data.receipts)
|
||||
{
|
||||
database::add_receipt(data.user, receipt);
|
||||
}
|
||||
|
||||
delete this;
|
||||
DialogAdd *dialog = new DialogAdd(_database, this);
|
||||
dialog->setWindowTitle(tr("Edit entry"));
|
||||
|
||||
QModelIndex index = tableview->selectionModel()->selectedRows().first();
|
||||
const string user = index.sibling(index.row(), 0).data()
|
||||
.toString().toStdString();
|
||||
|
||||
dialog->set_data(_database.get_user(user));
|
||||
dialog->setProperty("edit", true);
|
||||
dialog->show();
|
||||
}
|
||||
|
||||
void DialogAdd::dragEnterEvent(QDragEnterEvent *event)
|
||||
void MainWindow::about()
|
||||
{
|
||||
if (event->mimeData()->hasFormat("text/plain"))
|
||||
QMessageBox::about(this, tr("About Whyblocked"),
|
||||
tr("<p><b>Whyblocked</b> %1</p>"
|
||||
"<p>Reminds you why you blocked someone.</p>"
|
||||
"<p>Sourcecode: <a href=\"https://schlomp.space/tastytea/whyblocked\">"
|
||||
"https://schlomp.space/tastytea/whyblocked</a></p>"
|
||||
"<p><small>Copyright © 2018 <a href=\"mailto:tastytea@tastytea.de\">tastytea</a>.<br>"
|
||||
"Licence GPLv3: <a href=\"https://www.gnu.org/licenses/gpl-3.0.html\">"
|
||||
"GNU GPL version 3</a>.<br>"
|
||||
"This program comes with ABSOLUTELY NO WARRANTY. This is free software, "
|
||||
"and you are welcome to redistribute it under certain conditions.</small></p>")
|
||||
.arg(global::version));
|
||||
}
|
||||
|
||||
void MainWindow::show_details(QModelIndex index)
|
||||
{
|
||||
const string user = index.sibling(index.row(), 0).data()
|
||||
.toString().toStdString();
|
||||
Database::data data = _database.get_user(user);
|
||||
string text = "";
|
||||
|
||||
if (!data.receipts.empty())
|
||||
{
|
||||
event->acceptProposedAction();
|
||||
text += string("<b>") + tr("Receipts:").toStdString() + "</b>";
|
||||
for (const string &url : data.receipts)
|
||||
{
|
||||
text += "<br>" + url;
|
||||
}
|
||||
text = urls_to_hyperlinks(text);
|
||||
}
|
||||
label_receipts->setText(QString::fromStdString((text)));
|
||||
}
|
||||
|
||||
void MainWindow::populate_tableview(const vector<Database::data> &entries)
|
||||
{
|
||||
_model->clear();
|
||||
_model->setHorizontalHeaderLabels(
|
||||
{
|
||||
tr("User/Instance"),
|
||||
tr("Blocked/Silenced"),
|
||||
tr("Reason")
|
||||
});
|
||||
tableview->horizontalHeader()->resizeSection(0, _headersize[0]);
|
||||
tableview->horizontalHeader()->resizeSection(1, _headersize[1]);
|
||||
tableview->horizontalHeader()->resizeSection(2, _headersize[2]);
|
||||
|
||||
for (const Database::data &entry : entries)
|
||||
{
|
||||
add_row(QString::fromStdString(entry.user),
|
||||
entry.blocked,
|
||||
QString::fromStdString(entry.reason));
|
||||
}
|
||||
}
|
||||
|
||||
void DialogAdd::dropEvent(QDropEvent *event)
|
||||
void MainWindow::reload()
|
||||
{
|
||||
const QString text = event->mimeData()->text();
|
||||
QListWidgetItem *item = new QListWidgetItem(text);
|
||||
item->setFlags(item->flags() | Qt::ItemIsEditable);
|
||||
list_receipts->insertItem(list_receipts->count(), item);
|
||||
_database.reload();
|
||||
populate_tableview(_dbdata);
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
void MainWindow::find()
|
||||
{
|
||||
QApplication app(argc, argv);
|
||||
QCoreApplication::setApplicationName("Whyblocked");
|
||||
|
||||
QTranslator qtTranslator;
|
||||
qtTranslator.load("qt_" + QLocale::system().name(),
|
||||
QLibraryInfo::location(QLibraryInfo::TranslationsPath));
|
||||
app.installTranslator(&qtTranslator);
|
||||
QTranslator appTranslator;
|
||||
appTranslator.load("whyblocked_" + QLocale::system().name(),
|
||||
QLibraryInfo::location(QLibraryInfo::TranslationsPath));
|
||||
app.installTranslator(&appTranslator);
|
||||
|
||||
MainWindow win;
|
||||
win.show();
|
||||
|
||||
return app.exec();
|
||||
if (widget_find->isVisible())
|
||||
{
|
||||
widget_find->hide();
|
||||
}
|
||||
else
|
||||
{
|
||||
widget_find->show();
|
||||
text_find->setFocus();
|
||||
}
|
||||
}
|
||||
|
||||
void MainWindow::update_search(const QString &text)
|
||||
{
|
||||
const wstring searchfor = text.toLower().toStdWString();
|
||||
|
||||
vector<Database::data> filtered_entries;
|
||||
if (!_dbdata.empty())
|
||||
{
|
||||
for (const Database::data &entry : _dbdata)
|
||||
{
|
||||
wstring searchstring;
|
||||
std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>> convert;
|
||||
|
||||
if (check_user->isChecked())
|
||||
{
|
||||
searchstring += convert.from_bytes(entry.user);
|
||||
}
|
||||
if (check_reason->isChecked())
|
||||
{
|
||||
searchstring += convert.from_bytes(entry.reason);
|
||||
}
|
||||
std::transform(searchstring.begin(), searchstring.end(),
|
||||
searchstring.begin(), ::towlower);
|
||||
if (searchstring.find(searchfor) != std::string::npos)
|
||||
{
|
||||
filtered_entries.push_back(entry);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
populate_tableview(filtered_entries);
|
||||
}
|
||||
|
||||
void MainWindow::update_search()
|
||||
{
|
||||
update_search(text_find->text());
|
||||
}
|
|
@ -1,5 +1,5 @@
|
|||
/* This file is part of whyblocked.
|
||||
* Copyright © 2018 tastytea <tastytea@tastytea.de>
|
||||
* Copyright © 2018, 2019 tastytea <tastytea@tastytea.de>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
|
@ -14,29 +14,23 @@
|
|||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef INTERFACE_QT_HPP
|
||||
#define INTERFACE_QT_HPP
|
||||
#ifndef MAINWINDOW_HPP
|
||||
#define MAINWINDOW_HPP
|
||||
|
||||
#include <string>
|
||||
#include <memory>
|
||||
#include <array>
|
||||
#include <vector>
|
||||
#include <QMainWindow>
|
||||
#include <QStandardItemModel>
|
||||
#include <QDialog>
|
||||
#include <QtGui/qevent.h>
|
||||
#include "xdgcfg.hpp"
|
||||
#include "../xdgcfg.hpp"
|
||||
#include "../whyblocked.hpp"
|
||||
#include "ui_whyblocked.h"
|
||||
#include "ui_whyblocked_add.h"
|
||||
|
||||
using std::string;
|
||||
|
||||
struct Dialogdata
|
||||
{
|
||||
string user = "";
|
||||
bool blocked = true;
|
||||
string reason = "";
|
||||
std::vector<string> receipts = {};
|
||||
};
|
||||
using std::vector;
|
||||
|
||||
class MainWindow : public QMainWindow, private Ui::MainWindow
|
||||
{
|
||||
|
@ -59,36 +53,20 @@ private:
|
|||
QStandardItemModel *_model;
|
||||
xdgcfg _config;
|
||||
std::array<int, 3> _headersize;
|
||||
Database _database;
|
||||
std::vector<Database::data> &_dbdata;
|
||||
|
||||
private slots:
|
||||
void add();
|
||||
void edit();
|
||||
void about();
|
||||
void show_details(QModelIndex index);
|
||||
void populate_tableview();
|
||||
void populate_tableview(const vector<Database::data> &entries);
|
||||
void reload();
|
||||
void find();
|
||||
void update_search(const QString &text);
|
||||
void update_search();
|
||||
|
||||
};
|
||||
|
||||
class DialogAdd : public QDialog, private Ui::DialogAdd
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit DialogAdd(QMainWindow *parent = nullptr);
|
||||
const void set_data(const Dialogdata &data);
|
||||
|
||||
private:
|
||||
const Dialogdata get_data() const;
|
||||
void dragEnterEvent(QDragEnterEvent *event);
|
||||
void dropEvent(QDropEvent *event);
|
||||
|
||||
MainWindow *_parent;
|
||||
|
||||
private slots:
|
||||
void add_receipt();
|
||||
void remove_receipt();
|
||||
void accept();
|
||||
|
||||
};
|
||||
|
||||
#endif // INTERFACE_QT_HPP
|
||||
#endif // MAINWINDOW_HPP
|
|
@ -25,6 +25,60 @@
|
|||
</property>
|
||||
<widget class="QWidget" name="centralwidget">
|
||||
<layout class="QVBoxLayout" name="verticalLayout">
|
||||
<item>
|
||||
<widget class="QWidget" name="widget_find" native="true">
|
||||
<layout class="QHBoxLayout" name="hbox_find">
|
||||
<property name="leftMargin">
|
||||
<number>0</number>
|
||||
</property>
|
||||
<property name="topMargin">
|
||||
<number>0</number>
|
||||
</property>
|
||||
<property name="rightMargin">
|
||||
<number>0</number>
|
||||
</property>
|
||||
<property name="bottomMargin">
|
||||
<number>0</number>
|
||||
</property>
|
||||
<item>
|
||||
<widget class="QLineEdit" name="text_find">
|
||||
<property name="enabled">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="clearButtonEnabled">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QCheckBox" name="check_user">
|
||||
<property name="toolTip">
|
||||
<string>Search for Users/Instances</string>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>User/Instance</string>
|
||||
</property>
|
||||
<property name="checked">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QCheckBox" name="check_reason">
|
||||
<property name="toolTip">
|
||||
<string>Search for Reasons</string>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>Reason</string>
|
||||
</property>
|
||||
<property name="checked">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QTableView" name="tableview">
|
||||
<property name="acceptDrops">
|
||||
|
@ -113,6 +167,7 @@
|
|||
<addaction name="action_edit"/>
|
||||
<addaction name="action_remove"/>
|
||||
<addaction name="action_reload"/>
|
||||
<addaction name="action_find"/>
|
||||
<addaction name="separator"/>
|
||||
<addaction name="action_about"/>
|
||||
<addaction name="action_quit"/>
|
||||
|
@ -134,6 +189,7 @@
|
|||
<addaction name="action_edit"/>
|
||||
<addaction name="action_remove"/>
|
||||
<addaction name="action_reload"/>
|
||||
<addaction name="action_find"/>
|
||||
<addaction name="action_quit"/>
|
||||
</widget>
|
||||
<widget class="QMenu" name="menu_help">
|
||||
|
@ -232,6 +288,24 @@
|
|||
<string notr="true">Ctrl+E</string>
|
||||
</property>
|
||||
</action>
|
||||
<action name="action_find">
|
||||
<property name="checkable">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="icon">
|
||||
<iconset theme="edit-find">
|
||||
<normaloff>.</normaloff>.</iconset>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>&Find</string>
|
||||
</property>
|
||||
<property name="toolTip">
|
||||
<string>Find entries</string>
|
||||
</property>
|
||||
<property name="shortcut">
|
||||
<string>Ctrl+F</string>
|
||||
</property>
|
||||
</action>
|
||||
</widget>
|
||||
<resources/>
|
||||
<connections>
|
||||
|
@ -287,7 +361,7 @@
|
|||
<sender>action_reload</sender>
|
||||
<signal>triggered()</signal>
|
||||
<receiver>MainWindow</receiver>
|
||||
<slot>populate_tableview()</slot>
|
||||
<slot>reload()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>-1</x>
|
||||
|
@ -363,6 +437,70 @@
|
|||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
<connection>
|
||||
<sender>action_find</sender>
|
||||
<signal>triggered()</signal>
|
||||
<receiver>MainWindow</receiver>
|
||||
<slot>find()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>-1</x>
|
||||
<y>-1</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>299</x>
|
||||
<y>299</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
<connection>
|
||||
<sender>text_find</sender>
|
||||
<signal>textChanged(QString)</signal>
|
||||
<receiver>MainWindow</receiver>
|
||||
<slot>update_search(QString)</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>201</x>
|
||||
<y>83</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>299</x>
|
||||
<y>299</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
<connection>
|
||||
<sender>check_user</sender>
|
||||
<signal>clicked()</signal>
|
||||
<receiver>MainWindow</receiver>
|
||||
<slot>update_search()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>455</x>
|
||||
<y>82</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>299</x>
|
||||
<y>299</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
<connection>
|
||||
<sender>check_reason</sender>
|
||||
<signal>clicked()</signal>
|
||||
<receiver>MainWindow</receiver>
|
||||
<slot>update_search()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>553</x>
|
||||
<y>82</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>299</x>
|
||||
<y>299</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
</connections>
|
||||
<slots>
|
||||
<slot>add()</slot>
|
||||
|
@ -371,5 +509,11 @@
|
|||
<slot>about()</slot>
|
||||
<slot>show_details(QModelIndex)</slot>
|
||||
<slot>edit()</slot>
|
||||
<slot>find()</slot>
|
||||
<slot>reload()</slot>
|
||||
<slot>check_user_changed(int)</slot>
|
||||
<slot>check_reason_changed(int)</slot>
|
||||
<slot>update_search(QString)</slot>
|
||||
<slot>update_search()</slot>
|
||||
</slots>
|
||||
</ui>
|
|
@ -1,5 +1,5 @@
|
|||
/* This file is part of whyblocked.
|
||||
* Copyright © 2018 tastytea <tastytea@tastytea.de>
|
||||
* Copyright © 2018, 2019 tastytea <tastytea@tastytea.de>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
|
@ -17,7 +17,7 @@
|
|||
#include <iostream>
|
||||
#include <string>
|
||||
#include <vector>
|
||||
#include <tuple>
|
||||
#include <iterator>
|
||||
#include <experimental/filesystem>
|
||||
#include <basedir.h>
|
||||
#include <sqlite/connection.hpp>
|
||||
|
@ -28,20 +28,25 @@
|
|||
using std::cerr;
|
||||
namespace fs = std::experimental::filesystem;
|
||||
|
||||
const string get_filepath()
|
||||
Database::data::operator bool() const
|
||||
{
|
||||
string filepath;
|
||||
return !user.empty();
|
||||
}
|
||||
|
||||
const string Database::get_filepath() const
|
||||
{
|
||||
fs::path filepath;
|
||||
xdgHandle xdg;
|
||||
xdgInitHandle(&xdg);
|
||||
filepath = xdgDataHome(&xdg);
|
||||
xdgWipeHandle(&xdg);
|
||||
|
||||
filepath += "/whyblocked";
|
||||
filepath /= "whyblocked";
|
||||
if (!fs::exists(filepath))
|
||||
{
|
||||
fs::create_directories(filepath);
|
||||
}
|
||||
filepath += "/database.sqlite";
|
||||
filepath /= "database.sqlite";
|
||||
if (!fs::exists(filepath))
|
||||
{
|
||||
sqlite::connection con(filepath);
|
||||
|
@ -53,15 +58,30 @@ const string get_filepath()
|
|||
return filepath;
|
||||
}
|
||||
|
||||
const bool database::add_block(const string &user, const int blocked,
|
||||
const string &reason)
|
||||
bool Database::add_user(const Database::data &userdata)
|
||||
{
|
||||
try
|
||||
{
|
||||
int blocked_int = 0;
|
||||
if (userdata.blocked)
|
||||
{
|
||||
blocked_int = 1;
|
||||
}
|
||||
sqlite::connection con(get_filepath());
|
||||
sqlite::execute ins(con, "INSERT INTO blocks VALUES(?, ?, ?);");
|
||||
ins % user % blocked % reason;
|
||||
ins();
|
||||
{
|
||||
sqlite::execute ins(con, "INSERT INTO blocks VALUES(?, ?, ?);");
|
||||
ins % userdata.user % blocked_int % userdata.reason;
|
||||
ins();
|
||||
}
|
||||
{
|
||||
for (const string &receipt : userdata.receipts)
|
||||
{
|
||||
sqlite::execute ins(con, "INSERT INTO urls VALUES(?, ?);");
|
||||
ins % userdata.user % receipt;
|
||||
ins();
|
||||
}
|
||||
}
|
||||
_data.push_back(userdata);
|
||||
}
|
||||
catch (const std::exception &e)
|
||||
{
|
||||
|
@ -72,25 +92,7 @@ const bool database::add_block(const string &user, const int blocked,
|
|||
return true;
|
||||
}
|
||||
|
||||
const bool database::add_receipt(const string &user, const string &receipt)
|
||||
{
|
||||
try
|
||||
{
|
||||
sqlite::connection con(get_filepath());
|
||||
sqlite::execute ins(con, "INSERT INTO urls VALUES(?, ?);");
|
||||
ins % user % receipt;
|
||||
ins();
|
||||
}
|
||||
catch (const std::exception &e)
|
||||
{
|
||||
cerr << "An error occurred: " << e.what() << std::endl;
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
const bool database::remove(const string &user)
|
||||
bool Database::remove(const string &user)
|
||||
{
|
||||
try
|
||||
{
|
||||
|
@ -101,6 +103,7 @@ const bool database::remove(const string &user)
|
|||
rm_urls % user;
|
||||
rm_blocks();
|
||||
rm_urls();
|
||||
reload();
|
||||
}
|
||||
catch (const std::exception &e)
|
||||
{
|
||||
|
@ -111,69 +114,80 @@ const bool database::remove(const string &user)
|
|||
return true;
|
||||
}
|
||||
|
||||
const bool database::view(result_view &result)
|
||||
const vector<Database::data> Database::query(const string &sql_query) const
|
||||
{
|
||||
try
|
||||
{
|
||||
sqlite::connection con(get_filepath());
|
||||
sqlite::query q(con, "SELECT * FROM blocks;");
|
||||
sqlite::result_type res = q.get_result();
|
||||
while(res->next_row())
|
||||
sqlite::query q_blocks(con, sql_query);
|
||||
sqlite::result_type res_blocks = q_blocks.get_result();
|
||||
std::vector<data> result;
|
||||
|
||||
while(res_blocks->next_row())
|
||||
{
|
||||
const string user = res_blocks->get_string(0);
|
||||
const int blocked = res_blocks->get_int(1);
|
||||
const string reason = res_blocks->get_string(2);
|
||||
bool blocked_bool = false;
|
||||
if (blocked == 1)
|
||||
{
|
||||
blocked_bool = true;
|
||||
}
|
||||
|
||||
sqlite::query q_urls(con,
|
||||
"SELECT * FROM urls WHERE user = \'" + user + "\';");
|
||||
sqlite::result_type res_urls = q_urls.get_result();
|
||||
vector<string> receipts;
|
||||
while(res_urls->next_row())
|
||||
{
|
||||
receipts.push_back(res_urls->get_string(1));
|
||||
}
|
||||
|
||||
result.push_back(
|
||||
{
|
||||
res->get_string(0),
|
||||
res->get_int(1),
|
||||
res->get_string(2)
|
||||
user,
|
||||
blocked_bool,
|
||||
reason,
|
||||
receipts
|
||||
});
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
catch (const std::exception &e)
|
||||
{
|
||||
cerr << "An error occurred: " << e.what() << std::endl;
|
||||
return false;
|
||||
return {};
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
const bool database::details(const string &user, result_details &result)
|
||||
bool Database::reload()
|
||||
{
|
||||
try
|
||||
auto buffer = query();
|
||||
if (buffer.empty())
|
||||
{
|
||||
sqlite::connection con(get_filepath());
|
||||
sqlite::query q_blocks(con,
|
||||
"SELECT * FROM blocks WHERE user = \'" + user + "\';");
|
||||
sqlite::result_type res_blocks = q_blocks.get_result();
|
||||
|
||||
sqlite::query q_urls(con,
|
||||
"SELECT * FROM urls WHERE user = \'" + user + "\';");
|
||||
sqlite::result_type res_urls = q_urls.get_result();
|
||||
|
||||
if (!res_blocks->next_row())
|
||||
{
|
||||
cerr << user << " is not in the database.\n";
|
||||
return false;
|
||||
}
|
||||
|
||||
std::vector<string> urls;
|
||||
while (res_urls->next_row())
|
||||
{
|
||||
urls.push_back(res_urls->get_string(1));
|
||||
}
|
||||
|
||||
result =
|
||||
{
|
||||
res_blocks->get_int(1),
|
||||
res_blocks->get_string(2),
|
||||
urls
|
||||
};
|
||||
}
|
||||
catch (const std::exception &e)
|
||||
{
|
||||
cerr << "An error occurred: " << e.what() << std::endl;
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
else
|
||||
{
|
||||
_data = std::move(buffer);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
std::vector<Database::data> &Database::get_data()
|
||||
{
|
||||
return _data;
|
||||
}
|
||||
|
||||
const Database::data Database::get_user(const string &user) const
|
||||
{
|
||||
for (const Database::data &entry : _data)
|
||||
{
|
||||
if (entry.user == user)
|
||||
{
|
||||
return entry;
|
||||
}
|
||||
}
|
||||
return {};
|
||||
}
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/* This file is part of whyblocked.
|
||||
* Copyright © 2018 tastytea <tastytea@tastytea.de>
|
||||
* Copyright © 2018, 2019 tastytea <tastytea@tastytea.de>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
|
@ -18,22 +18,37 @@
|
|||
#define WHYBLOCKED_HPP
|
||||
|
||||
#include <vector>
|
||||
#include <tuple>
|
||||
#include <string>
|
||||
|
||||
using std::string;
|
||||
using result_view = std::vector<std::tuple<string, int, string>>;
|
||||
using result_details = std::tuple<int, string, std::vector<string>>;
|
||||
using std::vector;
|
||||
|
||||
const string get_filepath();
|
||||
namespace database
|
||||
class Database
|
||||
{
|
||||
const bool add_block(const string &user, const int blocked,
|
||||
const string &reason);
|
||||
const bool add_receipt(const string &user, const string &receipt);
|
||||
const bool remove(const string &user);
|
||||
const bool view(result_view &result);
|
||||
const bool details(const string &user, result_details &result);
|
||||
}
|
||||
public:
|
||||
struct data
|
||||
{
|
||||
string user;
|
||||
bool blocked;
|
||||
string reason;
|
||||
vector<string> receipts;
|
||||
|
||||
explicit operator bool() const;
|
||||
};
|
||||
|
||||
bool add_user(const data &userdata);
|
||||
bool remove(const string &user);
|
||||
const vector<data> query(const string &sql_query =
|
||||
"SELECT * FROM blocks;") const;
|
||||
bool reload();
|
||||
std::vector<data> &get_data();
|
||||
const data get_user(const string &user) const;
|
||||
|
||||
private:
|
||||
std::vector<data> _data;
|
||||
|
||||
private:
|
||||
const string get_filepath() const;
|
||||
};
|
||||
|
||||
#endif // WHYBLOCKED_HPP
|
||||
|
|
|
@ -1 +0,0 @@
|
|||
../xdgcfg/src/xdgcfg.cpp
|
|
@ -0,0 +1,95 @@
|
|||
/* Copyright © 2019 tastytea <tastytea@tastytea.de>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify it
|
||||
* under the terms of the BSD-3-Clause license.
|
||||
*/
|
||||
|
||||
#include <basedir.h>
|
||||
#include "xdgcfg.hpp"
|
||||
|
||||
xdgcfg::xdgcfg(const string &filename, const string &subdir)
|
||||
: _cfg()
|
||||
, _verbose(false)
|
||||
{
|
||||
xdgHandle xdg;
|
||||
xdgInitHandle(&xdg);
|
||||
_filepath = xdgConfigHome(&xdg);
|
||||
xdgWipeHandle(&xdg);
|
||||
|
||||
if (!subdir.empty())
|
||||
{
|
||||
_filepath /= subdir;
|
||||
}
|
||||
if (!fs::exists(_filepath))
|
||||
{
|
||||
fs::create_directories(_filepath);
|
||||
}
|
||||
_filepath /= filename;
|
||||
}
|
||||
|
||||
uint8_t xdgcfg::read()
|
||||
{
|
||||
try
|
||||
{
|
||||
_cfg.readFile(_filepath.c_str());
|
||||
}
|
||||
catch (const libconfig::FileIOException &e)
|
||||
{
|
||||
if (_verbose)
|
||||
{
|
||||
cerr << "I/O error while reading " << _filepath
|
||||
<< " - " << e.what() << endl;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
catch (const libconfig::ParseException &e)
|
||||
{
|
||||
if (_verbose)
|
||||
{
|
||||
cerr << "Parse error at " << e.getFile() << ":" << e.getLine()
|
||||
<< " - " << e.getError() << endl;
|
||||
}
|
||||
return 2;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
bool xdgcfg::write()
|
||||
{
|
||||
try
|
||||
{
|
||||
_cfg.writeFile(_filepath.c_str());
|
||||
}
|
||||
catch (const libconfig::FileIOException &e)
|
||||
{
|
||||
if (_verbose)
|
||||
{
|
||||
cerr << "I/O error while writing " << _filepath
|
||||
<< " - " << e.what() << endl;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
libconfig::Config &xdgcfg::get_cfg()
|
||||
{
|
||||
return _cfg;
|
||||
}
|
||||
|
||||
const fs::path xdgcfg::get_filepath() const
|
||||
{
|
||||
return _filepath;
|
||||
}
|
||||
|
||||
void xdgcfg::set_verbose(bool verbose)
|
||||
{
|
||||
_verbose = verbose;
|
||||
}
|
||||
|
||||
bool xdgcfg::get_verbose() const
|
||||
{
|
||||
return _verbose;
|
||||
}
|
|
@ -1 +0,0 @@
|
|||
../xdgcfg/src/xdgcfg.hpp
|
|
@ -0,0 +1,106 @@
|
|||
/* Copyright © 2019 tastytea <tastytea@tastytea.de>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify it
|
||||
* under the terms of the BSD-3-Clause license.
|
||||
*/
|
||||
|
||||
#ifndef XDGCFG_HPP
|
||||
#define XDGCFG_HPP
|
||||
|
||||
#if __cplusplus >= 201703L
|
||||
#include <filesystem>
|
||||
#else
|
||||
#include <experimental/filesystem>
|
||||
#endif
|
||||
#include <string>
|
||||
#include <iostream>
|
||||
#include <cstdint>
|
||||
#include <libconfig.h++>
|
||||
|
||||
#if __cplusplus >= 201703L
|
||||
namespace fs = std::filesystem;
|
||||
#else
|
||||
namespace fs = std::experimental::filesystem;
|
||||
#endif
|
||||
using std::string;
|
||||
using std::uint8_t;
|
||||
using std::cerr;
|
||||
using std::endl;
|
||||
|
||||
class xdgcfg
|
||||
{
|
||||
public:
|
||||
/*!
|
||||
* @brief Checks if subdir is present, creates it if necessary
|
||||
*
|
||||
* Example:
|
||||
* @code
|
||||
* xdgcfg config("test.cfg", "subdirectory");
|
||||
* @endcode
|
||||
*
|
||||
* @param filename The name of the file, including extension
|
||||
* @param subdir The subdir (optional)
|
||||
*/
|
||||
explicit xdgcfg(const string &filename, const string &subdir = "");
|
||||
|
||||
/*!
|
||||
* @brief Read the file
|
||||
*
|
||||
* @return 0 on success, 1 on I/O error, 2 on parse error.
|
||||
*/
|
||||
uint8_t read();
|
||||
|
||||
/*!
|
||||
* @brief Write the file
|
||||
*
|
||||
* @return `true` on success
|
||||
*/
|
||||
bool write();
|
||||
|
||||
/*!
|
||||
* @brief Returns a reference to the config as libconfig::Config
|
||||
*
|
||||
* Example:
|
||||
* @code
|
||||
* libconfig::Config &cfg = config.get_cfg();
|
||||
* @endcode
|
||||
*/
|
||||
libconfig::Config &get_cfg();
|
||||
|
||||
/*!
|
||||
* @brief Returns the complete filepath
|
||||
*/
|
||||
const fs::path get_filepath() const;
|
||||
|
||||
/*!
|
||||
* @brief Sets verbosity
|
||||
*/
|
||||
void set_verbose(bool verbose);
|
||||
|
||||
/*!
|
||||
* @brief Returns verbosity
|
||||
*/
|
||||
bool get_verbose() const;
|
||||
|
||||
private:
|
||||
/*!
|
||||
* Holds the contents of the CFG file
|
||||
*/
|
||||
libconfig::Config _cfg;
|
||||
|
||||
/*!
|
||||
* Complete filepath
|
||||
*/
|
||||
fs::path _filepath;
|
||||
|
||||
/*!
|
||||
* Print out error messages if true
|
||||
*/
|
||||
bool _verbose;
|
||||
};
|
||||
|
||||
/*!
|
||||
* @example example.cpp
|
||||
*/
|
||||
|
||||
#endif // XDGCFG_HPP
|
|
@ -8,6 +8,5 @@ qt5_create_translation(QM_FILES ${TS_SRC_FILES} ${TS_FILES}
|
|||
# qt5_add_translation(QM_FILES ${TS_FILES})
|
||||
add_custom_target(translations ALL DEPENDS ${QM_FILES})
|
||||
add_dependencies(${CMAKE_PROJECT_NAME} translations)
|
||||
add_dependencies(${CMAKE_PROJECT_NAME}-gui translations)
|
||||
install(FILES ${QM_FILES} DESTINATION
|
||||
${CMAKE_INSTALL_DATAROOTDIR}/qt5/translations)
|
||||
|
|
|
@ -4,77 +4,77 @@
|
|||
<context>
|
||||
<name>DialogAdd</name>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="17"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="17"/>
|
||||
<source>Add entry</source>
|
||||
<translation>Eintrag hinzufügen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="40"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="40"/>
|
||||
<source>Memory aids, proof</source>
|
||||
<translation>Gedächtnisstützen, Beweise</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="43"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="43"/>
|
||||
<source>Rece&ipts</source>
|
||||
<translation>Be&lege</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="56"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="56"/>
|
||||
<source>Add receipt</source>
|
||||
<translation>Beleg hinzufügen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="59"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="59"/>
|
||||
<source>&Add</source>
|
||||
<translation>&Hinzufügen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="79"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="79"/>
|
||||
<source>&Blocked</source>
|
||||
<translation>&Blockiert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="98"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="98"/>
|
||||
<source>&Silenced</source>
|
||||
<translation>&Gedämpft</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="105"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="105"/>
|
||||
<source>R&eason</source>
|
||||
<translation>B&egründung</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="134"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="134"/>
|
||||
<source>Blocked/Silenced</source>
|
||||
<translation>Blockiert/Gedämpft</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="144"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="144"/>
|
||||
<source>&User/Instance</source>
|
||||
<translation>Ben&utzer/Instanz</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="154"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="154"/>
|
||||
<source>Remove receipt</source>
|
||||
<translation>Beleg entfernen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="157"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="157"/>
|
||||
<source>Re&move</source>
|
||||
<translation>Ent&fernen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="164"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="164"/>
|
||||
<source>Del</source>
|
||||
<translation></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="171"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="171"/>
|
||||
<source>You can drag URLs in here</source>
|
||||
<translation type="unfinished">Du kannst URLs hier hineinziehen</translation>
|
||||
<translation>Du kannst URLs hier hineinziehen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="375"/>
|
||||
<location filename="../src/qt/dialog_add.cpp" line="79"/>
|
||||
<source>Insert receipt here.</source>
|
||||
<translation>Beleg hier einfügen.</translation>
|
||||
</message>
|
||||
|
@ -82,336 +82,207 @@
|
|||
<context>
|
||||
<name>MainWindow</name>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="17"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="17"/>
|
||||
<source>Whyblocked</source>
|
||||
<translation></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="34"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="56"/>
|
||||
<source>Search for Users/Instances</source>
|
||||
<translation>Suche nach Benutzern/Instanzen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/qt/whyblocked.ui" line="69"/>
|
||||
<source>Search for Reasons</source>
|
||||
<translation>Suche nach Begründungen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/qt/whyblocked.ui" line="88"/>
|
||||
<source>Click or press enter to view receipts</source>
|
||||
<translation>Klicken oder Eingabe drücken, um Belege zu anzuzeigen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="77"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="131"/>
|
||||
<source>Memory aids, proof</source>
|
||||
<translation>Gedächtnisstützen, Beweise</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="101"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="155"/>
|
||||
<source>Toolbar</source>
|
||||
<translation>Werkzeugleiste</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="131"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="186"/>
|
||||
<source>&Database</source>
|
||||
<translation>&Datenbank</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="141"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="197"/>
|
||||
<source>&Help</source>
|
||||
<translation>&Hilfe</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="154"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="210"/>
|
||||
<source>&Add</source>
|
||||
<translation>&Hinzufügen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="157"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="213"/>
|
||||
<source>Add user or instance</source>
|
||||
<translation>Benutzer oder Instanz hinzufügen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="160"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="216"/>
|
||||
<source>Ctrl+N</source>
|
||||
<translation></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="169"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="225"/>
|
||||
<source>Re&move</source>
|
||||
<translation>Ent&fernen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="172"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="228"/>
|
||||
<source>Remove user or instance</source>
|
||||
<translation>Benutzer oder Instanz entfernen</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="175"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="231"/>
|
||||
<source>Del</source>
|
||||
<translation></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="184"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="240"/>
|
||||
<source>&About</source>
|
||||
<translation>&Über</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="187"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="243"/>
|
||||
<source>About this application</source>
|
||||
<translation>Über dieses Programm</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="196"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="252"/>
|
||||
<source>&Reload</source>
|
||||
<translation>Neu &laden</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="199"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="255"/>
|
||||
<source>Reload database</source>
|
||||
<translation>Datenbank neu laden</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="202"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="258"/>
|
||||
<source>Ctrl+R</source>
|
||||
<translation></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="211"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="267"/>
|
||||
<source>&Quit</source>
|
||||
<translation>&Beenden</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="214"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="270"/>
|
||||
<source>Quit application</source>
|
||||
<translation>Programm beenden</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="217"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="273"/>
|
||||
<source>Ctrl+Q</source>
|
||||
<translation></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="226"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="282"/>
|
||||
<source>&Edit</source>
|
||||
<translation>B&earbeiten</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="229"/>
|
||||
<location filename="../src/interface_qt.cpp" line="209"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="285"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="279"/>
|
||||
<source>Edit entry</source>
|
||||
<translation>Eintrag bearbeiten</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="156"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="300"/>
|
||||
<source>&Find</source>
|
||||
<translation>&Finden</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/qt/whyblocked.ui" line="303"/>
|
||||
<source>Find entries</source>
|
||||
<translation>Finde Einträge</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/qt/whyblocked.ui" line="306"/>
|
||||
<source>Ctrl+F</source>
|
||||
<translation></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/qt/whyblocked.ui" line="59"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="329"/>
|
||||
<source>User/Instance</source>
|
||||
<translation>Benutzer/Instanz</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="157"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="330"/>
|
||||
<source>Blocked/Silenced</source>
|
||||
<translation>Blockiert/Gedämpft</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="158"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="72"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="331"/>
|
||||
<source>Reason</source>
|
||||
<translation>Begründung</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="90"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="109"/>
|
||||
<source>Try dragging an account from your webbrowser into this window.</source>
|
||||
<translation>Versuche, einen account von deinem webbrowser in dieses fenster zu ziehen.</translation>
|
||||
<translation>Versuche, einen Account von deinem Webbrowser in dieses Fenster zu ziehen.</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="183"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="184"/>
|
||||
<source>blocked</source>
|
||||
<translation>blockiert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="187"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="188"/>
|
||||
<source>silenced</source>
|
||||
<translation>gedämpft</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="203"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="273"/>
|
||||
<source>Invalid selection</source>
|
||||
<translation>Ungültige Auswahl</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="204"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="274"/>
|
||||
<source>Please select only 1 entry to edit.</source>
|
||||
<translation>Bitte nur 1 Eintrag zum bearbeiten auswählen.</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="247"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="212"/>
|
||||
<source>Nothing selected</source>
|
||||
<translation>Nichts ausgewählt</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="248"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="213"/>
|
||||
<source>Please select entries to remove.</source>
|
||||
<translation>Bitte wähle einträge aus, die gelöscht werden sollen.</translation>
|
||||
<translation>Bitte wähle Einträge aus, die gelöscht werden sollen.</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="254"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="292"/>
|
||||
<source>About Whyblocked</source>
|
||||
<translation>Über Whyblocked</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="255"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="293"/>
|
||||
<source><p><b>Whyblocked</b> %1</p><p>Reminds you why you blocked someone.</p><p>Sourcecode: <a href="https://schlomp.space/tastytea/whyblocked">https://schlomp.space/tastytea/whyblocked</a></p><p><small>Copyright © 2018 <a href="mailto:tastytea@tastytea.de">tastytea</a>.<br>Licence GPLv3: <a href="https://www.gnu.org/licenses/gpl-3.0.html">GNU GPL version 3</a>.<br>This program comes with ABSOLUTELY NO WARRANTY. This is free software, and you are welcome to redistribute it under certain conditions.</small></p></source>
|
||||
<translation><p><b>Whyblocked</b> %1</p><p>Erinnert dich, warum du jemanden blockiertest.</p><p>Quelltext: <a href="https://schlomp.space/tastytea/whyblocked">https://schlomp.space/tastytea/whyblocked</a></p><p><small>Copyright © 2018 <a href="mailto:tastytea@tastytea.de">tastytea</a>.<br>Lizenz GPLv3: <a href="https://www.gnu.org/licenses/gpl-3.0.html">GNU GPL version 3</a>.<br>Für dieses Programm besteht KEINERLEI GARANTIE. Dies ist freie Software, die Sie unter bestimmten Bedingungen weitergeben dürfen.</small></p></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="278"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="314"/>
|
||||
<source>Receipts:</source>
|
||||
<translation>Belege:</translation>
|
||||
</message>
|
||||
</context>
|
||||
<context>
|
||||
<name>Text</name>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="51"/>
|
||||
<source>Blocked or silenced?</source>
|
||||
<translation>Blockiert oder gedämpft?</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="68"/>
|
||||
<source>Add receipt? [y/n]</source>
|
||||
<translation>Beleg hinzufügen? [j/n]</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="69"/>
|
||||
<source>y</source>
|
||||
<translation>j</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="69"/>
|
||||
<source>Y</source>
|
||||
<translation>J</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="71"/>
|
||||
<source>Receipt</source>
|
||||
<translation>Beleg</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="75"/>
|
||||
<source>Receipt added.</source>
|
||||
<translation>Beleg hinzugefügt.</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="78"/>
|
||||
<source>n</source>
|
||||
<translation>n</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="78"/>
|
||||
<source>N</source>
|
||||
<translation>N</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="91"/>
|
||||
<location filename="../src/interface_text.cpp" line="115"/>
|
||||
<location filename="../src/interface_text.cpp" line="175"/>
|
||||
<location filename="../src/interface_text.cpp" line="206"/>
|
||||
<source>User or instance</source>
|
||||
<translation>Benutzer oder Instanz</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="102"/>
|
||||
<source>Reason</source>
|
||||
<translation>Begründung</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="106"/>
|
||||
<source>added.</source>
|
||||
<translation>hinzugefügt.</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="118"/>
|
||||
<source>A blank line keeps the former value.</source>
|
||||
<translation>Leere Zeile um den alten Wert zu erhalten.</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="119"/>
|
||||
<source>Change user or instance to</source>
|
||||
<translation>Ändere Benutzer oder Instanz zu</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="135"/>
|
||||
<source>Old reason was:</source>
|
||||
<translation>Alte Begründung war:</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="136"/>
|
||||
<source>Change reason to</source>
|
||||
<translation>Ändere Begründung zu</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="145"/>
|
||||
<source>Old receipt was:</source>
|
||||
<translation>Alter Beleg war:</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="146"/>
|
||||
<source>Change receipt to</source>
|
||||
<translation>Ändere beleg zu</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="168"/>
|
||||
<source>Could not remove</source>
|
||||
<translation>Konnte nicht entfernen:</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="179"/>
|
||||
<source>removed.</source>
|
||||
<translation>entfernt.</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="192"/>
|
||||
<source> Blocked:</source>
|
||||
<translation>Blockiert:</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="196"/>
|
||||
<source>Silenced:</source>
|
||||
<translation> Gedämpft:</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="198"/>
|
||||
<source>because:</source>
|
||||
<translation>weil:</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="211"/>
|
||||
<source>is</source>
|
||||
<translation>ist</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="214"/>
|
||||
<source>blocked, because:</source>
|
||||
<translation>blockiert, weil:</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="218"/>
|
||||
<source>silenced, because:</source>
|
||||
<translation>gedämpft, weil:</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="224"/>
|
||||
<source>Receipts:</source>
|
||||
<translation>Belege:</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="236"/>
|
||||
<source>Type add, edit, remove, view or details. Or just the first letter.</source>
|
||||
<translation>Schreibe a für hinzufügen, e für ändern, r für entfernen, v für anschauen oder d für Details.</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="239"/>
|
||||
<source>Type help or h to show this help. Type quit or q to quit the program.</source>
|
||||
<translation>Schreibe hilfe oder h, um die Hilfe anzuzeigen. Schreibe q um das Programm zu beenden.</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="248"/>
|
||||
<source>This is Whyblocked</source>
|
||||
<translation>Dies ist Whyblocked</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="299"/>
|
||||
<source>Response not understood.</source>
|
||||
<translation>Antwort nicht verstanden.</translation>
|
||||
</message>
|
||||
</context>
|
||||
</TS>
|
||||
|
|
|
@ -4,77 +4,77 @@
|
|||
<context>
|
||||
<name>DialogAdd</name>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="17"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="17"/>
|
||||
<source>Add entry</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="40"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="40"/>
|
||||
<source>Memory aids, proof</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="43"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="43"/>
|
||||
<source>Rece&ipts</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="56"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="56"/>
|
||||
<source>Add receipt</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="59"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="59"/>
|
||||
<source>&Add</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="79"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="79"/>
|
||||
<source>&Blocked</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="98"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="98"/>
|
||||
<source>&Silenced</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="105"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="105"/>
|
||||
<source>R&eason</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="134"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="134"/>
|
||||
<source>Blocked/Silenced</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="144"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="144"/>
|
||||
<source>&User/Instance</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="154"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="154"/>
|
||||
<source>Remove receipt</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="157"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="157"/>
|
||||
<source>Re&move</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="164"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="164"/>
|
||||
<source>Del</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked_add.ui" line="171"/>
|
||||
<location filename="../src/qt/whyblocked_add.ui" line="171"/>
|
||||
<source>You can drag URLs in here</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="375"/>
|
||||
<location filename="../src/qt/dialog_add.cpp" line="79"/>
|
||||
<source>Insert receipt here.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
|
@ -82,336 +82,207 @@
|
|||
<context>
|
||||
<name>MainWindow</name>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="17"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="17"/>
|
||||
<source>Whyblocked</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="34"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="56"/>
|
||||
<source>Search for Users/Instances</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/qt/whyblocked.ui" line="69"/>
|
||||
<source>Search for Reasons</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/qt/whyblocked.ui" line="88"/>
|
||||
<source>Click or press enter to view receipts</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="77"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="131"/>
|
||||
<source>Memory aids, proof</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="101"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="155"/>
|
||||
<source>Toolbar</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="131"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="186"/>
|
||||
<source>&Database</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="141"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="197"/>
|
||||
<source>&Help</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="154"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="210"/>
|
||||
<source>&Add</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="157"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="213"/>
|
||||
<source>Add user or instance</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="160"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="216"/>
|
||||
<source>Ctrl+N</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="169"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="225"/>
|
||||
<source>Re&move</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="172"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="228"/>
|
||||
<source>Remove user or instance</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="175"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="231"/>
|
||||
<source>Del</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="184"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="240"/>
|
||||
<source>&About</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="187"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="243"/>
|
||||
<source>About this application</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="196"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="252"/>
|
||||
<source>&Reload</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="199"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="255"/>
|
||||
<source>Reload database</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="202"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="258"/>
|
||||
<source>Ctrl+R</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="211"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="267"/>
|
||||
<source>&Quit</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="214"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="270"/>
|
||||
<source>Quit application</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="217"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="273"/>
|
||||
<source>Ctrl+Q</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="226"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="282"/>
|
||||
<source>&Edit</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/whyblocked.ui" line="229"/>
|
||||
<location filename="../src/interface_qt.cpp" line="209"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="285"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="279"/>
|
||||
<source>Edit entry</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="156"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="300"/>
|
||||
<source>&Find</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/qt/whyblocked.ui" line="303"/>
|
||||
<source>Find entries</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/qt/whyblocked.ui" line="306"/>
|
||||
<source>Ctrl+F</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/qt/whyblocked.ui" line="59"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="329"/>
|
||||
<source>User/Instance</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="157"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="330"/>
|
||||
<source>Blocked/Silenced</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="158"/>
|
||||
<location filename="../src/qt/whyblocked.ui" line="72"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="331"/>
|
||||
<source>Reason</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="90"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="109"/>
|
||||
<source>Try dragging an account from your webbrowser into this window.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="183"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="184"/>
|
||||
<source>blocked</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="187"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="188"/>
|
||||
<source>silenced</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="203"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="273"/>
|
||||
<source>Invalid selection</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="204"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="274"/>
|
||||
<source>Please select only 1 entry to edit.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="247"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="212"/>
|
||||
<source>Nothing selected</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="248"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="213"/>
|
||||
<source>Please select entries to remove.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="254"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="292"/>
|
||||
<source>About Whyblocked</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="255"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="293"/>
|
||||
<source><p><b>Whyblocked</b> %1</p><p>Reminds you why you blocked someone.</p><p>Sourcecode: <a href="https://schlomp.space/tastytea/whyblocked">https://schlomp.space/tastytea/whyblocked</a></p><p><small>Copyright © 2018 <a href="mailto:tastytea@tastytea.de">tastytea</a>.<br>Licence GPLv3: <a href="https://www.gnu.org/licenses/gpl-3.0.html">GNU GPL version 3</a>.<br>This program comes with ABSOLUTELY NO WARRANTY. This is free software, and you are welcome to redistribute it under certain conditions.</small></p></source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_qt.cpp" line="278"/>
|
||||
<location filename="../src/qt/mainwindow.cpp" line="314"/>
|
||||
<source>Receipts:</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
</context>
|
||||
<context>
|
||||
<name>Text</name>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="51"/>
|
||||
<source>Blocked or silenced?</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="68"/>
|
||||
<source>Add receipt? [y/n]</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="69"/>
|
||||
<source>y</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="69"/>
|
||||
<source>Y</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="71"/>
|
||||
<source>Receipt</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="75"/>
|
||||
<source>Receipt added.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="78"/>
|
||||
<source>n</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="78"/>
|
||||
<source>N</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="91"/>
|
||||
<location filename="../src/interface_text.cpp" line="115"/>
|
||||
<location filename="../src/interface_text.cpp" line="175"/>
|
||||
<location filename="../src/interface_text.cpp" line="206"/>
|
||||
<source>User or instance</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="102"/>
|
||||
<source>Reason</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="106"/>
|
||||
<source>added.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="118"/>
|
||||
<source>A blank line keeps the former value.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="119"/>
|
||||
<source>Change user or instance to</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="135"/>
|
||||
<source>Old reason was:</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="136"/>
|
||||
<source>Change reason to</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="145"/>
|
||||
<source>Old receipt was:</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="146"/>
|
||||
<source>Change receipt to</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="168"/>
|
||||
<source>Could not remove</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="179"/>
|
||||
<source>removed.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="192"/>
|
||||
<source> Blocked:</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="196"/>
|
||||
<source>Silenced:</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="198"/>
|
||||
<source>because:</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="211"/>
|
||||
<source>is</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="214"/>
|
||||
<source>blocked, because:</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="218"/>
|
||||
<source>silenced, because:</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="224"/>
|
||||
<source>Receipts:</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="236"/>
|
||||
<source>Type add, edit, remove, view or details. Or just the first letter.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="239"/>
|
||||
<source>Type help or h to show this help. Type quit or q to quit the program.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="248"/>
|
||||
<source>This is Whyblocked</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../src/interface_text.cpp" line="299"/>
|
||||
<source>Response not understood.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
</context>
|
||||
</TS>
|
||||
|
|
|
@ -0,0 +1,37 @@
|
|||
= whyblocked(1)
|
||||
:Author: tastytea
|
||||
:Email: tastytea@tastytea.de
|
||||
:Date: 2019-04-12
|
||||
:Revision: 0.0.0
|
||||
:man source: Whyblocked
|
||||
:man version: {revision}
|
||||
:man manual: General Commands Manual
|
||||
|
||||
== NAME
|
||||
|
||||
whyblocked - reminds you why you blocked someone.
|
||||
|
||||
== SYNOPSIS
|
||||
|
||||
*whyblocked*
|
||||
|
||||
== DESCRIPTION
|
||||
|
||||
Whyblocked allows you to store the reason why you blocked someone, along with
|
||||
"receipts", URLs to the posts that led you to block them.
|
||||
|
||||
Apart from the obvious method, you can add entries by dropping the link to a
|
||||
profile into the main window. In the "Add entry" dialog, you can add receipts by
|
||||
dropping links or text into the receipts list.
|
||||
|
||||
== FILES
|
||||
|
||||
- *Configuration file*: `${XDG_CONFIG_HOME}/whyblocked.cfg`
|
||||
- *Database*: `${XDG_DATA_HOME}/whyblocked/database.sqlite`
|
||||
|
||||
`${XDG_CONFIG_HOME}` is usually `~/.config` and `${XDG_DATA_HOME}` is usually
|
||||
`~/.local/share`
|
||||
|
||||
== REPORTING BUGS
|
||||
|
||||
Bugtracker: https://schlomp.space/tastytea/whyblocked/issues
|
1
xdgcfg
1
xdgcfg
|
@ -1 +0,0 @@
|
|||
Subproject commit 6c0976baa74f959ed3218af56e56ff58202a5a05
|
Loading…
Reference in New Issue