Revert "10000: report tables are always written LTR even for RTL locales"

This reverts commit 55fa9206288d50cf4bca3673e1d68a033b02c3ea.
This commit is contained in:
Paul Franklin 2017-04-30 12:31:42 -07:00
parent 55fa920628
commit 2b6cc3cd18
9 changed files with 34 additions and 101 deletions

View File

@ -6,7 +6,6 @@
# Copyright (C) 2007 Brian G. Matherly # Copyright (C) 2007 Brian G. Matherly
# Copyright (C) 2009 Benny Malengier # Copyright (C) 2009 Benny Malengier
# Copyright (C) 2009 Gary Burton # Copyright (C) 2009 Gary Burton
# Copyright (C) 2017 Paul Franklin
# #
# This program is free software; you can redistribute it and/or modify # 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 # it under the terms of the GNU General Public License as published by
@ -79,13 +78,6 @@ class BaseDoc(metaclass=ABCMeta):
self._creator = "" self._creator = ""
self.init_called = False self.init_called = False
self.uistate = uistate self.uistate = uistate
self._rtl_doc = False # does the document have right-to-left text?
def set_rtl_doc(self, value):
self._rtl_doc = value
def get_rtl_doc(self):
return self._rtl_doc
def init(self): def init(self):
self.init_called = True self.init_called = True

View File

@ -79,7 +79,6 @@ class Report:
self._get_date = locale.get_date self._get_date = locale.get_date
self._get_type = locale.get_type self._get_type = locale.get_type
self._ldd = locale.date_displayer self._ldd = locale.date_displayer
self.doc.set_rtl_doc(locale.rtl_locale)
self._name_display = NameDisplay(locale) # a legacy/historical name self._name_display = NameDisplay(locale) # a legacy/historical name
self._name_display.set_name_format(self.database.name_formats) self._name_display.set_name_format(self.database.name_formats)
fmt_default = config.get('preferences.name-format') fmt_default = config.get('preferences.name-format')

View File

@ -112,9 +112,6 @@ _LOCALE_NAMES = {
'zh_TW': ('Chinese_Taiwan', '950', _("Chinese (Traditional)")), 'zh_TW': ('Chinese_Taiwan', '950', _("Chinese (Traditional)")),
} }
# locales with right-to-left text
_RTL_LOCALES = ('ar', 'he')
# locales with less than 70% currently translated # locales with less than 70% currently translated
INCOMPLETE_TRANSLATIONS = ('ar', 'bg', 'he', 'ja', 'sq', 'ta', 'tr') INCOMPLETE_TRANSLATIONS = ('ar', 'bg', 'he', 'ja', 'sq', 'ta', 'tr')
@ -529,10 +526,6 @@ class GrampsLocale:
self._win_bindtextdomain(self.localedomain.encode('utf-8'), self._win_bindtextdomain(self.localedomain.encode('utf-8'),
self.localedir.encode('utf-8')) self.localedir.encode('utf-8'))
self.rtl_locale = False
if self.language[0] in _RTL_LOCALES:
self.rtl_locale = True # right-to-left
def _init_secondary_locale(self): def _init_secondary_locale(self):
""" """
Init a secondary locale. Secondary locales are used to provide Init a secondary locale. Secondary locales are used to provide
@ -567,9 +560,6 @@ class GrampsLocale:
self.numeric = self.currency = self.calendar = self.collation = self.lang self.numeric = self.currency = self.calendar = self.collation = self.lang
self.rtl_locale = False
if self.language[0] in _RTL_LOCALES:
self.rtl_locale = True # right-to-left
def __init__(self, localedir=None, lang=None, domain=None, languages=None): def __init__(self, localedir=None, lang=None, domain=None, languages=None):
""" """

View File

@ -6,7 +6,7 @@
# Copyright (C) 2009-2010 Benny Malengier <benny.malengier@gramps-project.org> # Copyright (C) 2009-2010 Benny Malengier <benny.malengier@gramps-project.org>
# Copyright (C) 2010 Peter Landgren # Copyright (C) 2010 Peter Landgren
# Copyright (C) 2011 Adam Stein <adam@csh.rit.edu> # Copyright (C) 2011 Adam Stein <adam@csh.rit.edu>
# Copyright (C) 2012,2017 Paul Franklin # Copyright (C) 2012 Paul Franklin
# #
# This program is free software; you can redistribute it and/or modify # 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 # it under the terms of the GNU General Public License as published by
@ -153,7 +153,6 @@ class AsciiDoc(BaseDoc, TextDoc):
self.tbl_style = None self.tbl_style = None
self.in_cell = None self.in_cell = None
self.ncols = 0 self.ncols = 0
self.column_order = []
self.cellpars = [] self.cellpars = []
self.cell_lines = [] self.cell_lines = []
self.cell_widths = [] self.cell_widths = []
@ -310,11 +309,6 @@ class AsciiDoc(BaseDoc, TextDoc):
styles = self.get_style_sheet() styles = self.get_style_sheet()
self.tbl_style = styles.get_table_style(style_name) self.tbl_style = styles.get_table_style(style_name)
self.ncols = self.tbl_style.get_columns() self.ncols = self.tbl_style.get_columns()
self.column_order = []
for cell in range(self.ncols):
self.column_order.append(cell)
if self.get_rtl_doc():
self.column_order.reverse()
#-------------------------------------------------------------------- #--------------------------------------------------------------------
# #
@ -339,7 +333,7 @@ class AsciiDoc(BaseDoc, TextDoc):
self.maxlines = 0 self.maxlines = 0
table_width = (self.get_usable_width() * table_width = (self.get_usable_width() *
self.tbl_style.get_width() / 100.0) self.tbl_style.get_width() / 100.0)
for cell in self.column_order: for cell in range(self.ncols):
self.cell_widths[cell] = int( self.cell_widths[cell] = int(
table_width * self.tbl_style.get_column_width(cell) / 100.0) table_width * self.tbl_style.get_column_width(cell) / 100.0)
@ -352,7 +346,7 @@ class AsciiDoc(BaseDoc, TextDoc):
def end_row(self): def end_row(self):
self.in_cell = 0 self.in_cell = 0
cell_text = [None]*self.ncols cell_text = [None]*self.ncols
for cell in self.column_order: for cell in range(self.ncols):
if self.cell_widths[cell]: if self.cell_widths[cell]:
blanks = ' '*self.cell_widths[cell] + '\n' blanks = ' '*self.cell_widths[cell] + '\n'
if self.cell_lines[cell] < self.maxlines: if self.cell_lines[cell] < self.maxlines:
@ -361,7 +355,7 @@ class AsciiDoc(BaseDoc, TextDoc):
) )
cell_text[cell] = self.cellpars[cell].split('\n') cell_text[cell] = self.cellpars[cell].split('\n')
for line in range(self.maxlines): for line in range(self.maxlines):
for cell in self.column_order: for cell in range(self.ncols):
if self.cell_widths[cell]: if self.cell_widths[cell]:
self.file.write(cell_text[cell][line]) self.file.write(cell_text[cell][line])
self.file.write('\n') self.file.write('\n')

View File

@ -67,7 +67,7 @@ _CLICKABLE = '\\url{\\1}'
# #
#------------------------------------------------------------------------ #------------------------------------------------------------------------
# For an interim mark e.g. for an intended linebreak I use a special pattern. # For an interim mark e.g. for an intended linebreak I use a special pattern.
# It shouldn't interfere with normal text. In LaTeX character '&' is used # It shouldn't interfere with normal text. In LaTeX charackter '&' is used
# for column separation in tables and may occur there in series. The pattern # for column separation in tables and may occur there in series. The pattern
# is used here before column separation is set. On the other hand incoming # is used here before column separation is set. On the other hand incoming
# text can't show this pattern for it would have been replaced by '\&\&'. # text can't show this pattern for it would have been replaced by '\&\&'.
@ -703,6 +703,7 @@ class LaTeXDoc(BaseDoc, TextDoc):
if self.in_multrow_cell: # cols of rows: convert to rows of cols if self.in_multrow_cell: # cols of rows: convert to rows of cols
self.repack_row() self.repack_row()
else: else:
self.tabmem = TabMem(text)
self.tabmem.rows.append(self.tabrow) self.tabmem.rows.append(self.tabrow)
elif tab_state == TAB_BEG: # text: \\begin{longtable}[l]{ elif tab_state == TAB_BEG: # text: \\begin{longtable}[l]{
self._backend.write(''.join(('\\grinittab{\\textwidth}{', self._backend.write(''.join(('\\grinittab{\\textwidth}{',
@ -769,6 +770,8 @@ class LaTeXDoc(BaseDoc, TextDoc):
self.tabmem.rows[-1].addit = self.tabrow.addit self.tabmem.rows[-1].addit = self.tabrow.addit
self.in_multrow_cell = False self.in_multrow_cell = False
return
def calc_latex_widths(self): def calc_latex_widths(self):
""" """
@ -951,7 +954,7 @@ class LaTeXDoc(BaseDoc, TextDoc):
self._backend.open() self._backend.open()
# Font size control seems to be limited. For now, ignore # Font size control seems to be limited. For now, ignore
# any style constraints, and use 12pt as the default # any style constraints, and use 12pt has the default
options = "12pt" options = "12pt"
@ -1023,6 +1026,7 @@ class LaTeXDoc(BaseDoc, TextDoc):
thisstyle.first_line_indent = first thisstyle.first_line_indent = first
self.latexstyle[style_name] = thisstyle self.latexstyle[style_name] = thisstyle
def close(self): def close(self):
"""Clean up and close the document""" """Clean up and close the document"""
if self.in_list: if self.in_list:
@ -1128,11 +1132,6 @@ class LaTeXDoc(BaseDoc, TextDoc):
styles = self.get_style_sheet() styles = self.get_style_sheet()
self.tblstyle = styles.get_table_style(style_name) self.tblstyle = styles.get_table_style(style_name)
self.numcols = self.tblstyle.get_columns() self.numcols = self.tblstyle.get_columns()
self.column_order = []
for cell in range(self.numcols):
self.column_order.append(cell)
if self.get_rtl_doc():
self.column_order.reverse()
tblfmt = '*{%d}{l}' % self.numcols tblfmt = '*{%d}{l}' % self.numcols
self.emit('\\begin{longtable}[l]{%s}\n' % (tblfmt), TAB_BEG) self.emit('\\begin{longtable}[l]{%s}\n' % (tblfmt), TAB_BEG)
@ -1149,7 +1148,7 @@ class LaTeXDoc(BaseDoc, TextDoc):
self.doline = False self.doline = False
self.skipfirst = False self.skipfirst = False
self.curcol = 0 self.curcol = 0
self.currow += 1 self.currow = self.currow + 1
def end_row(self): def end_row(self):
"""End the row (new line)""" """End the row (new line)"""
@ -1169,7 +1168,7 @@ class LaTeXDoc(BaseDoc, TextDoc):
We always place our data inside braces We always place our data inside braces
for safety of formatting.""" for safety of formatting."""
self.colspan = span self.colspan = span
self.curcol += self.colspan self.curcol = self.curcol + self.colspan
styles = self.get_style_sheet() styles = self.get_style_sheet()
self.cstyle = styles.get_cell_style(style_name) self.cstyle = styles.get_cell_style(style_name)
@ -1209,10 +1208,12 @@ class LaTeXDoc(BaseDoc, TextDoc):
self.emit('\\multicolumn{%d}{%s}' % (span, cellfmt), CELL_BEG, span) self.emit('\\multicolumn{%d}{%s}' % (span, cellfmt), CELL_BEG, span)
def end_cell(self): def end_cell(self):
"""Prepares for next cell""" """Prepares for next cell"""
self.emit('', CELL_END) self.emit('', CELL_END)
def add_media(self, infile, pos, x, y, alt='', style_name=None, crop=None): def add_media(self, infile, pos, x, y, alt='', style_name=None, crop=None):
"""Add photo to report""" """Add photo to report"""
outfile = os.path.splitext(infile)[0] outfile = os.path.splitext(infile)[0]

View File

@ -7,7 +7,7 @@
# Copyright (C) 2010 Peter Landgren # Copyright (C) 2010 Peter Landgren
# Copyright (C) 2010 Jakim Friant # Copyright (C) 2010 Jakim Friant
# Copyright (C) 2011 Adam Stein <adam@csh.rit.edu> # Copyright (C) 2011 Adam Stein <adam@csh.rit.edu>
# Copyright (C) 2012,2017 Paul Franklin # Copyright (C) 2012 Paul Franklin
# #
# This program is free software; you can redistribute it and/or modify # 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 # it under the terms of the GNU General Public License as published by
@ -424,8 +424,6 @@ class ODFDoc(BaseDoc, TextDoc, DrawDoc):
self.filename = None self.filename = None
self.lang = None self.lang = None
self._backend = None self._backend = None
self.column_order = None
self.row_cells = None
self.span = 0 self.span = 0
self.level = 0 self.level = 0
self.time = "0000-00-00T00:00:00" self.time = "0000-00-00T00:00:00"
@ -1048,12 +1046,7 @@ class ODFDoc(BaseDoc, TextDoc, DrawDoc):
styles = self.get_style_sheet() styles = self.get_style_sheet()
table = styles.get_table_style(style_name) table = styles.get_table_style(style_name)
self.column_order = [] for col in range(table.get_columns()):
for cell in range(table.get_columns()):
self.column_order.append(cell)
if self.get_rtl_doc():
self.column_order.reverse()
for col in self.column_order:
self.cntnt.write( self.cntnt.write(
'<table:table-column table:style-name="%s.%s"/>\n' '<table:table-column table:style-name="%s.%s"/>\n'
% (style_name, str(chr(ord('A')+col))) % (style_name, str(chr(ord('A')+col)))
@ -1070,25 +1063,17 @@ class ODFDoc(BaseDoc, TextDoc, DrawDoc):
open a row open a row
""" """
self.cntnt.write('<table:table-row>\n') self.cntnt.write('<table:table-row>\n')
self.row_cells = []
self.cntnt_saved = self.cntnt # save the content up to now
def end_row(self): def end_row(self):
""" """
close a row close a row
""" """
self.cntnt = self.cntnt_saved # restore the original contents
if self.get_rtl_doc():
self.row_cells.reverse()
for cell in self.row_cells:
self.cntnt.write(cell)
self.cntnt.write('</table:table-row>\n') self.cntnt.write('</table:table-row>\n')
def start_cell(self, style_name, span=1): def start_cell(self, style_name, span=1):
""" """
open a cell open a cell
""" """
self.cntnt = StringIO() # start a new buffer (with the expected name)
self.span = span self.span = span
self.cntnt.write( self.cntnt.write(
'<table:table-cell table:style-name="%s" ' % style_name + '<table:table-cell table:style-name="%s" ' % style_name +
@ -1108,7 +1093,6 @@ class ODFDoc(BaseDoc, TextDoc, DrawDoc):
#for col in range(1, self.span): #for col in range(1, self.span):
# self.cntnt.write('<table:covered-table-cell/>\n') # self.cntnt.write('<table:covered-table-cell/>\n')
self.new_cell = 0 self.new_cell = 0
self.row_cells.append(self.cntnt.getvalue()) # save the cell, for now
def start_bold(self): def start_bold(self):
""" """

View File

@ -6,7 +6,6 @@
# Copyright (C) 2009 Gary Burton # Copyright (C) 2009 Gary Burton
# Copyright (C) 2010 Peter Landgren # Copyright (C) 2010 Peter Landgren
# Copyright (C) 2011 Adam Stein <adam@csh.rit.edu> # Copyright (C) 2011 Adam Stein <adam@csh.rit.edu>
# Copyright (C) 2017 Paul Franklin
# #
# This program is free software; you can redistribute it and/or modify # 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 # it under the terms of the GNU General Public License as published by
@ -134,7 +133,6 @@ class RTFDoc(BaseDoc, TextDoc):
) )
self.in_table = 0 self.in_table = 0
self.text = "" self.text = ""
self.p_wide = float(self.paper.get_usable_width())
#-------------------------------------------------------------------- #--------------------------------------------------------------------
# #
@ -155,7 +153,7 @@ class RTFDoc(BaseDoc, TextDoc):
#-------------------------------------------------------------------- #--------------------------------------------------------------------
# #
# Starts a paragraph. Instead of using a style sheet, generate # Starts a paragraph. Instead of using a style sheet, generate the
# the style for each paragraph on the fly. Not the ideal, but it # the style for each paragraph on the fly. Not the ideal, but it
# does work. # does work.
# #
@ -315,20 +313,7 @@ class RTFDoc(BaseDoc, TextDoc):
def start_table(self, name, style_name): def start_table(self, name, style_name):
self.in_table = 1 self.in_table = 1
styles = self.get_style_sheet() styles = self.get_style_sheet()
table_style = styles.get_table_style(style_name) self.tbl_style = styles.get_table_style(style_name)
self._cells = []
if self.get_rtl_doc():
cell_percent = 100.0
else:
cell_percent = 0.0
for cell in range(table_style.get_columns()):
if self.get_rtl_doc():
cell_percent -= float(table_style.get_column_width(cell))
else:
cell_percent += float(table_style.get_column_width(cell))
self._cells.append(twips((self.p_wide * cell_percent) / 100.0))
if self._cells[-1:] == [0]:
self._cells[-1:] = [twips(self.p_wide)] # left edge => right edge
#-------------------------------------------------------------------- #--------------------------------------------------------------------
# #
@ -343,32 +328,24 @@ class RTFDoc(BaseDoc, TextDoc):
# Start a row. RTF uses the \trowd to start a row. RTF also specifies # Start a row. RTF uses the \trowd to start a row. RTF also specifies
# all the cell data after it has specified the cell definitions for # all the cell data after it has specified the cell definitions for
# the row. Therefore it is necessary to keep a list of cell contents # the row. Therefore it is necessary to keep a list of cell contents
# that is to be written after all the cells are defined. It is also # that is to be written after all the cells are defined.
# necessary to keep a list of the row columns definitions, since for
# RTL columns the columns which are processed last (in LTR) come first,
# and we don't know which will be skipped with a non-one "span" argument
# until we process them
# #
#-------------------------------------------------------------------- #--------------------------------------------------------------------
def start_row(self): def start_row(self):
self.contents = [] self.contents = []
self.columns = []
self.cell = 0 self.cell = 0
self.prev = 0
self.cell_percent = 0.0
self.text = "" self.text = ""
self.file.write('\\trowd\n') self.file.write('\\trowd\n')
#-------------------------------------------------------------------- #--------------------------------------------------------------------
# #
# End a row. Write the cell contents, separated by the \cell marker, # End a row. Write the cell contents, separated by the \cell marker,
# then terminate the row with a \row marker # then terminate the row
# #
#-------------------------------------------------------------------- #--------------------------------------------------------------------
def end_row(self): def end_row(self):
for column in sorted(self.columns):
for line in column[1]:
self.file.write(line)
if self.get_rtl_doc():
self.contents.reverse()
self.file.write('{') self.file.write('{')
for line in self.contents: for line in self.contents:
self.file.write(line) self.file.write(line)
@ -379,26 +356,29 @@ class RTFDoc(BaseDoc, TextDoc):
# #
# Start a cell. Dump out the cell specifics, such as borders. Cell # Start a cell. Dump out the cell specifics, such as borders. Cell
# widths are kind of interesting. RTF doesn't specify how wide a cell # widths are kind of interesting. RTF doesn't specify how wide a cell
# is, but rather where its right edge is in relationship to the # is, but rather where it's right edge is in relationship to the
# left margin. This means that each cell is the cumlative of the # left margin. This means that each cell is the cumlative of the
# previous cells plus its own width. # previous cells plus its own width.
# #
#-------------------------------------------------------------------- #--------------------------------------------------------------------
def start_cell(self, style_name, span=1): def start_cell(self, style_name, span=1):
cell_data = []
styles = self.get_style_sheet() styles = self.get_style_sheet()
s = styles.get_cell_style(style_name) s = styles.get_cell_style(style_name)
self.remain = span -1
if s.get_top_border(): if s.get_top_border():
cell_data.append('\\clbrdrt\\brdrs\\brdrw10\n') self.file.write('\\clbrdrt\\brdrs\\brdrw10\n')
if s.get_bottom_border(): if s.get_bottom_border():
cell_data.append('\\clbrdrb\\brdrs\\brdrw10\n') self.file.write('\\clbrdrb\\brdrs\\brdrw10\n')
if s.get_left_border(): if s.get_left_border():
cell_data.append('\\clbrdrl\\brdrs\\brdrw10\n') self.file.write('\\clbrdrl\\brdrs\\brdrw10\n')
if s.get_right_border(): if s.get_right_border():
cell_data.append('\\clbrdrr\\brdrs\\brdrw10\n') self.file.write('\\clbrdrr\\brdrs\\brdrw10\n')
table_width = float(self.paper.get_usable_width())
for cell in range(self.cell, self.cell+span):
self.cell_percent += float(self.tbl_style.get_column_width(cell))
cell_width = twips((table_width * self.cell_percent)/100.0)
self.need_nl = False self.need_nl = False
cell_data.append('\\cellx%d\n' % self._cells[self.cell + span - 1]) self.file.write('\\cellx%d\n' % cell_width)
self.columns.append([self._cells[self.cell + span - 1], cell_data])
self.cell += 1 self.cell += 1
#-------------------------------------------------------------------- #--------------------------------------------------------------------

View File

@ -7,7 +7,7 @@
# Copyright (C) 2009 Brian Matherly # Copyright (C) 2009 Brian Matherly
# Copyright (C) 2010 Peter Landgren # Copyright (C) 2010 Peter Landgren
# Copyright (C) 2010 Jakim Friant # Copyright (C) 2010 Jakim Friant
# Copyright (C) 2011-2017 Paul Franklin # Copyright (C) 2011-2012 Paul Franklin
# Copyright (C) 2012 Craig Anderson # Copyright (C) 2012 Craig Anderson
# #
# This program is free software; you can redistribute it and/or modify # This program is free software; you can redistribute it and/or modify
@ -1450,8 +1450,6 @@ class CairoDoc(BaseDoc, TextDoc, DrawDoc):
# this is an ugly hack, but got no better idea. # this is an ugly hack, but got no better idea.
self._active_row_style = list(map(style.get_column_width, self._active_row_style = list(map(style.get_column_width,
list(range(style.get_columns())))) list(range(style.get_columns()))))
if self.get_rtl_doc():
self._active_row_style.reverse()
def end_table(self): def end_table(self):
self._active_element = self._active_element.get_parent() self._active_element = self._active_element.get_parent()
@ -1462,8 +1460,6 @@ class CairoDoc(BaseDoc, TextDoc, DrawDoc):
self._active_element = new_row self._active_element = new_row
def end_row(self): def end_row(self):
if self.get_rtl_doc():
self._active_element._children.reverse()
self._active_element = self._active_element.get_parent() self._active_element = self._active_element.get_parent()
def start_cell(self, style_name, span=1): def start_cell(self, style_name, span=1):

View File

@ -919,14 +919,12 @@ class FamilyGroupOptions(MenuReportOptions):
cell.set_padding(0.1) cell.set_padding(0.1)
cell.set_bottom_border(1) cell.set_bottom_border(1)
cell.set_left_border(1) cell.set_left_border(1)
cell.set_right_border(1) # for RTL
default_style.add_cell_style('FGR-TextContents', cell) default_style.add_cell_style('FGR-TextContents', cell)
cell = TableCellStyle() cell = TableCellStyle()
cell.set_padding(0.1) cell.set_padding(0.1)
cell.set_bottom_border(0) cell.set_bottom_border(0)
cell.set_left_border(1) cell.set_left_border(1)
cell.set_right_border(1) # for RTL
cell.set_padding(0.1) cell.set_padding(0.1)
default_style.add_cell_style('FGR-TextChild1', cell) default_style.add_cell_style('FGR-TextChild1', cell)
@ -934,7 +932,6 @@ class FamilyGroupOptions(MenuReportOptions):
cell.set_padding(0.1) cell.set_padding(0.1)
cell.set_bottom_border(1) cell.set_bottom_border(1)
cell.set_left_border(1) cell.set_left_border(1)
cell.set_right_border(1) # for RTL
cell.set_padding(0.1) cell.set_padding(0.1)
default_style.add_cell_style('FGR-TextChild2', cell) default_style.add_cell_style('FGR-TextChild2', cell)