/terminal

This is a fork of https://github.com/linuxdeepin/deepin-terminal with better Gtk and tiling managers support

Primary LanguageValaGNU General Public License v3.0GPL-3.0

Deepin Terminal

This is default terminal emulation application for Deepin.

Dependencies

In debian, use below command to install compile dependencies:

sudo apt-get install valac libgtk-3-dev libgee-0.8-dev libjson-glib-dev libsecret-1-dev libwnck-3-dev

In debian, use below command to install running dependencies:

sudo apt-get install libatk1.0-0 libc6 libcairo-gobject2 libcairo2 libfontconfig1 libfreetype6 libgdk-pixbuf2.0-0 libgee-0.8-2 libglib2.0-0 libgnutls30 libgtk-3-0 libjson-glib-1.0-0 libpango-1.0-0 libpangocairo-1.0-0 libsecret-1-0 libwnck-3-0 libx11-6 libxcb1 zlib1g lrzsz

And you also need deepin-menu from http://mirrors.deepin.com/deepin/pool/main/d/deepin-menu/ .

Installation

mkdir build; cd build; cmake ..; make; ./deepin-terminal

Usage

Below is keymap list for deepin-terminal:

Function Shortcut
Copy Ctrl + Shift + c
Paste Ctrl + Shift + v
Select word Double click
Open URL Ctrl + LeftButton
Search Ctrl + Shfit + f
Zoom in Ctrl + =
Zoom out Ctrl + -
Default size Ctrl + 0
Select all Ctrl + Shift + a
New workspace Ctrl + Shift + t
Close workspace Ctrl + Shift + w
Next workspace Ctrl + Tab
Preview workspace Ctrl + Shfit + Tab
Select workspace with number Alt + number
Vertical split Ctrl + Shift + j
Horizontal split Ctrl + Shfit + h
Select upper window Alt + k
Select lower window Alt + j
Select left window Alt + h
Select right window Alt + l
Close window Ctrl + Alt + q
Close other windows Ctrl + Shift + q
Create new theme window Ctrl + Alt + number
Switch fullscreen F11
Adjust background opacity Ctrl + ScrollButton
Display shortcuts Ctrl + Shift + ?
Custom commands Ctrl + [
Remote management Ctrl + /

Config file

Terminal's configure save at: ~/.config/deepin/deepin-terminal/config.conf

Remote servers' configure save at: ~/.config/deepin/deepin-terminal/server-config.conf

Customize command's configure save at: ~/.config/deepin/deepin-terminal/command-config.conf

Advanced config

cursor_shape

Cursor shape type, can set with 'block', 'ibeam', 'underline', default is block type.

cursor_blink_mode

Whether blink cursor, the default is true, set with false will improve performance though decrease repaint times.

cursor_auto_hide

Whether auto hide cursor when don't type in terminal, this default option is false.

scroll_on_key

Scroll terminal when type something in terminal, this option the default is true.

scroll_on_output

Scroll terminal when have new output, this default option is false, please don't enable this option, it's nosing.

scroll_line

The line of terminal can scroll back, default is -1, mean save all history, don't stripe terminal output.

use_on_starting

The window status at start, can set with 'window', 'maximize' and 'fullscreen', default is 'window'.

blur_background

Whether blur terminal's background, blur feature provide by DDE's window manager -- deepin-wm, default set false for better performance.

window_width

Window width when start, this option is record when you adjust window size. Of course, you can set it manually.

window_height

Window height when start, this option is record when you adjust window size. Of course, you can set it manually.

quake_window_height

The max height of quake terminal, set it with 1.0 can make quake window with any height you like.

quake_window_fullscreen

Whether make quake window use fullscreen mode, default is false.

remote_commands

Remote command list to help deepin-terminal detect current environment whether in remote server, default is zssh. You can add new command in list, command separator use character ; like remote_commands=zssh;new_command;another_command;

hide_quakewindow_after_lost_focus

Hide quake window after lost keyboard focus immediately, default is false to keep quake window even lost keyboard focus. Anyway, feel free to turn this option if you more like quake window hide after lost keyboard focus.

show_quakewindow_tab

Whether show tabbar in quake terminal, the default is true. It's cool if you don't like tabbar in quake terminal.

follow_active_window

Create new terminal in active monitor when this option set as true, create new terminal with cursor place when this option set as false.

hide_quakewindow_when_active

Just hide quake window when cursor is active when this option is true, if cursor is inactive, press quake-terminal keystroke will focus quake window first, and hide quake-terminal when press quake-temrinal keystroke agian. This behaviour help user jump back to quake-terminal quickly. It's feel free to turn off this feature if you just like to toggle quake-terminal when you press quake-terminal keystroke.

print_notify_after_script_finish

Press notify after you use terminal execute script finish, terminal won't exit until you press key, this feature useful to watch script execute result. The default is true, feel free to turn off this option if you know script's result exactly.

run_as_login_shell

Run shell as login_shell, default is false.

show_highlight_frame

Show highlight frame when you focus on terminal window, notify user cursor place. this default option is false, because it's too nosing to me.

copy_on_select

Copy select text to system clipboard directly if you turn on this option, i think many XShell users like this. ;) This optoin default is false, because it's linux style. ;)

Customize search engine

Deepin terminal build-in many search engine for engineer, such as Google, Bing, Baidu, GitHub, Stackover Flow, DuckDuckGo. Anyway, if you want build your own search engine, just follow below command:

  • Create config file ~/.config/deepin/deepin-terminal/search-engine-config.conf with below content:
[flickr]
name=Flickr
api=https://www.flickr.com/search/?text=%s

[googleimage]
name=Google Image
api=http://images.google.com/search?q=%s
  • Content in [] is searchengine name, use by terminal for id search.

  • name mean human name of search engine, you can name it to anything you like

  • api mean search api for search engine, note, you need use %s replace search keyword, otherwise, deepin-terminal don't know how to concat search api url and search keyboard.

Getting help

Any usage issues can ask for help via

Getting involved

We encourage you to report issues and contribute changes

License

Deepin Terminal is licensed under GPLv3.