Merge branch 'master' into jellywx/fix-pageup-pagedown-binds
This commit is contained in:
commit
77114d0320
39 changed files with 1917 additions and 1609 deletions
40
.github/workflows/rust-checks.yml
vendored
40
.github/workflows/rust-checks.yml
vendored
|
|
@ -24,3 +24,43 @@ jobs:
|
|||
|
||||
- name: Check formatting
|
||||
run: cargo fmt --all -- --check
|
||||
|
||||
clippy:
|
||||
name: Clippy
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Install system dependencies
|
||||
run: |
|
||||
sudo apt-get update
|
||||
sudo apt-get install -y pkg-config libxkbcommon-dev libfontconfig1-dev libfreetype6-dev libglvnd-dev libinput-dev libvulkan-dev libwayland-dev libx11-dev libxcursor-dev libxi-dev libxrandr-dev libasound2-dev libdbus-1-dev
|
||||
|
||||
- name: Install Rust
|
||||
uses: dtolnay/rust-toolchain@stable
|
||||
with:
|
||||
components: clippy
|
||||
|
||||
- name: Run Clippy
|
||||
run: cargo clippy --all-targets --all-features -- -D warnings
|
||||
|
||||
test:
|
||||
name: Test
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Install system dependencies
|
||||
run: |
|
||||
sudo apt-get update
|
||||
sudo apt-get install -y pkg-config libxkbcommon-dev libfontconfig1-dev libfreetype6-dev libglvnd-dev libinput-dev libvulkan-dev libwayland-dev libx11-dev libxcursor-dev libxi-dev libxrandr-dev libasound2-dev libdbus-1-dev
|
||||
|
||||
- name: Install Rust
|
||||
uses: dtolnay/rust-toolchain@stable
|
||||
with:
|
||||
components: clippy
|
||||
|
||||
- name: Run Tests
|
||||
run: cargo test --all-targets --all-features
|
||||
|
|
|
|||
1976
Cargo.lock
generated
1976
Cargo.lock
generated
File diff suppressed because it is too large
Load diff
|
|
@ -1,6 +1,6 @@
|
|||
[package]
|
||||
name = "cosmic-term"
|
||||
version = "1.0.8"
|
||||
version = "1.0.13"
|
||||
authors = ["Jeremy Soller <jeremy@system76.com>"]
|
||||
edition = "2024"
|
||||
license = "GPL-3.0-only"
|
||||
|
|
@ -40,14 +40,14 @@ git = "https://github.com/pop-os/cosmic-files.git"
|
|||
default-features = false
|
||||
|
||||
[dependencies.cosmic-text]
|
||||
git = "https://github.com/pop-os/cosmic-text.git"
|
||||
version = "0.19"
|
||||
features = ["monospace_fallback", "shape-run-cache"]
|
||||
|
||||
[dependencies.libcosmic]
|
||||
git = "https://github.com/pop-os/libcosmic.git"
|
||||
default-features = false
|
||||
#TODO: a11y feature crashes file chooser dialog
|
||||
features = ["about", "multi-window", "tokio", "winit", "surface-message"]
|
||||
features = ["about", "autosize", "multi-window", "tokio", "winit", "surface-message"]
|
||||
|
||||
[target.'cfg(unix)'.dependencies]
|
||||
fork = "0.4"
|
||||
|
|
|
|||
24
debian/changelog
vendored
24
debian/changelog
vendored
|
|
@ -1,3 +1,27 @@
|
|||
cosmic-term (1.0.13) noble; urgency=medium
|
||||
|
||||
* Epoch 1.0.13 version update
|
||||
|
||||
-- Jeremy Soller <jeremy@system76.com> Tue, 12 May 2026 09:39:57 -0600
|
||||
|
||||
cosmic-term (1.0.12) noble; urgency=medium
|
||||
|
||||
* Epoch 1.0.12 version update
|
||||
|
||||
-- Jeremy Soller <jeremy@system76.com> Tue, 05 May 2026 10:25:04 -0600
|
||||
|
||||
cosmic-term (1.0.11) noble; urgency=medium
|
||||
|
||||
* Epoch 1.0.11 version update
|
||||
|
||||
-- Jeremy Soller <jeremy@system76.com> Tue, 14 Apr 2026 11:11:05 -0600
|
||||
|
||||
cosmic-term (1.0.9) noble; urgency=medium
|
||||
|
||||
* Epoch 1.0.9 version update
|
||||
|
||||
-- Jeremy Soller <jeremy@system76.com> Mon, 06 Apr 2026 15:10:35 -0600
|
||||
|
||||
cosmic-term (1.0.8) noble; urgency=medium
|
||||
|
||||
* Epoch 1.0.8 version update
|
||||
|
|
|
|||
|
|
@ -30,7 +30,7 @@ tab-title-description = تجاوز عنوان اللسان المبدئي
|
|||
add-profile = أضف ملف تعريف
|
||||
new-profile = ملف تعريف جديد
|
||||
make-default = اجعله المبدئي
|
||||
working-directory = مجلد العمل
|
||||
working-directory = المجلَّد الحالي
|
||||
hold = التعليق
|
||||
remain-open = البقاء مفتوحًا بعد خروج العملية الفرعية.
|
||||
|
||||
|
|
@ -138,10 +138,12 @@ shortcut-group-clipboard = الحافظة
|
|||
shortcut-group-other = أخرى
|
||||
shortcut-group-tabs = ألسنة
|
||||
shortcut-group-window = نافذة
|
||||
shortcut-group-zoom = كبِّر
|
||||
shortcut-group-zoom = تكبير
|
||||
shortcut-replace-body = عُيِّن { $binding } بالفعل لـ { $existing }. أتريد استبداله بـ { $new_action }؟
|
||||
shortcut-replace-title = استبدل الاختصار؟
|
||||
tab-activate = نشّط لسان { $number }
|
||||
toggle-fullscreen = بدّل ملء الشاشة
|
||||
type-to-search = اكتب للبحث...
|
||||
copy-link = انسخ الرابط
|
||||
tab-new-inherit-working-directory = الألسنة الجديدة تستخدم المجلد الحالي
|
||||
tab-new-inherit-working-directory-description = افتح ألسنة جديدة في مجلد العمل الخاص باللسان النشط
|
||||
|
|
|
|||
|
|
@ -0,0 +1,3 @@
|
|||
cancel = Cancel·lar
|
||||
settings = Configuració
|
||||
quit = Surt
|
||||
|
|
@ -41,7 +41,7 @@ default-font-stretch = Šířka písma
|
|||
default-font-weight = Normální tloušťka písma
|
||||
default-dim-font-weight = Tenká tloušťka písma
|
||||
default-bold-font-weight = Tučná tloušťka písma
|
||||
use-bright-bold = Zvýraznit tučný text
|
||||
use-bright-bold = Světlejší tučný text
|
||||
splits = Rozdělení
|
||||
focus-follow-mouse = Zaměření psaní sleduje myš
|
||||
advanced = Pokročilé
|
||||
|
|
@ -86,7 +86,7 @@ disable = Zakázat
|
|||
keyboard-shortcuts = Klávesové zkratky
|
||||
menu-keyboard-shortcuts = Klávesové zkratky...
|
||||
no-shortcuts = Žádné zkratky
|
||||
password-manager = Manažer hesel
|
||||
password-manager = Správce hesel
|
||||
replace = Nahradit
|
||||
reset-to-default = Obnovit výchozí
|
||||
shortcut-group-clipboard = Schránka
|
||||
|
|
@ -107,3 +107,5 @@ shortcut-replace-body = { $binding } je již přiřazena k „{ $existing }“.
|
|||
shortcut-capture-hint = Stiskněte kombinaci kláves
|
||||
paste-primary = Vložit primární
|
||||
copy-link = Kopírovat odkaz
|
||||
tab-new-inherit-working-directory = Nové karty používají aktuální adresář
|
||||
tab-new-inherit-working-directory-description = Otevírat nové karty v pracovním adresáři aktivní karty
|
||||
|
|
|
|||
|
|
@ -28,7 +28,7 @@ new-profile = Neues Profil
|
|||
make-default = Als Standard festlegen
|
||||
working-directory = Arbeitsverzeichnis
|
||||
hold = Halten
|
||||
remain-open = Nach Beendigung des Kindprozesses offen bleiben.
|
||||
remain-open = Nach Beendigung des untergeordneten Prozesses geöffnet lassen.
|
||||
|
||||
## Einstellungen
|
||||
|
||||
|
|
@ -38,7 +38,7 @@ settings = Einstellungen
|
|||
|
||||
appearance = Aussehen
|
||||
theme = Thema
|
||||
match-desktop = An System anpassen
|
||||
match-desktop = An Desktop anpassen
|
||||
dark = Dunkel
|
||||
light = Hell
|
||||
syntax-dark = Dunkles Farbschema
|
||||
|
|
@ -67,7 +67,7 @@ focus-follow-mouse = Tippfokus folgt Maus
|
|||
|
||||
advanced = Erweitert
|
||||
show-headerbar = Kopfzeile anzeigen
|
||||
show-header-description = Kopfzeile über das Rechtsklickmenü einblenden.
|
||||
show-header-description = Kopfzeile über das Rechtsklick-Menü aufzeigen
|
||||
# Suchen
|
||||
find-placeholder = Suchen...
|
||||
find-previous = Vorherigen suchen
|
||||
|
|
@ -141,3 +141,11 @@ type-to-search = Zum Suchen tippen...
|
|||
close-window = Fenster schließen
|
||||
copy-or-sigint = Kopieren oder SIGINT
|
||||
toggle-fullscreen = Vollbild umschalten
|
||||
shortcut-group-zoom = Zoom
|
||||
comment = Terminalemulator für den COSMIC Desktop
|
||||
paste-primary = Primär einfügen
|
||||
add-another-keybinding = Weitere Tastenbelegung hinzufügen
|
||||
shortcut-replace-body = { $binding } ist bereits { $existing } zugeordnet. Durch { $new_action } ersetzen?
|
||||
keywords = Befehl;Shell;Terminal;CLI;
|
||||
tab-new-inherit-working-directory = Neue Tabs verwenden das aktuelle Verzeichnis
|
||||
tab-new-inherit-working-directory-description = Neue Tabs im Arbeitsverzeichnis des aktiven Tabs öffnen
|
||||
|
|
|
|||
|
|
@ -1,5 +1,5 @@
|
|||
cosmic-terminal = Τερματικός COSMIC
|
||||
new-terminal = Νέος Τερματικός
|
||||
cosmic-terminal = Τερματικό COSMIC
|
||||
new-terminal = Νέο τερματικό
|
||||
|
||||
# Context Pages
|
||||
|
||||
|
|
@ -14,7 +14,7 @@ rename = Μετονομασία
|
|||
export = Εξαγωγή
|
||||
delete = Διαγραφή
|
||||
import = Εισαγωγή
|
||||
import-errors = Προβλήματα Εισαγωγής
|
||||
import-errors = Σφάλματα εισαγωγής
|
||||
|
||||
## Profiles
|
||||
|
||||
|
|
@ -22,16 +22,16 @@ profiles = Προφίλ
|
|||
name = Όνομα
|
||||
command-line = Γραμμή εντολών
|
||||
tab-title = Τίτλος καρτέλας
|
||||
tab-title-description = Μετονομασία του προεπιλεγμένου τίτλου καρτέλας
|
||||
tab-title-description = Παράκαμψη του προεπιλεγμένου τίτλου καρτέλας
|
||||
add-profile = Προσθήκη προφίλ
|
||||
new-profile = Νέο προφίλ
|
||||
make-default = Κάντο προεπιλογή
|
||||
working-directory = Τρέχων κατάλογος
|
||||
make-default = Ορισμός ως προεπιλογή
|
||||
working-directory = Κατάλογος εργασίας
|
||||
|
||||
## alt: Παύση
|
||||
|
||||
hold = Κράτηση
|
||||
remain-open = Παραμένει ανοιχτό μετά την έξοδο της θυγατρικής διεργασίας
|
||||
hold = Διατήρηση
|
||||
remain-open = Παραμένει ανοικτό μετά την έξοδο από τη θυγατρική διεργασία.
|
||||
|
||||
## Settings
|
||||
|
||||
|
|
@ -41,13 +41,13 @@ settings = Ρυθμίσεις
|
|||
|
||||
appearance = Εμφάνιση
|
||||
theme = Θέμα
|
||||
match-desktop = Αυτόματο
|
||||
dark = Σκοτεινό
|
||||
light = Φωτεινό
|
||||
syntax-dark = Σκοτεινός χρωματικός συνδυασμός
|
||||
syntax-light = Φωτεινός χρωματικός συνδυασμός
|
||||
default-zoom-step = Βήματα μεγέθυνσης
|
||||
opacity = Αδιαφάνια υπόβαθρου
|
||||
match-desktop = Συμφωνία με την επιφάνεια εργασίας
|
||||
dark = Σκουρόχρωμο
|
||||
light = Ανοιχτόχρωμο
|
||||
syntax-dark = Σκουρόχρωμος χρωματικός συνδυασμός
|
||||
syntax-light = Ανοιχτόχρωμος χρωματικός συνδυασμός
|
||||
default-zoom-step = Βήματα ζουμ
|
||||
opacity = Αδιαφάνεια φόντου
|
||||
|
||||
### Font
|
||||
|
||||
|
|
@ -56,21 +56,21 @@ advanced-font-settings = Προηγμένες ρυθμίσεις γραμματ
|
|||
default-font = Γραμματοσειρά
|
||||
default-font-size = Μέγεθος γραμματοσειράς
|
||||
default-font-stretch = Τέντωμα γραμματοσειράς
|
||||
default-font-weight = Βάρος κανονικής γραμματοσειράς
|
||||
default-dim-font-weight = Βάρος θαμπής γραμματοσειράς
|
||||
default-bold-font-weight = Βάρος έντονης γραμματοσειράς
|
||||
use-bright-bold = Κάνε το έντονο κείμενο πιο φωτεινό
|
||||
default-font-weight = Πάχος κανονικής γραμματοσειράς
|
||||
default-dim-font-weight = Πάχος θαμπής γραμματοσειράς
|
||||
default-bold-font-weight = Πάχος έντονης γραμματοσειράς
|
||||
use-bright-bold = Να εμφανίζεται πιο φωτεινό το κείμενο με έντονη γραφή
|
||||
|
||||
### Splits
|
||||
|
||||
splits = Διαχωρισμός
|
||||
focus-follow-mouse = H πληκτρολόγηση να ακολουθεί το ποντίκι
|
||||
splits = Διαχωρισμοί
|
||||
focus-follow-mouse = Να ακολουθεί η εστίαση πληκτρολόγησης το ποντίκι
|
||||
|
||||
### Advanced
|
||||
|
||||
advanced = Προχωρημένα
|
||||
advanced = Σύνθετες επιλογές
|
||||
show-headerbar = Εμφάνιση κεφαλίδας
|
||||
show-header-description = Εμφανήστε την κεφαλίδα από το μενού δεξιού κλικ.
|
||||
show-header-description = Εμφάνιση της κεφαλίδας από το μενού δεξιού κλικ
|
||||
# Find
|
||||
find-placeholder = Εύρεση...
|
||||
find-previous = Εύρεση προηγούμενου
|
||||
|
|
@ -82,12 +82,12 @@ find-next = Εύρεση επόμενου
|
|||
## File
|
||||
|
||||
file = Αρχείο
|
||||
new-tab = Νέα ταμπέλα
|
||||
new-tab = Νέα καρτέλα
|
||||
new-window = Νέο παράθυρο
|
||||
profile = Προφίλ
|
||||
menu-profiles = Περισσότερα Προφίλ...
|
||||
menu-profiles = Προφίλ...
|
||||
close-tab = Κλείσιμο καρτέλας
|
||||
quit = Τερματισμός
|
||||
quit = Έξοδος
|
||||
|
||||
## Edit
|
||||
|
||||
|
|
@ -99,19 +99,56 @@ find = Εύρεση
|
|||
|
||||
## View
|
||||
|
||||
view = Εμφάνιση
|
||||
zoom-in = Μεγέθυνση κείμενου
|
||||
zoom-reset = Επαναφορά κειμένου
|
||||
zoom-out = Σμίκρυνση κείμενου
|
||||
next-tab = Επόμενη ταμπέλα
|
||||
previous-tab = Προηγούμενη ταμπέλα
|
||||
view = Προβολή
|
||||
zoom-in = Μεγαλύτερο κείμενο
|
||||
zoom-reset = Προεπιλεγμένο μέγεθος κειμένου
|
||||
zoom-out = Μικρότερο κείμενο
|
||||
next-tab = Επόμενη καρτέλα
|
||||
previous-tab = Προηγούμενη καρτέλα
|
||||
split-horizontal = Οριζόντιος διαχωρισμός
|
||||
split-vertical = Κάθετος διαχωρισμός
|
||||
pane-toggle-maximize = Εναλλαγή μεγέθυνσης
|
||||
pane-toggle-maximize = Εναλλαγή μεγιστοποίησης
|
||||
menu-color-schemes = Χρωματικοί συνδυασμοί...
|
||||
menu-settings = Ρυθμίσεις...
|
||||
menu-about = Σχετικά με τον τερματικό COSMIC...
|
||||
menu-about = Σχετικά με το Τερματικό COSMIC...
|
||||
repository = Αποθετήριο
|
||||
support = Υποστήριξη
|
||||
cancel = Ακύρωση
|
||||
menu-keyboard-shortcuts = Συντομεύσεις πλήκτρων...
|
||||
menu-keyboard-shortcuts = Συντομεύσεις πληκτρολογίου...
|
||||
replace = Αντικατάσταση
|
||||
passwords-title = Κωδικοί πρόσβασης
|
||||
password-input = Κωδικός πρόσβασης
|
||||
password-input-description = Περιγραφή
|
||||
add-password = Προσθήκη κωδικού πρόσβασης
|
||||
menu-password-manager = Κωδικοί πρόσβασης...
|
||||
clear-scrollback = Απαλοιφή ιστορικού κύλισης
|
||||
open-link = Άνοιγμα συνδέσμου
|
||||
comment = Εξομοιωτής τερματικού για το περιβάλλον επιφάνειας εργασίας COSMIC
|
||||
keyboard-shortcuts = Συντομεύσεις πληκτρολογίου
|
||||
keywords = Εντολή;Κέλυφος;Τερματικό;Command;Shell;Terminal;CLI;
|
||||
close-window = Κλείσιμο παραθύρου
|
||||
disable = Απενεργοποίηση
|
||||
shortcut-group-clipboard = Πρόχειρο
|
||||
shortcut-group-tabs = Καρτέλες
|
||||
shortcut-group-window = Παράθυρο
|
||||
copy-link = Αντιγραφή συνδέσμου
|
||||
type-to-search = Πληκτρολογήστε για αναζήτηση...
|
||||
password-manager = Διαχείριση κωδικών πρόσβασης
|
||||
shortcut-replace-title = Αντικατάσταση συντόμευσης;
|
||||
tab-activate = Ενεργοποίηση καρτέλας { $number }
|
||||
reset-to-default = Επαναφορά προεπιλογών
|
||||
shortcut-capture-hint = Πατήστε τον συνδυασμό πλήκτρων
|
||||
toggle-fullscreen = Εναλλαγή πλήρους οθόνης
|
||||
add-another-keybinding = Προσθήκη άλλου συνδυασμού πλήκτρων
|
||||
copy-or-sigint = Αντιγραφή ή SIGINT
|
||||
focus-pane-down = Εστίαση στην κάτω περιοχή
|
||||
focus-pane-left = Εστίαση στην αριστερή περιοχή
|
||||
focus-pane-right = Εστίαση στη δεξιά περιοχή
|
||||
focus-pane-up = Εστίαση στην πάνω περιοχή
|
||||
no-shortcuts = Δεν υπάρχουν συντομεύσεις
|
||||
paste-primary = Πρωτεύουσα επικόλληση
|
||||
shortcut-group-other = Άλλες
|
||||
shortcut-group-zoom = Ζουμ
|
||||
shortcut-replace-body = Ο συνδυασμός { $binding } έχει ήδη αντιστοιχιστεί στην ενέργεια «{ $existing }». Θέλετε να αντικατασταθεί με την ενέργεια «{ $new_action }»;
|
||||
tab-new-inherit-working-directory = Οι νέες καρτέλες χρησιμοποιούν τον τρέχοντα κατάλογο
|
||||
tab-new-inherit-working-directory-description = Άνοιγμα νέων καρτελών στον τρέχοντα κατάλογο της ενεργής καρτέλας
|
||||
|
|
|
|||
|
|
@ -63,6 +63,8 @@ focus-follow-mouse = Typing focus follows mouse
|
|||
advanced = Advanced
|
||||
show-headerbar = Show header
|
||||
show-header-description = Reveal the header from the right-click menu
|
||||
tab-new-inherit-working-directory = New tabs use current directory
|
||||
tab-new-inherit-working-directory-description = Open new tabs in the active tab's working directory
|
||||
|
||||
### Keyboard shortcuts
|
||||
add-another-keybinding = Add another keybinding
|
||||
|
|
|
|||
|
|
@ -68,6 +68,8 @@ focus-follow-mouse = El enfoque de escritura sigue al mouse
|
|||
advanced = Avanzado
|
||||
show-headerbar = Mostrar encabezado
|
||||
show-header-description = Mostrar el encabezado desde el menú contextual.
|
||||
tab-new-inherit-working-directory = Las pestañas nuevas usan el directorio actual
|
||||
tab-new-inherit-working-directory-description = Abrir pestañas nuevas en el directorio de trabajo de la pestaña activa
|
||||
# Find
|
||||
find-placeholder = Buscar...
|
||||
find-previous = Buscar anterior
|
||||
|
|
|
|||
|
|
@ -70,6 +70,8 @@ focus-follow-mouse = Enfoque del tecleo sigue el ratón
|
|||
advanced = Avanzado
|
||||
show-headerbar = Mostrar encabezado
|
||||
show-header-description = Mostrar encabezado desde el menú del clic secundario.
|
||||
tab-new-inherit-working-directory = Las pestañas nuevas usan el directorio actual
|
||||
tab-new-inherit-working-directory-description = Abrir pestañas nuevas en el directorio de trabajo de la pestaña activa
|
||||
# Find
|
||||
find-placeholder = Buscar...
|
||||
find-previous = Buscar previo
|
||||
|
|
|
|||
0
i18n/eu/cosmic_term.ftl
Normal file
0
i18n/eu/cosmic_term.ftl
Normal file
|
|
@ -14,7 +14,7 @@ rename = Nimeä uudelleen
|
|||
export = Vie
|
||||
delete = Poista
|
||||
import = Tuo
|
||||
import-errors = Tuo virheet
|
||||
import-errors = Tuotaessa tapahtuneet virheet
|
||||
|
||||
## Profiles
|
||||
|
||||
|
|
@ -26,9 +26,9 @@ tab-title-description = Ylikirjoita välilehden oletusotsikko
|
|||
add-profile = Lisää profiili
|
||||
new-profile = Uusi profiili
|
||||
make-default = Aseta oletukseksi
|
||||
working-directory = Työkansio
|
||||
working-directory = Työhakemisto
|
||||
hold = Pidä
|
||||
remain-open = Pysy auki lapsiprosessin sulkeutumisen jälkeen.
|
||||
remain-open = Pysy avoinna lapsiprosessin sulkeutumisen jälkeen.
|
||||
|
||||
## Settings
|
||||
|
||||
|
|
@ -38,13 +38,13 @@ settings = Asetukset
|
|||
|
||||
appearance = Ulkoasu
|
||||
theme = Teema
|
||||
match-desktop = Sovita työpöydän kanssa
|
||||
match-desktop = Sovita työpöytään
|
||||
dark = Tumma
|
||||
light = Vaalea
|
||||
syntax-dark = Tumma väriteema
|
||||
syntax-light = Vaalea väriteema
|
||||
default-zoom-step = Zoomausaskeleet
|
||||
opacity = Taustan läpinäkyvyys
|
||||
default-zoom-step = Zoomauksen askeleet
|
||||
opacity = Taustan peittävyys
|
||||
|
||||
### Font
|
||||
|
||||
|
|
@ -52,11 +52,11 @@ font = Fontti
|
|||
advanced-font-settings = Fontin lisäasetukset
|
||||
default-font = Fontti
|
||||
default-font-size = Fontin koko
|
||||
default-font-stretch = Kirjasimen venyvyys
|
||||
default-font-weight = Oletuskirjasimen paino
|
||||
default-dim-font-weight = Kirjasimen painon himmennys
|
||||
default-bold-font-weight = Paksun kirjasimen paino
|
||||
use-bright-bold = Näytä paksu kirjasin kirkkaana
|
||||
default-font-stretch = Fontin venyvyys
|
||||
default-font-weight = Fontin normaalipaino
|
||||
default-dim-font-weight = Himmennetyn fontin paino
|
||||
default-bold-font-weight = Lihavoidun fontin paino
|
||||
use-bright-bold = Näytä lihavoitu teksti kirkkaampana
|
||||
|
||||
### Splits
|
||||
|
||||
|
|
@ -67,7 +67,7 @@ focus-follow-mouse = Kirjoituksen kohdistus seuraa hiirtä
|
|||
|
||||
advanced = Lisäasetukset
|
||||
show-headerbar = Näytä otsake
|
||||
show-header-description = Paljasta otsake hiiren oikean painikkeen valikosta.
|
||||
show-header-description = Paljasta otsake hiiren oikean painikkeen valikosta
|
||||
|
||||
# Find
|
||||
|
||||
|
|
@ -107,7 +107,7 @@ next-tab = Seuraava välilehti
|
|||
previous-tab = Edellinen välilehti
|
||||
split-horizontal = Halkaise näkymä vaakasuunnassa
|
||||
split-vertical = Halkaise näkymä pystysuunnassa
|
||||
pane-toggle-maximize = Maksimointi päälle tai pois päältä
|
||||
pane-toggle-maximize = Suurennus päällä tai pois
|
||||
menu-color-schemes = Väriteemat…
|
||||
menu-settings = Asetukset…
|
||||
menu-about = Tietoa COSMICin päätteestä…
|
||||
|
|
@ -134,3 +134,20 @@ menu-keyboard-shortcuts = Pikanäppäimet…
|
|||
tab-activate = Aktivoi välilehti { $number }
|
||||
type-to-search = Etsi kirjoittamalla…
|
||||
password-manager = Salasanahallinta
|
||||
reset-to-default = Palauta oletukseksi
|
||||
menu-password-manager = Salasanat…
|
||||
add-another-keybinding = Lisää toinen näppäinsidos
|
||||
focus-pane-down = Kohdista alempaan ruutuun
|
||||
focus-pane-left = Kohdista vasemmanpuoleiseen ruutuun
|
||||
focus-pane-right = Kohdista oikeanpuoleiseen ruutuun
|
||||
focus-pane-up = Kohdista ylempään ruutuun
|
||||
paste-primary = Liitä ensisijainen
|
||||
shortcut-capture-hint = Paina näppäinyhdistelmää
|
||||
shortcut-replace-body = { $binding } on jo kytketty toimintoon { $existing }. Korvataanko se toiminnolla { $new_action }?
|
||||
shortcut-replace-title = Korvataanko pikanäppäin?
|
||||
copy-or-sigint = Kopioi tai SIGINT
|
||||
shortcut-group-zoom = Lähennä
|
||||
toggle-fullscreen = Koko näyttö päällä tai pois
|
||||
shortcut-group-other = Muut
|
||||
tab-new-inherit-working-directory = Uudet välilehdet käyttävät nykyistä hakemistoa
|
||||
tab-new-inherit-working-directory-description = Avaa uudet välilehdet aktiivisen välilehden työskentelyhakemistossa
|
||||
|
|
|
|||
|
|
@ -147,3 +147,5 @@ reset-to-default = Rétablir les paramètres par défaut
|
|||
toggle-fullscreen = Basculer en plein écran
|
||||
comment = Émulateur de terminal pour le bureau COSMIC
|
||||
keywords = Commande;Shell;Terminal;CLI;
|
||||
tab-new-inherit-working-directory = Les nouveaux onglets utilisent le répertoire actuel
|
||||
tab-new-inherit-working-directory-description = Ouvrir les nouveaux onglets dans le répertoire de travail de l'onglet actif
|
||||
|
|
|
|||
|
|
@ -58,7 +58,7 @@ default-font = Betűtípus
|
|||
default-font-size = Betűméret
|
||||
default-font-stretch = Betűszélesség
|
||||
default-font-weight = Normál betűsúly
|
||||
default-dim-font-weight = Halvány betűsúly
|
||||
default-dim-font-weight = Vékony betűsúly
|
||||
default-bold-font-weight = Félkövér betűsúly
|
||||
use-bright-bold = Félkövér szöveg világosítása
|
||||
|
||||
|
|
@ -147,3 +147,5 @@ tab-activate = { $number }. lap aktiválása
|
|||
toggle-fullscreen = Teljes képernyő váltása
|
||||
type-to-search = Gépelj a kereséshez…
|
||||
copy-link = Hivatkozás másolása
|
||||
tab-new-inherit-working-directory = Az új lapok az aktuális könyvtárat használják
|
||||
tab-new-inherit-working-directory-description = Az új lapok az aktív lap munkakönyvtárában nyílnak meg
|
||||
|
|
|
|||
|
|
@ -107,3 +107,5 @@ focus-pane-up = Fokuskan panel ke atas
|
|||
comment = Emulator terminal untuk desktop COSMIC
|
||||
keywords = Perintah;Shell;Terminal;CLI;
|
||||
copy-link = Salin Tautan
|
||||
tab-new-inherit-working-directory = Tab baru menggunakan direktori saat ini
|
||||
tab-new-inherit-working-directory-description = Buka tab baru di direktori pekerjaan tab aktif
|
||||
|
|
|
|||
|
|
@ -70,6 +70,8 @@ focus-follow-mouse = Il focus di scrittura segue il mouse
|
|||
advanced = Avanzate
|
||||
show-headerbar = Mostra intestazione
|
||||
show-header-description = Mostra intestazione dal menu click destro.
|
||||
tab-new-inherit-working-directory = Le nuove schede usano la cartella corrente
|
||||
tab-new-inherit-working-directory-description = Apri nuove schede nella directory di lavoro della scheda attiva
|
||||
# Find
|
||||
find-placeholder = Trova...
|
||||
find-previous = Trova precedente
|
||||
|
|
|
|||
|
|
@ -0,0 +1,107 @@
|
|||
cancel = Sefsex
|
||||
name = Isem
|
||||
delete = kkes
|
||||
rename = Snifel isem
|
||||
quit = Tuffɣa
|
||||
support = Tallalt
|
||||
repository = Asarsay
|
||||
settings = Iɣewwaṛen
|
||||
appearance = Timeẓri
|
||||
theme = Asentel
|
||||
dark = Aɣmayan
|
||||
light = Aceɛlal
|
||||
paste = Senteḍ
|
||||
select-all = Fren akk
|
||||
view = Wali
|
||||
menu-settings = Iɣewwaṛen…
|
||||
match-desktop = Amṣada d tnarit
|
||||
file = Afaylu
|
||||
new-window = Asfaylu amaynut
|
||||
edit = Ẓreg
|
||||
copy = Nɣel
|
||||
default-zoom-step = Isurifen n usemɣer
|
||||
find = Af-d
|
||||
find-placeholder = Af-d…
|
||||
find-previous = Af-d uzwir
|
||||
find-next = Af-d uḍfir
|
||||
replace = Semselsi
|
||||
keyboard-shortcuts = Inegzumen n unasiw
|
||||
menu-keyboard-shortcuts = Inegzumen n unasiw…
|
||||
new-tab = Iccer amaynut
|
||||
close-tab = Mdel iccer
|
||||
import = Kter
|
||||
export = Sifeḍ
|
||||
reset-to-default = Ales awennez ɣer umezwer
|
||||
type-to-search = Aru iwakken ad tnadiḍ…
|
||||
add-another-keybinding = Rnu yiwen n unegzum n unasiw nniḍen
|
||||
font = Tasefsit
|
||||
default-font = Tasefsit
|
||||
password-input = Awal uffir
|
||||
password-input-description = Aglam
|
||||
close-window = Mdel asfaylu
|
||||
copy-or-sigint = Nɣel neɣ SIGINT
|
||||
disable = Kkes armad
|
||||
no-shortcuts = Ulac inegzumen
|
||||
password-manager = Amsefrak n wawal n uɛeddi
|
||||
shortcut-group-other = Ayen nniḍen
|
||||
shortcut-group-tabs = Iccaren
|
||||
shortcut-group-window = Asfaylu
|
||||
shortcut-replace-title = Semselsi anegzum?
|
||||
toggle-fullscreen = Qluqel ɣer ugdil aččuran
|
||||
shortcut-group-clipboard = Tacfawit
|
||||
shortcut-group-zoom = Asimɣeṛ
|
||||
show-header-description = Err-d inixef seg wumuɣ n usiti ayeffus
|
||||
new-terminal = Ixf amaynut
|
||||
color-schemes = Azenziɣ n yiniten
|
||||
import-errors = Kter tuccḍiwin
|
||||
profiles = imaɣnuten
|
||||
command-line = Izirig n tladna
|
||||
tab-title = Azwel n yiccer
|
||||
tab-title-description = Snifel azwel n yiccer amezwer
|
||||
add-profile = Rnu amaɣnu
|
||||
new-profile = Amaɣnu amaynut
|
||||
make-default = Err-it d amezwer
|
||||
working-directory = Akaram n umahil
|
||||
hold = Ṭṭef
|
||||
syntax-dark = Azenziɣ n yini aɣmayan
|
||||
syntax-light = Azenziɣ n yini aceɛlal
|
||||
opacity = Tiḍullest n ugilal
|
||||
advanced-font-settings = Iɣewwaṛen inaẓiyen n tsefsit
|
||||
default-font-size = Tiddi n tsefsit
|
||||
default-font-stretch = Ajbad n tsefsit
|
||||
default-font-weight = Taẓeyt n tsefsit tamagnut
|
||||
default-dim-font-weight = Taẓeyt n tsefsit tafessast
|
||||
default-bold-font-weight = Taẓeyt n tsefsit n tira tazurant
|
||||
use-bright-bold = Err aḍris azuran yettfeǧǧiǧ
|
||||
show-headerbar = Sken inixef
|
||||
profile = Amaɣnu
|
||||
menu-profiles = imaɣnuten…
|
||||
remain-open = Qqim teldiḍ deffir n tuffɣa n ukala aqrur.
|
||||
focus-follow-mouse = Asaḍas n tira yettḍafar taɣerdayt
|
||||
advanced = Leqqayen
|
||||
clear-scrollback = Sfeḍ adrurem ɣer deffir
|
||||
open-link = Ldi aseɣwen
|
||||
zoom-in = Aḍris ahrawan
|
||||
zoom-reset = Tiddi n uḍris amezwer
|
||||
zoom-out = Aḍris wezzilen ugar
|
||||
next-tab = Iccer uḍfir
|
||||
previous-tab = Iccer uzwir
|
||||
split-horizontal = Ẓun s wudem aglawan
|
||||
split-vertical = Ẓun s wudem ubdid
|
||||
pane-toggle-maximize = Qluqel asemɣer
|
||||
menu-about = Ɣef ixf COSMIC…
|
||||
menu-password-manager = Awalen uffiren...
|
||||
passwords-title = Awalen uffiren
|
||||
add-password = Rnu awal uffir
|
||||
splits = Tiẓunin
|
||||
menu-color-schemes = Azenziɣ n yini...
|
||||
comment = Amtellal n yixef i tnarit COSMIC
|
||||
keywords = Taladna; Ajeɣlal; Ixf; CLI;
|
||||
focus-pane-down = Err asaḍas ɣer ugalis ukessar
|
||||
focus-pane-left = Err asaḍas ɣer ugalis uzelmaḍ
|
||||
focus-pane-right = Err asaḍas ɣer ugalis uyeffus
|
||||
focus-pane-up = Err asaḍas ɣer ugalis uksawen
|
||||
paste-primary = Senṭeḍ agejdan
|
||||
shortcut-capture-hint = Sit ɣef usuddes n tqeffalin
|
||||
tab-activate = Sermed iccer { $number }
|
||||
copy-link = Nɣel aseɣwen
|
||||
|
|
@ -107,3 +107,5 @@ type-to-search = Іздеу үшін теріңіз...
|
|||
comment = COSMIC жұмыс үстелі үшін терминал эмуляторы
|
||||
keywords = Command;Shell;Terminal;CLI;Команда;Қоршам;Терминал;
|
||||
copy-link = Сілтемені көшіру
|
||||
tab-new-inherit-working-directory = Жаңа беттерде ағымдағы буманы қолдану
|
||||
tab-new-inherit-working-directory-description = Жаңа беттерді белсенді беттің жұмыс бумасында ашу
|
||||
|
|
|
|||
|
|
@ -51,7 +51,7 @@ default-dim-font-weight = 희미한 글꼴 굵기
|
|||
advanced = 고급
|
||||
use-bright-bold = 굵은 텍스트를 더 밝게 표시
|
||||
default-bold-font-weight = 굵은 글꼴 굵기
|
||||
show-header-description = 오른쪽 클릭 메뉴를 통해 헤더를 나타냅니다.
|
||||
show-header-description = 우클릭 메뉴를 통해 헤더를 나타냅니다
|
||||
password-input-description = 설명
|
||||
default-font = 글꼴
|
||||
paste = 붙여넣기
|
||||
|
|
@ -78,3 +78,23 @@ find = 찾기
|
|||
profile = 프로필
|
||||
new-tab = 새 탭
|
||||
comment = COSMIC 데스크톱용 터미널 에뮬레이터
|
||||
menu-keyboard-shortcuts = 단축키...
|
||||
keywords = 명령어;셸;터미널;CLI;
|
||||
cancel = 취소
|
||||
close-window = 창 닫기
|
||||
disable = 비활성화
|
||||
keyboard-shortcuts = 단축키
|
||||
password-manager = 암호 관리자
|
||||
replace = 대체
|
||||
shortcut-group-clipboard = 클립보드
|
||||
shortcut-group-tabs = 탭
|
||||
shortcut-group-window = 창
|
||||
shortcut-replace-title = 단축키를 대체할까요?
|
||||
tab-activate = 활성 탭 { $number }
|
||||
toggle-fullscreen = 전체 화면 전환
|
||||
type-to-search = 입력하여 검색…
|
||||
copy-link = 링크 복사
|
||||
no-shortcuts = 단축키 없음
|
||||
reset-to-default = 기본값으로 되돌리기
|
||||
shortcut-group-other = 기타
|
||||
shortcut-group-zoom = 확대
|
||||
|
|
|
|||
0
i18n/lo/cosmic_term.ftl
Normal file
0
i18n/lo/cosmic_term.ftl
Normal file
|
|
@ -19,11 +19,11 @@ make-default = Padaryti numatytu
|
|||
working-directory = Darbinis katalogas
|
||||
hold = Laikyti
|
||||
remain-open = Palikti atidarytą išsijungus vaikiniam procesui.
|
||||
settings = Nustatymai
|
||||
settings = Nuostatos
|
||||
appearance = Išvaizda
|
||||
theme = Stilius
|
||||
match-desktop = Pagal darbalaukio temą
|
||||
default-zoom-step = Priartinimo žingsniai
|
||||
default-zoom-step = Artinimo žingsniai
|
||||
opacity = Fono skaidrumas
|
||||
font = Šriftas
|
||||
advanced-font-settings = Išplėstiniai šrifto nustatymai
|
||||
|
|
@ -38,9 +38,9 @@ focus-follow-mouse = Teksto laukelio aktyvavimas sekant žymeklį
|
|||
advanced = Išplėstiniai
|
||||
show-headerbar = Rodyti antraštę
|
||||
show-header-description = Rodyti antraštę kontekstiname meniu atidaromu dešiniu klavišu
|
||||
find-placeholder = Surasti...
|
||||
find-previous = Atgalinis ieškojimas
|
||||
find-next = Ieškoti sekančio
|
||||
find-placeholder = Rasti...
|
||||
find-previous = Ieškoti ankstesnio
|
||||
find-next = Ieškoti tolesnio
|
||||
file = Failas
|
||||
new-tab = Naujas skirtukas
|
||||
new-window = Naujas langas
|
||||
|
|
@ -50,9 +50,9 @@ close-tab = Uždaryti skirtuką
|
|||
quit = Išeiti
|
||||
edit = Redaguoti
|
||||
copy = Kopijuoti
|
||||
paste = Įklijuoti
|
||||
select-all = Pažymėti viską
|
||||
find = Surasti
|
||||
paste = Įdėti
|
||||
select-all = Žymėti viską
|
||||
find = Rasti
|
||||
clear-scrollback = Išvalyti scrollback
|
||||
open-link = Atidaryti Nuorodą
|
||||
view = Rodymas
|
||||
|
|
@ -65,7 +65,7 @@ split-horizontal = Skaidyti horizontaliai
|
|||
split-vertical = Skaidyti vertikaliai
|
||||
pane-toggle-maximize = Perjungti maksimalų padidinimą
|
||||
menu-color-schemes = Spalvų schemos...
|
||||
menu-settings = Nustatymai...
|
||||
menu-settings = Nuostatos...
|
||||
menu-about = Apie COSMIC Terminal...
|
||||
menu-password-manager = Slaptažodžiai...
|
||||
passwords-title = Slaptažodžiai
|
||||
|
|
@ -82,12 +82,12 @@ cancel = Atšaukti
|
|||
close-window = Uždaryti langą
|
||||
copy-or-sigint = Kopijuoti arba SIGINT
|
||||
disable = Išjungti
|
||||
keyboard-shortcuts = Klaviatūros greitieji klavišai
|
||||
menu-keyboard-shortcuts = Klaviatūros greitieji klavišai...
|
||||
keyboard-shortcuts = Spartieji klavišai
|
||||
menu-keyboard-shortcuts = Spartieji klavišai...
|
||||
no-shortcuts = Nėra nustatytų klaviatūros derinių
|
||||
password-manager = Slaptažodžių tvarkyklė
|
||||
paste-primary = Įklijuotiį pirminį
|
||||
replace = Pakeisti
|
||||
replace = Keisti
|
||||
reset-to-default = Nustatyti į numatytąjį
|
||||
shortcut-capture-hint = Nuspauskite klavišų derinį
|
||||
shortcut-group-clipboard = Iškarpinė
|
||||
|
|
@ -101,3 +101,4 @@ tab-activate = Aktyvuoti skirtuką { $number }
|
|||
toggle-fullscreen = Įjungti/išjungti viso ekrano režimą
|
||||
type-to-search = Norint ieškoti, pradėkite rašyti…
|
||||
copy-link = Kopijuoti Nuorodą
|
||||
syntax-dark = Tamsi spalvų paletė
|
||||
|
|
|
|||
|
|
@ -71,3 +71,4 @@ syntax-light = Fargeskjema lyst
|
|||
default-zoom-step = Zoom steg
|
||||
focus-follow-mouse = Skrivefokus følger musen
|
||||
hold = Hold
|
||||
cancel = Avbryt
|
||||
|
|
|
|||
|
|
@ -147,3 +147,5 @@ focus-pane-left = Aktywuj lewy panel
|
|||
focus-pane-right = Aktywuj prawy panel
|
||||
focus-pane-up = Aktywuj panel wyżej
|
||||
copy-link = Skopiuj Odnośnik
|
||||
tab-new-inherit-working-directory = Nowe karty użyją obecnego katalogu
|
||||
tab-new-inherit-working-directory-description = Otwieraj nowe karty w katalogu roboczym aktywnej karty
|
||||
|
|
|
|||
|
|
@ -113,10 +113,10 @@ pane-toggle-maximize = Alternar maximização
|
|||
menu-color-schemes = Esquemas de cores...
|
||||
menu-settings = Configurações...
|
||||
menu-about = Sobre o Terminal...
|
||||
open-link = Abrir Link
|
||||
open-link = Abrir link
|
||||
menu-password-manager = Senhas...
|
||||
passwords-title = Senhas
|
||||
add-password = Adicionar Senha
|
||||
add-password = Adicionar senha
|
||||
password-input = Senha
|
||||
password-input-description = Descrição
|
||||
add-another-keybinding = Adicionar outra combinação de teclas
|
||||
|
|
@ -124,15 +124,15 @@ cancel = Cancelar
|
|||
close-window = Fechar janela
|
||||
copy-or-sigint = Copiar ou SIGINT
|
||||
disable = Desabilitar
|
||||
focus-pane-down = Focar painel abaixo
|
||||
focus-pane-left = Focar painel à esquerda
|
||||
focus-pane-right = Focar painel à direita
|
||||
focus-pane-up = Focar painel acima
|
||||
focus-pane-down = Focar o quadro abaixo
|
||||
focus-pane-left = Focar o quadro à esquerda
|
||||
focus-pane-right = Focar o quadro à direita
|
||||
focus-pane-up = Focar o quadro acima
|
||||
keyboard-shortcuts = Atalhos de teclado
|
||||
menu-keyboard-shortcuts = Atalhos de teclado...
|
||||
no-shortcuts = Sem atalhos
|
||||
password-manager = Gerenciador de senhas
|
||||
paste-primary = Colar
|
||||
paste-primary = Colar primário
|
||||
replace = Substituir
|
||||
reset-to-default = Restaurar padrão
|
||||
shortcut-capture-hint = Pressione a combinação de teclas
|
||||
|
|
@ -146,4 +146,6 @@ shortcut-replace-title = Substituir atalho?
|
|||
tab-activate = Ativar aba { $number }
|
||||
toggle-fullscreen = Alternar para tela cheia
|
||||
type-to-search = Digite para pesquisar...
|
||||
copy-link = Copiar Link
|
||||
copy-link = Copiar link
|
||||
tab-new-inherit-working-directory = Novas abas usam o diretório atual
|
||||
tab-new-inherit-working-directory-description = Abrir novas abas no diretório de trabalho da aba ativa
|
||||
|
|
|
|||
|
|
@ -141,3 +141,5 @@ tab-activate = Активировать вкладку { $number }
|
|||
toggle-fullscreen = Вкл./выкл. полноэкранный режим
|
||||
type-to-search = Введите для поиска...
|
||||
copy-link = Копировать ссылку
|
||||
tab-new-inherit-working-directory = В новых вкладках исп. текущий каталог
|
||||
tab-new-inherit-working-directory-description = Открывать новые вкладки в рабочем каталоге активной вкладки
|
||||
|
|
|
|||
|
|
@ -0,0 +1,111 @@
|
|||
quit = Изађи
|
||||
cancel = Откажи
|
||||
import = Увези
|
||||
export = Извези
|
||||
appearance = Изглед
|
||||
light = Светла
|
||||
dark = Тамна
|
||||
settings = Подешавања
|
||||
reset-to-default = Врати на подразумевано
|
||||
type-to-search = Куцајте за претрагу...
|
||||
add-another-keybinding = Додај још једну комбинацију тастера
|
||||
replace = Замени
|
||||
syntax-light = Светла шема боја
|
||||
default-font-weight = Нормална тежина фонта
|
||||
add-profile = Додај профил
|
||||
find-next = Нађи следеће
|
||||
splits = Подељено
|
||||
import-errors = Грешке при увозу
|
||||
zoom-in = Већи текст
|
||||
select-all = Означи све
|
||||
previous-tab = Претходни језичак
|
||||
show-headerbar = Прикажи заглавље
|
||||
new-window = Нови прозор
|
||||
zoom-out = Мањи текст
|
||||
split-vertical = Усправна подела
|
||||
syntax-dark = Тамна шема боја
|
||||
menu-profiles = Профили...
|
||||
new-terminal = Нови терминал
|
||||
tab-title-description = Замените подразумевани наслов језичка
|
||||
menu-about = О програму Космик Терминал...
|
||||
remain-open = Остани отворен након што се дечији процес заврши.
|
||||
menu-color-schemes = Шеме боја...
|
||||
working-directory = Радни директоријум
|
||||
profiles = Профили
|
||||
opacity = Непровидност позадине
|
||||
tab-title = Наслов језичка
|
||||
zoom-reset = Подразумевана величина текста
|
||||
rename = Преименуј
|
||||
passwords-title = Лозинке
|
||||
edit = Уреди
|
||||
copy = Умножи
|
||||
pane-toggle-maximize = Окини увећање
|
||||
theme = Тема
|
||||
password-input = Лозинка
|
||||
close-tab = Затвори језичак
|
||||
color-schemes = Шеме боја
|
||||
name = Назив
|
||||
default-dim-font-weight = Пригушена тежина фонта
|
||||
advanced = Напредно
|
||||
delete = Обриши
|
||||
repository = Ризница
|
||||
use-bright-bold = Учини подебљани текст светлијим
|
||||
support = Подршка
|
||||
default-bold-font-weight = Тежина подебљаног фонта
|
||||
password-input-description = Опис
|
||||
default-font = Фонт
|
||||
paste = Залепи
|
||||
menu-settings = Подешавања...
|
||||
add-password = Додај лозинку
|
||||
command-line = Линија наредби
|
||||
view = Преглед
|
||||
default-font-stretch = Развлачење писма
|
||||
hold = Задржи
|
||||
menu-password-manager = Лозинке...
|
||||
match-desktop = Прати радну површину
|
||||
find-previous = Нађи претходно
|
||||
default-font-size = Величина фонта
|
||||
cosmic-terminal = Космик терминал
|
||||
split-horizontal = Водоравна подела
|
||||
find-placeholder = Пронађи...
|
||||
focus-follow-mouse = Фокус куцања прати миша
|
||||
advanced-font-settings = Напредна подешавања фонта
|
||||
font = Фонт
|
||||
next-tab = Следећи језичак
|
||||
default-zoom-step = Кораци увећања
|
||||
clear-scrollback = Очисти историју помицања
|
||||
open-link = Отвори везу
|
||||
file = Датотека
|
||||
make-default = Постави као подразумеван
|
||||
new-profile = Нови профил
|
||||
find = Пронађи
|
||||
profile = Профил
|
||||
new-tab = Нови језичак
|
||||
keyboard-shortcuts = Пречице тастатуре
|
||||
menu-keyboard-shortcuts = Пречице на тастатури...
|
||||
comment = Емулатор терминала за Космик радну површину
|
||||
keywords = Command;Shell;Terminal;CLI;Наредба;Шкољка;Терминал;CLI;naredba;školjka;terminal;cli;
|
||||
show-header-description = Прикажи заглавље из менија са десним кликом
|
||||
close-window = Затвори прозор
|
||||
copy-or-sigint = Копирај или SIGINT
|
||||
disable = Онемогући
|
||||
focus-pane-down = Усредсреди површ испод
|
||||
focus-pane-left = Усредсреди површ лево
|
||||
focus-pane-right = Усредсреди површ десно
|
||||
focus-pane-up = Усредсреди површ изнад
|
||||
no-shortcuts = Нема пречица
|
||||
password-manager = Управник лозинки
|
||||
paste-primary = Убаци примарно
|
||||
shortcut-capture-hint = Притисните комбинацију тастера
|
||||
shortcut-group-clipboard = Остава
|
||||
shortcut-group-other = Друго
|
||||
shortcut-group-tabs = Језичци
|
||||
shortcut-group-window = Прозор
|
||||
shortcut-group-zoom = Увећање
|
||||
shortcut-replace-body = { $binding } је већ додељена за { $existing }. Заменити је са { $new_action }?
|
||||
shortcut-replace-title = Заменити пречицу?
|
||||
tab-activate = Активирај језичак { $number }
|
||||
toggle-fullscreen = Цео екран
|
||||
copy-link = Копирај везу
|
||||
tab-new-inherit-working-directory = Нови језичци користе тренутни директоријум
|
||||
tab-new-inherit-working-directory-description = Отвара нове језичке у радном директоријуму активног језичка
|
||||
|
|
@ -151,3 +151,5 @@ shortcut-group-other = Andra
|
|||
shortcut-group-tabs = Flikar
|
||||
shortcut-group-zoom = Zooma
|
||||
copy-link = Kopiera länk
|
||||
tab-new-inherit-working-directory-description = Öppna nya flikar i den aktiva flikens arbetskatalog
|
||||
tab-new-inherit-working-directory = Nya flikar använder aktuell katalog
|
||||
|
|
|
|||
|
|
@ -147,3 +147,5 @@ focus-pane-up = Фокус на верхню панель
|
|||
comment = Емулятор терміналу для середовища COSMIC
|
||||
keywords = Команда;Оболонка;Термінал;Інтерфейс;CLI;
|
||||
copy-link = Копіювати ланку
|
||||
tab-new-inherit-working-directory = У нових вкладках використовується поточний каталог
|
||||
tab-new-inherit-working-directory-description = Відкривати нові вкладки в робочому каталозі активної вкладки
|
||||
|
|
|
|||
|
|
@ -69,7 +69,7 @@ advanced = 高级
|
|||
show-headerbar = 显示标题栏
|
||||
show-header-description = 右键菜单提供显示标题栏选项
|
||||
# Find
|
||||
find-placeholder = 查找...
|
||||
find-placeholder = 查找…
|
||||
find-previous = 查找上一个
|
||||
find-next = 查找下一个
|
||||
|
||||
|
|
@ -82,7 +82,7 @@ file = 文件
|
|||
new-tab = 新建标签
|
||||
new-window = 新建窗口
|
||||
profile = 配置
|
||||
menu-profiles = 配置文件...
|
||||
menu-profiles = 配置文件…
|
||||
close-tab = 关闭标签
|
||||
quit = 退出
|
||||
|
||||
|
|
@ -106,9 +106,9 @@ previous-tab = 上一个标签
|
|||
split-horizontal = 水平分割
|
||||
split-vertical = 垂直分割
|
||||
pane-toggle-maximize = 切换最大化
|
||||
menu-color-schemes = 配色方案...
|
||||
menu-settings = 设置...
|
||||
menu-about = 关于 COSMIC 终端...
|
||||
menu-color-schemes = 配色方案…
|
||||
menu-settings = 设置…
|
||||
menu-about = 关于 COSMIC 终端…
|
||||
repository = 仓库
|
||||
support = 支持
|
||||
open-link = 打开链接
|
||||
|
|
@ -132,7 +132,7 @@ shortcut-group-clipboard = 剪切板
|
|||
shortcut-group-other = 其他
|
||||
shortcut-group-tabs = 标签
|
||||
shortcut-group-zoom = 缩放
|
||||
type-to-search = 输入即可搜索...
|
||||
type-to-search = 输入即可搜索…
|
||||
copy-or-sigint = 复制或 SIGINT
|
||||
focus-pane-down = 聚焦下方窗格
|
||||
focus-pane-left = 聚焦左侧窗格
|
||||
|
|
@ -147,3 +147,5 @@ toggle-fullscreen = 切换全屏
|
|||
comment = COSMIC 桌面的终端模拟器
|
||||
keywords = 指令;外壳;终端;命令行界面;
|
||||
copy-link = 复制链接
|
||||
tab-new-inherit-working-directory = 新标签使用当前目录
|
||||
tab-new-inherit-working-directory-description = 在活动标签的工作目录中打开新标签
|
||||
|
|
|
|||
|
|
@ -1,5 +1,5 @@
|
|||
cosmic-terminal = COSMIC 終端機
|
||||
new-terminal = 新增 終端機
|
||||
new-terminal = 新建終端機
|
||||
|
||||
# Context Pages
|
||||
|
||||
|
|
@ -9,7 +9,7 @@ new-terminal = 新增 終端機
|
|||
|
||||
## Color schemes
|
||||
|
||||
color-schemes = 主題
|
||||
color-schemes = 配色方案
|
||||
rename = 重命名
|
||||
export = 匯出
|
||||
delete = 刪除
|
||||
|
|
@ -38,36 +38,36 @@ settings = 設定
|
|||
|
||||
appearance = 外觀
|
||||
theme = 主題
|
||||
match-desktop = 配合桌面
|
||||
dark = 暗色
|
||||
light = 亮色
|
||||
match-desktop = 符合桌面
|
||||
dark = 深色
|
||||
light = 淺色
|
||||
syntax-dark = 暗色調
|
||||
syntax-light = 亮色調
|
||||
default-zoom-step = 縮放步進
|
||||
opacity = 背景透明度
|
||||
opacity = 背景不透明度
|
||||
|
||||
### Font
|
||||
|
||||
font = 字體
|
||||
advanced-font-settings = 進階字體設定
|
||||
default-font = 字體
|
||||
default-font-size = 字體大小
|
||||
default-font-stretch = 字體延伸
|
||||
default-font-weight = 字體粗細
|
||||
default-dim-font-weight = 淡色字體粗細
|
||||
default-bold-font-weight = 粗字體粗細
|
||||
use-bright-bold = 使粗體字更亮
|
||||
font = 字型
|
||||
advanced-font-settings = 進階字型設定
|
||||
default-font = 字型
|
||||
default-font-size = 字型大小
|
||||
default-font-stretch = 字型伸展
|
||||
default-font-weight = 正常字型粗細
|
||||
default-dim-font-weight = 黯淡字型粗細
|
||||
default-bold-font-weight = 粗體字型粗細
|
||||
use-bright-bold = 使粗體文字更亮
|
||||
|
||||
### Splits
|
||||
|
||||
splits = 終端介面分割
|
||||
focus-follow-mouse = 滑鼠點擊選擇輸入窗口
|
||||
splits = 分割
|
||||
focus-follow-mouse = 輸入焦點追隨滑鼠
|
||||
|
||||
### Advanced
|
||||
|
||||
advanced = 進階
|
||||
show-headerbar = 顯示標題列
|
||||
show-header-description = 右鍵選單提供標題列選項。
|
||||
show-header-description = 右鍵選單提供標題列選項
|
||||
# Find
|
||||
find-placeholder = 尋找...
|
||||
find-previous = 上一個
|
||||
|
|
@ -79,12 +79,12 @@ find-next = 下一個
|
|||
## File
|
||||
|
||||
file = 檔案
|
||||
new-tab = 新增分頁
|
||||
new-window = 新增視窗
|
||||
profile = 設定檔
|
||||
menu-profiles = 設定檔...
|
||||
new-tab = 新建分頁
|
||||
new-window = 新建視窗
|
||||
profile = 設定檔案
|
||||
menu-profiles = 設定檔案...
|
||||
close-tab = 關閉分頁
|
||||
quit = 結束
|
||||
quit = 退出
|
||||
|
||||
## Edit
|
||||
|
||||
|
|
@ -97,14 +97,55 @@ find = 尋找
|
|||
## View
|
||||
|
||||
view = 檢視
|
||||
zoom-in = 放大文字
|
||||
zoom-reset = 重設文字大小
|
||||
zoom-out = 縮小文字
|
||||
zoom-in = 較大文字
|
||||
zoom-reset = 預設文字大小
|
||||
zoom-out = 較小文字
|
||||
next-tab = 下個分頁
|
||||
previous-tab = 上個分頁
|
||||
split-horizontal = 水平分割
|
||||
split-vertical = 垂直分割
|
||||
pane-toggle-maximize = 切換最大化
|
||||
menu-color-schemes = 主題...
|
||||
menu-color-schemes = 配色方案...
|
||||
menu-settings = 設定...
|
||||
menu-about = 關於 COSMIC 終端機...
|
||||
menu-about = 關於 COSMIC 終端機…
|
||||
cancel = 取消
|
||||
repository = 軟體庫源
|
||||
support = 支援
|
||||
keyboard-shortcuts = 鍵盤快速鍵
|
||||
keywords = 指令;殼層;終端;指令行介面CLI;
|
||||
add-another-keybinding = 添加另一個按鍵組合
|
||||
close-window = 關閉視窗
|
||||
copy-or-sigint = 複製或 SIGINT
|
||||
disable = 停用
|
||||
menu-keyboard-shortcuts = 鍵盤快速鍵...
|
||||
no-shortcuts = 無快速鍵
|
||||
password-manager = 密碼管理器
|
||||
paste-primary = 貼上主要
|
||||
replace = 取代
|
||||
reset-to-default = 重新設定至預設
|
||||
shortcut-capture-hint = 按下組合鍵
|
||||
shortcut-group-clipboard = 剪貼簿
|
||||
shortcut-group-other = 其它
|
||||
shortcut-group-tabs = 分頁
|
||||
shortcut-group-window = 視窗
|
||||
shortcut-group-zoom = 縮放
|
||||
focus-pane-down = 聚焦下方窗格
|
||||
focus-pane-left = 聚焦左側窗格
|
||||
focus-pane-right = 聚焦右側窗格
|
||||
focus-pane-up = 聚焦上方窗格
|
||||
open-link = 開啟連結
|
||||
menu-password-manager = 密碼…
|
||||
passwords-title = 密碼
|
||||
add-password = 添增密碼
|
||||
password-input = 密碼
|
||||
password-input-description = 描述
|
||||
shortcut-replace-title = 取代快速鍵?
|
||||
tab-activate = 啟用分頁 { $number }
|
||||
toggle-fullscreen = 切換全螢幕
|
||||
type-to-search = 輸入進行搜尋...
|
||||
copy-link = 複製連結
|
||||
shortcut-replace-body = { $binding } 已經分配至 { $existing }。 要取代它為 { $new_action }?
|
||||
clear-scrollback = 清除捲動回朔
|
||||
comment = COSMIC 桌面終端機模擬器
|
||||
tab-new-inherit-working-directory = 新分頁使用目前目錄
|
||||
tab-new-inherit-working-directory-description = 在作用中分頁的工作目錄開啟新分頁
|
||||
|
|
|
|||
|
|
@ -235,6 +235,8 @@ pub struct Config {
|
|||
pub syntax_theme_dark: String,
|
||||
pub syntax_theme_light: String,
|
||||
pub focus_follow_mouse: bool,
|
||||
#[serde(default)]
|
||||
pub tab_new_inherit_working_directory: bool,
|
||||
pub default_profile: Option<ProfileId>,
|
||||
#[serde(default)]
|
||||
pub shortcuts_custom: Shortcuts,
|
||||
|
|
@ -249,6 +251,7 @@ impl Default for Config {
|
|||
color_schemes_light: BTreeMap::new(),
|
||||
dim_font_weight: Weight::NORMAL.0,
|
||||
focus_follow_mouse: false,
|
||||
tab_new_inherit_working_directory: false,
|
||||
font_name: "Noto Sans Mono".to_string(),
|
||||
font_size: 14,
|
||||
font_size_zoom_step_mul_100: 100,
|
||||
|
|
|
|||
581
src/main.rs
581
src/main.rs
|
|
@ -3,7 +3,7 @@
|
|||
|
||||
use alacritty_terminal::{event::Event as TermEvent, term, term::color::Colors as TermColors, tty};
|
||||
use cosmic::iced::clipboard::dnd::DndAction;
|
||||
use cosmic::iced_core::keyboard::key::Named;
|
||||
use cosmic::iced::core::keyboard::key::Named;
|
||||
use cosmic::widget::menu::action::MenuAction;
|
||||
use cosmic::widget::menu::key_bind::KeyBind;
|
||||
use cosmic::widget::pane_grid::Pane;
|
||||
|
|
@ -177,11 +177,7 @@ fn main() -> Result<(), Box<dyn Error>> {
|
|||
|
||||
let shortcuts_config = shortcuts::ShortcutsConfig::new(config.shortcuts_custom.clone());
|
||||
|
||||
let shell = if let Some(shell_program) = shell_program_opt {
|
||||
Some(tty::Shell::new(shell_program, shell_args))
|
||||
} else {
|
||||
None
|
||||
};
|
||||
let shell = shell_program_opt.map(|shell_program| tty::Shell::new(shell_program, shell_args));
|
||||
let startup_options = Some(tty::Options {
|
||||
shell,
|
||||
working_directory,
|
||||
|
|
@ -367,7 +363,7 @@ pub enum Message {
|
|||
ColorSchemeRename(ColorSchemeKind, ColorSchemeId, String),
|
||||
ColorSchemeRenameSubmit,
|
||||
ColorSchemeTabActivate(widget::segmented_button::Entity),
|
||||
Config(Config),
|
||||
Config(Box<Config>),
|
||||
Copy(Option<segmented_button::Entity>),
|
||||
CopyOrSigint(Option<segmented_button::Entity>),
|
||||
CopyPrimary(Option<segmented_button::Entity>),
|
||||
|
|
@ -379,7 +375,7 @@ pub enum Message {
|
|||
DefaultFontStretch(usize),
|
||||
DefaultFontWeight(usize),
|
||||
DefaultZoomStep(usize),
|
||||
DialogMessage(DialogMessage),
|
||||
DialogMessage(Box<DialogMessage>), // DialogMessage is huge, so we use a box to make the size of this enum smaller on the stack
|
||||
Drop(Option<(pane_grid::Pane, segmented_button::Entity, DndDrop)>),
|
||||
Find(bool),
|
||||
FindNext,
|
||||
|
|
@ -431,6 +427,7 @@ pub enum Message {
|
|||
ShowHeaderBar(bool),
|
||||
SyntaxTheme(ColorSchemeKind, usize),
|
||||
SystemThemeChange,
|
||||
TabNewInheritWorkingDirectory(bool),
|
||||
TabActivate(segmented_button::Entity),
|
||||
TabActivateJump(usize),
|
||||
TabClose(Option<segmented_button::Entity>),
|
||||
|
|
@ -453,6 +450,7 @@ pub enum Message {
|
|||
ZoomIn,
|
||||
ZoomOut,
|
||||
ZoomReset,
|
||||
ContextMenuPopupClosed(window::Id),
|
||||
}
|
||||
|
||||
#[derive(Clone, Copy, Debug, Eq, PartialEq)]
|
||||
|
|
@ -523,6 +521,14 @@ pub struct App {
|
|||
shortcut_search_regex: Option<regex::Regex>,
|
||||
shortcut_search_value: String,
|
||||
modifiers: Modifiers,
|
||||
context_menu_popup: Option<(
|
||||
window::Id,
|
||||
pane_grid::Pane,
|
||||
segmented_button::Entity,
|
||||
Option<String>,
|
||||
widget::Id,
|
||||
cosmic::iced::Point,
|
||||
)>,
|
||||
#[cfg(feature = "password_manager")]
|
||||
password_mgr: password_manager::PasswordManager,
|
||||
}
|
||||
|
|
@ -545,21 +551,19 @@ impl App {
|
|||
.config
|
||||
.color_schemes(color_scheme_kind)
|
||||
.get(&color_scheme_id)
|
||||
{
|
||||
if self
|
||||
&& self
|
||||
.themes
|
||||
.insert(
|
||||
(color_scheme_name.clone(), color_scheme_kind),
|
||||
color_scheme.into(),
|
||||
)
|
||||
.is_some()
|
||||
{
|
||||
log::warn!(
|
||||
"custom {:?} color scheme {:?} replaces builtin one",
|
||||
color_scheme_kind,
|
||||
color_scheme_name
|
||||
);
|
||||
}
|
||||
{
|
||||
log::warn!(
|
||||
"custom {:?} color scheme {:?} replaces builtin one",
|
||||
color_scheme_kind,
|
||||
color_scheme_name
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -593,6 +597,18 @@ impl App {
|
|||
}
|
||||
}
|
||||
|
||||
fn reset_active_pane_zoom(&mut self) {
|
||||
if let Some(tab_model) = self.pane_model.active() {
|
||||
for entity in tab_model.iter() {
|
||||
if tab_model.is_active(entity)
|
||||
&& let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity)
|
||||
{
|
||||
terminal.lock().unwrap().set_zoom_adj(0);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn save_shortcuts_custom(&mut self) {
|
||||
self.config.shortcuts_custom = self.shortcuts_config.custom.clone();
|
||||
match &self.config_handler {
|
||||
|
|
@ -690,21 +706,21 @@ impl App {
|
|||
// but only for the active pane/tab
|
||||
if let Some(tab_model) = self.pane_model.active() {
|
||||
for entity in tab_model.iter() {
|
||||
if tab_model.is_active(entity) {
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
let current_zoom_adj = terminal.zoom_adj();
|
||||
match zoom_message {
|
||||
Message::ZoomIn => {
|
||||
terminal.set_zoom_adj(current_zoom_adj.saturating_add(1))
|
||||
}
|
||||
Message::ZoomOut => {
|
||||
terminal.set_zoom_adj(current_zoom_adj.saturating_sub(1))
|
||||
}
|
||||
_ => {}
|
||||
if tab_model.is_active(entity)
|
||||
&& let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity)
|
||||
{
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
let current_zoom_adj = terminal.zoom_adj();
|
||||
match zoom_message {
|
||||
Message::ZoomIn => {
|
||||
terminal.set_zoom_adj(current_zoom_adj.saturating_add(1))
|
||||
}
|
||||
terminal.set_config(&self.config, &self.themes);
|
||||
Message::ZoomOut => {
|
||||
terminal.set_zoom_adj(current_zoom_adj.saturating_sub(1))
|
||||
}
|
||||
_ => {}
|
||||
}
|
||||
terminal.set_config(&self.config, &self.themes);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -713,16 +729,16 @@ impl App {
|
|||
|
||||
fn save_color_schemes(&mut self, color_scheme_kind: ColorSchemeKind) -> Task<Message> {
|
||||
// Optimized for just saving color_schemes
|
||||
if let Some(ref config_handler) = self.config_handler {
|
||||
if let Err(err) = config_handler.set(
|
||||
if let Some(ref config_handler) = self.config_handler
|
||||
&& let Err(err) = config_handler.set(
|
||||
match color_scheme_kind {
|
||||
ColorSchemeKind::Dark => "color_schemes_dark",
|
||||
ColorSchemeKind::Light => "color_schemes_light",
|
||||
},
|
||||
self.config.color_schemes(color_scheme_kind),
|
||||
) {
|
||||
log::error!("failed to save config: {}", err);
|
||||
}
|
||||
)
|
||||
{
|
||||
log::error!("failed to save config: {}", err);
|
||||
}
|
||||
self.update_color_schemes();
|
||||
Task::none()
|
||||
|
|
@ -745,16 +761,16 @@ impl App {
|
|||
if self.find {
|
||||
widget::text_input::focus(self.find_search_id.clone())
|
||||
} else if self.core.window.show_context {
|
||||
match self.context_page {
|
||||
ContextPage::KeyboardShortcuts => {
|
||||
if self.shortcut_search_focus.get() {
|
||||
self.shortcut_search_focus.set(false);
|
||||
return widget::text_input::focus(self.shortcut_search_id.clone());
|
||||
}
|
||||
}
|
||||
// TODO focus for other context pages?
|
||||
_ => {}
|
||||
// Right now we only care about the KeyboardShortcuts context page, so we use a simple if.
|
||||
// In the future if we are to care about other conext pages, we could switch this to a match
|
||||
// statement instead to be cleaner.
|
||||
if self.context_page == ContextPage::KeyboardShortcuts
|
||||
&& self.shortcut_search_focus.get()
|
||||
{
|
||||
self.shortcut_search_focus.set(false);
|
||||
return widget::text_input::focus(self.shortcut_search_id.clone());
|
||||
}
|
||||
|
||||
Task::none()
|
||||
} else if let Some(terminal_id) = self.terminal_ids.get(&self.pane_model.focused()).cloned()
|
||||
{
|
||||
|
|
@ -1017,10 +1033,10 @@ impl App {
|
|||
let mut found_actions = false;
|
||||
for action in group.actions {
|
||||
let action_label = shortcuts::action_label(action);
|
||||
if let Some(regex) = &self.shortcut_search_regex {
|
||||
if regex.find(&action_label).is_none() {
|
||||
continue;
|
||||
}
|
||||
if let Some(regex) = &self.shortcut_search_regex
|
||||
&& regex.find(&action_label).is_none()
|
||||
{
|
||||
continue;
|
||||
}
|
||||
found_actions = true;
|
||||
|
||||
|
|
@ -1483,11 +1499,21 @@ impl App {
|
|||
.toggler(self.config.focus_follow_mouse, Message::FocusFollowMouse),
|
||||
);
|
||||
|
||||
let advanced_section = widget::settings::section().title(fl!("advanced")).add(
|
||||
widget::settings::item::builder(fl!("show-headerbar"))
|
||||
.description(fl!("show-header-description"))
|
||||
.toggler(self.config.show_headerbar, Message::ShowHeaderBar),
|
||||
);
|
||||
let advanced_section = widget::settings::section()
|
||||
.title(fl!("advanced"))
|
||||
.add(
|
||||
widget::settings::item::builder(fl!("show-headerbar"))
|
||||
.description(fl!("show-header-description"))
|
||||
.toggler(self.config.show_headerbar, Message::ShowHeaderBar),
|
||||
)
|
||||
.add(
|
||||
widget::settings::item::builder(fl!("tab-new-inherit-working-directory"))
|
||||
.description(fl!("tab-new-inherit-working-directory-description"))
|
||||
.toggler(
|
||||
self.config.tab_new_inherit_working_directory,
|
||||
Message::TabNewInheritWorkingDirectory,
|
||||
),
|
||||
);
|
||||
|
||||
widget::settings::view_column(vec![
|
||||
appearance_section.into(),
|
||||
|
|
@ -1501,11 +1527,23 @@ impl App {
|
|||
self.config.default_profile
|
||||
}
|
||||
|
||||
fn active_terminal_working_directory(&self) -> Option<PathBuf> {
|
||||
let tab_model = self.pane_model.active()?;
|
||||
let entity = tab_model.active();
|
||||
let terminal = tab_model.data::<Mutex<Terminal>>(entity)?;
|
||||
let terminal = terminal.lock().unwrap();
|
||||
terminal.working_directory()
|
||||
}
|
||||
|
||||
fn create_and_focus_new_terminal(
|
||||
&mut self,
|
||||
pane: pane_grid::Pane,
|
||||
profile_id_opt: Option<ProfileId>,
|
||||
inherit_working_directory: bool,
|
||||
) -> Task<Message> {
|
||||
let inherited_working_directory = inherit_working_directory
|
||||
.then(|| self.active_terminal_working_directory())
|
||||
.flatten();
|
||||
self.pane_model.set_focus(pane);
|
||||
match &self.term_event_tx_opt {
|
||||
Some(term_event_tx) => {
|
||||
|
|
@ -1534,20 +1572,21 @@ impl App {
|
|||
self.startup_options.take().unwrap_or_default();
|
||||
let options = tty::Options {
|
||||
shell: startup_options.shell.or_else(|| {
|
||||
if let Some(mut args) = shlex::split(&profile.command) {
|
||||
if !args.is_empty() {
|
||||
let command = args.remove(0);
|
||||
return Some(tty::Shell::new(command, args));
|
||||
}
|
||||
if let Some(mut args) = shlex::split(&profile.command)
|
||||
&& !args.is_empty()
|
||||
{
|
||||
let command = args.remove(0);
|
||||
return Some(tty::Shell::new(command, args));
|
||||
}
|
||||
return None;
|
||||
None
|
||||
}),
|
||||
working_directory: startup_options.working_directory.or_else(
|
||||
|| {
|
||||
working_directory: startup_options
|
||||
.working_directory
|
||||
.or_else(|| inherited_working_directory.clone())
|
||||
.or_else(|| {
|
||||
(!profile.working_directory.is_empty())
|
||||
.then(|| profile.working_directory.clone().into())
|
||||
},
|
||||
),
|
||||
}),
|
||||
drain_on_exit: startup_options.drain_on_exit
|
||||
|| profile.drain_on_exit,
|
||||
..startup_options
|
||||
|
|
@ -1559,7 +1598,11 @@ impl App {
|
|||
};
|
||||
(options, tab_title_override)
|
||||
} else {
|
||||
(self.startup_options.take().unwrap_or_default(), None)
|
||||
let mut options = self.startup_options.take().unwrap_or_default();
|
||||
if options.working_directory.is_none() {
|
||||
options.working_directory = inherited_working_directory.clone();
|
||||
}
|
||||
(options, None)
|
||||
};
|
||||
|
||||
let entity = tab_model
|
||||
|
|
@ -1840,6 +1883,7 @@ impl Application for App {
|
|||
shortcut_search_regex: None,
|
||||
shortcut_search_value: String::new(),
|
||||
modifiers: Modifiers::empty(),
|
||||
context_menu_popup: None,
|
||||
#[cfg(feature = "password_manager")]
|
||||
password_mgr: Default::default(),
|
||||
};
|
||||
|
|
@ -1946,24 +1990,23 @@ impl Application for App {
|
|||
.get(&color_scheme_id)
|
||||
.map(|color_scheme| color_scheme.name.clone()),
|
||||
None => Some(format!("COSMIC {:?}", color_scheme_kind)),
|
||||
} {
|
||||
if self.dialog_opt.is_none() {
|
||||
let (dialog, command) = Dialog::new(
|
||||
DialogSettings::new().kind(DialogKind::SaveFile {
|
||||
filename: format!("{}.ron", color_scheme_name),
|
||||
}),
|
||||
Message::DialogMessage,
|
||||
move |result| {
|
||||
Message::ColorSchemeExportResult(
|
||||
color_scheme_kind,
|
||||
color_scheme_id_opt,
|
||||
result,
|
||||
)
|
||||
},
|
||||
);
|
||||
self.dialog_opt = Some(dialog);
|
||||
return command;
|
||||
}
|
||||
} && self.dialog_opt.is_none()
|
||||
{
|
||||
let (dialog, command) = Dialog::new(
|
||||
DialogSettings::new().kind(DialogKind::SaveFile {
|
||||
filename: format!("{}.ron", color_scheme_name),
|
||||
}),
|
||||
|msg| Message::DialogMessage(Box::new(msg)),
|
||||
move |result| {
|
||||
Message::ColorSchemeExportResult(
|
||||
color_scheme_kind,
|
||||
color_scheme_id_opt,
|
||||
result,
|
||||
)
|
||||
},
|
||||
);
|
||||
self.dialog_opt = Some(dialog);
|
||||
return command;
|
||||
}
|
||||
}
|
||||
Message::ColorSchemeExportResult(color_scheme_kind, color_scheme_id_opt, result) => {
|
||||
|
|
@ -2051,7 +2094,7 @@ impl Application for App {
|
|||
self.color_scheme_errors.clear();
|
||||
let (dialog, command) = Dialog::new(
|
||||
DialogSettings::new().kind(DialogKind::OpenMultipleFiles),
|
||||
Message::DialogMessage,
|
||||
|msg| Message::DialogMessage(Box::new(msg)),
|
||||
move |result| Message::ColorSchemeImportResult(color_scheme_kind, result),
|
||||
);
|
||||
self.dialog_opt = Some(dialog);
|
||||
|
|
@ -2105,15 +2148,13 @@ impl Application for App {
|
|||
Message::ColorSchemeRenameSubmit => {
|
||||
if let Some((color_scheme_kind, color_scheme_id, color_scheme_name)) =
|
||||
self.color_scheme_renaming.take()
|
||||
{
|
||||
if let Some(color_scheme) = self
|
||||
&& let Some(color_scheme) = self
|
||||
.config
|
||||
.color_schemes_mut(color_scheme_kind)
|
||||
.get_mut(&color_scheme_id)
|
||||
{
|
||||
color_scheme.name = color_scheme_name;
|
||||
return self.save_color_schemes(color_scheme_kind);
|
||||
}
|
||||
{
|
||||
color_scheme.name = color_scheme_name;
|
||||
return self.save_color_schemes(color_scheme_kind);
|
||||
}
|
||||
}
|
||||
Message::ColorSchemeTabActivate(entity) => {
|
||||
|
|
@ -2127,11 +2168,11 @@ impl Application for App {
|
|||
}
|
||||
}
|
||||
Message::Config(config) => {
|
||||
if config != self.config {
|
||||
if *config != self.config {
|
||||
let shortcuts_changed = config.shortcuts_custom != self.config.shortcuts_custom;
|
||||
log::info!("update config");
|
||||
//TODO: update syntax theme by clearing tabs, only if needed
|
||||
self.config = config;
|
||||
self.config = *config;
|
||||
if shortcuts_changed {
|
||||
self.shortcuts_config =
|
||||
shortcuts::ShortcutsConfig::new(self.config.shortcuts_custom.clone());
|
||||
|
|
@ -2295,7 +2336,8 @@ impl Application for App {
|
|||
},
|
||||
Message::DialogMessage(dialog_message) => {
|
||||
if let Some(dialog) = &mut self.dialog_opt {
|
||||
return dialog.update(dialog_message);
|
||||
// DialogMessage is boxed, so we need to dereference it before updating
|
||||
return dialog.update(*dialog_message);
|
||||
}
|
||||
}
|
||||
Message::Drop(Some((pane, entity, data))) => {
|
||||
|
|
@ -2334,13 +2376,13 @@ impl Application for App {
|
|||
return self.update_focus();
|
||||
}
|
||||
Message::FindNext => {
|
||||
if !self.find_search_value.is_empty() {
|
||||
if let Some(tab_model) = self.pane_model.active() {
|
||||
let entity = tab_model.active();
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
terminal.search(&self.find_search_value, true);
|
||||
}
|
||||
if !self.find_search_value.is_empty()
|
||||
&& let Some(tab_model) = self.pane_model.active()
|
||||
{
|
||||
let entity = tab_model.active();
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
terminal.search(&self.find_search_value, true);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -2348,13 +2390,13 @@ impl Application for App {
|
|||
return self.update_focus();
|
||||
}
|
||||
Message::FindPrevious => {
|
||||
if !self.find_search_value.is_empty() {
|
||||
if let Some(tab_model) = self.pane_model.active() {
|
||||
let entity = tab_model.active();
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
terminal.search(&self.find_search_value, false);
|
||||
}
|
||||
if !self.find_search_value.is_empty()
|
||||
&& let Some(tab_model) = self.pane_model.active()
|
||||
{
|
||||
let entity = tab_model.active();
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
terminal.search(&self.find_search_value, false);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -2431,7 +2473,6 @@ impl Application for App {
|
|||
if let Some(tab_model) = self.pane_model.active() {
|
||||
let entity = tab_model.active();
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
// Update context menu position
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
if let Some(url) =
|
||||
terminal.context_menu.as_ref().and_then(|m| m.link.as_ref())
|
||||
|
|
@ -2450,14 +2491,12 @@ impl Application for App {
|
|||
if let Some(tab_model) = self.pane_model.active() {
|
||||
let entity = tab_model.active();
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
// Update context menu position
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
if let Some(url) =
|
||||
terminal.context_menu.as_ref().and_then(|m| m.link.as_ref())
|
||||
&& let Err(err) = open::that_detached(url)
|
||||
{
|
||||
if let Err(err) = open::that_detached(url) {
|
||||
log::warn!("failed to open {:?}: {}", url, err);
|
||||
}
|
||||
log::warn!("failed to open {:?}: {}", url, err);
|
||||
}
|
||||
terminal.context_menu = None;
|
||||
terminal.active_regex_match = None;
|
||||
|
|
@ -2541,7 +2580,7 @@ impl Application for App {
|
|||
if let Some((pane, _)) = result {
|
||||
self.terminal_ids.insert(pane, widget::Id::unique());
|
||||
let command =
|
||||
self.create_and_focus_new_terminal(pane, self.get_default_profile());
|
||||
self.create_and_focus_new_terminal(pane, self.get_default_profile(), false);
|
||||
self.pane_model.panes_created += 1;
|
||||
return command;
|
||||
}
|
||||
|
|
@ -2653,8 +2692,11 @@ impl Application for App {
|
|||
return self.save_profiles();
|
||||
}
|
||||
Message::ProfileOpen(profile_id) => {
|
||||
return self
|
||||
.create_and_focus_new_terminal(self.pane_model.focused(), Some(profile_id));
|
||||
return self.create_and_focus_new_terminal(
|
||||
self.pane_model.focused(),
|
||||
Some(profile_id),
|
||||
false,
|
||||
);
|
||||
}
|
||||
Message::ProfileRemove(profile_id) => {
|
||||
// Reset matching terminals to default profile
|
||||
|
|
@ -2720,6 +2762,12 @@ impl Application for App {
|
|||
return self.update_config();
|
||||
}
|
||||
}
|
||||
Message::TabNewInheritWorkingDirectory(tab_new_inherit_working_directory) => {
|
||||
config_set!(
|
||||
tab_new_inherit_working_directory,
|
||||
tab_new_inherit_working_directory
|
||||
);
|
||||
}
|
||||
Message::UseBrightBold(use_bright_bold) => {
|
||||
if use_bright_bold != self.config.use_bright_bold {
|
||||
config_set!(use_bright_bold, use_bright_bold);
|
||||
|
|
@ -2810,63 +2858,138 @@ impl Application for App {
|
|||
return self.update_title(None);
|
||||
}
|
||||
Message::TabContextAction(entity, action) => {
|
||||
if let Some(tab_model) = self.pane_model.active() {
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
// Close context menu
|
||||
{
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
//Some actions need the menu_state,
|
||||
//so only clear the position for them.
|
||||
match action {
|
||||
Action::LaunchUrlByMenu | Action::CopyUrlByMenu => {
|
||||
if let Some(context_menu) = terminal.context_menu.as_mut() {
|
||||
context_menu.position = None;
|
||||
}
|
||||
}
|
||||
_ => {
|
||||
terminal.context_menu = None;
|
||||
}
|
||||
// Close context menu popup
|
||||
let mut tasks = Vec::new();
|
||||
if let Some((_popup_id, _, _, _, _, _)) = self.context_menu_popup.take() {
|
||||
#[cfg(feature = "wayland")]
|
||||
if is_wayland() {
|
||||
tasks.push(cosmic::task::message(Message::Surface(
|
||||
cosmic::surface::action::destroy_popup(_popup_id),
|
||||
)));
|
||||
}
|
||||
}
|
||||
// Close terminal context menu state
|
||||
if let Some(tab_model) = self.pane_model.active()
|
||||
&& let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity)
|
||||
{
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
//Some actions need the menu_state,
|
||||
//so only clear the position for them.
|
||||
match action {
|
||||
Action::LaunchUrlByMenu | Action::CopyUrlByMenu => {
|
||||
if let Some(context_menu) = terminal.context_menu.as_mut() {
|
||||
context_menu.position = None;
|
||||
}
|
||||
}
|
||||
// Run action's message
|
||||
return self.update(action.message(Some(entity)));
|
||||
_ => {
|
||||
terminal.context_menu = None;
|
||||
}
|
||||
}
|
||||
}
|
||||
tasks.push(self.update(action.message(Some(entity))));
|
||||
return cosmic::Task::batch(tasks);
|
||||
}
|
||||
Message::TabContextMenu(pane, menu_state) => {
|
||||
// Close any existing context menues
|
||||
let panes: Vec<_> = self.pane_model.panes.iter().collect();
|
||||
for (_pane, tab_model) in panes {
|
||||
let entity = tab_model.active();
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
terminal.context_menu = None;
|
||||
#[allow(unused_mut)]
|
||||
let mut tasks = Vec::new();
|
||||
|
||||
// Close existing context menu popup if any
|
||||
if let Some((_popup_id, _, _, _, _, _)) = self.context_menu_popup.take() {
|
||||
#[cfg(feature = "wayland")]
|
||||
if is_wayland() {
|
||||
tasks.push(cosmic::task::message(Message::Surface(
|
||||
cosmic::surface::action::destroy_popup(_popup_id),
|
||||
)));
|
||||
}
|
||||
}
|
||||
|
||||
// Show the context menu on the correct pane / terminal
|
||||
if let Some(tab_model) = self.pane_model.panes.get(pane) {
|
||||
let entity = tab_model.active();
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
// Update context menu position
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
terminal.context_menu = menu_state;
|
||||
// Clear all terminal context_menu state
|
||||
for (_, tab_model) in self.pane_model.panes.iter() {
|
||||
for entity in tab_model.iter() {
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
terminal.context_menu = None;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Shift focus to the pane / terminal
|
||||
// with the context menu
|
||||
self.pane_model.set_focus(pane);
|
||||
return self.update_title(Some(pane));
|
||||
if let Some(menu_state) = menu_state {
|
||||
if let Some(_position) = menu_state.position {
|
||||
let local_position = menu_state.local_position.unwrap_or(_position);
|
||||
if let Some(tab_model) = self.pane_model.panes.get(pane) {
|
||||
let entity = tab_model.active();
|
||||
let link = menu_state.link.clone();
|
||||
let popup_id = window::Id::unique();
|
||||
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
terminal.context_menu = Some(menu_state);
|
||||
}
|
||||
|
||||
self.context_menu_popup = Some((
|
||||
popup_id,
|
||||
pane,
|
||||
entity,
|
||||
link,
|
||||
widget::Id::unique(),
|
||||
local_position,
|
||||
));
|
||||
|
||||
#[cfg(feature = "wayland")]
|
||||
if is_wayland() {
|
||||
let main_window = self.core.main_window_id().unwrap();
|
||||
let pos_x = _position.x as i32;
|
||||
let pos_y = _position.y as i32;
|
||||
|
||||
tasks.push(cosmic::task::message(Message::Surface(
|
||||
cosmic::surface::action::app_popup(move |_app: &mut Self| {
|
||||
use cosmic::cctk::wayland_protocols::xdg::shell::client::xdg_positioner::{Anchor, Gravity};
|
||||
use cosmic::iced::runtime::platform_specific::wayland::popup::{SctkPopupSettings, SctkPositioner};
|
||||
|
||||
SctkPopupSettings {
|
||||
parent: main_window,
|
||||
id: popup_id,
|
||||
positioner: SctkPositioner {
|
||||
size: None,
|
||||
anchor_rect: cosmic::iced::Rectangle {
|
||||
x: pos_x,
|
||||
y: pos_y,
|
||||
width: 1,
|
||||
height: 1,
|
||||
},
|
||||
anchor: Anchor::None,
|
||||
gravity: Gravity::BottomRight,
|
||||
reactive: true,
|
||||
..Default::default()
|
||||
},
|
||||
parent_size: None,
|
||||
grab: true,
|
||||
close_with_children: false,
|
||||
input_zone: None,
|
||||
}
|
||||
}, None),
|
||||
)));
|
||||
}
|
||||
}
|
||||
}
|
||||
self.pane_model.set_focus(pane);
|
||||
}
|
||||
|
||||
return cosmic::Task::batch(tasks);
|
||||
}
|
||||
Message::TabNew => {
|
||||
return self.create_and_focus_new_terminal(
|
||||
self.pane_model.focused(),
|
||||
self.get_default_profile(),
|
||||
self.config.tab_new_inherit_working_directory,
|
||||
);
|
||||
}
|
||||
Message::TabNewNoProfile => {
|
||||
return self.create_and_focus_new_terminal(self.pane_model.focused(), None);
|
||||
return self.create_and_focus_new_terminal(
|
||||
self.pane_model.focused(),
|
||||
None,
|
||||
self.config.tab_new_inherit_working_directory,
|
||||
);
|
||||
}
|
||||
Message::TabNext => {
|
||||
if let Some(tab_model) = self.pane_model.active() {
|
||||
|
|
@ -2888,9 +3011,7 @@ impl Application for App {
|
|||
let pos = tab_model
|
||||
.position(tab_model.active())
|
||||
.and_then(|i| (i as usize).checked_sub(1))
|
||||
.unwrap_or_else(|| {
|
||||
tab_model.iter().count().checked_sub(1).unwrap_or_default()
|
||||
});
|
||||
.unwrap_or_else(|| tab_model.iter().count().saturating_sub(1));
|
||||
|
||||
let entity = tab_model.iter().nth(pos);
|
||||
if let Some(entity) = entity {
|
||||
|
|
@ -2929,13 +3050,13 @@ impl Application for App {
|
|||
}
|
||||
},
|
||||
TermEvent::ColorRequest(index, f) => {
|
||||
if let Some(tab_model) = self.pane_model.panes.get(pane) {
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let terminal = terminal.lock().unwrap();
|
||||
let rgb = terminal.colors()[index].unwrap_or_default();
|
||||
let text = f(rgb);
|
||||
terminal.input_no_scroll(text.into_bytes());
|
||||
}
|
||||
if let Some(tab_model) = self.pane_model.panes.get(pane)
|
||||
&& let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity)
|
||||
{
|
||||
let terminal = terminal.lock().unwrap();
|
||||
let rgb = terminal.colors()[index].unwrap_or_default();
|
||||
let text = f(rgb);
|
||||
terminal.input_no_scroll(text.into_bytes());
|
||||
}
|
||||
}
|
||||
TermEvent::CursorBlinkingChange => {
|
||||
|
|
@ -2945,11 +3066,11 @@ impl Application for App {
|
|||
return self.update(Message::TabClose(Some(entity)));
|
||||
}
|
||||
TermEvent::PtyWrite(text) => {
|
||||
if let Some(tab_model) = self.pane_model.panes.get(pane) {
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let terminal = terminal.lock().unwrap();
|
||||
terminal.input_no_scroll(text.into_bytes());
|
||||
}
|
||||
if let Some(tab_model) = self.pane_model.panes.get(pane)
|
||||
&& let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity)
|
||||
{
|
||||
let terminal = terminal.lock().unwrap();
|
||||
terminal.input_no_scroll(text.into_bytes());
|
||||
}
|
||||
}
|
||||
TermEvent::ResetTitle => {
|
||||
|
|
@ -2969,12 +3090,12 @@ impl Application for App {
|
|||
return self.update_title(Some(pane));
|
||||
}
|
||||
TermEvent::TextAreaSizeRequest(f) => {
|
||||
if let Some(tab_model) = self.pane_model.panes.get(pane) {
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let terminal = terminal.lock().unwrap();
|
||||
let text = f(terminal.size().into());
|
||||
terminal.input_no_scroll(text.into_bytes());
|
||||
}
|
||||
if let Some(tab_model) = self.pane_model.panes.get(pane)
|
||||
&& let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity)
|
||||
{
|
||||
let terminal = terminal.lock().unwrap();
|
||||
let text = f(terminal.size().into());
|
||||
terminal.input_no_scroll(text.into_bytes());
|
||||
}
|
||||
}
|
||||
TermEvent::Title(title) => {
|
||||
|
|
@ -2993,11 +3114,11 @@ impl Application for App {
|
|||
return self.update_title(Some(pane));
|
||||
}
|
||||
TermEvent::MouseCursorDirty | TermEvent::Wakeup => {
|
||||
if let Some(tab_model) = self.pane_model.panes.get(pane) {
|
||||
if let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity) {
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
terminal.needs_update = true;
|
||||
}
|
||||
if let Some(tab_model) = self.pane_model.panes.get(pane)
|
||||
&& let Some(terminal) = tab_model.data::<Mutex<Terminal>>(entity)
|
||||
{
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
terminal.needs_update = true;
|
||||
}
|
||||
}
|
||||
TermEvent::ChildExit(_error_code) => {
|
||||
|
|
@ -3130,9 +3251,25 @@ impl Application for App {
|
|||
return self.update_render_active_pane_zoom(message);
|
||||
}
|
||||
Message::ZoomReset => {
|
||||
self.reset_terminal_panes_zoom();
|
||||
self.reset_active_pane_zoom();
|
||||
return self.update_config();
|
||||
}
|
||||
Message::ContextMenuPopupClosed(id) => {
|
||||
if let Some((popup_id, pane, entity, _, _, _)) = &self.context_menu_popup
|
||||
&& id == *popup_id
|
||||
{
|
||||
// Clear link underline on the terminal
|
||||
if let Some(tab_model) = self.pane_model.panes.get(*pane)
|
||||
&& let Some(terminal) = tab_model.data::<Mutex<Terminal>>(*entity)
|
||||
{
|
||||
let mut terminal = terminal.lock().unwrap();
|
||||
terminal.context_menu = None;
|
||||
terminal.active_regex_match = None;
|
||||
terminal.needs_update = true;
|
||||
}
|
||||
self.context_menu_popup = None;
|
||||
}
|
||||
}
|
||||
Message::Surface(a) => {
|
||||
return cosmic::task::message(cosmic::Action::Cosmic(
|
||||
cosmic::app::Action::Surface(a),
|
||||
|
|
@ -3239,7 +3376,26 @@ impl Application for App {
|
|||
]
|
||||
}
|
||||
|
||||
fn on_close_requested(&self, id: window::Id) -> Option<Self::Message> {
|
||||
if let Some((popup_id, _, _, _, _, _)) = &self.context_menu_popup
|
||||
&& id == *popup_id
|
||||
{
|
||||
return Some(Message::ContextMenuPopupClosed(id));
|
||||
}
|
||||
None
|
||||
}
|
||||
|
||||
fn view_window(&self, window_id: window::Id) -> Element<'_, Message> {
|
||||
if let Some((popup_id, _pane, entity, ref link, ref autosize_id, _)) =
|
||||
self.context_menu_popup
|
||||
&& window_id == popup_id
|
||||
{
|
||||
return widget::autosize::autosize(
|
||||
menu::context_menu(&self.config, &self.key_binds, entity, link.clone()),
|
||||
autosize_id.clone(),
|
||||
)
|
||||
.into();
|
||||
}
|
||||
match &self.dialog_opt {
|
||||
Some(dialog) => dialog.view(window_id),
|
||||
None => widget::text("Unknown window ID").into(),
|
||||
|
|
@ -3267,7 +3423,7 @@ impl Application for App {
|
|||
)
|
||||
.class(style::Container::Custom(Box::new(|theme| {
|
||||
let cosmic = theme.cosmic();
|
||||
cosmic::iced_widget::container::Style {
|
||||
cosmic::iced::widget::container::Style {
|
||||
icon_color: Some(Color::from(cosmic.background.on)),
|
||||
text_color: Some(Color::from(cosmic.background.on)),
|
||||
background: Some(iced::Background::Color(
|
||||
|
|
@ -3307,25 +3463,48 @@ impl Application for App {
|
|||
terminal_box = terminal_box.on_mouse_enter(move || Message::MouseEnter(pane));
|
||||
}
|
||||
|
||||
let context_menu = {
|
||||
let terminal = terminal.lock().unwrap();
|
||||
terminal.context_menu.clone()
|
||||
// If a context menu popup is active for this pane, inform the
|
||||
// terminal_box so it will emit on_context_menu(None) on click
|
||||
// to dismiss the popup.
|
||||
if self.context_menu_popup.is_some() {
|
||||
terminal_box = terminal_box.context_menu(cosmic::iced::Point::ORIGIN);
|
||||
}
|
||||
|
||||
let use_wayland_popup = {
|
||||
#[cfg(feature = "wayland")]
|
||||
{
|
||||
is_wayland()
|
||||
}
|
||||
#[cfg(not(feature = "wayland"))]
|
||||
{
|
||||
false
|
||||
}
|
||||
};
|
||||
|
||||
let tab_element: Element<'_, Message> = match context_menu {
|
||||
Some(menu_state) => match menu_state.position {
|
||||
Some(point) => widget::popover(terminal_box.context_menu(point))
|
||||
.popup(menu::context_menu(
|
||||
&self.config,
|
||||
&self.key_binds,
|
||||
entity,
|
||||
menu_state.link,
|
||||
))
|
||||
.position(widget::popover::Position::Point(point))
|
||||
.into(),
|
||||
None => terminal_box.into(),
|
||||
},
|
||||
None => terminal_box.into(),
|
||||
let tab_element: Element<'_, Message> = if !use_wayland_popup {
|
||||
// Fallback: render context menu as an inline popover
|
||||
if let Some((_, popup_pane, popup_entity, ref link, _, point)) =
|
||||
self.context_menu_popup
|
||||
{
|
||||
if pane == popup_pane {
|
||||
let mut popover = widget::popover(terminal_box.context_menu(point));
|
||||
popover = popover
|
||||
.popup(menu::context_menu(
|
||||
&self.config,
|
||||
&self.key_binds,
|
||||
popup_entity,
|
||||
link.clone(),
|
||||
))
|
||||
.position(widget::popover::Position::Point(point));
|
||||
popover.into()
|
||||
} else {
|
||||
terminal_box.into()
|
||||
}
|
||||
} else {
|
||||
terminal_box.into()
|
||||
}
|
||||
} else {
|
||||
terminal_box.into()
|
||||
};
|
||||
tab_column = tab_column.push(tab_element);
|
||||
}
|
||||
|
|
@ -3471,7 +3650,7 @@ impl Application for App {
|
|||
update.errors
|
||||
);
|
||||
}
|
||||
Message::Config(update.config)
|
||||
Message::Config(Box::new(update.config))
|
||||
}),
|
||||
match &self.dialog_opt {
|
||||
Some(dialog) => dialog.subscription(),
|
||||
|
|
@ -3480,3 +3659,11 @@ impl Application for App {
|
|||
])
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(feature = "wayland")]
|
||||
fn is_wayland() -> bool {
|
||||
matches!(
|
||||
cosmic::app::cosmic::windowing_system(),
|
||||
Some(cosmic::app::cosmic::WindowingSystem::Wayland)
|
||||
)
|
||||
}
|
||||
|
|
|
|||
|
|
@ -7,8 +7,8 @@ use cosmic::widget::{Column, space};
|
|||
use cosmic::{
|
||||
Element,
|
||||
app::Core,
|
||||
iced::core::Border,
|
||||
iced::{Background, Length, advanced::widget::text::Style as TextStyle},
|
||||
iced_core::Border,
|
||||
theme,
|
||||
widget::{
|
||||
self, divider,
|
||||
|
|
@ -26,6 +26,7 @@ static MENU_ID: LazyLock<cosmic::widget::Id> =
|
|||
#[derive(Debug, Clone)]
|
||||
pub struct MenuState {
|
||||
pub position: Option<Point>,
|
||||
pub local_position: Option<Point>,
|
||||
pub link: Option<String>,
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -234,10 +234,10 @@ impl PasswordManager {
|
|||
}
|
||||
|
||||
// Don't do anything if nothing have changed
|
||||
if let Some(original) = &original {
|
||||
if original == &input_state.input {
|
||||
return Task::none();
|
||||
}
|
||||
if let Some(original) = &original
|
||||
&& original == &input_state.input
|
||||
{
|
||||
return Task::none();
|
||||
}
|
||||
|
||||
cosmic::task::future(async move {
|
||||
|
|
@ -246,19 +246,14 @@ impl PasswordManager {
|
|||
"Failed to add password {identifier}: {err}"
|
||||
)))
|
||||
} else {
|
||||
if let Some(original) = original {
|
||||
if original.identifier != identifier {
|
||||
if let Err(err) =
|
||||
store::delete_password(original.identifier.clone()).await
|
||||
{
|
||||
return Message::PasswordManager(PasswordManagerMessage::Error(
|
||||
format!(
|
||||
"Failed to delete password {}: {err}",
|
||||
original.identifier
|
||||
),
|
||||
));
|
||||
}
|
||||
}
|
||||
if let Some(original) = original
|
||||
&& original.identifier != identifier
|
||||
&& let Err(err) = store::delete_password(original.identifier.clone()).await
|
||||
{
|
||||
return Message::PasswordManager(PasswordManagerMessage::Error(format!(
|
||||
"Failed to delete password {}: {err}",
|
||||
original.identifier
|
||||
)));
|
||||
}
|
||||
Message::PasswordManager(PasswordManagerMessage::None)
|
||||
}
|
||||
|
|
@ -315,72 +310,68 @@ impl PasswordManager {
|
|||
.spacing(space_xxs),
|
||||
);
|
||||
|
||||
if expanded {
|
||||
if let Some(input_state) = &self.input_state {
|
||||
let expanded_section: Section<'_, Message> = widget::settings::section().add(
|
||||
if expanded && let Some(input_state) = &self.input_state {
|
||||
let expanded_section: Section<'_, Message> = widget::settings::section().add(
|
||||
widget::column::with_children(vec![
|
||||
widget::column::with_children(vec![
|
||||
widget::column::with_children(vec![
|
||||
widget::text(fl!("password-input-description")).into(),
|
||||
widget::text_input("", input_state.input.identifier.clone())
|
||||
.on_input(move |text| {
|
||||
Message::PasswordManager(
|
||||
PasswordManagerMessage::DescriptionInput(text),
|
||||
)
|
||||
})
|
||||
.on_submit(move |text| {
|
||||
Message::PasswordManager(
|
||||
PasswordManagerMessage::DescriptionInputAndUpdate(text),
|
||||
)
|
||||
})
|
||||
.on_unfocus(Message::PasswordManager(
|
||||
PasswordManagerMessage::Update,
|
||||
))
|
||||
.into(),
|
||||
])
|
||||
.spacing(space_xxxs)
|
||||
.into(),
|
||||
widget::column::with_children(vec![
|
||||
widget::text(fl!("password-input")).into(),
|
||||
widget::secure_input(
|
||||
"",
|
||||
input_state.input.password.clone(),
|
||||
Some(Message::PasswordManager(
|
||||
PasswordManagerMessage::ToggleShowPassword,
|
||||
)),
|
||||
!input_state.show_password,
|
||||
)
|
||||
widget::text(fl!("password-input-description")).into(),
|
||||
widget::text_input("", input_state.input.identifier.clone())
|
||||
.on_input(move |text| {
|
||||
Message::PasswordManager(PasswordManagerMessage::PasswordInput(
|
||||
text,
|
||||
))
|
||||
Message::PasswordManager(
|
||||
PasswordManagerMessage::DescriptionInput(text),
|
||||
)
|
||||
})
|
||||
.on_submit(move |text| {
|
||||
Message::PasswordManager(
|
||||
PasswordManagerMessage::PasswordInputAndUpdate(text),
|
||||
PasswordManagerMessage::DescriptionInputAndUpdate(text),
|
||||
)
|
||||
})
|
||||
.on_unfocus(Message::PasswordManager(
|
||||
PasswordManagerMessage::Update,
|
||||
))
|
||||
.into(),
|
||||
])
|
||||
.spacing(space_xxxs)
|
||||
])
|
||||
.spacing(space_xxxs)
|
||||
.into(),
|
||||
widget::column::with_children(vec![
|
||||
widget::text(fl!("password-input")).into(),
|
||||
widget::secure_input(
|
||||
"",
|
||||
input_state.input.password.clone(),
|
||||
Some(Message::PasswordManager(
|
||||
PasswordManagerMessage::ToggleShowPassword,
|
||||
)),
|
||||
!input_state.show_password,
|
||||
)
|
||||
.on_input(move |text| {
|
||||
Message::PasswordManager(PasswordManagerMessage::PasswordInput(
|
||||
text,
|
||||
))
|
||||
})
|
||||
.on_submit(move |text| {
|
||||
Message::PasswordManager(
|
||||
PasswordManagerMessage::PasswordInputAndUpdate(text),
|
||||
)
|
||||
})
|
||||
.on_unfocus(Message::PasswordManager(PasswordManagerMessage::Update))
|
||||
.into(),
|
||||
])
|
||||
.padding([0, space_s])
|
||||
.spacing(space_xs),
|
||||
);
|
||||
.spacing(space_xxxs)
|
||||
.into(),
|
||||
])
|
||||
.padding([0, space_s])
|
||||
.spacing(space_xs),
|
||||
);
|
||||
|
||||
let padding = Padding {
|
||||
top: 0.0,
|
||||
bottom: 0.0,
|
||||
left: space_s.into(),
|
||||
right: space_s.into(),
|
||||
};
|
||||
let padding = Padding {
|
||||
top: 0.0,
|
||||
bottom: 0.0,
|
||||
left: space_s.into(),
|
||||
right: space_s.into(),
|
||||
};
|
||||
|
||||
passwords_section =
|
||||
passwords_section.add(widget::container(expanded_section).padding(padding))
|
||||
}
|
||||
passwords_section =
|
||||
passwords_section.add(widget::container(expanded_section).padding(padding))
|
||||
}
|
||||
}
|
||||
sections.push(passwords_section.into());
|
||||
|
|
|
|||
|
|
@ -2,8 +2,8 @@
|
|||
|
||||
use cosmic::widget::menu::key_bind::{KeyBind, Modifier};
|
||||
use cosmic::{
|
||||
iced::core::keyboard::key::Named,
|
||||
iced::keyboard::{Key, Modifiers},
|
||||
iced_core::keyboard::key::Named,
|
||||
};
|
||||
use serde::{Deserialize, Serialize};
|
||||
use std::collections::{BTreeMap, HashMap};
|
||||
|
|
@ -245,11 +245,11 @@ impl ShortcutsConfig {
|
|||
// Remove any matching bindings
|
||||
return false;
|
||||
}
|
||||
if let Some(default_action) = self.defaults.0.get(binding) {
|
||||
if *default_action == reset_action {
|
||||
// Remove binding that overrode a default
|
||||
return false;
|
||||
}
|
||||
if let Some(default_action) = self.defaults.0.get(binding)
|
||||
&& *default_action == reset_action
|
||||
{
|
||||
// Remove binding that overrode a default
|
||||
return false;
|
||||
}
|
||||
true
|
||||
});
|
||||
|
|
|
|||
|
|
@ -28,7 +28,8 @@ use indexmap::IndexSet;
|
|||
use std::{
|
||||
borrow::Cow,
|
||||
collections::HashMap,
|
||||
io, mem,
|
||||
fs, io, mem,
|
||||
path::PathBuf,
|
||||
sync::{
|
||||
Arc, Mutex, Weak,
|
||||
atomic::{AtomicU32, Ordering},
|
||||
|
|
@ -257,6 +258,7 @@ pub struct Terminal {
|
|||
notifier: Notifier,
|
||||
search_regex_opt: Option<RegexSearch>,
|
||||
search_value: String,
|
||||
shell_pid: Option<u32>,
|
||||
size: Size,
|
||||
use_bright_bold: bool,
|
||||
zoom_adj: i8,
|
||||
|
|
@ -264,6 +266,7 @@ pub struct Terminal {
|
|||
|
||||
impl Terminal {
|
||||
//TODO: error handling
|
||||
#[allow(clippy::too_many_arguments)]
|
||||
pub fn new(
|
||||
pane: pane_grid::Pane,
|
||||
entity: segmented_button::Entity,
|
||||
|
|
@ -303,13 +306,13 @@ impl Terminal {
|
|||
let (cell_width, cell_height) = {
|
||||
let mut font_system = font_system().write().unwrap();
|
||||
let font_system = font_system.raw();
|
||||
buffer.set_wrap(font_system, Wrap::None);
|
||||
buffer.set_wrap(Wrap::None);
|
||||
|
||||
// Use size of space to determine cell size
|
||||
buffer.set_text(font_system, " ", &default_attrs, Shaping::Advanced, None);
|
||||
buffer.set_text(" ", &default_attrs, Shaping::Advanced, None);
|
||||
let layout = buffer.line_layout(font_system, 0).unwrap();
|
||||
let w = layout[0].w;
|
||||
buffer.set_monospace_width(font_system, Some(w));
|
||||
buffer.set_monospace_width(Some(w));
|
||||
(w, metrics.line_height)
|
||||
};
|
||||
|
||||
|
|
@ -328,6 +331,10 @@ impl Terminal {
|
|||
|
||||
let window_id = 0;
|
||||
let pty = tty::new(&options, size.into(), window_id)?;
|
||||
#[cfg(not(windows))]
|
||||
let shell_pid = Some(pty.child().id());
|
||||
#[cfg(windows)]
|
||||
let shell_pid = pty.child_watcher().pid().map(|pid| pid.get());
|
||||
|
||||
let pty_event_loop =
|
||||
EventLoop::new(term.clone(), event_proxy, pty, options.drain_on_exit, false)?;
|
||||
|
|
@ -352,6 +359,7 @@ impl Terminal {
|
|||
profile_id_opt,
|
||||
search_regex_opt: None,
|
||||
search_value: String::new(),
|
||||
shell_pid,
|
||||
size,
|
||||
tab_title_override,
|
||||
term,
|
||||
|
|
@ -407,6 +415,19 @@ impl Terminal {
|
|||
self.notifier.notify(input);
|
||||
}
|
||||
|
||||
pub fn working_directory(&self) -> Option<PathBuf> {
|
||||
#[cfg(target_os = "linux")]
|
||||
{
|
||||
let shell_pid = self.shell_pid?;
|
||||
fs::read_link(format!("/proc/{shell_pid}/cwd")).ok()
|
||||
}
|
||||
|
||||
#[cfg(not(target_os = "linux"))]
|
||||
{
|
||||
None
|
||||
}
|
||||
}
|
||||
|
||||
pub fn input_scroll<I: Into<Cow<'static, [u8]>>>(&self, input: I) {
|
||||
self.input_no_scroll(input);
|
||||
self.scroll(TerminalScroll::Bottom);
|
||||
|
|
@ -448,8 +469,7 @@ impl Terminal {
|
|||
self.term.lock().resize(self.size);
|
||||
|
||||
self.with_buffer_mut(|buffer| {
|
||||
let mut font_system = font_system().write().unwrap();
|
||||
buffer.set_size(font_system.raw(), Some(width as f32), Some(height as f32));
|
||||
buffer.set_size(Some(width as f32), Some(height as f32));
|
||||
});
|
||||
|
||||
self.needs_update = true;
|
||||
|
|
@ -632,10 +652,7 @@ impl Terminal {
|
|||
|
||||
let metrics = config.metrics(zoom_adj);
|
||||
if metrics != self.buffer.metrics() {
|
||||
{
|
||||
let mut font_system = font_system().write().unwrap();
|
||||
self.with_buffer_mut(|buffer| buffer.set_metrics(font_system.raw(), metrics));
|
||||
}
|
||||
self.with_buffer_mut(|buffer| buffer.set_metrics(metrics));
|
||||
update_cell_size = true;
|
||||
}
|
||||
|
||||
|
|
@ -692,19 +709,13 @@ impl Terminal {
|
|||
let (cell_width, cell_height) = {
|
||||
let mut font_system = font_system().write().unwrap();
|
||||
self.with_buffer_mut(|buffer| {
|
||||
buffer.set_wrap(font_system.raw(), Wrap::None);
|
||||
buffer.set_wrap(Wrap::None);
|
||||
|
||||
// Use size of space to determine cell size
|
||||
buffer.set_text(
|
||||
font_system.raw(),
|
||||
" ",
|
||||
&default_attrs,
|
||||
Shaping::Advanced,
|
||||
None,
|
||||
);
|
||||
buffer.set_text(" ", &default_attrs, Shaping::Advanced, None);
|
||||
let layout = buffer.line_layout(font_system.raw(), 0).unwrap();
|
||||
let w = layout[0].w;
|
||||
buffer.set_monospace_width(font_system.raw(), Some(w));
|
||||
buffer.set_monospace_width(Some(w));
|
||||
(w, buffer.metrics().line_height)
|
||||
})
|
||||
};
|
||||
|
|
@ -868,13 +879,12 @@ impl Terminal {
|
|||
}
|
||||
|
||||
// Change color if selected
|
||||
if let Some(selection) = &term.selection {
|
||||
if let Some(range) = selection.to_range(&term) {
|
||||
if range.contains(indexed.point) {
|
||||
//TODO: better handling of selection
|
||||
mem::swap(&mut fg, &mut bg);
|
||||
}
|
||||
}
|
||||
if let Some(selection) = &term.selection
|
||||
&& let Some(range) = selection.to_range(&term)
|
||||
&& range.contains(indexed.point)
|
||||
{
|
||||
//TODO: better handling of selection
|
||||
mem::swap(&mut fg, &mut bg);
|
||||
}
|
||||
|
||||
// Convert foreground to linear
|
||||
|
|
@ -888,10 +898,10 @@ impl Terminal {
|
|||
|
||||
let mut flags = indexed.cell.flags;
|
||||
|
||||
if let Some(active_match) = &self.active_regex_match {
|
||||
if active_match.contains(&indexed.point) {
|
||||
flags |= Flags::UNDERLINE;
|
||||
}
|
||||
if let Some(active_match) = &self.active_regex_match
|
||||
&& active_match.contains(&indexed.point)
|
||||
{
|
||||
flags |= Flags::UNDERLINE;
|
||||
}
|
||||
if let Some(active_id) = &self.active_hyperlink_id {
|
||||
let mut matches_active = indexed
|
||||
|
|
@ -1200,13 +1210,12 @@ impl<'a, T> Iterator for HintPostProcessor<'a, T> {
|
|||
fn next(&mut self) -> Option<Self::Item> {
|
||||
let next_match = self.next_match.take()?;
|
||||
|
||||
if self.start <= self.end {
|
||||
if let Some(rm) = self
|
||||
if self.start <= self.end
|
||||
&& let Some(rm) = self
|
||||
.term
|
||||
.regex_search_right(self.regex, self.start, self.end)
|
||||
{
|
||||
self.next_processed_match(rm);
|
||||
}
|
||||
{
|
||||
self.next_processed_match(rm);
|
||||
}
|
||||
|
||||
Some(next_match)
|
||||
|
|
|
|||
|
|
@ -10,15 +10,7 @@ use alacritty_terminal::{
|
|||
use cosmic::{
|
||||
Renderer,
|
||||
cosmic_theme::palette::{WithAlpha, blend::Compose},
|
||||
iced::{
|
||||
Color, Element, Length, Padding, Point, Rectangle, Size, Vector,
|
||||
advanced::graphics::text::Raw,
|
||||
event::{Event, Status},
|
||||
keyboard::{Event as KeyEvent, Key, Modifiers},
|
||||
mouse::{self, Button, Event as MouseEvent, ScrollDelta},
|
||||
window::RedrawRequest,
|
||||
},
|
||||
iced_core::{
|
||||
iced::core::{
|
||||
Border, Shell,
|
||||
clipboard::Clipboard,
|
||||
keyboard::key::Named,
|
||||
|
|
@ -31,9 +23,16 @@ use cosmic::{
|
|||
tree,
|
||||
},
|
||||
},
|
||||
iced::{
|
||||
Color, Element, Length, Padding, Point, Rectangle, Size, Vector,
|
||||
advanced::graphics::text::Raw,
|
||||
event::Event,
|
||||
keyboard::{Event as KeyEvent, Key, Modifiers},
|
||||
mouse::{self, Button, Event as MouseEvent, ScrollDelta},
|
||||
},
|
||||
theme::Theme,
|
||||
};
|
||||
use cosmic::{iced_core::SmolStr, widget::menu::key_bind::KeyBind};
|
||||
use cosmic::{iced::core::SmolStr, widget::menu::key_bind::KeyBind};
|
||||
use cosmic_text::LayoutGlyph;
|
||||
use indexmap::IndexSet;
|
||||
use std::{
|
||||
|
|
@ -863,8 +862,8 @@ where
|
|||
if is_mouse_mode {
|
||||
state.autoscroll.stop();
|
||||
} else {
|
||||
if let Some((pointer, multiplier)) = state.autoscroll.next_due() {
|
||||
if update_buffer_drag(
|
||||
if let Some((pointer, multiplier)) = state.autoscroll.next_due()
|
||||
&& update_buffer_drag(
|
||||
state,
|
||||
&mut terminal,
|
||||
buffer_size,
|
||||
|
|
@ -872,9 +871,9 @@ where
|
|||
layout.bounds(),
|
||||
self.padding,
|
||||
multiplier,
|
||||
) {
|
||||
shell.capture_event();
|
||||
}
|
||||
)
|
||||
{
|
||||
shell.capture_event();
|
||||
}
|
||||
if state.autoscroll.is_active() {
|
||||
shell.request_redraw();
|
||||
|
|
@ -1300,8 +1299,13 @@ where
|
|||
None,
|
||||
);
|
||||
let link = get_hyperlink(&terminal, location);
|
||||
let abs = cosmic::iced::Point::new(
|
||||
layout.bounds().x + p.x,
|
||||
layout.bounds().y + p.y,
|
||||
);
|
||||
shell.publish(on_context_menu(Some(MenuState {
|
||||
position: Some(p),
|
||||
position: Some(abs),
|
||||
local_position: Some(p),
|
||||
link,
|
||||
})));
|
||||
}
|
||||
|
|
@ -1314,21 +1318,20 @@ where
|
|||
}
|
||||
Event::Mouse(MouseEvent::ButtonReleased(Button::Left)) => {
|
||||
state.autoscroll.stop();
|
||||
if let Some(dragging) = state.dragging.take() {
|
||||
if let Dragging::Buffer {
|
||||
if let Some(dragging) = state.dragging.take()
|
||||
&& let Dragging::Buffer {
|
||||
last_point,
|
||||
last_side,
|
||||
..
|
||||
} = dragging
|
||||
{
|
||||
{
|
||||
{
|
||||
let mut term = terminal.term.lock();
|
||||
if let Some(selection) = &mut term.selection {
|
||||
selection.update(last_point, last_side);
|
||||
}
|
||||
let mut term = terminal.term.lock();
|
||||
if let Some(selection) = &mut term.selection {
|
||||
selection.update(last_point, last_side);
|
||||
}
|
||||
terminal.needs_update = true;
|
||||
}
|
||||
terminal.needs_update = true;
|
||||
}
|
||||
if let Some(p) = cursor_position.position_in(layout.bounds()) {
|
||||
let x = p.x - self.padding.left;
|
||||
|
|
@ -1339,13 +1342,12 @@ where
|
|||
|
||||
let location = terminal
|
||||
.viewport_to_point(TermPoint::new(row as usize, TermColumn(col as usize)));
|
||||
if state.modifiers.control() {
|
||||
if let Some(on_open_hyperlink) = &self.on_open_hyperlink {
|
||||
if let Some(hyperlink) = get_hyperlink(&terminal, location) {
|
||||
shell.publish(on_open_hyperlink(hyperlink));
|
||||
shell.capture_event();
|
||||
}
|
||||
}
|
||||
if state.modifiers.control()
|
||||
&& let Some(on_open_hyperlink) = &self.on_open_hyperlink
|
||||
&& let Some(hyperlink) = get_hyperlink(&terminal, location)
|
||||
{
|
||||
shell.publish(on_open_hyperlink(hyperlink));
|
||||
shell.capture_event();
|
||||
}
|
||||
|
||||
if is_mouse_mode {
|
||||
|
|
@ -1358,8 +1360,6 @@ where
|
|||
} else {
|
||||
shell.capture_event();
|
||||
}
|
||||
} else {
|
||||
shell.capture_event();
|
||||
}
|
||||
}
|
||||
Event::Mouse(MouseEvent::ButtonReleased(_button)) => {
|
||||
|
|
@ -1650,10 +1650,10 @@ fn update_active_regex_match(
|
|||
.find(|bounds| bounds.contains(&location))
|
||||
{
|
||||
'update: {
|
||||
if let Some(active_match) = &terminal.active_regex_match {
|
||||
if active_match == match_ {
|
||||
break 'update;
|
||||
}
|
||||
if let Some(active_match) = &terminal.active_regex_match
|
||||
&& active_match == match_
|
||||
{
|
||||
break 'update;
|
||||
}
|
||||
terminal.active_regex_match = Some(match_.clone());
|
||||
terminal.needs_update = true;
|
||||
|
|
@ -1714,6 +1714,7 @@ enum EdgeScrollDirection {
|
|||
Bottom,
|
||||
}
|
||||
|
||||
#[allow(clippy::too_many_arguments)]
|
||||
fn edge_scroll_adjustment(
|
||||
y: f32,
|
||||
buffer_height: f32,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue