diff --git a/lib/scripts/prefs2prefs_lfuns.py b/lib/scripts/prefs2prefs_lfuns.py index 386a167d20..3a0b0e2503 100644 --- a/lib/scripts/prefs2prefs_lfuns.py +++ b/lib/scripts/prefs2prefs_lfuns.py @@ -52,13 +52,13 @@ def optional_insert(line): return simple_renaming(line, "argument-insert", "optional-insert") -re_nm = re.compile(r'^(.*)notes-mutate\s+(\w+)\s+(\w+)(.*)') +re_nm = re.compile(r'^(.*)notes-mutate\s+(\w+)\s+(\w+)(.*)$') def notes_mutate(line): m = re_nm.search(line) if not m: return no_match - prerix = m.group(1) + prefix = m.group(1) source = m.group(2) target = m.group(3) suffix = m.group(4) @@ -67,6 +67,37 @@ def notes_mutate(line): return (True, newline) +re_ait = re.compile(r'^(.*)all-insets-toggle\s+(\w+)(?:\s+(\w+))?(.*)$') +def all_insets_toggle(line): + m = re_ait.search(line) + if not m: + return no_match + + prefix = m.group(1) + action = m.group(2) + target = m.group(3) + suffix = m.group(4) + + # we need to transform the target to match the inset layout names + # this will not be perfect + if target == "ert": + target = "ERT" + elif target == None: + target = "*" + elif target == "tabular": + # There does not seem to be an InsetLayout for tables, so + # I do not know what to do here. If anyone does, then please + # fix this. For now, we just have to remove this line. + return (True, "") + else: + target = target.capitalize() + + newline = prefix + "inset-forall " + target + " inset-toggle " + \ + action + suffix + return (True, newline) + + + # # ########################################################### @@ -79,7 +110,8 @@ conversions = [ next_inset_toggle, next_inset_modify, optional_insert, - notes_mutate + notes_mutate, + all_insets_toggle ] # end conversions for format 0 ]