forked from CastroFidel/winehelper
Compare commits
6 Commits
3527846c6c
...
904c9c9895
Author | SHA1 | Date | |
---|---|---|---|
|
904c9c9895 | ||
|
1d4ee1fd70 | ||
|
02a2256c8c | ||
|
adf5f78360 | ||
|
01f19cd94d | ||
|
117e497f94 |
@@ -1328,7 +1328,8 @@ use_winetricks () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
kill_wine () {
|
kill_wine () {
|
||||||
wine_pids=$(ls -l /proc/*/exe 2>/dev/null | grep -E 'wine(64)?-preloader|wineserver' | awk -F/ '{print $3}')
|
wine_pids=$(ls -l /proc/*/exe 2>/dev/null | grep -E 'wine(64)?-preloader|wineserver' \
|
||||||
|
| grep "$USER_WORK_PATH" | awk -F/ '{print $3}')
|
||||||
|
|
||||||
for pw_kill_pids in ${wine_pids}; do
|
for pw_kill_pids in ${wine_pids}; do
|
||||||
if ps cax | grep "${pw_kill_pids}" ; then
|
if ps cax | grep "${pw_kill_pids}" ; then
|
||||||
@@ -1416,6 +1417,12 @@ wine_run_install () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
run_autoinstall () {
|
run_autoinstall () {
|
||||||
|
if [[ $WH_USE_GUI == "1" ]] \
|
||||||
|
&& [[ $(ps -o command= -p "$PPID" | awk '{print $2}') =~ "$DATA_PATH/winehelper_gui.py" ]]
|
||||||
|
then print_ok "Соглашения приняты из графического интерфейса."
|
||||||
|
else print_license_agreement
|
||||||
|
fi
|
||||||
|
|
||||||
if [[ $1 == "--clear-pfx" ]] ; then
|
if [[ $1 == "--clear-pfx" ]] ; then
|
||||||
export CLEAR_PREFIX="1"
|
export CLEAR_PREFIX="1"
|
||||||
shift
|
shift
|
||||||
|
@@ -1210,9 +1210,9 @@ class CreatePrefixDialog(QDialog):
|
|||||||
|
|
||||||
def __init__(self, parent=None):
|
def __init__(self, parent=None):
|
||||||
super().__init__(parent)
|
super().__init__(parent)
|
||||||
self.parent_gui = parent # Store reference to main window
|
self.parent_gui = parent # Сохранить ссылку на главное окно
|
||||||
self.setWindowTitle("Создание нового префикса")
|
self.setWindowTitle("Создание нового префикса")
|
||||||
self.setMinimumSize(500, 250)
|
self.setMinimumSize(680, 250)
|
||||||
self.setModal(True)
|
self.setModal(True)
|
||||||
|
|
||||||
# Attributes to store results
|
# Attributes to store results
|
||||||
@@ -1226,9 +1226,22 @@ class CreatePrefixDialog(QDialog):
|
|||||||
form_layout = QFormLayout()
|
form_layout = QFormLayout()
|
||||||
form_layout.setSpacing(10)
|
form_layout.setSpacing(10)
|
||||||
|
|
||||||
|
# Создаем виджет для поля ввода и предупреждения
|
||||||
|
name_input_widget = QWidget()
|
||||||
|
name_input_layout = QVBoxLayout(name_input_widget)
|
||||||
|
name_input_layout.setContentsMargins(0, 0, 0, 0)
|
||||||
|
name_input_layout.setSpacing(2)
|
||||||
|
|
||||||
self.prefix_name_edit = QLineEdit()
|
self.prefix_name_edit = QLineEdit()
|
||||||
self.prefix_name_edit.setPlaceholderText("Например: my_prefix")
|
self.prefix_name_edit.setPlaceholderText("Например: my_prefix")
|
||||||
form_layout.addRow("<b>Имя нового префикса:</b>", self.prefix_name_edit)
|
name_input_layout.addWidget(self.prefix_name_edit)
|
||||||
|
|
||||||
|
self.name_warning_label = QLabel("Имя может содержать только латинские буквы, цифры, тире и знаки подчеркивания.")
|
||||||
|
self.name_warning_label.setStyleSheet("color: red;")
|
||||||
|
self.name_warning_label.setVisible(False)
|
||||||
|
name_input_layout.addWidget(self.name_warning_label)
|
||||||
|
|
||||||
|
form_layout.addRow("<b>Имя нового префикса:</b>", name_input_widget)
|
||||||
|
|
||||||
arch_widget = QWidget()
|
arch_widget = QWidget()
|
||||||
arch_layout = QHBoxLayout(arch_widget)
|
arch_layout = QHBoxLayout(arch_widget)
|
||||||
@@ -1285,7 +1298,7 @@ class CreatePrefixDialog(QDialog):
|
|||||||
|
|
||||||
# Connect signals
|
# Connect signals
|
||||||
self.arch_win32_radio.toggled.connect(self.clear_wine_version_selection)
|
self.arch_win32_radio.toggled.connect(self.clear_wine_version_selection)
|
||||||
self.prefix_name_edit.textChanged.connect(self.update_create_button_state)
|
self.prefix_name_edit.textChanged.connect(self.validate_prefix_name)
|
||||||
self.wine_version_edit.textChanged.connect(self.update_create_button_state)
|
self.wine_version_edit.textChanged.connect(self.update_create_button_state)
|
||||||
|
|
||||||
def open_wine_version_dialog(self):
|
def open_wine_version_dialog(self):
|
||||||
@@ -1301,11 +1314,28 @@ class CreatePrefixDialog(QDialog):
|
|||||||
self.wine_version_edit.clear()
|
self.wine_version_edit.clear()
|
||||||
self.selected_wine_version_value = None
|
self.selected_wine_version_value = None
|
||||||
|
|
||||||
|
def validate_prefix_name(self, text):
|
||||||
|
"""Проверяет имя префикса в реальном времени и показывает/скрывает предупреждение."""
|
||||||
|
valid_pattern = r'^[a-zA-Z0-9_-]*$'
|
||||||
|
if re.match(valid_pattern, text):
|
||||||
|
self.name_warning_label.setVisible(False)
|
||||||
|
else:
|
||||||
|
# Удаляем недопустимые символы
|
||||||
|
cleaned_text = re.sub(r'[^a-zA-Z0-9_-]', '', text)
|
||||||
|
# Блокируем сигналы, чтобы избежать рекурсии при изменении текста
|
||||||
|
self.prefix_name_edit.blockSignals(True)
|
||||||
|
self.prefix_name_edit.setText(cleaned_text)
|
||||||
|
self.prefix_name_edit.blockSignals(False)
|
||||||
|
self.name_warning_label.setVisible(True)
|
||||||
|
|
||||||
|
self.update_create_button_state()
|
||||||
|
|
||||||
def update_create_button_state(self):
|
def update_create_button_state(self):
|
||||||
"""Включает или выключает кнопку 'Создать'."""
|
"""Включает или выключает кнопку 'Создать'."""
|
||||||
name_ok = bool(self.prefix_name_edit.text().strip())
|
name_ok = bool(self.prefix_name_edit.text().strip())
|
||||||
version_ok = bool(self.wine_version_edit.text().strip())
|
version_ok = bool(self.wine_version_edit.text().strip())
|
||||||
self.create_button.setEnabled(name_ok and version_ok)
|
# Кнопка активна, только если имя валидно и версия выбрана
|
||||||
|
self.create_button.setEnabled(name_ok and version_ok and not self.name_warning_label.isVisible())
|
||||||
|
|
||||||
def accept_creation(self):
|
def accept_creation(self):
|
||||||
"""Валидирует данные, сохраняет их и закрывает диалог с успехом."""
|
"""Валидирует данные, сохраняет их и закрывает диалог с успехом."""
|
||||||
@@ -1315,8 +1345,8 @@ class CreatePrefixDialog(QDialog):
|
|||||||
QMessageBox.warning(self, "Ошибка", "Имя префикса не может быть пустым.")
|
QMessageBox.warning(self, "Ошибка", "Имя префикса не может быть пустым.")
|
||||||
return
|
return
|
||||||
|
|
||||||
if not re.match(r'^[a-zA-Z0-9_.-]+$', prefix_name):
|
if not re.match(r'^[a-zA-Z0-9_-]+$', prefix_name):
|
||||||
QMessageBox.warning(self, "Ошибка", "Имя префикса может содержать только латинские буквы, цифры, точки, дефисы и подчеркивания.")
|
QMessageBox.warning(self, "Ошибка", "Имя префикса может содержать только латинские буквы, цифры, дефисы и знаки подчеркивания.")
|
||||||
return
|
return
|
||||||
|
|
||||||
prefix_path = os.path.join(Var.USER_WORK_PATH, "prefixes", prefix_name)
|
prefix_path = os.path.join(Var.USER_WORK_PATH, "prefixes", prefix_name)
|
||||||
@@ -2133,7 +2163,7 @@ class WineHelperGUI(QMainWindow):
|
|||||||
|
|
||||||
# --- Контейнер для выбора и управления созданными префиксами ---
|
# --- Контейнер для выбора и управления созданными префиксами ---
|
||||||
self.management_container_groupbox = QGroupBox()
|
self.management_container_groupbox = QGroupBox()
|
||||||
self.management_container_groupbox.setVisible(False) # Скрыт, пока нет префиксов
|
self.management_container_groupbox.setVisible(True) # Всегда виден
|
||||||
container_layout = QVBoxLayout(self.management_container_groupbox)
|
container_layout = QVBoxLayout(self.management_container_groupbox)
|
||||||
|
|
||||||
selector_layout = QHBoxLayout()
|
selector_layout = QHBoxLayout()
|
||||||
@@ -2313,8 +2343,8 @@ class WineHelperGUI(QMainWindow):
|
|||||||
def _load_created_prefixes(self):
|
def _load_created_prefixes(self):
|
||||||
"""Загружает и обновляет список созданных префиксов в выпадающем списке."""
|
"""Загружает и обновляет список созданных префиксов в выпадающем списке."""
|
||||||
prefixes_root_path = os.path.join(Var.USER_WORK_PATH, "prefixes")
|
prefixes_root_path = os.path.join(Var.USER_WORK_PATH, "prefixes")
|
||||||
if not os.path.isdir(prefixes_root_path):
|
has_prefixes_dir = os.path.isdir(prefixes_root_path)
|
||||||
self.management_container_groupbox.setVisible(False)
|
if not has_prefixes_dir:
|
||||||
return
|
return
|
||||||
|
|
||||||
try:
|
try:
|
||||||
@@ -2333,12 +2363,9 @@ class WineHelperGUI(QMainWindow):
|
|||||||
self.created_prefix_selector.blockSignals(False)
|
self.created_prefix_selector.blockSignals(False)
|
||||||
|
|
||||||
if not prefix_names:
|
if not prefix_names:
|
||||||
self.management_container_groupbox.setVisible(False)
|
|
||||||
self.on_created_prefix_selected(-1) # Убедимся, что панель управления сброшена
|
self.on_created_prefix_selected(-1) # Убедимся, что панель управления сброшена
|
||||||
return
|
return
|
||||||
|
|
||||||
self.management_container_groupbox.setVisible(True)
|
|
||||||
|
|
||||||
def on_created_prefix_selected(self, index):
|
def on_created_prefix_selected(self, index):
|
||||||
"""Обрабатывает выбор префикса из выпадающего списка."""
|
"""Обрабатывает выбор префикса из выпадающего списка."""
|
||||||
if index == -1:
|
if index == -1:
|
||||||
@@ -3014,14 +3041,15 @@ class WineHelperGUI(QMainWindow):
|
|||||||
authors_text = QTextEdit()
|
authors_text = QTextEdit()
|
||||||
authors_text.setReadOnly(True)
|
authors_text.setReadOnly(True)
|
||||||
authors_text.setHtml("""
|
authors_text.setHtml("""
|
||||||
<div style="text-align: center;">
|
<div style="text-align: center; font-size: 10pt;">
|
||||||
<h2>Разработчики</h2>
|
<p><span style="font-size: 11pt;"><b>Разработчики</b></span><br>
|
||||||
Михаил Тергоев (fidel)<br>
|
Михаил Тергоев (fidel)<br>
|
||||||
Сергей Пальчех (minergenon)</p>
|
Сергей Пальчех (minergenon)</p>
|
||||||
<p><b>Помощники</b><br>
|
<p><span style="font-size: 11pt;"><b>Помощники</b></span><br>
|
||||||
Иван Мажукин (vanomj)</p>
|
Иван Мажукин (vanomj)</p>
|
||||||
<p><b>Идея и поддержка:</b><br>
|
<p><span style="font-size: 11pt;"><b>Идея и поддержка</b></span><br>
|
||||||
сообщество ALT Linux</p>
|
ООО "Базальт СПО"<br>
|
||||||
|
ALT Linux Team</p>
|
||||||
<br>
|
<br>
|
||||||
<p>Отдельная благодарность всем, кто вносит свой вклад в развитие проекта,<br>
|
<p>Отдельная благодарность всем, кто вносит свой вклад в развитие проекта,<br>
|
||||||
тестирует и сообщает об ошибках!</p>
|
тестирует и сообщает об ошибках!</p>
|
||||||
@@ -3199,9 +3227,6 @@ class WineHelperGUI(QMainWindow):
|
|||||||
|
|
||||||
self.created_prefix_selector.setCurrentText(prefix_name)
|
self.created_prefix_selector.setCurrentText(prefix_name)
|
||||||
|
|
||||||
if not self.management_container_groupbox.isVisible():
|
|
||||||
self.management_container_groupbox.setVisible(True)
|
|
||||||
|
|
||||||
def update_installed_apps(self):
|
def update_installed_apps(self):
|
||||||
"""Обновляет список установленных приложений в виде кнопок"""
|
"""Обновляет список установленных приложений в виде кнопок"""
|
||||||
# Если активная кнопка находится в списке удаляемых, сбрасываем ее
|
# Если активная кнопка находится в списке удаляемых, сбрасываем ее
|
||||||
|
Reference in New Issue
Block a user