# This file is part of lyx2lyx # Copyright (C) 2002 José Matos # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # 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. import re, string, sys from parser_tools import * lyxtable_re = re.compile(r".*\\LyXTable$") def update_tabular(lines): i=0 while 1: i = find_re(lines, lyxtable_re, i) if i == -1: break prop_dict = {"family" : "default", "series" : "default", "shape" : "default", "size" : "default", "emph" : "default", "bar" : "default", "noun" : "default", "latex" : "default", "color" : "default"} # remove \LyXTable lines[i] = lines[i][:-9] i = i + 1 lines.insert(i,'') i = i + 1 lines[i] = "\\begin_inset Tabular" i = i + 1 head = string.split(lines[i]) rows = int(head[0]) columns = int(head[1]) lines[i] = '' % (head[0],head[1]) i = i +1 lines.insert(i, '' % (head[2],head[3],head[4],head[5],head[6],head[7])) i = i +1 row_info = [] for j in range(rows): row_info.append(string.split(lines[i])) del lines[i] column_info = [] for j in range(columns): column_info.append(string.split(lines[i])) del lines[i] cell_info = [] ncells = 0 for j in range(rows): for k in range(columns): cell_info.append(string.split(lines[i])) if lines[i][0] != "2": ncells = ncells + 1 del lines[i] del lines[i] if not lines[i]: del lines[i] tmp = [] tmp.append("") l = 0 for j in range(rows): tmp.append('' % (row_info[j][0],row_info[j][1],row_info[j][2])) for k in range(columns): if j: tmp.append('') else: tmp.append('' % (column_info[k][0],column_info[k][1], column_info[k][2], column_info[k][3], column_info[k][4])) m = j*columns + k leftline = int(cell_info[m][4]) or int(column_info[k][1]) if cell_info[m][0] == '1': n = m + 1 while n < rows * columns - 1 and cell_info[n][0] == '2': n = n + 1 rightline = int(cell_info[n][5]) or int(column_info[k][2]) else: # not a multicolumn main cell # rightline = int(cell_info[m][5]) or int(column_info[k][2]) rightline = int(column_info[k][2]) tmp.append('' % (cell_info[m][0],cell_info[m][1],cell_info[m][2],cell_info[m][3],leftline,rightline,cell_info[m][6],cell_info[m][7],cell_info[m][8])) tmp.append('\\begin_inset Text') tmp.append('') tmp.append('\\layout Standard') tmp.append('') if cell_info[m][0] == '2': tmp.append('\\end_inset ') tmp.append('') tmp.append('') continue if l == ncells -1: end = find_tokens(lines, ['\\layout','\\the_end','\\end_deeper','\\end_float'], i) if end == -1: sys.stderr.write("Malformed lyx file\n") else: end = end - i paragraph = [] while end > 0: paragraph.append(lines[i]) del lines[i] end = end -1 tmp.extend(set_paragraph_properties(paragraph, prop_dict)) else: paragraph = [] while lines[i] != '\\newline ': paragraph.append(lines[i]) del lines[i] del lines[i] tmp.extend(set_paragraph_properties(paragraph, prop_dict)) tmp.append('\\end_inset ') tmp.append('') tmp.append('') l = l + 1 tmp.append('') tmp.append('') tmp.append('') tmp.append('\\end_inset ') tmp.append('') tmp.append('') tail = lines[i:] lines[i:] = [] lines.extend(tmp) lines.extend(tail) i = i + len(tmp) prop_exp = re.compile(r"\\(\S*)\s*(\S*)") def set_paragraph_properties(lines, prop_dict): # we need to preserve the order of options properties = ["family","series","shape","size", "emph","bar","noun","latex","color"] prop_value = {"family" : "default", "series" : "medium", "shape" : "up", "size" : "normal", "emph" : "off", "bar" : "no", "noun" : "off", "latex" : "no_latex", "color" : "none"} start = 0 end = 0 i = 0 n = len(lines) #skip empty lines while i