+def convert_pdf_options(document):
+ # Set the pdfusetitle tag, delete the pdf_store_options,
+ # set quotes for bookmarksopenlevel"
+ has_hr = get_value(document.header, "\\use_hyperref", 0, default = "0")
+ if has_hr == "1":
+ k = find_token(document.header, "\\use_hyperref", 0)
+ document.header.insert(k + 1, "\\pdf_pdfusetitle true")
+ k = find_token(document.header, "\\pdf_store_options", 0)
+ if k != -1:
+ del document.header[k]
+ i = find_token(document.header, "\\pdf_bookmarksopenlevel", k)
+ if i == -1: return
+ document.header[i] = document.header[i].replace('"', '')
+
+
+def revert_pdf_options_2(document):
+ # reset the pdfusetitle tag, set quotes for bookmarksopenlevel"
+ k = find_token(document.header, "\\use_hyperref", 0)
+ i = find_token(document.header, "\\pdf_pdfusetitle", k)
+ if i != -1:
+ del document.header[i]
+ i = find_token(document.header, "\\pdf_bookmarksopenlevel", k)
+ if i == -1: return
+ values = document.header[i].split()
+ values[1] = ' "' + values[1] + '"'
+ document.header[i] = ''.join(values)
+
+
+def convert_htmlurl(document):
+ 'Convert "htmlurl" to "href" insets for docbook'
+ if document.backend != "docbook":
+ return
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_inset CommandInset url", i)
+ if i == -1:
+ return
+ document.body[i] = "\\begin_inset CommandInset href"
+ document.body[i + 1] = "LatexCommand href"
+ i = i + 1
+
+
+def convert_url(document):
+ 'Convert url insets to url charstyles'
+ if document.backend == "docbook":
+ return
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_inset CommandInset url", i)
+ if i == -1:
+ break
+ n = find_token(document.body, "name", i)
+ if n == i + 2:
+ # place the URL name in typewriter before the new URL insert
+ # grab the name 'bla' from the e.g. the line 'name "bla"',
+ # therefore start with the 6th character
+ name = document.body[n][6:-1]
+ newname = [name + " "]
+ document.body[i:i] = newname
+ i = i + 1
+ j = find_token(document.body, "target", i)
+ if j == -1:
+ document.warning("Malformed LyX document: Can't find target for url inset")
+ i += 1
+ continue
+ target = document.body[j][8:-1]
+ k = find_token(document.body, "\\end_inset", j)
+ if k == -1:
+ document.warning("Malformed LyX document: Can't find end of url inset")
+ i = j
+ continue
+ newstuff = ["\\begin_inset Flex URL",
+ "status collapsed", "",
+ "\\begin_layout Standard",
+ "",
+ target,
+ "\\end_layout",
+ ""]
+ document.body[i:k] = newstuff
+ i = i + len(newstuff)
+
+def convert_ams_classes(document):
+ tc = document.textclass
+ if (tc != "amsart" and tc != "amsart-plain" and
+ tc != "amsart-seq" and tc != "amsbook"):
+ return
+ if tc == "amsart-plain":
+ document.textclass = "amsart"
+ document.set_textclass()
+ document.add_module("Theorems (Starred)")
+ return
+ if tc == "amsart-seq":
+ document.textclass = "amsart"
+ document.set_textclass()
+ document.add_module("Theorems (AMS)")
+
+ #Now we want to see if any of the environments in the extended theorems
+ #module were used in this document. If so, we'll add that module, too.
+ layouts = ["Criterion", "Algorithm", "Axiom", "Condition", "Note", \
+ "Notation", "Summary", "Acknowledgement", "Conclusion", "Fact", \
+ "Assumption"]
+
+ r = re.compile(r'^\\begin_layout (.*?)\*?\s*$')
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_layout", i)
+ if i == -1:
+ return
+ m = r.match(document.body[i])
+ if m == None:
+ # This is an empty layout
+ # document.warning("Weirdly formed \\begin_layout at line %d of body!" % i)
+ i += 1
+ continue
+ m = m.group(1)
+ if layouts.count(m) != 0:
+ document.add_module("Theorems (AMS-Extended)")
+ return
+ i += 1
+
+def revert_href(document):
+ 'Reverts hyperlink insets (href) to url insets (url)'
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_inset CommandInset href", i)
+ if i == -1:
+ return
+ document.body[i : i + 2] = \
+ ["\\begin_inset CommandInset url", "LatexCommand url"]
+ i = i + 2
+
+def revert_url(document):
+ 'Reverts Flex URL insets to old-style URL insets'
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_inset Flex URL", i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Can't find end of inset in revert_url!")
+ return
+ k = find_default_layout(document, i, j)
+ if k == -1:
+ document.warning("Can't find default layout in revert_url!")
+ i = j
+ continue
+ l = find_end_of(document.body, k, "\\begin_layout", "\\end_layout")
+ if l == -1 or l >= j:
+ document.warning("Can't find end of default layout in revert_url!")
+ i = j
+ continue
+ # OK, so the inset's data is between lines k and l.
+ data = " ".join(document.body[k+1:l])
+ data = data.strip()
+ newinset = ["\\begin_inset LatexCommand url", "target \"" + data + "\"",\
+ "", "\\end_inset"]
+ document.body[i:j+1] = newinset
+ i = i + len(newinset)
+
+
+def convert_include(document):
+ 'Converts include insets to new format.'
+ i = 0
+ r = re.compile(r'\\begin_inset Include\s+\\([^{]+){([^}]*)}(?:\[(.*)\])?')
+ while True:
+ i = find_token(document.body, "\\begin_inset Include", i)
+ if i == -1:
+ return
+ line = document.body[i]
+ previewline = document.body[i + 1]
+ m = r.match(line)
+ if m == None:
+ document.warning("Unable to match line " + str(i) + " of body!")
+ i += 1
+ continue
+ cmd = m.group(1)
+ fn = m.group(2)
+ opt = m.group(3)
+ insertion = ["\\begin_inset CommandInset include",
+ "LatexCommand " + cmd, previewline,
+ "filename \"" + fn + "\""]
+ newlines = 2
+ if opt:
+ insertion.append("lstparams " + '"' + opt + '"')
+ newlines += 1
+ document.body[i : i + 2] = insertion
+ i += newlines
+
+
+def revert_include(document):
+ 'Reverts include insets to old format.'
+ i = 0
+ r0 = re.compile('preview.*')
+ r1 = re.compile('LatexCommand (.+)')
+ r2 = re.compile('filename "(.+)"')
+ r3 = re.compile('lstparams "(.*)"')
+ while True:
+ i = find_token(document.body, "\\begin_inset CommandInset include", i)
+ if i == -1:
+ return
+ nextline = i + 1
+ m = r1.match(document.body[nextline])
+ if m == None:
+ document.warning("Malformed LyX document: No LatexCommand line for `" +
+ document.body[i] + "' on line " + str(i) + ".")
+ i += 1
+ continue
+ cmd = m.group(1)
+ nextline += 1
+ if r0.match(document.body[nextline]):
+ previewline = document.body[nextline]
+ nextline += 1
+ else:
+ previewline = ""
+ m = r2.match(document.body[nextline])
+ if m == None:
+ document.warning("Malformed LyX document: No filename line for `" + \
+ document.body[i] + "' on line " + str(i) + ".")
+ i += 2
+ continue
+ fn = m.group(1)
+ nextline += 1
+ options = ""
+ if (cmd == "lstinputlisting"):
+ m = r3.match(document.body[nextline])
+ if m != None:
+ options = m.group(1)
+ numlines = 5
+ nextline += 1
+ newline = "\\begin_inset Include \\" + cmd + "{" + fn + "}"
+ if options:
+ newline += ("[" + options + "]")
+ insertion = [newline]
+ if previewline != "":
+ insertion.append(previewline)
+ document.body[i : nextline] = insertion
+ i += 2
+
+
+def revert_albanian(document):
+ "Set language Albanian to English"
+ i = 0
+ if document.language == "albanian":
+ document.language = "english"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language english"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang albanian", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang albanian", "\\lang english")
+ j = j + 1
+
+
+def revert_lowersorbian(document):
+ "Set language lower Sorbian to English"
+ i = 0
+ if document.language == "lowersorbian":
+ document.language = "english"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language english"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang lowersorbian", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang lowersorbian", "\\lang english")
+ j = j + 1
+
+
+def revert_uppersorbian(document):
+ "Set language uppersorbian to usorbian as this was used in LyX 1.5"
+ i = 0
+ if document.language == "uppersorbian":
+ document.language = "usorbian"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language usorbian"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang uppersorbian", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang uppersorbian", "\\lang usorbian")
+ j = j + 1
+
+
+def convert_usorbian(document):
+ "Set language usorbian to uppersorbian"
+ i = 0
+ if document.language == "usorbian":
+ document.language = "uppersorbian"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language uppersorbian"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang usorbian", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang usorbian", "\\lang uppersorbian")
+ j = j + 1
+
+
+def convert_macro_global(document):
+ "Remove TeX code command \global when it is in front of a macro"
+ # math macros are nowadays already defined \global, so that an additional
+ # \global would make the document uncompilable, see
+ # http://www.lyx.org/trac/ticket/5371
+ # We're looking for something like this:
+ # \begin_inset ERT
+ # status collapsed
+ #
+ # \begin_layout Plain Layout
+ #
+ #
+ # \backslash
+ # global
+ # \end_layout
+ #
+ # \end_inset
+ #
+ #
+ # \begin_inset FormulaMacro
+ # \renewcommand{\foo}{123}
+ # \end_inset
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_inset FormulaMacro", i)
+ if i == -1:
+ return
+ # if i <= 13, then there isn't enough room for the ERT
+ if i <= 12:
+ i += 1
+ continue
+ if document.body[i-6] == "global":
+ del document.body[i-13 : i]
+ i = i - 12
+ else:
+ i += 1
+
+
+def revert_macro_optional_params(document):
+ "Convert macro definitions with optional parameters into ERTs"
+ # Stub to convert macro definitions with one or more optional parameters
+ # into uninterpreted ERT insets
+
+
+def revert_hyperlinktype(document):
+ 'Reverts hyperlink type'
+ i = 0
+ j = 0
+ while True:
+ i = find_token(document.body, "target", i)
+ if i == -1:
+ return
+ j = find_token(document.body, "type", i)
+ if j == -1:
+ return
+ if j == i + 1:
+ del document.body[j]
+ i = i + 1
+
+
+def revert_pagebreak(document):
+ 'Reverts pagebreak to ERT'
+ i = 0
+ while True:
+ i = find_token(document.body, "\\pagebreak", i)
+ if i == -1:
+ return
+ document.body[i] = '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout Standard\n\n\n\\backslash\n' \
+ 'pagebreak{}\n\\end_layout\n\n\\end_inset\n\n'
+ i = i + 1
+
+
+def revert_linebreak(document):
+ 'Reverts linebreak to ERT'
+ i = 0
+ while True:
+ i = find_token(document.body, "\\linebreak", i)
+ if i == -1:
+ return
+ document.body[i] = '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout Standard\n\n\n\\backslash\n' \
+ 'linebreak{}\n\\end_layout\n\n\\end_inset\n\n'
+ i = i + 1
+
+
+def revert_latin(document):
+ "Set language Latin to English"
+ i = 0
+ if document.language == "latin":
+ document.language = "english"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language english"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang latin", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang latin", "\\lang english")
+ j = j + 1
+
+
+def revert_samin(document):
+ "Set language North Sami to English"
+ i = 0
+ if document.language == "samin":
+ document.language = "english"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language english"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang samin", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang samin", "\\lang english")
+ j = j + 1
+
+
+def convert_serbocroatian(document):
+ "Set language Serbocroatian to Croatian as this was really Croatian in LyX 1.5"
+ i = 0
+ if document.language == "serbocroatian":
+ document.language = "croatian"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language croatian"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang serbocroatian", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang serbocroatian", "\\lang croatian")
+ j = j + 1
+
+
+def convert_framed_notes(document):
+ "Convert framed notes to boxes. "
+ i = 0
+ while 1:
+ i = find_tokens(document.body, ["\\begin_inset Note Framed", "\\begin_inset Note Shaded"], i)
+ if i == -1:
+ return
+ subst = [document.body[i].replace("\\begin_inset Note", "\\begin_inset Box"),
+ 'position "t"',
+ 'hor_pos "c"',
+ 'has_inner_box 0',
+ 'inner_pos "t"',
+ 'use_parbox 0',
+ 'width "100col%"',
+ 'special "none"',
+ 'height "1in"',
+ 'height_special "totalheight"']
+ document.body[i:i+1] = subst
+ i = i + 9
+
+
+def convert_module_names(document):
+ modulemap = { 'Braille' : 'braille', 'Endnote' : 'endnotes', 'Foot to End' : 'foottoend',\
+ 'Hanging' : 'hanging', 'Linguistics' : 'linguistics', 'Logical Markup' : 'logicalmkup', \
+ 'Theorems (AMS-Extended)' : 'theorems-ams-extended', 'Theorems (AMS)' : 'theorems-ams', \
+ 'Theorems (Order By Chapter)' : 'theorems-chap', 'Theorems (Order By Section)' : 'theorems-sec', \
+ 'Theorems (Starred)' : 'theorems-starred', 'Theorems' : 'theorems-std' }
+ modlist = document.get_module_list()
+ if len(modlist) == 0:
+ return
+ newmodlist = []
+ for mod in modlist:
+ if modulemap.has_key(mod):
+ newmodlist.append(modulemap[mod])
+ else:
+ document.warning("Can't find module %s in the module map!" % mod)
+ newmodlist.append(mod)
+ document.set_module_list(newmodlist)
+
+
+def revert_module_names(document):
+ modulemap = { 'braille' : 'Braille', 'endnotes' : 'Endnote', 'foottoend' : 'Foot to End',\
+ 'hanging' : 'Hanging', 'linguistics' : 'Linguistics', 'logicalmkup' : 'Logical Markup', \
+ 'theorems-ams-extended' : 'Theorems (AMS-Extended)', 'theorems-ams' : 'Theorems (AMS)', \
+ 'theorems-chap' : 'Theorems (Order By Chapter)', 'theorems-sec' : 'Theorems (Order By Section)', \
+ 'theorems-starred' : 'Theorems (Starred)', 'theorems-std' : 'Theorems'}
+ modlist = document.get_module_list()
+ if len(modlist) == 0:
+ return
+ newmodlist = []
+ for mod in modlist:
+ if mod in modulemap:
+ newmodlist.append(modulemap[mod])
+ else:
+ document.warning("Can't find module %s in the module map!" % mod)
+ newmodlist.append(mod)
+ document.set_module_list(newmodlist)
+
+
+def revert_colsep(document):
+ i = find_token(document.header, "\\columnsep", 0)
+ if i == -1:
+ return
+ colsepline = document.header[i]
+ r = re.compile(r'\\columnsep (.*)')
+ m = r.match(colsepline)
+ if not m:
+ document.warning("Malformed column separation line!")
+ return
+ colsep = m.group(1)
+ del document.header[i]
+ #it seems to be safe to add the package even if it is already used
+ pretext = ["\\usepackage{geometry}", "\\geometry{columnsep=" + colsep + "}"]
+
+ add_to_preamble(document, pretext)
+
+
+def revert_framed_notes(document):
+ "Revert framed boxes to notes. "
+ i = 0
+ while 1:
+ i = find_tokens(document.body, ["\\begin_inset Box Framed", "\\begin_inset Box Shaded"], i)
+
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i + 1)
+ if j == -1:
+ # should not happen
+ document.warning("Malformed LyX document: Could not find end of Box inset.")
+ i += 1
+ continue
+ k = find_token(document.body, "status", i + 1, j)
+ if k == -1:
+ document.warning("Malformed LyX document: Missing `status' tag in Box inset.")
+ i = j
+ continue
+ status = document.body[k]
+ l = find_default_layout(document, i + 1, j)
+ if l == -1:
+ document.warning("Malformed LyX document: Missing `\\begin_layout' in Box inset.")
+ i = j
+ continue
+ m = find_token(document.body, "\\end_layout", i + 1, j)
+ if m == -1:
+ document.warning("Malformed LyX document: Missing `\\end_layout' in Box inset.")
+ i = j
+ continue
+ ibox = find_token(document.body, "has_inner_box 1", i + 1, k)
+ pbox = find_token(document.body, "use_parbox 1", i + 1, k)
+ if ibox == -1 and pbox == -1:
+ document.body[i] = document.body[i].replace("\\begin_inset Box", "\\begin_inset Note")
+ del document.body[i+1:k]
+ else:
+ document.body[i] = document.body[i].replace("\\begin_inset Box Shaded", "\\begin_inset Box Frameless")
+ subst1 = [document.body[l],
+ "\\begin_inset Note Shaded",
+ status,
+ '\\begin_layout Standard']
+ document.body[l:l + 1] = subst1
+ subst2 = [document.body[m], "\\end_layout", "\\end_inset"]
+ document.body[m:m + 1] = subst2
+ i = i + 1
+
+
+def revert_slash(document):
+ 'Revert \\SpecialChar \\slash{} to ERT'
+ i = 0
+ while i < len(document.body):
+ m = re.match(r'(.*)\\SpecialChar \\slash{}(.*)', document.body[i])
+ if m:
+ before = m.group(1)
+ after = m.group(2)
+ subst = [before,
+ '\\begin_inset ERT',
+ 'status collapsed', '',
+ '\\begin_layout Standard',
+ '', '', '\\backslash',
+ 'slash{}',
+ '\\end_layout', '',
+ '\\end_inset', '',
+ after]
+ document.body[i: i+1] = subst
+ i = i + len(subst)
+ else:
+ i = i + 1
+
+
+def revert_nobreakdash(document):
+ 'Revert \\SpecialChar \\nobreakdash- to ERT'
+ i = 0
+ while i < len(document.body):
+ m = re.match(r'(.*)\\SpecialChar \\nobreakdash-(.*)', document.body[i])
+ if m:
+ before = m.group(1)
+ after = m.group(2)
+ subst = [before,
+ '\\begin_inset ERT',
+ 'status collapsed', '',
+ '\\begin_layout Standard', '', '',
+ '\\backslash',
+ 'nobreakdash-',
+ '\\end_layout', '',
+ '\\end_inset', '',
+ after]
+ document.body[i: i+1] = subst
+ i = i + len(subst)
+ j = find_token(document.header, "\\use_amsmath", 0)
+ if j == -1:
+ document.warning("Malformed LyX document: Missing '\\use_amsmath'.")
+ i += 1
+ continue
+ document.header[j] = "\\use_amsmath 2"
+ else:
+ i = i + 1
+
+
+#Returns number of lines added/removed
+def revert_nocite_key(body, start, end):
+ 'key "..." -> \nocite{...}'
+ r = re.compile(r'^key "(.*)"')
+ i = start
+ j = end
+ while i < j:
+ m = r.match(body[i])
+ if m:
+ body[i:i+1] = ["\\backslash", "nocite{" + m.group(1) + "}"]
+ j += 1 # because we added a line
+ i += 2 # skip that line
+ else:
+ del body[i]
+ j -= 1 # because we deleted a line
+ # no need to change i, since it now points to the next line
+ return j - end
+
+
+def revert_nocite(document):
+ "Revert LatexCommand nocite to ERT"
+ i = 0
+ while 1:
+ i = find_token(document.body, "\\begin_inset CommandInset citation", i)
+ if i == -1:
+ return
+ if (document.body[i+1] != "LatexCommand nocite"):
+ # note that we already incremented i
+ i = i + 1
+ continue
+ insetEnd = find_end_of_inset(document.body, i)
+ if insetEnd == -1:
+ #this should not happen
+ document.warning("End of CommandInset citation not found in revert_nocite!")
+ return
+
+ paramLocation = i + 2 #start of the inset's parameters
+ addedLines = 0
+ document.body[i:i+2] = \
+ ["\\begin_inset ERT", "status collapsed", "", "\\begin_layout Standard"]
+ # that added two lines
+ paramLocation += 2
+ insetEnd += 2
+ #print insetEnd, document.body[i: insetEnd + 1]
+ insetEnd += revert_nocite_key(document.body, paramLocation, insetEnd)
+ #print insetEnd, document.body[i: insetEnd + 1]
+ document.body.insert(insetEnd, "\\end_layout")
+ document.body.insert(insetEnd + 1, "")
+ i = insetEnd + 1
+
+
+def revert_btprintall(document):
+ "Revert (non-bibtopic) btPrintAll option to ERT \nocite{*}"
+ i = find_token(document.header, '\\use_bibtopic', 0)
+ if i == -1:
+ document.warning("Malformed lyx document: Missing '\\use_bibtopic'.")
+ return
+ if get_value(document.header, '\\use_bibtopic', 0) == "false":
+ i = 0
+ while i < len(document.body):
+ i = find_token(document.body, "\\begin_inset CommandInset bibtex", i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i + 1)
+ if j == -1:
+ #this should not happen
+ document.warning("End of CommandInset bibtex not found in revert_btprintall!")
+ j = len(document.body)
+ # this range isn't really right, but it should be OK, since we shouldn't
+ # see more than one matching line in each inset
+ addedlines = 0
+ for k in range(i, j):
+ if (document.body[k] == 'btprint "btPrintAll"'):
+ del document.body[k]
+ subst = ["\\begin_inset ERT",
+ "status collapsed", "",
+ "\\begin_layout Standard", "",
+ "\\backslash",
+ "nocite{*}",
+ "\\end_layout",
+ "\\end_inset"]
+ document.body[i:i] = subst
+ addlines = addedlines + len(subst) - 1
+ i = j + addedlines
+
+
+def revert_bahasam(document):
+ "Set language Bahasa Malaysia to Bahasa Indonesia"
+ i = 0
+ if document.language == "bahasam":
+ document.language = "bahasa"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language bahasa"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang bahasam", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang bahasam", "\\lang bahasa")
+ j = j + 1
+
+
+def revert_interlingua(document):
+ "Set language Interlingua to English"
+ i = 0
+ if document.language == "interlingua":
+ document.language = "english"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language english"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang interlingua", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang interlingua", "\\lang english")
+ j = j + 1
+
+
+def revert_serbianlatin(document):
+ "Set language Serbian-Latin to Croatian"
+ i = 0
+ if document.language == "serbian-latin":
+ document.language = "croatian"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language croatian"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang serbian-latin", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang serbian-latin", "\\lang croatian")
+ j = j + 1
+
+
+def revert_rotfloat(document):
+ " Revert sideways custom floats. "
+ i = 0
+ while 1:
+ # whitespace intended (exclude \\begin_inset FloatList)
+ i = find_token(document.body, "\\begin_inset Float ", i)
+ if i == -1:
+ return
+ line = document.body[i]
+ r = re.compile(r'\\begin_inset Float (.*)$')
+ m = r.match(line)
+ if m == None:
+ document.warning("Unable to match line " + str(i) + " of body!")
+ i += 1
+ continue
+ floattype = m.group(1)
+ if floattype == "figure" or floattype == "table":
+ i += 1
+ continue
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed lyx document: Missing '\\end_inset' in revert_rotfloat.")
+ i += 1
+ continue
+ addedLines = 0
+ if get_value(document.body, 'sideways', i, j) == "false":
+ i += 1
+ continue
+ l = find_default_layout(document, i + 1, j)
+ if l == -1:
+ document.warning("Malformed LyX document: Missing `\\begin_layout' in Float inset.")
+ i = j
+ continue
+ subst = ['\\begin_layout Standard',
+ '\\begin_inset ERT',
+ 'status collapsed', '',
+ '\\begin_layout Standard', '', '',
+ '\\backslash', '',
+ 'end{sideways' + floattype + '}',
+ '\\end_layout', '', '\\end_inset']
+ document.body[j : j+1] = subst
+ addedLines = len(subst) - 1
+ del document.body[i+1 : l]
+ addedLines -= (l-1) - (i+1)
+ subst = ['\\begin_inset ERT', 'status collapsed', '',
+ '\\begin_layout Standard', '', '', '\\backslash',
+ 'begin{sideways' + floattype + '}',
+ '\\end_layout', '', '\\end_inset', '',
+ '\\end_layout', '']
+ document.body[i : i+1] = subst
+ addedLines += len(subst) - 1
+ if floattype == "algorithm":
+ add_to_preamble(document,
+ ['% Commands inserted by lyx2lyx for sideways algorithm float',
+ '\\usepackage{rotfloat}',
+ '\\floatstyle{ruled}',
+ '\\newfloat{algorithm}{tbp}{loa}',
+ '\\floatname{algorithm}{Algorithm}'])
+ else:
+ document.warning("Cannot create preamble definition for custom float" + floattype + ".")
+ i += addedLines + 1
+
+
+def revert_widesideways(document):
+ " Revert wide sideways floats. "
+ i = 0
+ while 1:
+ # whitespace intended (exclude \\begin_inset FloatList)
+ i = find_token(document.body, '\\begin_inset Float ', i)
+ if i == -1:
+ return
+ line = document.body[i]
+ r = re.compile(r'\\begin_inset Float (.*)$')
+ m = r.match(line)
+ if m == None:
+ document.warning("Unable to match line " + str(i) + " of body!")
+ i += 1
+ continue
+ floattype = m.group(1)
+ if floattype != "figure" and floattype != "table":
+ i += 1
+ continue
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed lyx document: Missing '\\end_inset' in revert_widesideways.")
+ i += 1
+ continue
+ if get_value(document.body, 'sideways', i, j) == "false" or \
+ get_value(document.body, 'wide', i, j) == "false":
+ i += 1
+ continue
+ l = find_default_layout(document, i + 1, j)
+ if l == -1:
+ document.warning("Malformed LyX document: Missing `\\begin_layout' in Float inset.")
+ i = j
+ continue
+ subst = ['\\begin_layout Standard', '\\begin_inset ERT',
+ 'status collapsed', '',
+ '\\begin_layout Standard', '', '', '\\backslash',
+ 'end{sideways' + floattype + '*}',
+ '\\end_layout', '', '\\end_inset']
+ document.body[j : j+1] = subst
+ addedLines = len(subst) - 1
+ del document.body[i+1:l-1]
+ addedLines -= (l-1) - (i+1)
+ subst = ['\\begin_inset ERT', 'status collapsed', '',
+ '\\begin_layout Standard', '', '', '\\backslash',
+ 'begin{sideways' + floattype + '*}', '\\end_layout', '',
+ '\\end_inset', '', '\\end_layout', '']
+ document.body[i : i+1] = subst
+ addedLines += len(subst) - 1
+ add_to_preamble(document, ['\\usepackage{rotfloat}\n'])
+ i += addedLines + 1
+
+
+def revert_inset_embedding(document, type):
+ ' Remove embed tag from certain type of insets'
+ i = 0
+ while 1:
+ i = find_token(document.body, "\\begin_inset %s" % type, i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed lyx document: Missing '\\end_inset' in revert_inset_embedding.")
+ i = i + 1
+ continue
+ k = find_token(document.body, "\tembed", i, j)
+ if k == -1:
+ k = find_token(document.body, "embed", i, j)
+ if k != -1:
+ del document.body[k]
+ i = i + 1
+
+
+def revert_external_embedding(document):
+ ' Remove embed tag from external inset '
+ revert_inset_embedding(document, 'External')
+
+
+def convert_subfig(document):
+ " Convert subfigures to subfloats. "
+ i = 0
+ while 1:
+ addedLines = 0
+ i = find_token(document.body, '\\begin_inset Graphics', i)
+ if i == -1:
+ return
+ endInset = find_end_of_inset(document.body, i)
+ if endInset == -1:
+ document.warning("Malformed lyx document: Missing '\\end_inset' in convert_subfig.")
+ i += 1
+ continue
+ k = find_token(document.body, '\tsubcaption', i, endInset)
+ if k == -1:
+ i = endInset
+ continue
+ l = find_token(document.body, '\tsubcaptionText', i, endInset)
+ if l == -1:
+ caption = ""
+ else:
+ caption = document.body[l][16:].strip('"')
+ del document.body[l]
+ addedLines -= 1
+ del document.body[k]
+ addedLines -= 1
+ subst = ['\\begin_inset Float figure', 'wide false', 'sideways false',
+ 'status open', '', '\\begin_layout Plain Layout', '\\begin_inset Caption',
+ '', '\\begin_layout Plain Layout'] + latex2lyx(caption, False) + \
+ [ '\\end_layout', '', '\\end_inset', '',
+ '\\end_layout', '', '\\begin_layout Plain Layout']
+ document.body[i : i] = subst
+ addedLines += len(subst)
+ endInset += addedLines
+ subst = ['', '\\end_inset', '', '\\end_layout']
+ document.body[endInset : endInset] = subst
+ addedLines += len(subst)
+ i += addedLines + 1
+
+
+def revert_subfig(document):
+ " Revert subfloats. "
+ i = 0
+ while 1:
+ # whitespace intended (exclude \\begin_inset FloatList)
+ i = find_tokens(document.body, ['\\begin_inset Float ', '\\begin_inset Wrap'], i)
+ if i == -1:
+ return
+ j = 0
+ addedLines = 0
+ while j != -1:
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed lyx document: Missing '\\end_inset' (float) at line " + str(i + len(document.header)) + ".\n\t" + document.body[i])
+ # document.warning(document.body[i-1] + "\n" + document.body[i+1])
+ i += 1
+ continue # this will get us back to the outer loop, since j == -1
+ # look for embedded float (= subfloat)
+ # whitespace intended (exclude \\begin_inset FloatList)
+ k = find_token(document.body, '\\begin_inset Float ', i + 1, j)
+ if k == -1:
+ break
+ # is the subfloat aligned?
+ al = find_token(document.body, '\\align ', k - 1, j)
+ alignment_beg = ""
+ alignment_end = ""
+ if al != -1:
+ if get_value(document.body, '\\align', al) == "center":
+ alignment_beg = "\\backslash\nbegin{centering}"
+ alignment_end = "\\backslash\npar\\backslash\nend{centering}"
+ elif get_value(document.body, '\\align', al) == "left":
+ alignment_beg = "\\backslash\nbegin{raggedright}"
+ alignment_end = "\\backslash\npar\\backslash\nend{raggedright}"
+ elif get_value(document.body, '\\align', al) == "right":
+ alignment_beg = "\\backslash\nbegin{raggedleft}"
+ alignment_end = "\\backslash\npar\\backslash\nend{raggedleft}"
+ l = find_end_of_inset(document.body, k)
+ if l == -1:
+ document.warning("Malformed lyx document: Missing '\\end_inset' (embedded float).")
+ i += 1
+ j = -1
+ continue # escape to the outer loop
+ m = find_default_layout(document, k + 1, l)
+ # caption?
+ cap = find_token(document.body, '\\begin_inset Caption', k + 1, l)
+ caption = ''
+ shortcap = ''
+ capend = cap
+ if cap != -1:
+ capend = find_end_of_inset(document.body, cap)
+ if capend == -1:
+ document.warning("Malformed lyx document: Missing '\\end_inset' (caption).")
+ return
+ # label?
+ label = ''
+ lbl = find_token(document.body, '\\begin_inset CommandInset label', cap, capend)
+ if lbl != -1:
+ lblend = find_end_of_inset(document.body, lbl + 1)
+ if lblend == -1:
+ document.warning("Malformed lyx document: Missing '\\end_inset' (label).")
+ return
+ for line in document.body[lbl:lblend + 1]:
+ if line.startswith('name '):
+ label = line.split()[1].strip('"')
+ break
+ else:
+ lbl = capend
+ lblend = capend
+ label = ''
+ # opt arg?
+ opt = find_token(document.body, '\\begin_inset OptArg', cap, capend)
+ if opt != -1:
+ optend = find_end_of_inset(document.body, opt)
+ if optend == -1:
+ document.warning("Malformed LyX document: Missing '\\end_inset' (OptArg).")
+ return
+ optc = find_default_layout(document, opt, optend)
+ if optc == -1:
+ document.warning("Malformed LyX document: Missing `\\begin_layout' in Float inset.")
+ return
+ optcend = find_end_of(document.body, optc, "\\begin_layout", "\\end_layout")
+ for line in document.body[optc:optcend]:
+ if not line.startswith('\\'):
+ shortcap += line.strip()
+ else:
+ opt = capend
+ optend = capend
+ for line in document.body[cap:capend]:
+ if line in document.body[lbl:lblend]:
+ continue
+ elif line in document.body[opt:optend]:
+ continue
+ else:
+ inert = True
+ caption += lyxline2latex(document, line, inert)
+ if len(label) > 0:
+ caption += "\n\\backslash\nlabel{" + label + "}"
+ subst = '\\begin_layout PlainLayout\n\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout PlainLayout\n\n}' + alignment_end + \
+ '\n\\end_layout\n\n\\end_inset\n\n' \
+ '\\end_layout\n\n\\begin_layout PlainLayout\n'
+ subst = subst.split('\n')
+ document.body[l : l+1] = subst
+ addedLines = len(subst) - 1
+ # this is before l and so is unchanged by the multiline insertion
+ if cap != capend:
+ del document.body[cap:capend+1]
+ addedLines -= (capend + 1 - cap)
+ del document.body[k+1:m-1]
+ addedLines -= (m - 1 - (k + 1))
+ insertion = '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout PlainLayout\n\n' + alignment_beg + '\n\\backslash\n' \
+ 'subfloat'
+ if len(shortcap) > 0:
+ insertion = insertion + "[" + shortcap + "]"
+ if len(caption) > 0:
+ insertion = insertion + "[" + caption + "]"
+ insertion = insertion + '{%\n\\end_layout\n\n\\end_inset\n\n\\end_layout\n'
+ insertion = insertion.split('\n')
+ document.body[k : k + 1] = insertion
+ addedLines += len(insertion) - 1
+ al = find_token(document.body, '\\align ', k - 1, j + addedLines)
+ if al != -1:
+ del document.body[al]
+ addedLines -= 1
+ add_to_preamble(document, ['\\usepackage{subfig}\n'])
+ i += addedLines + 1
+
+
+def revert_wrapplacement(document):
+ " Revert placement options wrap floats (wrapfig). "
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_inset Wrap figure", i)
+ if i == -1:
+ return
+ e = find_end_of_inset(document.body, i)
+ j = find_token(document.body, "placement", i + 1, e)
+ if j == -1:
+ document.warning("Malformed LyX document: Couldn't find placement parameter of wrap float.")
+ i += 1
+ continue
+ r = re.compile("placement (o|i|l|r|O|I|L|R)")
+ m = r.match(document.body[j])
+ if m == None:
+ document.warning("Malformed LyX document: Placement option isn't O|I|R|L!")
+ else:
+ document.body[j] = "placement " + m.group(1).lower()
+ i = j
+
+
+def remove_extra_embedded_files(document):
+ " Remove \extra_embedded_files from buffer params "
+ i = find_token(document.header, '\\extra_embedded_files', 0)
+ if i == -1:
+ return
+ document.header.pop(i)
+
+
+def convert_spaceinset(document):
+ " Convert '\\InsetSpace foo' to '\\begin_inset Space foo\n\\end_inset' "
+ i = 0
+ while i < len(document.body):
+ m = re.match(r'(.*)\\InsetSpace (.*)', document.body[i])
+ if m:
+ before = m.group(1)
+ after = m.group(2)
+ subst = [before, "\\begin_inset Space " + after, "\\end_inset"]
+ document.body[i: i+1] = subst
+ i = i + len(subst)
+ else:
+ i = i + 1
+
+
+def revert_spaceinset(document):
+ " Revert '\\begin_inset Space foo\n\\end_inset' to '\\InsetSpace foo' "
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_inset Space", i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed LyX document: Could not find end of space inset.")
+ i += 1
+ continue
+ document.body[i] = document.body[i].replace('\\begin_inset Space', '\\InsetSpace')
+ del document.body[j]
+
+
+def convert_hfill(document):
+ " Convert hfill to space inset "
+ i = 0
+ while True:
+ i = find_token(document.body, "\\hfill", i)
+ if i == -1:
+ return
+ subst = document.body[i].replace('\\hfill', \
+ '\n\\begin_inset Space \\hfill{}\n\\end_inset')
+ subst = subst.split('\n')
+ document.body[i : i+1] = subst
+ i += len(subst)
+
+
+def revert_hfills(document):
+ ' Revert \\hfill commands '
+ hfill = re.compile(r'\\hfill')
+ dotfill = re.compile(r'\\dotfill')
+ hrulefill = re.compile(r'\\hrulefill')
+ i = 0
+ while True:
+ i = find_token(document.body, "\\InsetSpace", i)
+ if i == -1:
+ return
+ if hfill.search(document.body[i]):
+ document.body[i] = \
+ document.body[i].replace('\\InsetSpace \\hfill{}', '\\hfill')
+ i += 1
+ continue
+ if dotfill.search(document.body[i]):
+ subst = document.body[i].replace('\\InsetSpace \\dotfill{}', \
+ '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout Standard\n\n\n\\backslash\n' \
+ 'dotfill{}\n\\end_layout\n\n\\end_inset\n\n')
+ subst = subst.split('\n')
+ document.body[i : i+1] = subst
+ i += len(subst)
+ continue
+ if hrulefill.search(document.body[i]):
+ subst = document.body[i].replace('\\InsetSpace \\hrulefill{}', \
+ '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout Standard\n\n\n\\backslash\n' \
+ 'hrulefill{}\n\\end_layout\n\n\\end_inset\n\n')
+ subst = subst.split('\n')
+ document.body[i : i+1] = subst
+ i += len(subst)
+ continue
+ i += 1
+
+def revert_hspace(document):
+ ' Revert \\InsetSpace \\hspace{} to ERT '
+ i = 0
+ hspace = re.compile(r'\\hspace{}')
+ hstar = re.compile(r'\\hspace\*{}')
+ while True:
+ i = find_token(document.body, "\\InsetSpace \\hspace", i)
+ if i == -1:
+ return
+ length = get_value(document.body, '\\length', i+1)
+ if length == '':
+ document.warning("Malformed lyx document: Missing '\\length' in Space inset.")
+ return
+ del document.body[i+1]
+ addedLines = -1
+ if hstar.search(document.body[i]):
+ subst = document.body[i].replace('\\InsetSpace \\hspace*{}', \
+ '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout Standard\n\n\n\\backslash\n' \
+ 'hspace*{' + length + '}\n\\end_layout\n\n\\end_inset\n\n')
+ subst = subst.split('\n')
+ document.body[i : i+1] = subst
+ addedLines += len(subst) - 1
+ i += addedLines + 1
+ continue
+ if hspace.search(document.body[i]):
+ subst = document.body[i].replace('\\InsetSpace \\hspace{}', \
+ '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout Standard\n\n\n\\backslash\n' \
+ 'hspace{' + length + '}\n\\end_layout\n\n\\end_inset\n\n')
+ subst = subst.split('\n')
+ document.body[i : i+1] = subst
+ addedLines += len(subst) - 1
+ i += addedLines + 1
+ continue
+ i += 1
+
+
+def revert_protected_hfill(document):
+ ' Revert \\begin_inset Space \\hspace*{\\fill} to ERT '
+ i = 0
+ while True:
+ i = find_token(document.body, '\\begin_inset Space \\hspace*{\\fill}', i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed LyX document: Could not find end of space inset.")
+ i += 1
+ continue
+ del document.body[j]
+ subst = document.body[i].replace('\\begin_inset Space \\hspace*{\\fill}', \
+ '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout Standard\n\n\n\\backslash\n' \
+ 'hspace*{\n\\backslash\nfill}\n\\end_layout\n\n\\end_inset\n\n')
+ subst = subst.split('\n')
+ document.body[i : i+1] = subst
+ i += len(subst)
+
+
+def revert_leftarrowfill(document):
+ ' Revert \\begin_inset Space \\leftarrowfill{} to ERT '
+ i = 0
+ while True:
+ i = find_token(document.body, '\\begin_inset Space \\leftarrowfill{}', i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed LyX document: Could not find end of space inset.")
+ i += 1
+ continue
+ del document.body[j]
+ subst = document.body[i].replace('\\begin_inset Space \\leftarrowfill{}', \
+ '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout Standard\n\n\n\\backslash\n' \
+ 'leftarrowfill{}\n\\end_layout\n\n\\end_inset\n\n')
+ subst = subst.split('\n')
+ document.body[i : i+1] = subst
+ i += len(subst)
+
+
+def revert_rightarrowfill(document):
+ ' Revert \\begin_inset Space \\rightarrowfill{} to ERT '
+ i = 0
+ while True:
+ i = find_token(document.body, '\\begin_inset Space \\rightarrowfill{}', i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed LyX document: Could not find end of space inset.")
+ i += 1
+ continue
+ del document.body[j]
+ subst = document.body[i].replace('\\begin_inset Space \\rightarrowfill{}', \
+ '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout Standard\n\n\n\\backslash\n' \
+ 'rightarrowfill{}\n\\end_layout\n\n\\end_inset\n\n')
+ subst = subst.split('\n')
+ document.body[i : i+1] = subst
+ i += len(subst)
+
+
+def revert_upbracefill(document):
+ ' Revert \\begin_inset Space \\upbracefill{} to ERT '
+ i = 0
+ while True:
+ i = find_token(document.body, '\\begin_inset Space \\upbracefill{}', i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed LyX document: Could not find end of space inset.")
+ i += 1
+ continue
+ del document.body[j]
+ subst = document.body[i].replace('\\begin_inset Space \\upbracefill{}', \
+ '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout Standard\n\n\n\\backslash\n' \
+ 'upbracefill{}\n\\end_layout\n\n\\end_inset\n\n')
+ subst = subst.split('\n')
+ document.body[i : i+1] = subst
+ i += len(subst)
+
+
+def revert_downbracefill(document):
+ ' Revert \\begin_inset Space \\downbracefill{} to ERT '
+ i = 0
+ while True:
+ i = find_token(document.body, '\\begin_inset Space \\downbracefill{}', i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed LyX document: Could not find end of space inset.")
+ i += 1
+ continue
+ del document.body[j]
+ subst = document.body[i].replace('\\begin_inset Space \\downbracefill{}', \
+ '\\begin_inset ERT\nstatus collapsed\n\n' \
+ '\\begin_layout Standard\n\n\n\\backslash\n' \
+ 'downbracefill{}\n\\end_layout\n\n\\end_inset\n\n')
+ subst = subst.split('\n')
+ document.body[i : i+1] = subst
+ i += len(subst)
+
+
+def revert_local_layout(document):
+ ' Revert local layout headers.'
+ i = 0
+ while True:
+ i = find_token(document.header, "\\begin_local_layout", i)
+ if i == -1:
+ return
+ j = find_end_of(document.header, i, "\\begin_local_layout", "\\end_local_layout")
+ if j == -1:
+ # this should not happen
+ break
+ document.header[i : j + 1] = []
+
+
+def convert_pagebreaks(document):
+ ' Convert inline Newpage insets to new format '
+ i = 0
+ while True:
+ i = find_token(document.body, '\\newpage', i)
+ if i == -1:
+ break
+ document.body[i:i+1] = ['\\begin_inset Newpage newpage',
+ '\\end_inset']
+ i = 0
+ while True:
+ i = find_token(document.body, '\\pagebreak', i)
+ if i == -1:
+ break
+ document.body[i:i+1] = ['\\begin_inset Newpage pagebreak',
+ '\\end_inset']
+ i = 0
+ while True:
+ i = find_token(document.body, '\\clearpage', i)
+ if i == -1:
+ break
+ document.body[i:i+1] = ['\\begin_inset Newpage clearpage',
+ '\\end_inset']
+ i = 0
+ while True:
+ i = find_token(document.body, '\\cleardoublepage', i)
+ if i == -1:
+ break
+ document.body[i:i+1] = ['\\begin_inset Newpage cleardoublepage',
+ '\\end_inset']
+
+
+def revert_pagebreaks(document):
+ ' Revert \\begin_inset Newpage to previous inline format '
+ i = 0
+ while True:
+ i = find_token(document.body, '\\begin_inset Newpage', i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed LyX document: Could not find end of Newpage inset.")
+ i += 1
+ continue
+ del document.body[j]
+ document.body[i] = document.body[i].replace('\\begin_inset Newpage newpage', '\\newpage')
+ document.body[i] = document.body[i].replace('\\begin_inset Newpage pagebreak', '\\pagebreak')
+ document.body[i] = document.body[i].replace('\\begin_inset Newpage clearpage', '\\clearpage')
+ document.body[i] = document.body[i].replace('\\begin_inset Newpage cleardoublepage', '\\cleardoublepage')
+
+
+def convert_linebreaks(document):
+ ' Convert inline Newline insets to new format '
+ i = 0
+ while True:
+ i = find_token(document.body, '\\newline', i)
+ if i == -1:
+ break
+ document.body[i:i+1] = ['\\begin_inset Newline newline',
+ '\\end_inset']
+ i = 0
+ while True:
+ i = find_token(document.body, '\\linebreak', i)
+ if i == -1:
+ break
+ document.body[i:i+1] = ['\\begin_inset Newline linebreak',
+ '\\end_inset']
+
+
+def revert_linebreaks(document):
+ ' Revert \\begin_inset Newline to previous inline format '
+ i = 0
+ while True:
+ i = find_token(document.body, '\\begin_inset Newline', i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed LyX document: Could not find end of Newline inset.")
+ i += 1
+ continue
+ del document.body[j]
+ document.body[i] = document.body[i].replace('\\begin_inset Newline newline', '\\newline')
+ document.body[i] = document.body[i].replace('\\begin_inset Newline linebreak', '\\linebreak')
+
+
+def convert_japanese_plain(document):
+ ' Set language japanese-plain to japanese '
+ i = 0
+ if document.language == "japanese-plain":
+ document.language = "japanese"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language japanese"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang japanese-plain", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang japanese-plain", "\\lang japanese")
+ j = j + 1
+
+
+def revert_pdfpages(document):
+ ' Revert pdfpages external inset to ERT '
+ i = 0
+ while 1:
+ i = find_token(document.body, "\\begin_inset External", i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed lyx document: Missing '\\end_inset' in revert_pdfpages.")
+ i = i + 1
+ continue
+ if get_value(document.body, 'template', i, j) == "PDFPages":
+ filename = get_value(document.body, 'filename', i, j)
+ extra = ''
+ r = re.compile(r'\textra PDFLaTeX \"(.*)\"$')
+ for k in range(i, j):
+ m = r.match(document.body[k])
+ if m:
+ extra = m.group(1)
+ angle = get_value(document.body, 'rotateAngle', i, j)
+ width = get_value(document.body, 'width', i, j)
+ height = get_value(document.body, 'height', i, j)
+ scale = get_value(document.body, 'scale', i, j)
+ keepAspectRatio = find_token(document.body, "\tkeepAspectRatio", i, j)
+ options = extra
+ if angle != '':
+ if options != '':
+ options += ",angle=" + angle
+ else:
+ options += "angle=" + angle
+ if width != '':
+ if options != '':
+ options += ",width=" + convert_len(width)
+ else:
+ options += "width=" + convert_len(width)
+ if height != '':
+ if options != '':
+ options += ",height=" + convert_len(height)
+ else:
+ options += "height=" + convert_len(height)
+ if scale != '':
+ if options != '':
+ options += ",scale=" + scale
+ else:
+ options += "scale=" + scale
+ if keepAspectRatio != '':
+ if options != '':
+ options += ",keepaspectratio"
+ else:
+ options += "keepaspectratio"
+ if options != '':
+ options = '[' + options + ']'
+ del document.body[i+1:j+1]
+ document.body[i:i+1] = ['\\begin_inset ERT',
+ 'status collapsed',
+ '',
+ '\\begin_layout Standard',
+ '',
+ '\\backslash',
+ 'includepdf' + options + '{' + filename + '}',
+ '\\end_layout',
+ '',
+ '\\end_inset']
+ add_to_preamble(document, ['\\usepackage{pdfpages}\n'])
+ i = i + 1
+ continue
+ i = i + 1
+
+
+def revert_mexican(document):
+ ' Set language Spanish(Mexico) to Spanish '
+ i = 0
+ if document.language == "spanish-mexico":
+ document.language = "spanish"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language spanish"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang spanish-mexico", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang spanish-mexico", "\\lang spanish")
+ j = j + 1
+
+
+def remove_embedding(document):
+ ' Remove embed tag from all insets '
+ revert_inset_embedding(document, 'Graphics')
+ revert_inset_embedding(document, 'External')
+ revert_inset_embedding(document, 'CommandInset include')
+ revert_inset_embedding(document, 'CommandInset bibtex')
+
+
+def revert_master(document):
+ ' Remove master param '
+ i = find_token(document.header, "\\master", 0)
+ if i != -1:
+ del document.header[i]
+
+
+def revert_graphics_group(document):
+ ' Revert group information from graphics insets '
+ i = 0
+ while 1:
+ i = find_token(document.body, "\\begin_inset Graphics", i)
+ if i == -1:
+ return
+ j = find_end_of_inset(document.body, i)
+ if j == -1:
+ document.warning("Malformed lyx document: Missing '\\end_inset' in revert_graphics_group.")
+ i = i + 1
+ continue
+ k = find_token(document.body, " groupId", i, j)
+ if k == -1:
+ i = i + 1
+ continue
+ del document.body[k]
+ i = i + 1
+
+
+def update_apa_styles(document):
+ ' Replace obsolete styles '
+
+ if document.textclass != "apa":
+ return
+
+ obsoletedby = { "Acknowledgments": "Acknowledgements",
+ "Section*": "Section",
+ "Subsection*": "Subsection",
+ "Subsubsection*": "Subsubsection",
+ "Paragraph*": "Paragraph",
+ "Subparagraph*": "Subparagraph"}
+ i = 0
+ while 1:
+ i = find_token(document.body, "\\begin_layout", i)
+ if i == -1:
+ return
+
+ layout = document.body[i][14:]
+ if layout in obsoletedby:
+ document.body[i] = "\\begin_layout " + obsoletedby[layout]
+
+ i += 1
+
+
+def convert_paper_sizes(document):
+ ' exchange size options legalpaper and executivepaper to correct order '
+ # routine is needed to fix http://www.lyx.org/trac/ticket/4868
+ i = 0
+ j = 0
+ i = find_token(document.header, "\\papersize executivepaper", 0)
+ if i != -1:
+ document.header[i] = "\\papersize legalpaper"
+ return
+ j = find_token(document.header, "\\papersize legalpaper", 0)
+ if j != -1:
+ document.header[j] = "\\papersize executivepaper"
+
+
+def revert_paper_sizes(document):
+ ' exchange size options legalpaper and executivepaper to correct order '
+ i = 0
+ j = 0
+ i = find_token(document.header, "\\papersize executivepaper", 0)
+ if i != -1:
+ document.header[i] = "\\papersize legalpaper"
+ return
+ j = find_token(document.header, "\\papersize legalpaper", 0)
+ if j != -1:
+ document.header[j] = "\\papersize executivepaper"
+
+
+def convert_InsetSpace(document):
+ " Convert '\\begin_inset Space foo' to '\\begin_inset space foo'"
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_inset Space", i)
+ if i == -1:
+ return
+ document.body[i] = document.body[i].replace('\\begin_inset Space', '\\begin_inset space')
+
+
+def revert_InsetSpace(document):
+ " Revert '\\begin_inset space foo' to '\\begin_inset Space foo'"
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_inset space", i)
+ if i == -1:
+ return
+ document.body[i] = document.body[i].replace('\\begin_inset space', '\\begin_inset Space')
+
+
+def convert_display_enum(document):
+ " Convert 'display foo' to 'display false/true'"
+ i = 0
+ while True:
+ i = find_token(document.body, "\tdisplay", i)
+ if i == -1:
+ return
+ val = get_value(document.body, 'display', i)
+ if val == "none":
+ document.body[i] = document.body[i].replace('none', 'false')
+ if val == "default":
+ document.body[i] = document.body[i].replace('default', 'true')
+ if val == "monochrome":
+ document.body[i] = document.body[i].replace('monochrome', 'true')
+ if val == "grayscale":
+ document.body[i] = document.body[i].replace('grayscale', 'true')
+ if val == "color":
+ document.body[i] = document.body[i].replace('color', 'true')
+ if val == "preview":
+ document.body[i] = document.body[i].replace('preview', 'true')
+ i += 1
+
+
+def revert_display_enum(document):
+ " Revert 'display false/true' to 'display none/color'"
+ i = 0
+ while True:
+ i = find_token(document.body, "\tdisplay", i)
+ if i == -1:
+ return
+ val = get_value(document.body, 'display', i)
+ if val == "false":
+ document.body[i] = document.body[i].replace('false', 'none')
+ if val == "true":
+ document.body[i] = document.body[i].replace('true', 'default')
+ i += 1
+
+
+def remove_fontsCJK(document):
+ ' Remove font_cjk param '
+ i = find_token(document.header, "\\font_cjk", 0)
+ if i != -1:
+ del document.header[i]
+
+
+def convert_plain_layout(document):
+ " Convert 'PlainLayout' to 'Plain Layout'"
+ i = 0
+ while True:
+ i = find_token(document.body, '\\begin_layout PlainLayout', i)
+ if i == -1:
+ return
+ document.body[i] = document.body[i].replace('\\begin_layout PlainLayout', \
+ '\\begin_layout Plain Layout')
+ i += 1
+
+
+def revert_plain_layout(document):
+ " Revert 'Plain Layout' to 'PlainLayout'"
+ i = 0
+ while True:
+ i = find_token(document.body, '\\begin_layout Plain Layout', i)
+ if i == -1:
+ return
+ document.body[i] = document.body[i].replace('\\begin_layout Plain Layout', \
+ '\\begin_layout PlainLayout')
+ i += 1
+
+
+def revert_plainlayout(document):
+ " Revert 'PlainLayout' to 'Standard'"
+ i = 0
+ while True:
+ i = find_token(document.body, '\\begin_layout PlainLayout', i)
+ if i == -1:
+ return
+ # This will be incorrect for some document classes, since Standard is not always
+ # the default. But (a) it is probably the best we can do and (b) it will actually
+ # work, in fact, since an unknown layout will be converted to default.
+ document.body[i] = document.body[i].replace('\\begin_layout PlainLayout', \
+ '\\begin_layout Standard')
+ i += 1
+
+
+def revert_polytonicgreek(document):
+ "Set language polytonic Greek to Greek"
+ i = 0
+ if document.language == "polutonikogreek":
+ document.language = "greek"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language greek"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang polutonikogreek", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang polutonikogreek", "\\lang greek")
+ j = j + 1
+
+
+def revert_removed_modules(document):
+ i = 0
+ while True:
+ i = find_token(document.header, "\\begin_remove_modules", i)
+ if i == -1:
+ return
+ j = find_end_of(document.header, i, "\\begin_remove_modules", "\\end_remove_modules")
+ if j == -1:
+ # this should not happen
+ break
+ document.header[i : j + 1] = []
+
+
+def add_plain_layout(document):
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_layout", i)
+ if i == -1:
+ return
+ if len(document.body[i].split()) == 1:
+ document.body[i] = "\\begin_layout Plain Layout"
+ i += 1
+
+
+def revert_tabulators(document):
+ "Revert tabulators to 4 spaces"
+ i = 0
+ while True:
+ i = find_token(document.body, "\t", i)
+ if i == -1:
+ return
+ document.body[i] = document.body[i].replace("\t", " ")
+ i += 1
+
+
+def revert_tabsize(document):
+ "Revert the tabsize parameter of listings"
+ i = 0
+ j = 0
+ while True:
+ # either it is the only parameter
+ i = find_token(document.body, 'lstparams "tabsize=4"', i)
+ if i != -1:
+ del document.body[i]
+ # or the last one
+ j = find_token(document.body, "lstparams", j)
+ if j == -1:
+ return
+ pos = document.body[j].find(",tabsize=")
+ document.body[j] = document.body[j][:pos] + '"'
+ i += 1
+ j += 1
+
+
+def revert_mongolian(document):
+ "Set language Mongolian to English"
+ i = 0
+ if document.language == "mongolian":
+ document.language = "english"
+ i = find_token(document.header, "\\language", 0)
+ if i != -1:
+ document.header[i] = "\\language english"
+ j = 0
+ while True:
+ j = find_token(document.body, "\\lang mongolian", j)
+ if j == -1:
+ return
+ document.body[j] = document.body[j].replace("\\lang mongolian", "\\lang english")
+ j = j + 1
+
+
+def revert_default_options(document):
+ ' Remove param use_default_options '
+ i = find_token(document.header, "\\use_default_options", 0)
+ if i != -1:
+ del document.header[i]
+
+
+def convert_default_options(document):
+ ' Add param use_default_options and set it to false '
+ i = find_token(document.header, "\\textclass", 0)
+ if i == -1:
+ document.warning("Malformed LyX document: Missing `\\textclass'.")
+ return
+ document.header.insert(i, '\\use_default_options false')
+
+
+def revert_backref_options(document):
+ ' Revert option pdf_backref=page to pagebackref '
+ i = find_token(document.header, "\\pdf_backref page", 0)
+ if i != -1:
+ document.header[i] = "\\pdf_pagebackref true"
+
+
+def convert_backref_options(document):
+ ' We have changed the option pagebackref to backref=true '
+ i = find_token(document.header, "\\pdf_pagebackref true", 0)
+ if i != -1:
+ document.header[i] = "\\pdf_backref page"
+ j = find_token(document.header, "\\pdf_pagebackref false", 0)
+ if j != -1:
+ del document.header[j]
+ # backref=true was not a valid option, we meant backref=section
+ k = find_token(document.header, "\\pdf_backref true", 0)
+ if k != -1 and i != -1:
+ del document.header[k]
+ elif k != -1 and j != -1:
+ document.header[k] = "\\pdf_backref section"
+
+
+def convert_charstyle_element(document):
+ "Convert CharStyle to Element for docbook backend"
+ if document.backend != "docbook":
+ return
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_inset Flex CharStyle:", i)
+ if i == -1:
+ return
+ document.body[i] = document.body[i].replace('\\begin_inset Flex CharStyle:',
+ '\\begin_inset Flex Element:')
+
+def revert_charstyle_element(document):
+ "Convert Element to CharStyle for docbook backend"
+ if document.backend != "docbook":
+ return
+ i = 0
+ while True:
+ i = find_token(document.body, "\\begin_inset Flex Element:", i)
+ if i == -1:
+ return
+ document.body[i] = document.body[i].replace('\\begin_inset Flex Element:',
+ '\\begin_inset Flex CharStyle:')
+