X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=autorandr.py;h=c2fdb9ad08f300a259a8832fe30cd55bde62ce71;hb=53f7af43c6e0d597ebe7836c2d9aab94cc5d28d3;hp=feee62b58bc4f2e220c9295b9e5b18f32c7194f7;hpb=af4a3f82fde54436b5393682364c0340b661c554;p=deb_pkgs%2Fautorandr.git diff --git a/autorandr.py b/autorandr.py index feee62b..c2fdb9a 100755 --- a/autorandr.py +++ b/autorandr.py @@ -23,22 +23,21 @@ # from __future__ import print_function -import copy -import getopt import binascii +import copy +import getopt import hashlib import os +import posix import re import subprocess import sys -from distutils.version import LooseVersion as Version +from collections import OrderedDict +from distutils.version import LooseVersion as Version from functools import reduce from itertools import chain -from collections import OrderedDict - -import posix virtual_profiles = [ @@ -544,6 +543,8 @@ def apply_configuration(new_configuration, current_configuration, dry_run=False) # the xrandr call fails with an invalid RRSetScreenSize parameter error. # Update the configuration in 3 passes in that case. (On Haswell graphics, # at least.) + # - Some implementations can not handle --transform at all, so avoid it unless + # necessary. (See https://github.com/phillipberndt/autorandr/issues/37) auxiliary_changes_pre = [] disable_outputs = [] @@ -555,9 +556,20 @@ def apply_configuration(new_configuration, current_configuration, dry_run=False) else: if "off" not in current_configuration[output].options: remain_active_count += 1 - enable_outputs.append(new_configuration[output].option_vector) - if xrandr_version() >= Version("1.3.0") and "transform" in current_configuration[output].options: - auxiliary_changes_pre.append(["--output", output, "--transform", "none"]) + + option_vector = new_configuration[output].option_vector + if xrandr_version() >= Version("1.3.0"): + if "transform" in current_configuration[output].options: + auxiliary_changes_pre.append(["--output", output, "--transform", "none"]) + else: + try: + transform_index = option_vector.index("--transform") + if option_vector[transform_index+1] == XrandrOutput.XRANDR_DEFAULTS["transform"]: + option_vector = option_vector[:transform_index] + option_vector[transform_index+2:] + except ValueError: + pass + + enable_outputs.append(option_vector) # Perform pe-change auxiliary changes if auxiliary_changes_pre: