Clean up revert_rule routine.

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@36014 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Richard Heck 2010-11-03 22:01:30 +00:00
parent f7e80e6681
commit b6a6520118

View File

@ -2299,38 +2299,39 @@ def revert_rule(document):
i = 0 i = 0
while 1: while 1:
i = find_token(document.body, "\\begin_inset CommandInset line" , i) i = find_token(document.body, "\\begin_inset CommandInset line" , i)
if i != -1: if i == -1:
# find end of inset
j = find_token(document.body, "\\end_inset" , i)
# assure we found the end_inset of the current inset
if j > i + 6 or j == -1:
document.warning("Malformed LyX document: Can't find end of line inset.")
return
# determine the optional offset
k = find_token(document.body, 'offset', i)
if k != -1 and k < j:
offset = document.body[k][8:]
else:
offset = '0"'
# determine the width
l = find_token(document.body, 'width', k + 1)
width = document.body[l][7:]
# determine the height
m = find_token(document.body, 'height', l + 1)
height = document.body[m][8:]
# remove trailing '"'
offset = offset[:-1]
width = width[:-1]
height = height[:-1]
# output the \rule command
if offset <> "0":
subst = "\\rule[" + offset + "]{" + width + "}{" + height + "}"
else:
subst = "\\rule{" + width + "}{" + height + "}"
document.body[i:j + 1] = put_cmd_in_ert(subst)
i += 1
else:
return return
# find end of inset
j = find_token(document.body, "\\end_inset" , i)
# assure we found the end_inset of the current inset
if j > i + 6 or j == -1:
document.warning("Malformed LyX document: Can't find end of line inset.")
return
# determine the optional offset
k = find_token(document.body, 'offset', i, j)
if k != -1:
offset = document.body[k][8:-1]
else:
offset = ""
# determine the width
l = find_token(document.body, 'width', i, j)
if l != -1:
width = document.body[l][7:-1]
else:
width = "100col%"
# determine the height
m = find_token(document.body, 'height', i, j)
if m != -1:
height = document.body[m][8:-1]
else:
height = "1pt"
# output the \rule command
if offset:
subst = "\\rule[" + offset + "]{" + width + "}{" + height + "}"
else:
subst = "\\rule{" + width + "}{" + height + "}"
document.body[i:j + 1] = put_cmd_in_ert(subst)
i += 1
def revert_diagram(document): def revert_diagram(document):
@ -2377,8 +2378,8 @@ def convert_bibtex_clearpage(document):
continue continue
# only act if there is the option "bibtotoc" # only act if there is the option "bibtotoc"
m = find_token(document.body, 'options', j) m = find_token(document.body, 'options', j, k)
if m == -1 or m > k: if m == -1:
document.warning("Can't find options for bibliography inset at line " + str(j)) document.warning("Can't find options for bibliography inset at line " + str(j))
j = k j = k
continue continue