ports/contrib (3.5): picom: initial import takes over compton
commit 5350e9ee11a979da41bd1a4d722a3ea293c73d7a Author: Danny Rawlins <monster.romster@gmail.com> Date: Sat Nov 30 18:52:09 2019 +1100 picom: initial import takes over compton diff --git a/picom/.footprint b/picom/.footprint new file mode 100644 index 000000000..25d015c25 --- /dev/null +++ b/picom/.footprint @@ -0,0 +1,27 @@ +drwxr-xr-x root/root etc/ +drwxr-xr-x root/root etc/xdg/ +-rw-r--r-- root/root etc/xdg/picom.conf +-rw-r--r-- root/root etc/xdg/picom.conf.example +drwxr-xr-x root/root usr/ +drwxr-xr-x root/root usr/bin/ +lrwxrwxrwx root/root usr/bin/compton -> picom +-rwxr-xr-x root/root usr/bin/compton-convgen.py +lrwxrwxrwx root/root usr/bin/compton-trans -> picom-trans +-rwxr-xr-x root/root usr/bin/picom +-rwxr-xr-x root/root usr/bin/picom-trans +drwxr-xr-x root/root usr/share/ +drwxr-xr-x root/root usr/share/applications/ +-rw-r--r-- root/root usr/share/applications/compton.desktop +-rw-r--r-- root/root usr/share/applications/picom.desktop +drwxr-xr-x root/root usr/share/icons/ +drwxr-xr-x root/root usr/share/icons/hicolor/ +drwxr-xr-x root/root usr/share/icons/hicolor/48x48/ +drwxr-xr-x root/root usr/share/icons/hicolor/48x48/apps/ +-rw-r--r-- root/root usr/share/icons/hicolor/48x48/apps/compton.png +drwxr-xr-x root/root usr/share/icons/hicolor/scalable/ +drwxr-xr-x root/root usr/share/icons/hicolor/scalable/apps/ +-rw-r--r-- root/root usr/share/icons/hicolor/scalable/apps/compton.svg +drwxr-xr-x root/root usr/share/man/ +drwxr-xr-x root/root usr/share/man/man1/ +-rw-r--r-- root/root usr/share/man/man1/picom-trans.1.gz +-rw-r--r-- root/root usr/share/man/man1/picom.1.gz diff --git a/picom/.signature b/picom/.signature new file mode 100644 index 000000000..70048cc4a --- /dev/null +++ b/picom/.signature @@ -0,0 +1,8 @@ +untrusted comment: verify with /etc/ports/contrib.pub +RWSagIOpLGJF3yKalMYUiiYBIs+HYDolQ7oqlUWcybZtlOqY9qkoWChfFGW4ig+WGqXn7pG3AQu89SaNugfIIMmhJfNkbkLYWw0= +SHA256 (Pkgfile) = f070b90b180c6462a0ff694cdee7bf7f6de3004c89a84785a87ea50400a0ddd8 +SHA256 (.footprint) = c73f21ca780f8416356f4fb323258fdf9d109b9d0edf32a270aabe26b7497381 +SHA256 (picom-v7.5.tar.gz) = 1fdeda688d09643563e4314f885beaf074023235e56598ae98d481364e615607 +SHA256 (picom.conf) = 24f76e9b5fde92d3e4f3bd46d8396dab424f6af343b6ae4e7cd5bd2a1b5169e0 +SHA256 (picom-trans.1) = e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 +SHA256 (picom.1) = e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 diff --git a/picom/Pkgfile b/picom/Pkgfile new file mode 100644 index 000000000..25b49fcff --- /dev/null +++ b/picom/Pkgfile @@ -0,0 +1,30 @@ +# Description: A compositor for X, and a fork of xcompmgr-dana, and a fork of compton. +# URL: https://github.com/yshui/picom +# Maintainer: Danny Rawlins, crux at romster dot me +# Depends on: hicolor-icon-theme libconfig libev libxdg-basedir mesa3d xorg-libpixman xorg-xcb-util-image xorg-xcb-util-renderutil uthash dbus +# Optional: asciidoc + +name=picom +version=7.5 +release=1 +source=(https://github.com/yshui/picom/archive/v$version/$name-v$version.tar.gz + picom.conf picom-trans.1 picom.1) + +build() { + cd $name-$version + +[ -e '/usr/bin/asciidoctor' ] && PKGMK_PICOM+=' -D build_docs=true' + + meson build ${PKGMK_PICOM} \ + --prefix=/usr \ + -D b_ndebug=true + + ninja -C build -j ${JOBS:-1} + + DESTDIR=$PKG ninja -C build install + + install -Dm644 $SRC/picom.conf $PKG/etc/xdg/picom.conf + install -Dm644 picom.sample.conf $PKG/etc/xdg/picom.conf.example + +[ -e '/usr/bin/asciidoctor' ] || install -D -m 0644 -t $PKG/usr/share/man/man1 $SRC/picom-trans.1 $SRC/picom.1 +} diff --git a/picom/picom-trans.1 b/picom/picom-trans.1 new file mode 100644 index 000000000..e69de29bb diff --git a/picom/picom.1 b/picom/picom.1 new file mode 100644 index 000000000..e69de29bb diff --git a/picom/picom.conf b/picom/picom.conf new file mode 100644 index 000000000..b0fd82829 --- /dev/null +++ b/picom/picom.conf @@ -0,0 +1,227 @@ +# https://duncanlock.net/blog/2013/06/07/how-to-switch-to-compton-for-beautifu... +# https://git.archlinux.org/svntogit/community.git/plain/trunk/picom.conf?h=pa... + +################################# +# +# Backend +# +################################# + +# Backend to use: "xrender" or "glx". +# GLX backend is typically much faster but depends on a sane driver. +backend = "glx"; + +################################# +# +# GLX backend +# +################################# + +glx-no-stencil = true; + +# GLX backend: Copy unmodified regions from front buffer instead of redrawing them all. +# My tests with nvidia-drivers show a 10% decrease in performance when the whole screen is modified, +# but a 20% increase when only 1/4 is. +# My tests on nouveau show terrible slowdown. +glx-copy-from-front = false; + +# GLX backend: Use MESA_copy_sub_buffer to do partial screen update. +# My tests on nouveau shows a 200% performance boost when only 1/4 of the screen is updated. +# May break VSync and is not available on some drivers. +# Overrides --glx-copy-from-front. +# glx-use-copysubbuffermesa = true; + +# GLX backend: Avoid rebinding pixmap on window damage. +# Probably could improve performance on rapid window content changes, but is known to break things on some drivers (LLVMpipe). +# Recommended if it works. +# glx-no-rebind-pixmap = true; + +# GLX backend: GLX buffer swap method we assume. +# Could be undefined (0), copy (1), exchange (2), 3-6, or buffer-age (-1). +# undefined is the slowest and the safest, and the default value. +# copy is fastest, but may fail on some drivers, +# 2-6 are gradually slower but safer (6 is still faster than 0). +# Usually, double buffer means 2, triple buffer means 3. +# buffer-age means auto-detect using GLX_EXT_buffer_age, supported by some drivers. +# Useless with --glx-use-copysubbuffermesa. +# Partially breaks --resize-damage. +# Defaults to undefined. +#glx-swap-method = "undefined"; + +################################# +# +# Shadows +# +################################# + +# Enabled client-side shadows on windows. +shadow = true; +# The blur radius for shadows. (default 12) +shadow-radius = 5; +# The left offset for shadows. (default -15) +shadow-offset-x = -5; +# The top offset for shadows. (default -15) +shadow-offset-y = -5; +# The translucency for shadows. (default .75) +shadow-opacity = 0.5; + +# Set if you want different colour shadows +# shadow-red = 0.0; +# shadow-green = 0.0; +# shadow-blue = 0.0; + +# The shadow exclude options are helpful if you have shadows enabled. Due to the way picom draws its shadows, certain applications will have visual glitches +# (most applications are fine, only apps that do weird things with xshapes or argb are affected). +# This list includes all the affected apps I found in my testing. The "! name~=''" part excludes shadows on any "Unknown" windows, this prevents a visual glitch with the XFWM alt tab switcher. +shadow-exclude = [ + "! name~=''", + "name = 'Notification'", + "name = 'Plank'", + "name = 'Docky'", + "name = 'Kupfer'", + "name = 'xfce4-notifyd'", + "name *= 'VLC'", + "name *= 'compton'", + "name *= 'picom'", + "name *= 'Chromium'", + "name *= 'Chrome'", + "class_g = 'Firefox' && argb", + "class_g = 'Conky'", + "class_g = 'Kupfer'", + "class_g = 'Synapse'", + "class_g ?= 'Notify-osd'", + "class_g ?= 'Cairo-dock'", + "class_g ?= 'Xfce4-notifyd'", + "class_g ?= 'Xfce4-power-manager'", + "_GTK_FRAME_EXTENTS@:c", + "_NET_WM_STATE@:32a *= '_NET_WM_STATE_HIDDEN'" +]; +# Avoid drawing shadow on all shaped windows (see also: --detect-rounded-corners) +shadow-ignore-shaped = false; + +################################# +# +# Opacity +# +################################# + +inactive-opacity = 1; +active-opacity = 1; +frame-opacity = 1; +inactive-opacity-override = false; + +# Dim inactive windows. (0.0 - 1.0) +# inactive-dim = 0.2; +# Do not let dimness adjust based on window opacity. +# inactive-dim-fixed = true; +# Blur background of transparent windows. Bad performance with X Render backend. GLX backend is preferred. +# blur-background = true; +# Blur background of opaque windows with transparent frames as well. +# blur-background-frame = true; +# Do not let blur radius adjust based on window opacity. +blur-background-fixed = false; +blur-background-exclude = [ + "window_type = 'dock'", + "window_type = 'desktop'" +]; + +################################# +# +# Fading +# +################################# + +# Fade windows during opacity changes. +fading = true; +# The time between steps in a fade in milliseconds. (default 10). +fade-delta = 4; +# Opacity change between steps while fading in. (default 0.028). +fade-in-step = 0.03; +# Opacity change between steps while fading out. (default 0.03). +fade-out-step = 0.03; +# Fade windows in/out when opening/closing +# no-fading-openclose = true; + +# Specify a list of conditions of windows that should not be faded. +fade-exclude = [ ]; + +################################# +# +# Other +# +################################# + +# Try to detect WM windows and mark them as active. +mark-wmwin-focused = true; +# Mark all non-WM but override-redirect windows active (e.g. menus). +mark-ovredir-focused = true; +# Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused instead of using FocusIn/Out events. +# Usually more reliable but depends on a EWMH-compliant WM. +use-ewmh-active-win = true; +# Detect rounded corners and treat them as rectangular when --shadow-ignore-shaped is on. +detect-rounded-corners = true; + +# Detect _NET_WM_OPACITY on client windows, useful for window managers not passing _NET_WM_OPACITY of client windows to frame windows. +# This prevents opacity being ignored for some apps. +# For example without this enabled my xfce4-notifyd is 100% opacity no matter what. +detect-client-opacity = true; + +# Specify refresh rate of the screen. +# If not specified or 0, picom will try detecting this with X RandR extension. +refresh-rate = 0; + +# Vertical synchronization: match the refresh rate of the monitor +vsync = true; + +# Enable DBE painting mode, intended to use with VSync to (hopefully) eliminate tearing. +# Reported to have no effect, though. +dbe = false; + +# Limit picom to repaint at most once every 1 / refresh_rate second to boost performance. +# This should not be used with --vsync drm/opengl/opengl-oml as they essentially does --sw-opti's job already, +# unless you wish to specify a lower refresh rate than the actual value. +#sw-opti = true; + +# Unredirect all windows if a full-screen opaque window is detected, to maximize performance for full-screen windows, like games. +# Known to cause flickering when redirecting/unredirecting windows. +unredir-if-possible = false; + +# Specify a list of conditions of windows that should always be considered focused. +focus-exclude = [ ]; + +# Use WM_TRANSIENT_FOR to group windows, and consider windows in the same group focused at the same time. +detect-transient = true; +# Use WM_CLIENT_LEADER to group windows, and consider windows in the same group focused at the same time. +# WM_TRANSIENT_FOR has higher priority if --detect-transient is enabled, too. +detect-client-leader = true; + +################################# +# +# Window type settings +# +################################# + +wintypes: +{ + tooltip = + { + # fade: Fade the particular type of windows. + fade = true; + # shadow: Give those windows shadow + shadow = false; + # opacity: Default opacity for the type of windows. + opacity = 0.85; + # focus: Whether to always consider windows of this type focused. + focus = true; + }; +}; + +###################### +# +# XSync +# See: https://github.com/yshui/picom/commit/b18d46bcbdc35a3b5620d817dd46fbc76485c2... +# +###################### + +# Use X Sync fence to sync clients' draw calls. Needed on nvidia-drivers with GLX backend for some users. +xrender-sync-fence = true;
participants (1)
-
crux@crux.nu