X
Configuration
- xset is a user preference utility for X. It can be used to set different settings in X.
To get the current configuration settings:
xset q
xhost
For security, xhost is disabled by default on Ubuntu. To enable it back ([1]):
- Edit /etc/X11/xinit/xserverrc:
Remove the-nolisten tcp
- Edit /etc/gdm/gdm.conf:
Comment out theDisallowTCP=true
so that it doesn't add the-nolisten
back. - Really restart X — kill gdm and restart it:
sudo /etc/init.d/gdm stop
sudo /etc/init.d/gdm start
Windows Manager
References
The function of the window manager is to draw the windows in a certain place, with a certain size, and let them be movable and resizable.
Most common Window Managers on Ubuntu:
- Metacity — The default GNOME Window Manager
- Kwin — KDE Window Manager
- Compiz
Windows Decorator
The window decorator draws the window borders. It is not necessary to move the window, since alt+click & drag will still work even when the window decorator has crashed.
- Metacity has its own window decorator built-in
- KWin also has its own window decorator built-in
- Compiz supports 3 different window decorators:
- gtk-window-decorator
- kde-window-decorator
- emerald — The window decorator inherited from Beryl, the ancestor of Compiz.
Themes
Gnome:
- GTK theme — controls how buttons look, the colors of text, the window background, the scrollbars, and the menubar styles.
- Metacity theme — just controls the window border's style.
KDE:
- Qt theme — does the buttons, scrollbars, etc.,
- Kwin has its own themes for window borders.
When Compiz is used, the theme used depends on the selected window decorator. gtk-window-decorator uses Metacity themes, kde-window-decorator used kwin themes, Emerald has its own themes.
Input Devices
Use xev (package x11-utils) to detect keyboard or mouse presses, as well as any X events (show keycode - i.e. scancode, keypress, button press...).
Mouse
To adjust mouse properties, use xset m. Default settings (restored with xset m):
Pointer Control: acceleration: 2/1 threshold: 4
Set custom settings:
xset m 1/1 2 # xset m [acc_mult[/acc_div] [thr]]
In Gnome, mouse settings can also be configured in System → Hardware → Mouse.
Keyboard
Qwerty / Azerty
Some tips and tricks to (touch-)type on a QWERTY keyboard when the keymap is set to AZERTY.
The main issue is that AZERTY keyboard has an additional key next to the left SHIFT key. This key gives access to <, to > (Shift) and to \ (AltGr). To obtain these keys on a QWERTY keyboard, the basic trick is to temporarily switch the keyboard layout. Alternatively, one can use under X:
- <:
- >:
- \: Use AltGr-- (on QWERTY, i.e. AltGr-) on AZERTY)
Layout
To change keyboard layout (xfree86):
#Set to BE layout
xprop -root -f _XKB_RULES_NAMES 8s -set _XKB_RULES_NAMES xfree86
setxkbmap -model pc105 -layout be
#Set to US layout
xprop -root -f _XKB_RULES_NAMES 8s -set _XKB_RULES_NAMES xfree86
setxkbmap -model pc104 -layout us
Multiple keyboards - Change keyboard layout on each device separately ([2])
setxkbmap -device 3 af #Set device 3 to Farsi (to find device id, try 1 and then up)
setxkbmap -device 3 us #Set it back to US
Utilities
See Linux Commands for a list of X-related commands, and programs to manage key bindings in X. See Linux Software for list of X-related software.
Screenshot
- In Gnome,
- Press PrtScn to take a screenshot of the complete desktop.
- Press Alt + PrtScn to take a snapshot of window under mouse pointer.
- See all Linux Software#Shutter
- There exists also plenty of command-line & GUI solutions ([3]).
Synergy
Install Windows Client
- Execute setup program.
- Set the client to start automatically at PC startup
- Set the service Synergy Client to start manually.
- Check that the keymap for all users are identical.
- To launch the client:
net start "Synergy Client"
Install Linux Client
- Manual launch:
sudo synergyc --daemon --restart -n clientname servername
Install Linux Server
- Configuration file /etc/synergy.conf (see [http://synergy2.sourceforge.net/configuration.html reference manual) . Example
- Firewall — open up port 24800/TCP
- Server on gdm — Requires editing 3 gdm startup scripts. /etc/gdm/Init/Default:
- At the beginning of /etc/gdm/PostLogin/Default:
- At the beginning of /etc/gdm/PreSession/Default:
section: screens
gryphon:
BEQLEUNXP1NB103:
minimoy:
end
section: links
gryphon:
left = BEQLEUNXP1NB103
right = minimoy
BEQLEUNXP1NB103:
right = gryphon
minimoy:
left = gryphon
end
section: options
screenSaverSync = true
keystroke(shift+alt+right) = switchInDirection(right)
keystroke(shift+alt+left) = switchInDirection(left)
end
#
# Start the synergy server
#
/usr/bin/killall synergys
sleep 1
/usr/bin/synergys --config /etc/synergy.conf --daemon
exit 0
#
# Kill all running synergy server
#
/usr/bin/killall synergys
sleep 1
#
# Start synergy server
#
/usr/bin/killall synergys
sleep 1
/usr/bin/synergys --config /etc/synergy.conf --daemon
Starting manually with aliases
The aliases make it easy to restart synergy on the client / server in case of crashes (quite frequent),
Add to /etc/sudoers:
ALL ALL=NOPASSWD: /usr/bin/synergyc
ALL ALL=NOPASSWD: /usr/bin/synergys
ALL ALL=NOPASSWD: /usr/bin/killall -9 synergyc
ALL ALL=NOPASSWD: /usr/bin/killall -9 synergys
Define the following aliases:
alias synclient="sudo killall -9 synergyc; read -p 'Press ENTER...'; sudo synergyc --daemon --restart -n $HOSTNAME"
alias synserver='sudo killall -9 synergys 2>/dev/null; read -p "Press ENTER..."; sudo synergys --daemon --restart --config /etc/synergy.conf'
To start synergy:
synserver # On the server
synclient <servername> # On the client
Building from sources
Instructions to build synergy 1.3.8 on Lucid.
Build instructions say that we have to use cmake and the given hm.sh script. However that does not work! The script always complains about a missing generator argument, even though we try to give it in all possible ways.
Instead, do the usual configure; make
:
- Install the dependencies:
sudo apt-get install cmake make g++ xorg-dev libqt4-dev
- Unpack the archive, then
./configure
make
sudo cp bin/synergyc /usr/bin
sudo cp bin/synergys /usr/bin
Troubleshoot
- Sticky modifier keys (ctrl/alt/shift), desync capslock — This problem occurs at least one during my Linux - Linux session (Ubuntu Lucid client, Maverick client), belgium keyboard. Also Capslock event not seen on client. Some related bugs: [4], [5].
- Firefox Chinese bug — When copy/pasting text (incl. address bar) from Firefox to a remote Windows screen, chinese characters are printed instead. Workaround:
- Security — Data are not encrypted between the server and the client(s). To enable this, use SSH port forwarding. Run on the remote client:
- Login / Unlocking screen saver on Windows client — On Windows client, Synergy must be configured to autostart at boot in order to be able to unlock a session (eg. when client screensaver is protected by a password).
- Keymaps — Server and all client must be configured to all use exactly the same keymap. On Windows client, this is valid for logged user but also for at least Administrator account. Otherwise typing in the login window will give incorrect characters.
- Can't get tilde character (~) on a Belgian-french keyboard on windows client / Linux server with AltGr= Workaround: Use CA= followed by space.
- Can't connect to server. Possibly because synergy client not started with root privileges
- VirtualBox — When the Synergy Server is also a VirtualBox host, with the guest in fullscreen mode, the mouse will not leave the guest screen. It seems that VirtualBox doesn't release the mouse. See bugs [6], [7], [8]. Workarounds:
- Press VB Host Key (typically ctrl), either before or after going to Synergy Client. — tried and works on Synergy 1.3.7 - VB 4.0.10
- Disable VB mouse integration
sudo apt-get install xsel # Install xsel (Ubuntu) / xselection (opensuse)
xsel -p # (Ubuntu) Before pasting in the remote Windows screen
xselection PRIMARY # (opensuse)
ssh -f -N -L 24800:<server-name>:24800 <user-server-name>@<server-name> && synergyc localhost
However, this creates some lag, and mouse movement are a bit jerky. Another solution is to not use wireless connection, and connect computers through a network switch so that local communication are not visible to other computers on the network.