X-Git-Url: http://iramuteq.org/git?p=iramuteq;a=blobdiff_plain;f=functions.py;h=2909a4449b9f8f2aeb48aa7eb8e2a00e24d26cbf;hp=3922fd50c081279420adc4b45c9f052e0ae92685;hb=44b2ba75167b1ed5508e2f110130805bfe43a3bd;hpb=22cd27b2bbe9ab1ffa7ef06fa764b5147ae17dad diff --git a/functions.py b/functions.py index 3922fd5..2909a44 100644 --- a/functions.py +++ b/functions.py @@ -10,6 +10,7 @@ from ConfigParser import ConfigParser from subprocess import Popen, call, PIPE import thread import os +import ast import sys import csv import platform @@ -71,6 +72,7 @@ class History : sections = self.corpora.keys() + self.analyses.keys() parametres = [self.corpora[key] for key in self.corpora.keys()] + [self.analyses[key] for key in self.analyses.keys()] self.conf.makeoptions(sections, parametres) + log.info('write history') def add(self, analyse) : if 'corpus' in analyse : @@ -87,6 +89,19 @@ class History : self.corpora[analyse['uuid']] = analyse self.write() + def delete(self, uuid, corpus = False) : + if corpus : + del self.corpora[uuid] + self.conf.conf.remove_section(uuid) + for analyse in self.history[uuid].get('analyses', [False]) : + if analyse : + del self.analyses[analyse['uuid']] + self.conf.conf.remove_section(analyse['uuid']) + else : + del self.analyses[uuid] + self.conf.conf.remove_section(uuid) + self.write() + def addtab(self, analyse) : self.opened[analyse['uuid']] = analyse @@ -116,6 +131,12 @@ class DoConf : for option in self.conf.options(section) : if self.conf.get(section, option).isdigit() : parametres[option] = int(self.conf.get(section, option)) + elif self.conf.get(section, option) == 'False' : + parametres[option] = False + elif self.conf.get(section, option) == 'True' : + parametres[option] = True + elif self.conf.get(section, option).startswith('(') and self.conf.get(section, option).endswith(')') : + parametres[option] = ast.literal_eval(self.conf.get(section, option)) else : parametres[option] = self.conf.get(section, option) if 'type' not in parametres : @@ -131,8 +152,13 @@ class DoConf : self.conf.set(section, option, `parametres[i][option]`) elif isinstance(parametres[i][option], basestring) : self.conf.set(section, option, parametres[i][option].encode('utf8')) + elif isinstance(parametres[i][option], wx.Colour) : + self.conf.set(section, option, str(parametres[i][option])) + else : + self.conf.set(section, option, `parametres[i][option]`) if outfile is None : outfile = self.configfile + print outfile with codecs.open(outfile, 'w', 'utf8') as f : self.conf.write(f)