add initial barrier function and fix history
This commit is contained in:
parent
9b87a34ab0
commit
1866e4924e
73
src/fenrirscreenreader/core/textManager.py
Normal file
73
src/fenrirscreenreader/core/textManager.py
Normal file
@ -0,0 +1,73 @@
|
||||
#!/bin/python
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
# Fenrir TTY screen reader
|
||||
# By Chrys, Storm Dragon, and contributers.
|
||||
|
||||
from fenrirscreenreader.core import debug
|
||||
import re, string
|
||||
|
||||
class textManager():
|
||||
def __init__(self):
|
||||
self.regExSingle = re.compile(r'(([^\w\s])\2{5,})')
|
||||
self.regExDouble = re.compile(r'([^\w\s]{2,}){5,}')
|
||||
def initialize(self, environment):
|
||||
self.env = environment
|
||||
def shutdown(self):
|
||||
pass
|
||||
def hasBarrier(self, start, end):
|
||||
# check for corners here
|
||||
return True
|
||||
def getBarrierText(self, line, xCursor):
|
||||
offset = xCursor
|
||||
# is the cursor at the begin or end of an entry:
|
||||
if line[:offset + 1].count('│') > line[offset + 1:].count('│'):
|
||||
offset = xCursor - 1
|
||||
start = line[:offset + 1].rfind('│') + 1
|
||||
end = line[offset + 1:].find('│') + offset + 1
|
||||
if start == -1:
|
||||
return line
|
||||
if end == -1:
|
||||
return line
|
||||
if not self.hasBarrier(start, end):
|
||||
return line
|
||||
return line[start:end]
|
||||
|
||||
def replaceHeadLines(self, text):
|
||||
# fast len check for bigger typing echo
|
||||
if len(text) < 5:
|
||||
return text
|
||||
# more strong check, to not match if not needed:
|
||||
if len(text.strip(string.ascii_letters+string.digits+string.whitespace)) < 5:
|
||||
return text
|
||||
result = ''
|
||||
newText = ''
|
||||
lastPos = 0
|
||||
for match in self.regExDouble.finditer(text):
|
||||
span = match.span()
|
||||
newText += text[lastPos:span[0]]
|
||||
numberOfChars = len(text[span[0]:span[1]])
|
||||
name = text[span[0]:span[1]][:2]
|
||||
if name[0] == name[1]:
|
||||
newText += ' ' + str(numberOfChars) + ' ' + self.env['runtime']['punctuationManager'].proceedPunctuation(name[0], True) + ' '
|
||||
else:
|
||||
newText += ' ' + str(int(numberOfChars / 2)) + ' ' + self.env['runtime']['punctuationManager'].proceedPunctuation(name, True) + ' '
|
||||
lastPos = span[1]
|
||||
if lastPos != 0:
|
||||
newText += ' '
|
||||
newText += text[lastPos:]
|
||||
lastPos = 0
|
||||
for match in self.regExSingle.finditer(newText):
|
||||
span = match.span()
|
||||
result += text[lastPos:span[0]]
|
||||
numberOfChars = len(newText[span[0]:span[1]])
|
||||
name = newText[span[0]:span[1]][:2]
|
||||
if name[0] == name[1]:
|
||||
result += ' ' + str(numberOfChars) + ' ' + self.env['runtime']['punctuationManager'].proceedPunctuation(name[0], True) + ' '
|
||||
else:
|
||||
result += ' ' + str(int(numberOfChars / 2)) + ' ' + self.env['runtime']['punctuationManager'].proceedPunctuation(name, True) + ' '
|
||||
lastPos = span[1]
|
||||
if lastPos != 0:
|
||||
result += ' '
|
||||
result += newText[lastPos:]
|
||||
return result
|
Loading…
Reference in New Issue
Block a user