# # Gramps - a GTK+/GNOME based genealogy program # # Copyright (C) 2000 Donald N. Allingham # # 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 os import tempfile import string from TextDoc import * from SpreadSheetDoc import * from latin_utf8 import latin_to_utf8 import const class OpenSpreadSheet(SpreadSheetDoc): def __init__(self,type,orientation): SpreadSheetDoc.__init__(self,type,orientation) self.f = None self.filename = None self.level = 0 self.time = "0000-00-00T00:00:00" def open(self,filename): import time t = time.localtime(time.time()) self.time = "%04d-%02d-%02dT%02d:%02d:%02d" % \ (t[0],t[1],t[2],t[3],t[4],t[5]) if filename[-4:] != ".sxc": self.filename = filename + ".sxc" else: self.filename = filename tempfile.tempdir = "/tmp" self.tempdir = tempfile.mktemp() os.mkdir(self.tempdir,0700) os.mkdir(self.tempdir + os.sep + "Pictures") os.mkdir(self.tempdir + os.sep + "META-INF") self.f = open(self.tempdir + os.sep + "content.xml","w") self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') for key in self.table_styles.keys(): table = self.table_styles[key] self.f.write('\n') self.f.write('\n') self.f.write('\n') for index in range(0,table.get_columns()): self.f.write('\n') self.f.write('\n' % table.get_column_width(index)) self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') for key in self.style_list.keys(): style = self.style_list[key] font = style.get_font() self.f.write('\n') self.f.write('\n') else: self.f.write('fo:font-weight="normal"/>\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') def close(self): self.f.write('\n') self.f.write('\n') self.f.close() self._write_styles_file() self._write_manifest() self._write_meta_file() self._write_zip() def start_row(self): self.f.write('\n') def end_row(self): self.f.write('\n') def start_cell(self,style_name,span=1): self.content = 0 self.span = span self.f.write(' 1: self.f.write(' table:number-columns-spanned="' + str(span) + '">\n') else: self.f.write('>\n') def end_cell(self): if self.content == 0: self.f.write('\n') else: self.f.write('\n') self.f.write('\n') for col in range(1,self.span): self.f.write('\n') def _write_zip(self): if os.path.isfile(self.filename): os.unlink(self.filename) os.system("cd " + self.tempdir + "; " + const.zipcmd + " " \ + self.filename + " .") os.unlink(self.tempdir + os.sep + "META-INF" + os.sep + "manifest.xml") os.unlink(self.tempdir + os.sep + "content.xml") os.unlink(self.tempdir + os.sep + "meta.xml") os.unlink(self.tempdir + os.sep + "styles.xml") # for image in self.image_list: # os.unlink(self.tempdir + os.sep + "Pictures" + os.sep + image) os.rmdir(self.tempdir + os.sep + "Pictures") os.rmdir(self.tempdir + os.sep + "META-INF") os.rmdir(self.tempdir) def _write_styles_file(self): file = self.tempdir + os.sep + "styles.xml" self.f = open(file,"w") self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('???\n') self.f.write('\n') self.f.write('\n') self.f.write('Page 1\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('??? ') self.f.write('(???)\n') self.f.write('\n') self.f.write('\n') self.f.write('05/16/2001, ') self.f.write('10:53:17\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('Page 1 / ') self.f.write('99\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.close() def start_page(self,name,style_name): table = self.table_styles[style_name] self.f.write('\n') for col in range(0,table.get_columns()): self.f.write('\n') def end_page(self): self.f.write('\n') def write_text(self,text): if text == "": return if self.content == 0: self.f.write('') self.content = 1 text = string.replace(text,'\t','') text = string.replace(text,'\n','') self.f.write(latin_to_utf8(text)) def _write_manifest(self): file = self.tempdir + os.sep + "META-INF" + os.sep + "manifest.xml" self.f = open(file,"w") self.f.write('\n') self.f.write('') self.f.write('') self.f.write('') self.f.write('') self.f.write('') self.f.write('') #self.f.write('') self.f.write('\n') self.f.close() def _write_meta_file(self): file = self.tempdir + os.sep + "meta.xml" name = latin_to_utf8(self.name) self.f = open(file,"w") self.f.write('\n') self.f.write('\n'); self.f.write('\n') self.f.write('') self.f.write(const.progName + ' ' + const.version) self.f.write('\n') self.f.write('') self.f.write(name) self.f.write('\n') self.f.write('') self.f.write(self.time) self.f.write('\n') self.f.write('') self.f.write(name) self.f.write('\n') self.f.write('') self.f.write(self.time) self.f.write('\n') self.f.write('0-00-00T00:00:00\n') self.f.write('en-US\n') self.f.write('1\n') self.f.write('PT0S\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.close() if __name__ == "__main__": doc = OpenSpreadSheet(PaperStyle("junk",21.59,27),PAPER_PORTRAIT) t = TableStyle() t.set_columns(3) t.set_column_width(0,4) t.set_column_width(1,2) t.set_column_width(2,1) doc.add_table_style("mytblstyle",t) f = FontStyle() f.set_type_face(FONT_SANS_SERIF) f.set_size(16) f.set_bold(1) p = ParagraphStyle() p.set_font(f) p.set_background_color((0xcc,0xff,0xff)) p.set_padding(0.5) doc.add_style("p1",p) doc.open("/home/dona/test") doc.start_page("Page 1","mytblstyle") doc.start_row() doc.start_cell("p1") doc.write_text("Hello") doc.end_cell() doc.end_row() doc.end_page() doc.close()