]> git.lyx.org Git - lyx.git/blobdiff - lib/lyx2lyx/lyx_1_3.py
Don't use widest label for numerical citations.
[lyx.git] / lib / lyx2lyx / lyx_1_3.py
index 57d3ff17b66691a7fce263404fcf705e9a3b5661..195f0dcbac15bef29f71dd3c2fd1277d8ef908f5 100644 (file)
@@ -1,7 +1,7 @@
 # This file is part of lyx2lyx
-# -*- coding: iso-8859-1 -*-
+# -*- coding: utf-8 -*-
 # Copyright (C) 2002 Dekel Tsur <dekel@lyx.org>
-# Copyright (C) 2004 José Matos <jamatos@lyx.org>
+# Copyright (C) 2004 José Matos <jamatos@lyx.org>
 #
 # This program is free software; you can redistribute it and/or
 # modify it under the terms of the GNU General Public License
 #
 # You should have received a copy of the GNU General Public License
 # along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
+
+""" Convert files to the file format generated by lyx 1.3"""
 
-import string
 import re
-from parser_tools import find_token, find_end_of_inset, get_value,\
-                         find_token_exact, del_token
+from parser_tools import find_token, find_end_of, get_value,\
+                         find_token_exact
+
+####################################################################
+# Private helper functions
+
+def find_end_of_inset(lines, i):
+    "Finds the matching \end_inset"
+    return find_end_of(lines, i, "\\begin_inset", "\\end_inset")
+
+
+def del_token(lines, token, start, end):
+    """ del_token(lines, token, start, end) -> int
+
+    Find the lower line in lines where token is the first element and
+    delete that line.
 
-def change_insetgraphics(file):
-    lines = file.body
+    Returns the number of lines remaining."""
+
+    k = find_token_exact(lines, token, start, end)
+    if k == -1:
+        return end
+    else:
+        del lines[k]
+        return end - 1
+
+# End of helper functions
+####################################################################
+
+
+def change_insetgraphics(document):
+    " Change inset Graphics."
+    lines = document.body
     i = 0
     while 1:
-       i = find_token(lines, "\\begin_inset Graphics", i)
-       if i == -1:
-           break
-       j = find_end_of_inset(lines, i)
-
-       lines[i] = "\\begin_inset Graphics"
-
-       if get_value(lines, "display", i, j) == "default":
-           j = del_token(lines, "display", i, j)
-       if get_value(lines, "rotateOrigin", i, j) == "leftBaseline":
-           j = del_token(lines, "rotateOrigin", i, j)
-
-       k = find_token_exact(lines, "rotate", i, j)
-       if k != -1:
-           del lines[k]
-           j = j-1
-       else:
-           j = del_token(lines, "rotateAngle", i, j)
-
-       k = find_token_exact(lines, "size_type", i, j)
-       if k == -1:
-           k = find_token_exact(lines, "size_kind", i, j)
-       if k != -1:
-           size_type = string.split(lines[k])[1]
-           del lines[k]
-           j = j-1
-           if size_type in ["0", "original"]:
-               j = del_token(lines, "width", i, j)
-               j = del_token(lines, "height", i, j)
-               j = del_token(lines, "scale", i, j)
-           elif size_type in ["2", "scale"]:
-               j = del_token(lines, "width", i, j)
-               j = del_token(lines, "height", i, j)
-               if get_value(lines, "scale", i, j) == "100":
-                   j = del_token(lines, "scale", i, j)
-           else:
-               j = del_token(lines, "scale", i, j)
-
-       k = find_token_exact(lines, "lyxsize_type", i, j)
-       if k == -1:
-           k = find_token_exact(lines, "lyxsize_kind", i, j)
-       if k != -1:
-           lyxsize_type = string.split(lines[k])[1]
-           del lines[k]
-           j = j-1
-           j = del_token(lines, "lyxwidth", i, j)
-           j = del_token(lines, "lyxheight", i, j)
-           if lyxsize_type not in ["2", "scale"] or \
-              get_value(lines, "lyxscale", i, j) == "100":
-               j = del_token(lines, "lyxscale", i, j)
-
-       i = i+1
-
-
-def change_tabular(file):
-    lines = file.body
+        i = find_token(lines, "\\begin_inset Graphics", i)
+        if i == -1:
+            break
+        j = find_end_of_inset(lines, i)
+
+        lines[i] = "\\begin_inset Graphics"
+
+        if get_value(lines, "display", i, j) == "default":
+            j = del_token(lines, "display", i, j)
+        if get_value(lines, "rotateOrigin", i, j) == "leftBaseline":
+            j = del_token(lines, "rotateOrigin", i, j)
+
+        k = find_token_exact(lines, "rotate", i, j)
+        if k != -1:
+            del lines[k]
+            j = j-1
+        else:
+            j = del_token(lines, "rotateAngle", i, j)
+
+        k = find_token_exact(lines, "size_type", i, j)
+        if k == -1:
+            k = find_token_exact(lines, "size_kind", i, j)
+        if k != -1:
+            size_type = lines[k].split()[1]
+            del lines[k]
+            j = j-1
+            if size_type in ["0", "original"]:
+                j = del_token(lines, "width", i, j)
+                j = del_token(lines, "height", i, j)
+                j = del_token(lines, "scale", i, j)
+            elif size_type in ["2", "scale"]:
+                j = del_token(lines, "width", i, j)
+                j = del_token(lines, "height", i, j)
+                if get_value(lines, "scale", i, j) == "100":
+                    j = del_token(lines, "scale", i, j)
+            else:
+                j = del_token(lines, "scale", i, j)
+
+        k = find_token_exact(lines, "lyxsize_type", i, j)
+        if k == -1:
+            k = find_token_exact(lines, "lyxsize_kind", i, j)
+        if k != -1:
+            lyxsize_type = lines[k].split()[1]
+            del lines[k]
+            j = j-1
+            j = del_token(lines, "lyxwidth", i, j)
+            j = del_token(lines, "lyxheight", i, j)
+            if lyxsize_type not in ["2", "scale"] or \
+               get_value(lines, "lyxscale", i, j) == "100":
+                j = del_token(lines, "lyxscale", i, j)
+
+        i = i+1
+
+
+def change_tabular(document):
+    " Change tabular."
+    lines = document.body
     i = 0
     while 1:
         i = find_token(lines, "<column", i)
@@ -92,6 +122,7 @@ def change_tabular(file):
         i = i+1
 
 
+supported_versions = ["1.3.%d" % i for i in range(8)] + ["1.3"]
 convert = [[221, [change_insetgraphics, change_tabular]]]
 revert  = []