diff options
author | Mattias Andrée <maandree@operamail.com> | 2014-02-16 19:19:36 +0100 |
---|---|---|
committer | Mattias Andrée <maandree@operamail.com> | 2014-02-16 19:19:36 +0100 |
commit | a7ab7860a57cdd41944355a400f62581f8b19d03 (patch) | |
tree | 532e3e68540102655e16f212386ff1fcf3440e31 | |
parent | c binding (diff) | |
download | blueshift-a7ab7860a57cdd41944355a400f62581f8b19d03.tar.gz blueshift-a7ab7860a57cdd41944355a400f62581f8b19d03.tar.bz2 blueshift-a7ab7860a57cdd41944355a400f62581f8b19d03.tar.xz |
use randr
Signed-off-by: Mattias Andrée <maandree@operamail.com>
Diffstat (limited to '')
-rw-r--r-- | .gitignore | 2 | ||||
-rw-r--r-- | Makefile | 10 | ||||
-rwxr-xr-x | src/__main__.py | 4 | ||||
-rw-r--r-- | src/blueshift_randr.pyx (renamed from src/_blueshift_randr.pyx) | 0 | ||||
-rw-r--r-- | src/monitor.py | 23 |
5 files changed, 32 insertions, 7 deletions
@@ -10,5 +10,5 @@ obj/ *.out *.gch __pycache__/ -/src/_blueshift_randr.c +/src/blueshift_randr.c @@ -11,7 +11,7 @@ FLAGS = $$($(PKGCONFIG) --cflags --libs $(LIBS)) -std=$(STD) $(WARN) $(OPTIMISE) all: bin/blueshift_randr.so -bin/blueshift_randr.so: obj/_blueshift_randr.o obj/blueshift_randr_c.o +bin/blueshift_randr.so: obj/blueshift_randr.o obj/blueshift_randr_c.o @mkdir -p bin $(CC) $(FLAGS) -shared -o $@ $^ @@ -23,13 +23,13 @@ obj/%.o: obj/%.c @mkdir -p obj $(CC) $(FLAGS) -c -o $@ $< -obj/_blueshift_randr.c: src/_blueshift_randr.pyx +obj/blueshift_randr.c: src/blueshift_randr.pyx @mkdir -p obj - if ! cython -3 -v $<; then src/_blueshift_randr.c ; false ; fi - mv src/_blueshift_randr.c $@ + if ! cython -3 -v $<; then src/blueshift_randr.c ; false ; fi + mv src/blueshift_randr.c $@ .PHONY: all clean: - -rm -r bin obj src/_blueshift_randr.c + -rm -r bin obj src/blueshift_randr.c diff --git a/src/__main__.py b/src/__main__.py index 400c675..f8db7a2 100755 --- a/src/__main__.py +++ b/src/__main__.py @@ -150,7 +150,6 @@ if config_file is not None: code = code.decode('utf8', 'error') + '\n' code = compile(code, file, 'exec') exec(code, globals) - break else: print('No configuration file found') sys.exit(1) @@ -168,6 +167,7 @@ if periodically is not None: running = False start_over() monitor_controller() + close_c_bindings() sys.exit(0) running = False signal.signal(signal.SIGTERM, signal_SIGTERM) @@ -205,3 +205,5 @@ if periodically is not None: start_over() monitor_controller() +close_c_bindings() + diff --git a/src/_blueshift_randr.pyx b/src/blueshift_randr.pyx index e022714..e022714 100644 --- a/src/_blueshift_randr.pyx +++ b/src/blueshift_randr.pyx diff --git a/src/monitor.py b/src/monitor.py index 37f6b00..b8f5cff 100644 --- a/src/monitor.py +++ b/src/monitor.py @@ -15,6 +15,15 @@ # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see <http://www.gnu.org/licenses/>. +import sys + +# /usr/lib +LIBDIR = 'bin' +sys.path.append(LIBDIR) + +from blueshift_randr import * +randr_opened = False + def translate_to_integers(): ''' @@ -31,17 +40,31 @@ def translate_to_integers(): return (R_curve, G_curve, B_curve) +def close_c_bindings(): + global randr_opened + if randr_opened: + randr_close() + + def randr(*crtcs): ''' Applies colour curves using the X11 extension randr @param *crtcs The CRT controllers to use, all are used if none are specified ''' + global randr_opened crtcs = sum([1 << i for i in list(crtcs)]) if crtcs == 0: crtcs = -1; (R_curve, G_curve, B_curve) = translate_to_integers() + if not randr_opened: + if randr_open(0) == 0: ## TODO support specifying screen + randr_opened = True + else: + sys.exit(1) + if not randr_apply(crtcs, R_curve, G_curve, B_curve) == 0: + sys.exit(1) def print_curves(*crtcs): |