Handle encoding error in layout file parsing more gracefully

Issue a warning about non-decodable files, but do not break
completely.

Addresses #11736

(cherry picked from commit c4da8d38c9d235c6da85c554c391ad4a5b6d958e)
This commit is contained in:
Juergen Spitzmueller 2020-02-13 08:13:22 +01:00
parent 0be206c976
commit 457c568dbd
2 changed files with 30 additions and 19 deletions

View File

@ -1417,25 +1417,34 @@ def checkLatexConfig(check_config, bool_docbook):
classname = file.split(os.sep)[-1].split('.')[0]
decline = ""
catline = ""
for line in open(file, 'r', encoding='utf8').readlines():
if not empty.match(line) and line[0] != '#'[0]:
if decline == "":
logger.warning("Failed to find valid \Declare line "
"for layout file `%s'.\n\t=> Skipping this file!" % file)
nodeclaration = True
# A class, but no category declaration. Just break.
try:
for line in open(file, 'r', encoding='utf8').readlines():
if not empty.match(line) and line[0] != '#'[0]:
if decline == "":
logger.warning("Failed to find valid \Declare line "
"for layout file `%s'.\n\t=> Skipping this file!" % file)
nodeclaration = True
# A class, but no category declaration. Just break.
break
if declare.match(line) != None:
decline = "\\TestDocClass{%s}{%s}" % (classname, line[1:].strip())
testclasses.append(decline)
elif category.match(line) != None:
catline = ("\\DeclareCategory{%s}{%s}"
% (classname, category.match(line).groups()[0]))
testclasses.append(catline)
if catline == "" or decline == "":
continue
break
if declare.match(line) != None:
decline = "\\TestDocClass{%s}{%s}" % (classname, line[1:].strip())
testclasses.append(decline)
elif category.match(line) != None:
catline = ("\\DeclareCategory{%s}{%s}"
% (classname, category.match(line).groups()[0]))
testclasses.append(catline)
if catline == "" or decline == "":
if nodeclaration:
continue
break
if nodeclaration:
except UnicodeDecodeError:
logger.warning("**************************************************\n"
"Layout file '%s'\n"
"cannot be decoded in utf-8.\n"
"Please check if the file has the correct encoding.\n"
"Skipping this file!\n"
"**************************************************" % file)
continue
testclasses.sort()
cl = open('chklayouts.tex', 'w', encoding='utf8')

View File

@ -53,6 +53,7 @@ What's new
- Correctly strike out deleted text after deleted display math (bug 11716).
* USER INTERFACE
- Fix backspace deletion of selected items with change tracking (bug 11630).
@ -84,11 +85,12 @@ What's new
* ADVANCED FIND AND REPLACE
* BUILD/INSTALLATION
- Do not break configuration if a layout file is not decodable. Rather than that,
issue a warning and skip that file (bug 11736).