1
0
mirror of https://github.com/arsenetar/dupeguru.git synced 2026-01-28 17:31:38 +00:00

Compare commits

..

9 Commits

Author SHA1 Message Date
Stanislav
5d67511315 Merge cd70c99c67 into 3a97ba941a 2024-06-03 22:15:47 +02:00
Stanislav
cd70c99c67 Merge branch 'arsenetar:master' into i18n_Russian 2023-12-07 21:52:39 +03:00
Stanislav
7eafb86c2b Merge branch 'arsenetar:master' into i18n_Russian 2023-08-13 18:35:41 +03:00
Stanislav
71672bc2c9 Update ui.po 2023-06-25 20:39:10 +03:00
Stanislav
f4e6768caf Update core.po 2023-06-24 12:39:40 +03:00
Stanislav
8ce4080c4e Update ui.po 2023-06-24 12:38:57 +03:00
Stanislav
f191b64cca Update columns.po 2023-06-24 12:34:42 +03:00
Stanislav
a714a0860c Update core.po 2023-06-24 12:33:16 +03:00
Stanislav
5fb8caefa9 Small fix Russian language 2023-06-24 12:04:47 +03:00
10 changed files with 69 additions and 66 deletions

12
.github/FUNDING.yml vendored
View File

@@ -1 +1,13 @@
# These are supported funding model platforms
github: arsenetar
patreon: # Replace with a single Patreon username
open_collective: # Replace with a single Open Collective username
ko_fi: # Replace with a single Ko-fi username
tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry
liberapay: # Replace with a single Liberapay username
issuehunt: # Replace with a single IssueHunt username
otechie: # Replace with a single Otechie username
lfx_crowdfunding: # Replace with a single LFX Crowdfunding project-name e.g., cloud-foundry
custom: # Replace with up to 4 custom sponsorship URLs e.g., ['link1', 'link2']

View File

@@ -25,10 +25,11 @@ jobs:
steps:
- name: Checkout repository
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
uses: actions/checkout@v2
# Initializes the CodeQL tools for scanning.
- name: Initialize CodeQL
uses: github/codeql-action/init@5d4e8d1aca955e8d8589aabd499c5cae939e33c7 # v4.31.9
uses: github/codeql-action/init@v1
with:
languages: ${{ matrix.language }}
# If you wish to specify custom queries, you can do so here or in a config file.
@@ -43,7 +44,7 @@ jobs:
make modules
- if: matrix.language == 'python'
name: Autobuild
uses: github/codeql-action/autobuild@5d4e8d1aca955e8d8589aabd499c5cae939e33c7 # v4.31.9
uses: github/codeql-action/autobuild@v1
# Analysis
- name: Perform CodeQL Analysis
uses: github/codeql-action/analyze@5d4e8d1aca955e8d8589aabd499c5cae939e33c7 # v4.31.9
uses: github/codeql-action/analyze@v1

View File

@@ -11,9 +11,9 @@ jobs:
pre-commit:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
- uses: actions/checkout@v4
- name: Set up Python 3.12
uses: actions/setup-python@83679a892e2d95755f2dac6acb0bfd1e9ac5d548 # v6.1.0
uses: actions/setup-python@v5
with:
python-version: "3.12"
- uses: pre-commit/action@v3.0.1
@@ -23,7 +23,7 @@ jobs:
strategy:
matrix:
os: [ubuntu-latest]
python-version: [3.8, 3.9, "3.10", "3.11", "3.12", "3.13", "3.14"]
python-version: [3.7, 3.8, 3.9, "3.10", "3.11", "3.12"]
include:
- os: windows-latest
python-version: "3.12"
@@ -31,9 +31,9 @@ jobs:
python-version: "3.12"
steps:
- uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
- uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@83679a892e2d95755f2dac6acb0bfd1e9ac5d548 # v6.1.0
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Install dependencies
@@ -49,7 +49,7 @@ jobs:
pytest core hscommon
- name: Upload Artifacts
if: matrix.os == 'ubuntu-latest'
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
uses: actions/upload-artifact@v4
with:
name: modules ${{ matrix.python-version }}
path: build/**/*.so
@@ -58,7 +58,7 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Merge Artifacts
uses: actions/upload-artifact/merge@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
uses: actions/upload-artifact/merge@v4
with:
name: modules
pattern: modules*

View File

@@ -15,7 +15,7 @@ jobs:
push-source:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
- uses: actions/checkout@v4
- name: Get Transifex Client
run: |
curl -o- https://raw.githubusercontent.com/transifex/cli/master/install.sh | bash -s -- $TX_VERSION

View File

@@ -10,6 +10,7 @@ from optparse import OptionParser
import shutil
from multiprocessing import Pool
from setuptools import sandbox
from hscommon import sphinxgen
from hscommon.build import (
add_to_pythonpath,
@@ -17,7 +18,6 @@ from hscommon.build import (
fix_qt_resource_file,
)
from hscommon import loc
import subprocess
def parse_args():
@@ -118,7 +118,7 @@ def build_normpo():
def build_pe_modules():
print("Building PE Modules")
# Leverage setup.py to build modules
subprocess.check_call([sys.executable, "setup.py", "build_ext", "--inplace"])
sandbox.run_setup("setup.py", ["build_ext", "--inplace"])
def build_normal():

View File

@@ -96,8 +96,6 @@ class FilenameCategory(CriterionCategory):
DOESNT_END_WITH_NUMBER = 1
LONGEST = 2
SHORTEST = 3
LONGEST_PATH = 4
SHORTEST_PATH = 5
def format_criterion_value(self, value):
return {
@@ -105,8 +103,6 @@ class FilenameCategory(CriterionCategory):
self.DOESNT_END_WITH_NUMBER: tr("Doesn't end with number"),
self.LONGEST: tr("Longest"),
self.SHORTEST: tr("Shortest"),
self.LONGEST_PATH: tr("Longest Path"),
self.SHORTEST_PATH: tr("Shortest Path"),
}[value]
def extract_value(self, dupe):
@@ -120,10 +116,6 @@ class FilenameCategory(CriterionCategory):
return 0 if ends_with_digit else 1
else:
return 1 if ends_with_digit else 0
elif crit_value == self.LONGEST_PATH:
return len(str(dupe.folder_path)) * -1
elif crit_value == self.SHORTEST_PATH:
return len(str(dupe.folder_path))
else:
value = len(value)
if crit_value == self.LONGEST:
@@ -138,8 +130,6 @@ class FilenameCategory(CriterionCategory):
self.DOESNT_END_WITH_NUMBER,
self.LONGEST,
self.SHORTEST,
self.LONGEST_PATH,
self.SHORTEST_PATH,
]
]

View File

@@ -325,7 +325,7 @@ class Results(Markable):
del self.__group_of_duplicate[dupe]
self._remove_mark_flag(dupe)
self.__total_count -= 1
self.__total_size = max(0, self.__total_size - dupe.size)
self.__total_size -= dupe.size
if not group:
del self.__group_of_duplicate[ref]
self.__groups.remove(group)

View File

@@ -112,7 +112,7 @@ msgstr "Размеры"
#: core\pe\result_table.py:21 core\se\result_table.py:21
msgid "Size (KB)"
msgstr "Размер (КБ)"
msgstr "Размер (кБ)"
#: core\pe\result_table.py:24
msgid "EXIF Timestamp"

View File

@@ -100,15 +100,15 @@ msgstr ""
#: core\app.py:469
msgid "Select a directory to copy marked files to"
msgstr "Выберите каталог, в который вы хотите скопировать отмеченные файлы"
msgstr "Выберите каталог, в который Вы хотите скопировать отмеченные файлы"
#: core\app.py:471
msgid "Select a directory to move marked files to"
msgstr "Выберите каталог, в который вы хотите переместить отмеченные файлы"
msgstr "Выберите каталог для перемещения отмеченных файлов"
#: core\app.py:510
msgid "Select a destination for your exported CSV"
msgstr "Выберите назначение для экспортируемого "
msgstr "Выберите назначение для Вашего экспортируемого CSV"
#: core\app.py:516 core\app.py:777 core\app.py:787
msgid "Couldn't write to file: {}"
@@ -124,7 +124,7 @@ msgstr "Вы собираетесь удалить %d файлов из резу
#: core\app.py:749
msgid "{} duplicate groups were changed by the re-prioritization."
msgstr "{} групп дубликатов было изменено при реприоритезации."
msgstr "{} групп дубликатов было изменено при обновлении приоритета."
#: core\app.py:797
msgid "The selected directories contain no scannable file."
@@ -136,7 +136,7 @@ msgstr "Сбор файлов для сканирования"
#: core\app.py:863
msgid "%s (%d discarded)"
msgstr "%s. (%d отменено)"
msgstr "%s (%d отменено)"
#: core\directories.py:191
msgid "Collected {} files to scan"
@@ -148,7 +148,7 @@ msgstr "Собрано {} каталогов для сканирования"
#: core\engine.py:27
msgid "%d matches found from %d groups"
msgstr "Найдено %d совпадений из %d групп"
msgstr "%d совпадений найдено из %d групп"
#: core\gui\deletion_options.py:71
msgid "You are sending {} file(s) to the Trash."
@@ -249,7 +249,7 @@ msgstr "%d / %d (%s / %s) дубликатов отмечено."
#: core\results.py:142
msgid " filter: %s"
msgstr "фильтр: %s"
msgstr " фильтр: %s"
#: core\scanner.py:114
msgid "Read metadata of %d/%d files"
@@ -262,3 +262,4 @@ msgstr "Почти готово! Вожусь с результатами..."
#: core\se\scanner.py:18
msgid "Folders"
msgstr "Папки"

View File

@@ -93,8 +93,8 @@ msgid ""
"Instead of sending files to trash, delete them directly. This option is "
"usually used as a workaround when the normal deletion method doesn't work."
msgstr ""
"Удалить файлы с диска вместо отправки в Корзину. Используйте если нормальный"
" метод удаления не работает."
"Удалить файлы с диска вместо отправки в Корзину. Используйте, если нормальный "
"метод удаления не работает."
#: qt/deletion_options.py:59 cocoa/en.lproj/Localizable.strings:0
msgid "Proceed"
@@ -189,7 +189,7 @@ msgstr "Несохранённые результаты"
#: qt/directories_dialog.py:231 cocoa/en.lproj/Localizable.strings:0
msgid "You have unsaved results, do you really want to quit?"
msgstr "Имеются несохранённые результаты, вы действительно хотите выйти?"
msgstr "Имеются несохранённые результаты, Вы действительно хотите выйти?"
#: qt/directories_dialog.py:239 cocoa/en.lproj/Localizable.strings:0
msgid "Select a folder to add to the scanning list"
@@ -205,7 +205,7 @@ msgstr "Все файлы (*.*)"
#: qt/directories_dialog.py:267 qt/result_window.py:311
msgid "dupeGuru Results (*.dupeguru)"
msgstr "Результаты dupeGuru (*. dupeguru)"
msgstr "Результаты dupeGuru (*.dupeguru)"
#: qt/directories_dialog.py:278
msgid "Start a new scan"
@@ -213,7 +213,7 @@ msgstr "Начать новую проверку"
#: qt/directories_dialog.py:279 cocoa/en.lproj/Localizable.strings:0
msgid "You have unsaved results, do you really want to continue?"
msgstr "Имеются несохранённые результаты, вы действительно хотите продолжить?"
msgstr "Имеются несохранённые результаты, Вы действительно хотите продолжить?"
#: qt/directories_model.py:23 cocoa/en.lproj/Localizable.strings:0
msgid "Name"
@@ -256,7 +256,7 @@ msgstr "Теги для проверки:"
#: qt/me/preferences_dialog.py:36 cocoa/en.lproj/Localizable.strings:0
msgid "Track"
msgstr "Трек"
msgstr "Дорожка"
#: qt/me/preferences_dialog.py:38 cocoa/en.lproj/Localizable.strings:0
msgid "Artist"
@@ -323,7 +323,7 @@ msgstr "Уровень фильтрации:"
#: qt/preferences_dialog.py:69
msgid "More Results"
msgstr "Дополнительные результаты"
msgstr "Больше результатов"
#: qt/preferences_dialog.py:74
msgid "Fewer Results"
@@ -379,7 +379,7 @@ msgstr ""
#: qt/problem_dialog.py:33 cocoa/en.lproj/Localizable.strings:0
msgid "Problems!"
msgstr "Проблемка!"
msgstr "Проблема!"
#: qt/problem_dialog.py:37 cocoa/en.lproj/Localizable.strings:0
msgid ""
@@ -409,15 +409,15 @@ msgstr "Показать значения разницы"
#: qt/result_window.py:60
msgid "Send Marked to Recycle Bin..."
msgstr "Переместить отмеченные в Корзину"
msgstr "Переместить отмеченные в Корзину..."
#: qt/result_window.py:61 cocoa/en.lproj/Localizable.strings:0
msgid "Move Marked to..."
msgstr "Переместить отмеченные в"
msgstr "Переместить отмеченные в..."
#: qt/result_window.py:62 cocoa/en.lproj/Localizable.strings:0
msgid "Copy Marked to..."
msgstr "Скопировать отмеченные в"
msgstr "Скопировать отмеченные в..."
#: qt/result_window.py:63 cocoa/en.lproj/Localizable.strings:0
msgid "Remove Marked from Results"
@@ -477,7 +477,7 @@ msgstr "Экспорт в CSV"
#: qt/result_window.py:89 cocoa/en.lproj/Localizable.strings:0
msgid "Save Results..."
msgstr "Сохранить результаты"
msgstr "Сохранить результаты..."
#: qt/result_window.py:90 cocoa/en.lproj/Localizable.strings:0
msgid "Invoke Custom Command"
@@ -509,15 +509,15 @@ msgstr "Значения разницы"
#: qt/result_window.py:310 cocoa/en.lproj/Localizable.strings:0
msgid "Select a file to save your results to"
msgstr "Выберите файл, чтобы сохранить ваши результаты"
msgstr "Выберите файл для сохранения Ваших результатов"
#: qt/se/preferences_dialog.py:41
msgid "Ignore files smaller than"
msgstr "Игнорировать файлы меньше чем"
msgstr "Игнорировать файлы меньше, чем"
#: qt/se/preferences_dialog.py:52 cocoa/en.lproj/Localizable.strings:0
msgid "KB"
msgstr "КБ"
msgstr "кБ"
#: cocoa/en.lproj/Localizable.strings:0
msgid "%@ Results"
@@ -549,7 +549,7 @@ msgstr "Все на передний план"
#: cocoa/en.lproj/Localizable.strings:0
msgid "Check for update..."
msgstr "Проверка обновлений"
msgstr "Проверка обновлений..."
#: cocoa/en.lproj/Localizable.strings:0
msgid "Close Window"
@@ -594,7 +594,7 @@ msgstr "Настройки dupeGuru"
#: cocoa/en.lproj/Localizable.strings:0
msgid "dupeGuru Results"
msgstr "Результаты dupeGuru "
msgstr "Результаты dupeGuru"
#: cocoa/en.lproj/Localizable.strings:0
msgid "dupeGuru Website"
@@ -626,7 +626,7 @@ msgstr "Уровень фильтрации:"
#: cocoa/en.lproj/Localizable.strings:0
msgid "Filter Results..."
msgstr "Отфильтровать результаты"
msgstr "Отфильтровать результаты..."
#: cocoa/en.lproj/Localizable.strings:0
msgid "Folder Selection Window"
@@ -646,11 +646,11 @@ msgstr "Скрыть остальные"
#: cocoa/en.lproj/Localizable.strings:0
msgid "Ignore files smaller than:"
msgstr "Пропускать файлы меньше чем:"
msgstr "Пропускать файлы меньше, чем:"
#: cocoa/en.lproj/Localizable.strings:0
msgid "Load from file..."
msgstr "Загрузить из файла"
msgstr "Загрузить из файла..."
#: cocoa/en.lproj/Localizable.strings:0
msgid "Minimize"
@@ -674,7 +674,7 @@ msgstr "Вставить"
#: cocoa/en.lproj/Localizable.strings:0
msgid "Preferences..."
msgstr "Настройки"
msgstr "Настройки..."
#: cocoa/en.lproj/Localizable.strings:0
msgid "Quick Look"
@@ -686,7 +686,7 @@ msgstr "Выйти из dupeGuru"
#: cocoa/en.lproj/Localizable.strings:0
msgid "Reset to Default"
msgstr "Восстановить значения по умолчанию"
msgstr "Восстановить значение по умолчанию"
#: cocoa/en.lproj/Localizable.strings:0
msgid "Reset To Defaults"
@@ -706,7 +706,7 @@ msgstr "Выбрать все"
#: cocoa/en.lproj/Localizable.strings:0
msgid "Send Marked to Trash..."
msgstr "Переместить отмеченные в Корзину"
msgstr "Переместить отмеченные в Корзину..."
#: cocoa/en.lproj/Localizable.strings:0
msgid "Services"
@@ -754,11 +754,11 @@ msgstr "Выберите файл каталогов для загрузки"
#: qt\directories_dialog.py:338
msgid "dupeGuru Results (*.dupegurudirs)"
msgstr "Каталоги dupeGuru (*.dupegurudirs)"
msgstr "Результаты dupeGuru (*.dupegurudirs)"
#: qt\directories_dialog.py:347
msgid "Select a file to save your directories to"
msgstr "Выберите файл для сохранения каталогов"
msgstr "Выберите файл для сохранения Ваших каталогов"
#: qt\directories_dialog.py:348
msgid "dupeGuru Directories (*.dupegurudirs)"
@@ -798,7 +798,7 @@ msgstr ""
#: qt\exclude_list_table.py:36
msgid "Compilation error: "
msgstr "Ошибка компиляции:"
msgstr "Ошибка компиляции: "
#: qt\pe\image_viewer.py:56
msgid "Increase zoom"
@@ -835,7 +835,7 @@ msgstr "Переопределить значки темы на панели и
#: qt\pe\preferences_dialog.py:58
msgid ""
"Use our own internal icons instead of those provided by the theme engine"
msgstr "Используйте внутренние значки вместо значков, встроенных в тему"
msgstr "Использовать наши внутренние значки вместо значков, встроенных в тему"
#: qt\pe\preferences_dialog.py:66
msgid "Show scrollbars in image viewers"
@@ -965,7 +965,7 @@ msgstr ""
#: qt\se\preferences_dialog.py:68
msgid "Ignore files larger than"
msgstr "Игнорировать файлы больше чем"
msgstr "Игнорировать файлы больше, чем"
#: qt\app.py:135 qt\app.py:293
msgid "Clear Cache"
@@ -981,7 +981,7 @@ msgstr ""
#: qt\app.py:299
msgid "Cache cleared."
msgstr "Кэш очищен "
msgstr "Кэш очищен."
#: qt\preferences_dialog.py:173
msgid "Use dark style"
@@ -994,8 +994,7 @@ msgstr "Сохранить профиль сканирования"
#: qt\preferences_dialog.py:242
msgid "Profile the scan operation and save logs for optimization."
msgstr ""
"В папке установленной или портативной программы, есть папка Data в которую "
"сохраняется логи и файл с раширением *.profile для оптимизации."
"Настройте операцию сканирования и сохраните журналы для оптимизации."
#: qt\preferences_dialog.py:246
msgid "Logs located in: <a href=\"{}\">{}</a>"
@@ -1023,11 +1022,11 @@ msgstr "Под лицензией GPLv3"
#: qt\about_box.py:68
msgid "No update available."
msgstr "У вас самая свежая версия"
msgstr "Обновления недоступны."
#: qt\about_box.py:71
msgid "New version {} available, download <a href=\"{}\">here</a>."
msgstr "Обнаружена новая {} версия, загружать <a href=\"{}\">тут</a>."
msgstr "Обнаружена новая {} версия, загрузить <a href=\"{}\">тут</a>."
#: qt\error_report_dialog.py:50
msgid "Error Report"