Mercurial > vim
view src/testdir/test_channel_pipe.py @ 11698:4f59d2a66bf7 v8.0.0732
patch 8.0.0732: when updating a buffer modeless selection is lost
commit https://github.com/vim/vim/commit/80dd3f9d41ce2ff6ab3544cdb266627bbdfc34a6
Author: Bram Moolenaar <Bram@vim.org>
Date: Wed Jul 19 12:51:52 2017 +0200
patch 8.0.0732: when updating a buffer modeless selection is lost
Problem: When updating a buffer for a callback the modeless selection is
lost.
Solution: Do not insert or delete screen lines when redrawing for a callback
and there is a modeless selection.
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Wed, 19 Jul 2017 13:00:03 +0200 |
parents | c31782d57569 |
children | c522585ce88d |
line wrap: on
line source
#!/usr/bin/python # # Server that will communicate over stdin/stderr # # This requires Python 2.6 or later. from __future__ import print_function import sys import time if __name__ == "__main__": if len(sys.argv) > 1: if sys.argv[1].startswith("err"): print(sys.argv[1], file=sys.stderr) sys.stderr.flush() else: print(sys.argv[1]) sys.stdout.flush() if sys.argv[1].startswith("quit"): sys.exit(0) while True: typed = sys.stdin.readline() if typed.startswith("quit"): print("Goodbye!") sys.stdout.flush() break if typed.startswith("echo "): print(typed[5:-1]) sys.stdout.flush() if typed.startswith("echosplit "): for part in typed[10:-1].split('|'): sys.stdout.write(part) sys.stdout.flush() time.sleep(0.05) if typed.startswith("double "): print(typed[7:-1] + "\nAND " + typed[7:-1]) sys.stdout.flush() if typed.startswith("split "): print(typed[6:-1], end='') sys.stdout.flush() time.sleep(0.05) print(typed[6:-1], end='') sys.stdout.flush() time.sleep(0.05) print(typed[6:-1]) sys.stdout.flush() if typed.startswith("echoerr "): print(typed[8:-1], file=sys.stderr) sys.stderr.flush() if typed.startswith("doubleerr "): print(typed[10:-1] + "\nAND " + typed[10:-1], file=sys.stderr) sys.stderr.flush()