2002-10-20 14:25:16 +00:00
|
|
|
#
|
|
|
|
# Gramps - a GTK+/GNOME based genealogy program
|
|
|
|
#
|
2006-03-11 01:12:06 +00:00
|
|
|
# Copyright (C) 2000-2006 Donald N. Allingham
|
2009-03-19 02:24:29 +00:00
|
|
|
# Copyright (C) 2007-2009 Brian G. Matherly
|
2009-03-04 22:41:45 +00:00
|
|
|
# Copyright (C) 2009 Gary Burton
|
2010-01-13 18:40:55 +00:00
|
|
|
# Copyright (C) 2010 Peter Landgren
|
2002-10-20 14:25:16 +00:00
|
|
|
#
|
|
|
|
# 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
|
|
|
|
#
|
|
|
|
|
2008-02-24 13:55:55 +00:00
|
|
|
# $Id:RTFDoc.py 9912 2008-01-22 09:17:46Z acraphae $
|
2003-12-13 04:05:01 +00:00
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# python modules
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
2010-01-18 04:42:17 +00:00
|
|
|
from gen.ggettext import gettext as _
|
2003-12-13 04:05:01 +00:00
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
2003-08-25 03:11:40 +00:00
|
|
|
# Load the base BaseDoc class
|
2002-10-20 14:25:16 +00:00
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
2009-06-23 20:49:18 +00:00
|
|
|
from gui.utils import open_file_with_default_application
|
2009-05-31 14:59:56 +00:00
|
|
|
from gen.plug.docgen import (BaseDoc, TextDoc, FONT_SERIF, PARA_ALIGN_RIGHT,
|
|
|
|
PARA_ALIGN_CENTER, PARA_ALIGN_JUSTIFY)
|
2002-10-20 14:25:16 +00:00
|
|
|
import ImgManip
|
2003-06-16 04:57:25 +00:00
|
|
|
import Errors
|
2006-06-18 20:58:25 +00:00
|
|
|
import Utils
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# RTF uses a unit called "twips" for its measurements. According to the
|
|
|
|
# RTF specification, 1 point is 20 twips. This routines converts
|
|
|
|
# centimeters to twips
|
|
|
|
#
|
|
|
|
# 2.54 cm/inch 72pts/inch, 20twips/pt
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
def twips(cm):
|
|
|
|
return int(((cm/2.54)*72)+0.5)*20
|
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Rich Text Format Document interface. The current inteface does not
|
|
|
|
# use style sheets. Instead it writes raw formatting.
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
2009-05-29 22:25:44 +00:00
|
|
|
class RTFDoc(BaseDoc,TextDoc):
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Opens the file, and writes the header. Builds the color and font
|
|
|
|
# tables. Fonts are chosen using the MS TrueType fonts, since it
|
|
|
|
# is assumed that if you are generating RTF, you are probably
|
|
|
|
# targeting Word. This generator assumes a Western Europe character
|
|
|
|
# set.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def open(self,filename):
|
|
|
|
if filename[-4:] != ".rtf":
|
|
|
|
self.filename = filename + ".rtf"
|
|
|
|
else:
|
|
|
|
self.filename = filename
|
|
|
|
|
2003-05-16 01:49:50 +00:00
|
|
|
try:
|
|
|
|
self.f = open(self.filename,"w")
|
|
|
|
except IOError,msg:
|
|
|
|
errmsg = "%s\n%s" % (_("Could not create %s") % self.filename, msg)
|
|
|
|
raise Errors.ReportError(errmsg)
|
|
|
|
except:
|
|
|
|
raise Errors.ReportError(_("Could not create %s") % self.filename)
|
2007-04-23 11:46:26 +00:00
|
|
|
|
|
|
|
style_sheet = self.get_style_sheet()
|
2003-05-16 01:49:50 +00:00
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('{\\rtf1\\ansi\\ansicpg1252\\deff0\n')
|
|
|
|
self.f.write('{\\fonttbl\n')
|
|
|
|
self.f.write('{\\f0\\froman\\fcharset0\\fprq0 Times New Roman;}\n')
|
|
|
|
self.f.write('{\\f1\\fswiss\\fcharset0\\fprq0 Arial;}}\n')
|
|
|
|
self.f.write('{\colortbl\n')
|
|
|
|
self.color_map = {}
|
|
|
|
index = 1
|
|
|
|
self.color_map[(0,0,0)] = 0
|
|
|
|
self.f.write('\\red0\\green0\\blue0;')
|
2007-04-23 11:46:26 +00:00
|
|
|
for style_name in style_sheet.get_paragraph_style_names():
|
|
|
|
style = style_sheet.get_paragraph_style(style_name)
|
2002-10-20 14:25:16 +00:00
|
|
|
fgcolor = style.get_font().get_color()
|
|
|
|
bgcolor = style.get_background_color()
|
2008-07-17 18:10:32 +00:00
|
|
|
if fgcolor not in self.color_map:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.color_map[fgcolor] = index
|
|
|
|
self.f.write('\\red%d\\green%d\\blue%d;' % fgcolor)
|
2009-09-10 18:49:48 +00:00
|
|
|
index += 1
|
2008-07-17 18:10:32 +00:00
|
|
|
if bgcolor not in self.color_map:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('\\red%d\\green%d\\blue%d;' % bgcolor)
|
|
|
|
self.color_map[bgcolor] = index
|
2009-09-10 18:49:48 +00:00
|
|
|
index += 1
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('}\n')
|
|
|
|
self.f.write('\\kerning0\\cf0\\viewkind1')
|
2007-02-24 21:15:21 +00:00
|
|
|
self.f.write('\\paperw%d' % twips(self.paper.get_size().get_width()))
|
|
|
|
self.f.write('\\paperh%d' % twips(self.paper.get_size().get_height()))
|
|
|
|
self.f.write('\\margl%d' % twips(self.paper.get_left_margin()))
|
|
|
|
self.f.write('\\margr%d' % twips(self.paper.get_right_margin()))
|
|
|
|
self.f.write('\\margt%d' % twips(self.paper.get_top_margin()))
|
|
|
|
self.f.write('\\margb%d' % twips(self.paper.get_bottom_margin()))
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('\\widowctl\n')
|
2005-01-15 20:24:29 +00:00
|
|
|
self.in_table = 0
|
|
|
|
self.text = ""
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Write the closing brace, and close the file.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def close(self):
|
|
|
|
self.f.write('}\n')
|
|
|
|
self.f.close()
|
|
|
|
|
2009-02-01 04:21:17 +00:00
|
|
|
if self.open_req:
|
2009-06-23 20:49:18 +00:00
|
|
|
open_file_with_default_application(self.filename)
|
2004-01-01 18:17:47 +00:00
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Force a section page break
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def end_page(self):
|
|
|
|
self.f.write('\\sbkpage\n')
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Starts a paragraph. Instead of using a style sheet, generate the
|
|
|
|
# the style for each paragraph on the fly. Not the ideal, but it
|
|
|
|
# does work.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def start_paragraph(self,style_name,leader=None):
|
|
|
|
self.opened = 0
|
2007-04-23 11:46:26 +00:00
|
|
|
style_sheet = self.get_style_sheet()
|
|
|
|
p = style_sheet.get_paragraph_style(style_name)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2005-01-15 20:24:29 +00:00
|
|
|
# build font information
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
f = p.get_font()
|
|
|
|
size = f.get_size()*2
|
|
|
|
bgindex = self.color_map[p.get_background_color()]
|
|
|
|
fgindex = self.color_map[f.get_color()]
|
2009-05-29 22:25:44 +00:00
|
|
|
if f.get_type_face() == FONT_SERIF:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.font_type = '\\f0\\fs%d\\cf%d\\cb%d' % (size,fgindex,bgindex)
|
|
|
|
else:
|
|
|
|
self.font_type = '\\f1\\fs%d\\cf%d\\cb%d' % (size,fgindex,bgindex)
|
|
|
|
if f.get_bold():
|
|
|
|
self.font_type = self.font_type + "\\b"
|
|
|
|
if f.get_underline():
|
|
|
|
self.font_type = self.font_type + "\\ul"
|
|
|
|
if f.get_italic():
|
|
|
|
self.font_type = self.font_type + "\\i"
|
|
|
|
|
2005-01-15 20:24:29 +00:00
|
|
|
# build paragraph information
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2005-01-15 20:24:29 +00:00
|
|
|
if not self.in_table:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('\\pard')
|
2009-05-29 22:25:44 +00:00
|
|
|
if p.get_alignment() == PARA_ALIGN_RIGHT:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('\\qr')
|
2009-05-29 22:25:44 +00:00
|
|
|
elif p.get_alignment() == PARA_ALIGN_CENTER:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('\\qc')
|
|
|
|
self.f.write('\\ri%d' % twips(p.get_right_margin()))
|
|
|
|
self.f.write('\\li%d' % twips(p.get_left_margin()))
|
|
|
|
self.f.write('\\fi%d' % twips(p.get_first_indent()))
|
2009-05-29 22:25:44 +00:00
|
|
|
if p.get_alignment() == PARA_ALIGN_JUSTIFY:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('\\qj')
|
|
|
|
if p.get_padding():
|
|
|
|
self.f.write('\\sa%d' % twips(p.get_padding()/2.0))
|
|
|
|
if p.get_top_border():
|
|
|
|
self.f.write('\\brdrt\\brdrs')
|
|
|
|
if p.get_bottom_border():
|
|
|
|
self.f.write('\\brdrb\\brdrs')
|
|
|
|
if p.get_left_border():
|
|
|
|
self.f.write('\\brdrl\\brdrs')
|
|
|
|
if p.get_right_border():
|
|
|
|
self.f.write('\\brdrr\\brdrs')
|
|
|
|
if p.get_first_indent():
|
|
|
|
self.f.write('\\fi%d' % twips(p.get_first_indent()))
|
|
|
|
if p.get_left_margin():
|
|
|
|
self.f.write('\\li%d' % twips(p.get_left_margin()))
|
|
|
|
if p.get_right_margin():
|
|
|
|
self.f.write('\\ri%d' % twips(p.get_right_margin()))
|
|
|
|
|
|
|
|
if leader:
|
|
|
|
self.opened = 1
|
|
|
|
self.f.write('\\tx%d' % twips(p.get_left_margin()))
|
|
|
|
self.f.write('{%s ' % self.font_type)
|
|
|
|
self.write_text(leader)
|
2009-03-04 22:41:45 +00:00
|
|
|
self.f.write(self.text)
|
|
|
|
self.text = ""
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('\\tab}')
|
|
|
|
self.opened = 0
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Ends a paragraph. Care has to be taken to make sure that the
|
|
|
|
# braces are closed properly. The self.opened flag is used to indicate
|
|
|
|
# if braces are currently open. If the last write was the end of
|
|
|
|
# a bold-faced phrase, braces may already be closed.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def end_paragraph(self):
|
2005-01-15 20:24:29 +00:00
|
|
|
if not self.in_table:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write(self.text)
|
|
|
|
if self.opened:
|
|
|
|
self.f.write('}')
|
|
|
|
self.opened = 0
|
|
|
|
self.f.write('\n\\par')
|
2003-09-27 19:41:39 +00:00
|
|
|
self.text = ""
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
if self.text == "":
|
|
|
|
self.write_text(" ")
|
|
|
|
self.text = self.text + '}'
|
|
|
|
|
2006-09-13 04:33:45 +00:00
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Inserts a manual page break
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def page_break(self):
|
|
|
|
self.f.write('\\page\n')
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Starts boldfaced text, enclosed the braces
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def start_bold(self):
|
|
|
|
if self.opened:
|
|
|
|
self.f.write('}')
|
|
|
|
self.f.write('{%s\\b ' % self.font_type)
|
|
|
|
self.opened = 1
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Ends boldfaced text, closing the braces
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def end_bold(self):
|
|
|
|
self.opened = 0
|
2009-03-04 22:41:45 +00:00
|
|
|
self.f.write(self.text)
|
|
|
|
self.text = ""
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('}')
|
|
|
|
|
2007-01-31 03:13:31 +00:00
|
|
|
def start_superscript(self):
|
|
|
|
self.text = self.text + '{{\*\updnprop5801}\up10 '
|
|
|
|
|
|
|
|
def end_superscript(self):
|
|
|
|
self.text = self.text + '}'
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Start a table. Grab the table style, and store it. Keep a flag to
|
|
|
|
# indicate that we are in a table. This helps us deal with paragraphs
|
|
|
|
# internal to a table. RTF does not require anything to start a
|
|
|
|
# table, since a table is treated as a bunch of rows.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
2008-02-24 13:55:55 +00:00
|
|
|
def start_table(self, name,style_name):
|
2005-01-15 20:24:29 +00:00
|
|
|
self.in_table = 1
|
2007-04-23 11:46:26 +00:00
|
|
|
styles = self.get_style_sheet()
|
|
|
|
self.tbl_style = styles.get_table_style(style_name)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# End a table. Turn off the table flag
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def end_table(self):
|
2005-01-15 20:24:29 +00:00
|
|
|
self.in_table = 0
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# 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
|
|
|
|
# the row. Therefore it is necessary to keep a list of cell contents
|
|
|
|
# that is to be written after all the cells are defined.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def start_row(self):
|
|
|
|
self.contents = []
|
2005-01-15 20:24:29 +00:00
|
|
|
self.cell = 0
|
|
|
|
self.prev = 0
|
|
|
|
self.cell_percent = 0.0
|
|
|
|
self.f.write('\\trowd\n')
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# End a row. Write the cell contents, separated by the \cell marker,
|
|
|
|
# then terminate the row
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def end_row(self):
|
2005-01-15 20:24:29 +00:00
|
|
|
self.f.write('{')
|
|
|
|
for line in self.contents:
|
|
|
|
self.f.write(line)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('\\cell ')
|
2005-01-15 20:24:29 +00:00
|
|
|
self.f.write('}\\pard\\intbl\\row\n')
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# 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
|
|
|
|
# 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
|
|
|
|
# previous cells plus its own width.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def start_cell(self,style_name,span=1):
|
2007-04-23 11:46:26 +00:00
|
|
|
styles = self.get_style_sheet()
|
|
|
|
s = styles.get_cell_style(style_name)
|
2005-01-15 20:24:29 +00:00
|
|
|
self.remain = span -1
|
|
|
|
if s.get_top_border():
|
|
|
|
self.f.write('\\clbrdrt\\brdrs\\brdrw10\n')
|
|
|
|
if s.get_bottom_border():
|
|
|
|
self.f.write('\\clbrdrb\\brdrs\\brdrw10\n')
|
|
|
|
if s.get_left_border():
|
|
|
|
self.f.write('\\clbrdrl\\brdrs\\brdrw10\n')
|
|
|
|
if s.get_right_border():
|
|
|
|
self.f.write('\\clbrdrr\\brdrs\\brdrw10\n')
|
2007-04-30 01:56:34 +00:00
|
|
|
table_width = float(self.paper.get_usable_width())
|
2005-01-15 20:24:29 +00:00
|
|
|
for cell in range(self.cell,self.cell+span):
|
|
|
|
self.cell_percent = self.cell_percent + float(self.tbl_style.get_column_width(cell))
|
|
|
|
cell_width = twips((table_width * self.cell_percent)/100.0)
|
|
|
|
self.f.write('\\cellx%d\\pard\intbl\n' % cell_width)
|
|
|
|
self.cell = self.cell+1
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# End a cell. Save the current text in the content lists, since data
|
|
|
|
# must be saved until all cells are defined.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def end_cell(self):
|
|
|
|
self.contents.append(self.text)
|
|
|
|
self.text = ""
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Add a photo. Embed the photo in the document. Use the Python
|
|
|
|
# imaging library to load and scale the photo. The image is converted
|
|
|
|
# to JPEG, since it is smaller, and supported by RTF. The data is
|
|
|
|
# dumped as a string of HEX numbers.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
2009-06-08 23:19:37 +00:00
|
|
|
def add_media_object(self, name, pos, x_cm, y_cm, alt=''):
|
2007-09-11 03:51:35 +00:00
|
|
|
|
2008-02-24 13:55:55 +00:00
|
|
|
nx, ny = ImgManip.image_size(name)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2008-02-24 13:55:55 +00:00
|
|
|
if (nx, ny) == (0,0):
|
2006-05-01 21:11:26 +00:00
|
|
|
return
|
|
|
|
|
2008-02-24 13:55:55 +00:00
|
|
|
if (nx, ny) == (0,0):
|
2006-04-08 01:59:33 +00:00
|
|
|
return
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
ratio = float(x_cm)*float(ny)/(float(y_cm)*float(nx))
|
|
|
|
|
|
|
|
if ratio < 1:
|
|
|
|
act_width = x_cm
|
|
|
|
act_height = y_cm*ratio
|
|
|
|
else:
|
|
|
|
act_height = y_cm
|
|
|
|
act_width = x_cm/ratio
|
|
|
|
|
2007-09-11 03:51:35 +00:00
|
|
|
buf = ImgManip.resize_to_jpeg_buffer(name, int(act_width*40),
|
|
|
|
int(act_height*40))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
act_width = twips(act_width)
|
|
|
|
act_height = twips(act_height)
|
|
|
|
|
2005-01-15 20:24:29 +00:00
|
|
|
self.f.write('{\*\shppict{\\pict\\jpegblip')
|
2002-10-20 14:25:16 +00:00
|
|
|
self.f.write('\\picwgoal%d\\pichgoal%d\n' % (act_width,act_height))
|
2005-01-15 20:24:29 +00:00
|
|
|
index = 1
|
|
|
|
for i in buf:
|
|
|
|
self.f.write('%02x' % ord(i))
|
|
|
|
if index%32==0:
|
|
|
|
self.f.write('\n')
|
|
|
|
index = index+1
|
|
|
|
self.f.write('}}\\par\n')
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2010-01-13 18:40:55 +00:00
|
|
|
def write_styled_note(self,styledtext,format,style_name):
|
|
|
|
text = str(styledtext)
|
2010-01-19 12:47:48 +00:00
|
|
|
if format:
|
2010-01-13 18:40:55 +00:00
|
|
|
# Preformatted note
|
2003-12-13 04:05:01 +00:00
|
|
|
for line in text.split('\n'):
|
|
|
|
self.start_paragraph(style_name)
|
|
|
|
self.write_text(line)
|
2010-01-13 18:40:55 +00:00
|
|
|
if self.in_table:
|
2010-01-19 12:47:48 +00:00
|
|
|
# # Add LF when in table as in indiv_complete report
|
2010-01-13 18:40:55 +00:00
|
|
|
self.write_text('\n')
|
2003-12-13 04:05:01 +00:00
|
|
|
self.end_paragraph()
|
2010-01-19 12:47:48 +00:00
|
|
|
else:
|
|
|
|
firstline = True
|
2003-12-13 04:05:01 +00:00
|
|
|
for line in text.split('\n\n'):
|
|
|
|
self.start_paragraph(style_name)
|
2010-01-19 12:47:48 +00:00
|
|
|
if len(line) > 0:
|
|
|
|
# Remember first char, can be a LF.
|
|
|
|
firstchar = line[0]
|
|
|
|
# Replace all LF's with space and reformat.
|
|
|
|
line = line.replace('\n',' ')
|
|
|
|
line = ' '.join(line.split())
|
|
|
|
# If rememberd first char is LF, insert in front of lines
|
|
|
|
#This takes care of the case with even number of empry lines.
|
|
|
|
if firstchar == '\n':
|
|
|
|
line = firstchar + line
|
|
|
|
#Insert LF's if not first line.
|
|
|
|
if not firstline:
|
|
|
|
line = '\n\n' + line
|
|
|
|
else:
|
|
|
|
# If odd number of empty lines line will be empty.
|
|
|
|
line = '\n\n'
|
2003-12-13 04:05:01 +00:00
|
|
|
self.write_text(line)
|
|
|
|
self.end_paragraph()
|
2010-01-19 12:47:48 +00:00
|
|
|
firstline = False
|
|
|
|
self.start_paragraph(style_name)
|
|
|
|
self.write_text('\n')
|
|
|
|
self.end_paragraph()
|
|
|
|
print
|
2010-01-13 18:40:55 +00:00
|
|
|
|
|
|
|
def write_endnotes_ref(self,text,style_name):
|
|
|
|
"""
|
|
|
|
Overwrite base method for lines of endnotes references
|
|
|
|
"""
|
|
|
|
for line in text.split('\n'):
|
|
|
|
self.start_paragraph(style_name)
|
|
|
|
self.write_text(line)
|
|
|
|
if self.in_table:
|
|
|
|
# Add LF when in table as in indiv_complete report
|
|
|
|
self.write_text('\n')
|
|
|
|
self.end_paragraph()
|
2010-01-19 12:47:48 +00:00
|
|
|
# Write an empty para after all ref lines for each source
|
2010-01-13 18:40:55 +00:00
|
|
|
self.start_paragraph(style_name)
|
|
|
|
self.end_paragraph()
|
2003-12-13 04:05:01 +00:00
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Writes text. If braces are not currently open, open them. Loop
|
|
|
|
# character by character (terribly inefficient, but it works). If a
|
|
|
|
# character is 8 bit (>127), convert it to a hex representation in
|
|
|
|
# the form of \`XX. Make sure to escape braces.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
2006-06-03 03:32:26 +00:00
|
|
|
def write_text(self,text,mark=None):
|
2008-10-21 20:05:11 +00:00
|
|
|
# Convert to unicode, just in case it's not. Fix of bug 2449.
|
|
|
|
text = unicode(text)
|
2007-01-25 04:29:39 +00:00
|
|
|
text = text.replace('\n','\n\\par ')
|
2002-10-20 14:25:16 +00:00
|
|
|
if self.opened == 0:
|
|
|
|
self.opened = 1
|
|
|
|
self.text = self.text + '{%s ' % self.font_type
|
2003-06-14 03:49:09 +00:00
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
for i in text:
|
|
|
|
if ord(i) > 127:
|
|
|
|
self.text = self.text + '\\\'%2x' % ord(i)
|
|
|
|
elif i == '{' or i == '}' :
|
|
|
|
self.text = self.text + '\\%s' % i
|
|
|
|
else:
|
|
|
|
self.text = self.text + i
|