Browse Source

Fix #118 : Terminal Paste not working

pull/119/head
Eugenio Parodi 3 years ago
parent
commit
441af5e772
  1. 2
      TermTk/TTkCore/TTkTerm/input.py
  2. 22
      TermTk/TTkCore/TTkTerm/readinputlinux.py
  3. 6
      TermTk/TTkGui/textcursor.py
  4. 84
      tests/test.input.raw.py

2
TermTk/TTkCore/TTkTerm/input.py

@ -73,7 +73,7 @@ class TTkInput:
def start(self):
self._readInput = ReadInput()
while stdinRead := self._readInput.read():
for stdinRead in self._readInput.read():
self.key_process(stdinRead)
TTkLog.debug("Close TTkInput")

22
TermTk/TTkCore/TTkTerm/readinputlinux.py

@ -46,15 +46,19 @@ class ReadInput():
tty.setcbreak(sys.stdin)
def read(self):
rlist, _, _ = select.select( [sys.stdin, self._readPipe[0]], [], [] )
if self._readPipe[0] in rlist:
return None
if (stdinRead := sys.stdin.read(1)) == "\033": # Check if the stream start with an escape sequence
while self._readPipe[0] not in (list := select.select( [sys.stdin, self._readPipe[0]], [], [] )[0]):
# Read all the full input
_fl = fcntl.fcntl(sys.stdin, fcntl.F_GETFL)
fcntl.fcntl(sys.stdin, fcntl.F_SETFL, _fl | os.O_NONBLOCK) # Set the input as NONBLOCK to read the full sequence
stdinRead += sys.stdin.read(20) # Check if the stream start with an escape sequence
if stdinRead.startswith("\033[<"): # Clear the buffer if this is a mouse code
sys.stdin.read(0x40)
stdinRead = sys.stdin.read()
fcntl.fcntl(sys.stdin, fcntl.F_SETFL, _fl)
return stdinRead
# Split all the ansi sequences
# or yield any separate input char
if '\033' in stdinRead:
stdinSplit = stdinRead.split('\033')
for ansi in stdinSplit[1:]:
yield '\033'+ansi
else:
for ch in stdinRead:
yield ch

6
TermTk/TTkGui/textcursor.py

@ -242,7 +242,6 @@ class TTkTextCursor():
return color
def setPosition(self, line, pos, moveMode=MoveMode.MoveAnchor, cID=0):
# TTkLog.debug(f"{line=}, {pos=}, {moveMode=}")
self._properties[cID].position.set(line,pos)
if moveMode==TTkTextCursor.MoveAnchor:
self._properties[cID].anchor.set(line,pos)
@ -483,11 +482,6 @@ class TTkTextCursor():
return True
return False
def clearSelection(self):
for p in self._properties:
p.anchor.pos = p.position.pos
p.anchor.line = p.position.line
def _removeSelectedText(self):
currPos = self.position().toNum()

84
tests/test.input.raw.py

@ -0,0 +1,84 @@
#!/usr/bin/env python3
# MIT License
#
# Copyright (c) 2021 Eugenio Parodi <ceccopierangiolieugenio AT googlemail DOT com>
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in all
# copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
import sys, os, select
import logging
try: import fcntl, termios, tty
except Exception as e:
print(f'ERROR: {e}')
exit(1)
sys.path.append(os.path.join(sys.path[0],'..'))
from TermTk import TTkLog, TTkK, TTkInput, TTkTerm
TTkLog.info("Retrieve Keyboard, Mouse press/drag/wheel Events")
TTkLog.info("Press q or <ESC> to exit")
TTkTerm.push(TTkTerm.Mouse.ON)
# TTkTerm.push(TTkTerm.Mouse.DIRECT_ON)
TTkTerm.setEcho(False)
# Init
_attr = termios.tcgetattr(sys.stdin)
tty.setcbreak(sys.stdin)
def read():
rlist, _, _ = select.select( [sys.stdin], [], [] )
_fl = fcntl.fcntl(sys.stdin, fcntl.F_GETFL)
fcntl.fcntl(sys.stdin, fcntl.F_SETFL, _fl | os.O_NONBLOCK) # Set the input as NONBLOCK to read the full sequence
if (stdinRead := sys.stdin.read(10000))[0] == "\033": # Check if the stream start with an escape sequence
# stdinRead += sys.stdin.read(20) # Check if the stream start with an escape sequence
# if stdinRead.startswith("\033[<"): # Clear the buffer if this is a mouse code
# sys.stdin.read(0x40)
pass
fcntl.fcntl(sys.stdin, fcntl.F_SETFL, _fl)
print(f"{len(stdinRead)=}")
return stdinRead
def read_new():
stdinRead = ''
while rlist := select.select( [sys.stdin], [], [] )[0]:
_fl = fcntl.fcntl(sys.stdin, fcntl.F_GETFL)
fcntl.fcntl(sys.stdin, fcntl.F_SETFL, _fl | os.O_NONBLOCK) # Set the input as NONBLOCK to read the full sequence
stdinRead = sys.stdin.read()
fcntl.fcntl(sys.stdin, fcntl.F_SETFL, _fl)
print(f"{len(stdinRead)=}")
if '\033' in stdinRead:
stdinSplit = stdinRead.split('\033')
for ansi in stdinSplit[1:]:
print(f"{ansi=}")
yield '\033'+ansi
else:
for ch in stdinRead:
yield ch
try:
for stdinRead in read_new():
print(f"{stdinRead=}")
finally:
termios.tcsetattr(sys.stdin, termios.TCSANOW, _attr)
TTkTerm.push(TTkTerm.Mouse.OFF + TTkTerm.Mouse.DIRECT_OFF)
TTkTerm.setEcho(True)
Loading…
Cancel
Save