From 1866e4924ebdd8c3b0316797aab517490a64d408 Mon Sep 17 00:00:00 2001 From: chrys Date: Sun, 10 Jun 2018 14:45:00 +0200 Subject: [PATCH] add initial barrier function and fix history --- src/fenrirscreenreader/core/textManager.py | 73 ++++++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 src/fenrirscreenreader/core/textManager.py diff --git a/src/fenrirscreenreader/core/textManager.py b/src/fenrirscreenreader/core/textManager.py new file mode 100644 index 00000000..8a81d7f2 --- /dev/null +++ b/src/fenrirscreenreader/core/textManager.py @@ -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