2004-02-29 00:04:45 +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
|
2010-09-23 21:03:15 +00:00
|
|
|
# Copyright (C) 2009-2010 Benny Malengier <benny.malengier@gramps-project.org>
|
2010-01-13 18:40:55 +00:00
|
|
|
# Copyright (C) 2010 Peter Landgren
|
2004-02-29 00:04:45 +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:AsciiDoc.py 9912 2008-01-22 09:17:46Z acraphae $
|
2004-02-29 00:04:45 +00:00
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# python modules
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
2010-01-18 04:42:17 +00:00
|
|
|
from gen.ggettext import gettext as _
|
2004-02-29 00:04:45 +00:00
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
2005-02-19 00:49:49 +00:00
|
|
|
# Gramps modules
|
2004-02-29 00:04:45 +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,\
|
|
|
|
PARA_ALIGN_RIGHT, PARA_ALIGN_CENTER
|
2004-02-29 00:04:45 +00:00
|
|
|
import Errors
|
2006-06-18 20:58:25 +00:00
|
|
|
import Utils
|
|
|
|
|
2005-12-06 06:38:09 +00:00
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Constants
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
2004-02-29 00:04:45 +00:00
|
|
|
LEFT,RIGHT,CENTER = 'LEFT','RIGHT','CENTER'
|
|
|
|
_WIDTH_IN_CHARS = 72
|
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# This routine was written by David Mertz and placed into the public
|
|
|
|
# domain. It is sample code from his book, "Text Processing in Python"
|
|
|
|
#
|
|
|
|
# Modified by Alex Roitman: right-pad with spaces, if right_pad==1;
|
|
|
|
# return empty string if no text was given
|
2005-12-06 06:38:09 +00:00
|
|
|
# Another argument: "first" is the first line indent in characters
|
|
|
|
# _relative_ to the "left" margin. It can be negative!
|
2004-02-29 00:04:45 +00:00
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
2005-12-06 06:38:09 +00:00
|
|
|
def reformat_para(para='',left=0,right=72,just=LEFT,right_pad=0,first=0):
|
2004-12-21 17:04:52 +00:00
|
|
|
if not para.strip():
|
2004-02-29 00:04:45 +00:00
|
|
|
return "\n"
|
2010-09-23 21:03:15 +00:00
|
|
|
|
2004-02-29 00:04:45 +00:00
|
|
|
lines = []
|
2005-12-06 06:38:09 +00:00
|
|
|
real_left = left+first
|
2010-09-23 21:03:15 +00:00
|
|
|
alllines = para.split('\n')
|
|
|
|
for realline in alllines:
|
|
|
|
words = realline.split()
|
|
|
|
line = ''
|
|
|
|
word = 0
|
|
|
|
end_words = 0
|
|
|
|
while not end_words:
|
|
|
|
if not words:
|
|
|
|
lines.append("\n")
|
|
|
|
break
|
|
|
|
if len(words[word]) > right-real_left: # Handle very long words
|
|
|
|
line = words[word]
|
|
|
|
word +=1
|
2004-02-29 00:04:45 +00:00
|
|
|
if word >= len(words):
|
|
|
|
end_words = 1
|
2010-09-23 21:03:15 +00:00
|
|
|
else: # Compose line of words
|
|
|
|
while len(line)+len(words[word]) <= right-real_left:
|
|
|
|
line += words[word]+' '
|
|
|
|
word += 1
|
|
|
|
if word >= len(words):
|
|
|
|
end_words = 1
|
|
|
|
break
|
|
|
|
lines.append(line)
|
|
|
|
#first line finished, discard first
|
|
|
|
real_left = left
|
|
|
|
line = ''
|
2004-02-29 00:04:45 +00:00
|
|
|
if just==CENTER:
|
|
|
|
if right_pad:
|
2005-12-06 06:38:09 +00:00
|
|
|
return '\n'.join(
|
|
|
|
[' '*(left+first) + ln.center(right-left-first)
|
|
|
|
for ln in lines[0:1] ] +
|
|
|
|
[ ' '*left + ln.center(right-left) for ln in lines[1:] ]
|
|
|
|
)
|
2004-02-29 00:04:45 +00:00
|
|
|
else:
|
2005-12-06 06:38:09 +00:00
|
|
|
return '\n'.join(
|
|
|
|
[' '*(left+first) + ln.center(right-left-first).rstrip()
|
|
|
|
for ln in lines[0:1] ] +
|
|
|
|
[' '*left + ln.center(right-left).rstrip()
|
|
|
|
for ln in lines[1:] ]
|
|
|
|
)
|
2004-02-29 00:04:45 +00:00
|
|
|
elif just==RIGHT:
|
|
|
|
if right_pad:
|
|
|
|
return '\n'.join([line.rjust(right) for line in lines])
|
|
|
|
else:
|
|
|
|
return '\n'.join([line.rjust(right).rstrip() for line in lines])
|
|
|
|
else: # left justify
|
|
|
|
if right_pad:
|
2005-12-06 06:38:09 +00:00
|
|
|
return '\n'.join(
|
|
|
|
[' '*(left+first) + line.ljust(right-left-first)
|
|
|
|
for line in lines[0:1] ] +
|
|
|
|
[' '*left + line.ljust(right-left) for line in lines[1:] ]
|
|
|
|
)
|
2004-02-29 00:04:45 +00:00
|
|
|
else:
|
2005-12-06 06:38:09 +00:00
|
|
|
return '\n'.join(
|
|
|
|
[' '*(left+first) + line for line in lines[0:1] ] +
|
|
|
|
[' '*left + line for line in lines[1:] ]
|
|
|
|
)
|
2004-02-29 00:04:45 +00:00
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Ascii
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
2009-05-29 22:25:44 +00:00
|
|
|
class AsciiDoc(BaseDoc,TextDoc):
|
2004-02-29 00:04:45 +00:00
|
|
|
|
2010-01-13 18:40:55 +00:00
|
|
|
def __init__(self, styles, type):
|
|
|
|
BaseDoc.__init__(self, styles, type)
|
|
|
|
self.__note_format = False
|
|
|
|
|
2004-02-29 00:04:45 +00:00
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Opens the file, resets the text buffer.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def open(self,filename):
|
|
|
|
if filename[-4:] != ".txt":
|
|
|
|
self.filename = filename + ".txt"
|
|
|
|
else:
|
|
|
|
self.filename = filename
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
self.in_cell = 0
|
|
|
|
self.text = ""
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Close the file. Call the app if required.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def close(self):
|
|
|
|
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-02-29 00:04:45 +00:00
|
|
|
|
|
|
|
def get_usable_width(self):
|
|
|
|
return _WIDTH_IN_CHARS
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Force a section page break
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
2008-02-24 23:21:19 +00:00
|
|
|
def page_break(self):
|
2004-02-29 00:04:45 +00:00
|
|
|
self.f.write('\012')
|
|
|
|
|
2007-04-30 01:56:34 +00:00
|
|
|
def start_bold(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def end_bold(self):
|
|
|
|
pass
|
2004-02-29 00:04:45 +00:00
|
|
|
|
|
|
|
def start_superscript(self):
|
2007-04-30 01:56:34 +00:00
|
|
|
self.text = self.text + '['
|
2004-02-29 00:04:45 +00:00
|
|
|
|
|
|
|
def end_superscript(self):
|
2007-04-30 01:56:34 +00:00
|
|
|
self.text = self.text + ']'
|
2004-02-29 00:04:45 +00:00
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Starts a paragraph.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def start_paragraph(self,style_name,leader=None):
|
2007-04-23 11:46:26 +00:00
|
|
|
styles = self.get_style_sheet()
|
|
|
|
self.p = styles.get_paragraph_style(style_name)
|
2004-02-29 00:04:45 +00:00
|
|
|
self.leader = leader
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# End a paragraph. First format it to the desired widths.
|
|
|
|
# If not in table cell, write it immediately. If in the cell,
|
|
|
|
# add it to the list for this cell after formatting.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def end_paragraph(self):
|
2009-05-29 22:25:44 +00:00
|
|
|
if self.p.get_alignment() == PARA_ALIGN_RIGHT:
|
2004-02-29 00:04:45 +00:00
|
|
|
fmt = RIGHT
|
2009-05-29 22:25:44 +00:00
|
|
|
elif self.p.get_alignment() == PARA_ALIGN_CENTER:
|
2004-02-29 00:04:45 +00:00
|
|
|
fmt = CENTER
|
|
|
|
else:
|
|
|
|
fmt = LEFT
|
|
|
|
|
|
|
|
if self.in_cell:
|
|
|
|
right = self.cell_widths[self.cellnum]
|
|
|
|
else:
|
|
|
|
right = self.get_usable_width()
|
|
|
|
|
2005-12-06 06:38:09 +00:00
|
|
|
# Compute indents in characters. Keep first_indent relative!
|
|
|
|
regular_indent = 0
|
|
|
|
first_indent = 0
|
2004-02-29 00:04:45 +00:00
|
|
|
if self.p.get_left_margin():
|
2005-12-06 06:38:09 +00:00
|
|
|
regular_indent = int(4*self.p.get_left_margin())
|
|
|
|
if self.p.get_first_indent():
|
|
|
|
first_indent = int(4*self.p.get_first_indent())
|
2004-02-29 00:04:45 +00:00
|
|
|
|
|
|
|
if self.in_cell and self.cellnum < self.ncols - 1:
|
|
|
|
right_pad = 1
|
|
|
|
the_pad = ' '*right
|
|
|
|
else:
|
|
|
|
right_pad = 0
|
|
|
|
the_pad = ''
|
|
|
|
|
2005-12-06 06:38:09 +00:00
|
|
|
# Depending on the leader's presence, treat the first line differently
|
|
|
|
if self.leader:
|
|
|
|
# If we have a leader then we need to reformat the text
|
|
|
|
# as if there's no special treatment for the first line.
|
|
|
|
# Then add leader and eat up the beginning of the first line pad.
|
2010-01-19 12:47:17 +00:00
|
|
|
# Do not reformat if preformatted notes
|
|
|
|
if not self.__note_format:
|
2010-05-13 17:12:18 +00:00
|
|
|
self.leader += ' '
|
2010-01-19 12:47:17 +00:00
|
|
|
start_at = regular_indent + min(len(self.leader)+first_indent,0)
|
|
|
|
this_text = reformat_para(self.text,regular_indent,right,fmt,
|
|
|
|
right_pad)
|
|
|
|
this_text = ' '*(regular_indent+first_indent) + \
|
|
|
|
self.leader + this_text[start_at:]
|
|
|
|
else:
|
|
|
|
this_text = self.text
|
2004-02-29 00:04:45 +00:00
|
|
|
else:
|
2005-12-06 06:38:09 +00:00
|
|
|
# If no leader then reformat the text according to the first
|
|
|
|
# line indent, as specified by style.
|
2010-01-19 12:47:17 +00:00
|
|
|
# Do not reformat if preformatted notes
|
|
|
|
if not self.__note_format:
|
|
|
|
this_text = reformat_para(self.text,regular_indent,right,fmt,
|
2005-12-06 06:38:09 +00:00
|
|
|
right_pad,first_indent)
|
2010-01-19 12:47:17 +00:00
|
|
|
else:
|
|
|
|
this_text = self.text
|
|
|
|
|
2010-01-13 18:40:55 +00:00
|
|
|
if self.__note_format:
|
|
|
|
# don't add an extra LF before the_pad if preformatted notes.
|
|
|
|
if this_text != '\n':
|
|
|
|
# don't add LF if there is this_text is a LF
|
|
|
|
this_text += the_pad + '\n'
|
|
|
|
else:
|
|
|
|
this_text += '\n' + the_pad + '\n'
|
2004-02-29 00:04:45 +00:00
|
|
|
|
|
|
|
if self.in_cell:
|
2005-12-06 06:38:09 +00:00
|
|
|
self.cellpars[self.cellnum] = self.cellpars[self.cellnum] + \
|
|
|
|
this_text
|
2004-02-29 00:04:45 +00:00
|
|
|
else:
|
|
|
|
self.f.write(this_text)
|
|
|
|
|
|
|
|
self.text = ""
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Start a table. Grab the table style, and store it.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
2008-02-24 13:55:55 +00:00
|
|
|
def start_table(self, name,style_name):
|
2007-04-23 11:46:26 +00:00
|
|
|
styles = self.get_style_sheet()
|
|
|
|
self.tbl_style = styles.get_table_style(style_name)
|
2004-02-29 00:04:45 +00:00
|
|
|
self.ncols = self.tbl_style.get_columns()
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# End a table. Turn off the self.in_cell flag
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def end_table(self):
|
|
|
|
self.in_cell = 0
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Start a row. Initialize lists for cell contents, number of lines,
|
2004-03-01 03:47:58 +00:00
|
|
|
# and the widths. It is necessary to keep a list of cell contents
|
2004-02-29 00:04:45 +00:00
|
|
|
# that is to be written after all the cells are defined.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def start_row(self):
|
|
|
|
self.cellpars = [''] * self.ncols
|
|
|
|
self.cell_lines = [0] * self.ncols
|
|
|
|
self.cell_widths = [0] * self.ncols
|
|
|
|
self.cellnum = -1
|
|
|
|
self.maxlines = 0
|
|
|
|
table_width = self.get_usable_width() * self.tbl_style.get_width() / 100.0
|
|
|
|
for cell in range(self.ncols):
|
|
|
|
self.cell_widths[cell] = int( table_width * \
|
|
|
|
self.tbl_style.get_column_width(cell) / 100.0 )
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# End a row. Write the cell contents. Write the line of spaces
|
|
|
|
# if the cell has fewer lines than the maximum number.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def end_row(self):
|
|
|
|
self.in_cell = 0
|
|
|
|
cell_text = [None]*self.ncols
|
|
|
|
for cell in range(self.ncols):
|
2004-03-01 03:47:58 +00:00
|
|
|
if self.cell_widths[cell]:
|
|
|
|
blanks = ' '*self.cell_widths[cell] + '\n'
|
2005-02-19 00:49:49 +00:00
|
|
|
if self.cell_lines[cell] < self.maxlines:
|
2004-03-01 03:47:58 +00:00
|
|
|
self.cellpars[cell] = self.cellpars[cell] \
|
2004-02-29 00:04:45 +00:00
|
|
|
+ blanks * (self.maxlines-self.cell_lines[cell])
|
2004-03-01 03:47:58 +00:00
|
|
|
cell_text[cell] = self.cellpars[cell].split('\n')
|
2004-02-29 00:04:45 +00:00
|
|
|
for line in range(self.maxlines):
|
|
|
|
for cell in range(self.ncols):
|
2004-03-01 03:47:58 +00:00
|
|
|
if self.cell_widths[cell]:
|
|
|
|
self.f.write(cell_text[cell][line])
|
2004-02-29 00:04:45 +00:00
|
|
|
self.f.write('\n')
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Start a cell. Set the self.in_cell flag, increment the curren cell number.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def start_cell(self,style_name,span=1):
|
|
|
|
self.in_cell = 1
|
|
|
|
self.cellnum = self.cellnum + span
|
2009-09-10 18:49:48 +00:00
|
|
|
span -= 1
|
2004-03-01 03:47:58 +00:00
|
|
|
while span:
|
2007-07-30 04:17:31 +00:00
|
|
|
self.cell_widths[self.cellnum] += \
|
|
|
|
self.cell_widths[self.cellnum-span]
|
2004-03-01 03:47:58 +00:00
|
|
|
self.cell_widths[self.cellnum-span] = 0
|
2009-09-10 18:49:48 +00:00
|
|
|
span -= 1
|
2004-03-01 03:47:58 +00:00
|
|
|
|
2004-02-29 00:04:45 +00:00
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# End a cell. Find out the number of lines in this cell, correct
|
|
|
|
# the maximum number of lines if necessary.
|
|
|
|
#
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
def end_cell(self):
|
|
|
|
self.in_cell = 0
|
|
|
|
self.cell_lines[self.cellnum] = self.cellpars[self.cellnum].count('\n')
|
|
|
|
if self.cell_lines[self.cellnum] > self.maxlines:
|
|
|
|
self.maxlines = self.cell_lines[self.cellnum]
|
|
|
|
|
2009-06-08 23:19:37 +00:00
|
|
|
def add_media_object(self, name, align, w_cm, h_cm, alt=''):
|
2005-02-19 00:49:49 +00:00
|
|
|
this_text = '(photo)'
|
|
|
|
if self.in_cell:
|
|
|
|
self.cellpars[self.cellnum] = self.cellpars[self.cellnum] + this_text
|
|
|
|
else:
|
|
|
|
self.f.write(this_text)
|
|
|
|
|
2010-04-16 20:59:10 +00:00
|
|
|
def write_styled_note(self, styledtext, format, style_name,
|
|
|
|
contains_html=False):
|
|
|
|
"""
|
|
|
|
Convenience function to write a styledtext to the ASCII doc.
|
|
|
|
styledtext : assumed a StyledText object to write
|
|
|
|
format : = 0 : Flowed, = 1 : Preformatted
|
|
|
|
style_name : name of the style to use for default presentation
|
|
|
|
contains_html: bool, the backend should not check if html is present.
|
|
|
|
If contains_html=True, then the textdoc is free to handle that in
|
|
|
|
some way. Eg, a textdoc could remove all tags, or could make sure
|
|
|
|
a link is clickable. AsciiDoc prints the html without handling it
|
|
|
|
"""
|
2010-09-23 21:03:15 +00:00
|
|
|
if contains_html:
|
|
|
|
return
|
2010-01-13 18:40:55 +00:00
|
|
|
text = str(styledtext)
|
2010-01-19 12:47:17 +00:00
|
|
|
if format:
|
|
|
|
#Preformatted note, keep all white spaces, tabs, LF's
|
2010-01-13 18:40:55 +00:00
|
|
|
self.__note_format = True
|
2004-02-29 00:04:45 +00:00
|
|
|
for line in text.split('\n'):
|
|
|
|
self.start_paragraph(style_name)
|
|
|
|
self.write_text(line)
|
|
|
|
self.end_paragraph()
|
2010-01-19 12:47:17 +00:00
|
|
|
# Add an extra empty para all lines in each preformatted note
|
2010-01-13 18:40:55 +00:00
|
|
|
self.start_paragraph(style_name)
|
|
|
|
self.end_paragraph()
|
2010-01-19 12:47:17 +00:00
|
|
|
self.__note_format = False
|
|
|
|
else:
|
2004-02-29 00:04:45 +00:00
|
|
|
for line in text.split('\n\n'):
|
|
|
|
self.start_paragraph(style_name)
|
2010-09-23 21:03:15 +00:00
|
|
|
#line = line.replace('\n',' ')
|
|
|
|
#line = ' '.join(line.split())
|
2004-02-29 00:04:45 +00:00
|
|
|
self.write_text(line)
|
|
|
|
self.end_paragraph()
|
|
|
|
|
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)
|
|
|
|
self.end_paragraph()
|
|
|
|
|
2004-02-29 00:04:45 +00:00
|
|
|
#--------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Writes text.
|
|
|
|
#--------------------------------------------------------------------
|
2006-06-03 03:32:26 +00:00
|
|
|
def write_text(self,text,mark=None):
|
2004-02-29 00:04:45 +00:00
|
|
|
self.text = self.text + text
|