removed configparser in favor of yaml

main
Fabien Benureau 13 years ago
parent cdd2796638
commit 09b737b210

@ -1,7 +1,7 @@
[header] [header]
title = citekey support title = citekey support
id = 956ed1a521100b3b0bb0638f61b3b5a03204ffa6 id = 956ed1a521100b3b0bb0638f61b3b5a03204ffa6
status = open status = closed
type = feature type = feature
author = Fabien Benureau author = Fabien Benureau
mail = fabien.benureau+git@gmail.com mail = fabien.benureau+git@gmail.com
@ -9,6 +9,7 @@ date = 2012-10-05 at 15:00 UCT
[eventlog] [eventlog]
opened[0] = opened the 2012-10-05 at 15:00 UCT by Fabien Benureau opened[0] = opened the 2012-10-05 at 15:00 UCT by Fabien Benureau
closed[1] = closed the 2012-10-11 at 17:57(UCT) by Fabien Benureau
[discussion] [discussion]
desc = # enter your description here desc = # enter your description here

@ -1,7 +1,7 @@
[header] [header]
title = remove configparser for internal mapping title = remove configparser for internal mapping
id = ac8c05c020d251c6fa9ac5fc239038837b636b3b id = ac8c05c020d251c6fa9ac5fc239038837b636b3b
status = open status = closed
type = bug type = bug
author = Fabien Benureau author = Fabien Benureau
mail = fabien.benureau+git@gmail.com mail = fabien.benureau+git@gmail.com
@ -9,6 +9,7 @@ date = 2012-10-11 at 07:25 UCT
[eventlog] [eventlog]
opened[0] = opened the 2012-10-11 at 07:25 UCT by Fabien Benureau opened[0] = opened the 2012-10-11 at 07:25 UCT by Fabien Benureau
closed[1] = closed the 2012-10-11 at 17:57(UCT) by Fabien Benureau
[discussion] [discussion]
desc = # enter your description here desc = # enter your description here

@ -26,12 +26,11 @@ def command(config):
os.makedirs(papersdir+os.sep+'bibdata') os.makedirs(papersdir+os.sep+'bibdata')
os.makedirs(papersdir+os.sep+'meta') os.makedirs(papersdir+os.sep+'meta')
papers = configparser.ConfigParser() papers = {}
papers.add_section('header') papers['count'] = 0
papers.set('header', 'count', 0) papers['citekeys'] = {}
papers.add_section('citekeys') papers['numbers'] = {}
papers.add_section('numbers') files.save_papers(papers)
files.write_papers(papers)
else: else:
print('{}error {} : papers already present in {}{}{}'.format( print('{}error {} : papers already present in {}{}{}'.format(

@ -13,10 +13,10 @@ def command(config):
rp = repo.Repository() rp = repo.Repository()
articles = [] articles = []
for n in rp.numbers: for n in sorted(rp.numbers.keys()):
paper = rp.paper_from_number(n, fatal = True) paper = rp.paper_from_number(n, fatal = True)
bibdesc = pretty.bib_oneliner(paper.bibdata) bibdesc = pretty.bib_oneliner(paper.bib_data)
articles.append('{:3d} {}{}{}{} {}'.format(int(paper.number), color.purple, citekey, color.end, (8-len(paper.citekey))*' ', bibdesc)) articles.append('{:3d} {}{}{}{} {}'.format(int(paper.number), color.purple, paper.citekey, color.end, (8-len(paper.citekey))*' ', bibdesc))
with tempfile.NamedTemporaryFile(suffix=".tmp", delete=True) as tmpf: with tempfile.NamedTemporaryFile(suffix=".tmp", delete=True) as tmpf:
tmpf.write('\n'.join(articles)) tmpf.write('\n'.join(articles))

@ -11,7 +11,7 @@ def parser(subparsers, config):
def command(config, citekey): def command(config, citekey):
rp = repo.Repository() rp = repo.Repository()
paper = rp.paper_from_any(citekey, fatal = True) paper = rp.paper_from_any(citekey, fatal = True)
filepath = paper.metadata.get('metadata', 'path') filepath = paper.metadata['path']
p = subprocess.Popen(['open', filepath]) p = subprocess.Popen(['open', filepath])
print('{}{}{} opened.{}'.format(color.filepath, filepath, color.normal, color.end)) print('{}{}{} opened.{}'.format(color.filepath, filepath, color.normal, color.end))

@ -8,6 +8,8 @@ try:
except ImportError: except ImportError:
import configparser import configparser
import yaml
import color import color
try: try:
@ -66,29 +68,46 @@ def check_file(filepath):
print '{}error{}: {}{}{} is not a file{}'.format( print '{}error{}: {}{}{} is not a file{}'.format(
color.red, color.grey, color.cyan, filepath, color.grey, color.end) color.red, color.grey, color.cyan, filepath, color.grey, color.end)
exit(-1) exit(-1)
# yaml I/O
def write_configfile(config, filepath): def write_yamlfile(filepath, datamap):
try: try:
with open(filepath, 'w') as f: with open(filepath, 'w') as f:
config.write(f) yaml.dump(datamap, f)
except IOError as e: except IOError as e:
print '{}error{} : impossible to write on file {}{:s}{}'.format( print '{}error{} : impossible to read file {}{:s}{}'.format(
color.red, color.grey, color.cyan, filepath, color.end) color.red, color.grey, color.cyan, filepath, color.end)
print 'Verify permissions'
exit(-1) exit(-1)
def read_configfile(filepath): def read_yamlfile(filepath):
check_file(filepath)
try: try:
with open(filepath, 'r') as f: with open(filepath, 'r') as f:
config = configparser.ConfigParser() return yaml.load(f)
config.readfp(f)
return config
except IOError as e: except IOError as e:
print '{}error{} : impossible to read file {}{:s}{}'.format( print '{}error{} : impossible to read file {}{:s}{}'.format(
color.red, color.grey, color.cyan, filepath, color.end) color.red, color.grey, color.cyan, paperdir, color.end)
print 'Verify permissions'
exit(-1) exit(-1)
def save_papers(datamap):
paperyaml = find_papersdir() + os.sep + 'papers.yaml'
write_yamlfile(paperyaml, datamap)
def load_papers():
paperyaml = find_papersdir() + os.sep + 'papers.yaml'
return read_yamlfile(paperyaml)
def save_meta(meta_data, filename):
filepath = find_papersdir() + os.sep + 'meta' + os.sep + filename + '.meta'
write_yamlfile(filepath, meta_data)
def load_meta(filename):
filepath = find_papersdir() + os.sep + 'meta' + os.sep + filename + '.meta'
return read_yamlfile(filepath)
# specific to bibliography data
def load_externalbibfile(fullbibpath): def load_externalbibfile(fullbibpath):
check_file(fullbibpath) check_file(fullbibpath)
@ -109,31 +128,17 @@ def load_externalbibfile(fullbibpath):
return bib_data return bib_data
def write_papers(config):
write_configfile(config, find_papersdir() + os.sep + 'papers')
def load_papers():
return read_configfile(find_papersdir() + os.sep + 'papers')
def load_bibdata(filename): def load_bibdata(filename):
fullbibpath = find_papersdir() + os.sep + 'bibdata' + os.sep + filename + '.bibyaml' fullbibpath = find_papersdir() + os.sep + 'bibdata' + os.sep + filename + '.bibyaml'
return load_externalbibfile(fullbibpath) return load_externalbibfile(fullbibpath)
def write_bibdata(bib_data, filename): def save_bibdata(bib_data, filename):
filepath = find_papersdir() + os.sep + 'bibdata' + os.sep + filename + '.bibyaml' filepath = find_papersdir() + os.sep + 'bibdata' + os.sep + filename + '.bibyaml'
with open(filepath, 'w') as f: with open(filepath, 'w') as f:
parser = pybtex.database.output.bibyaml.Writer() parser = pybtex.database.output.bibyaml.Writer()
parser.write_stream(bib_data, f) parser.write_stream(bib_data, f)
def write_meta(meta_data, filename): # vim input
filepath = find_papersdir() + os.sep + 'meta' + os.sep + filename + '.meta'
write_configfile(meta_data, filepath)
def load_meta(filename):
filepath = find_papersdir() + os.sep + 'meta' + os.sep + filename + '.meta'
return read_configfile(filepath)
try: try:
EDITOR = os.environ['EDITOR'] EDITOR = os.environ['EDITOR']

@ -1,8 +1,4 @@
import os import os
try:
import ConfigParser as configparser
except ImportError:
import configparser
import files import files
import color import color
@ -15,8 +11,8 @@ class Paper(object):
@classmethod @classmethod
def from_disc(cls, name, citekey = None, number = None): def from_disc(cls, name, citekey = None, number = None):
bib_data = files.load_bibdata(self.name) bib_data = files.load_bibdata(name)
metadata = files.load_meta(self.name) metadata = files.load_meta(name)
p = Paper(name, bib_data = bib_data, metadata = metadata, p = Paper(name, bib_data = bib_data, metadata = metadata,
citekey = citekey, number = number) citekey = citekey, number = number)
return p return p
@ -24,7 +20,7 @@ class Paper(object):
@classmethod @classmethod
def from_bibpdffiles(cls, pdfpath, bibpath): def from_bibpdffiles(cls, pdfpath, bibpath):
bib_data = cls.import_bibdata(bibpath) bib_data = cls.import_bibdata(bibpath)
name, meta = cls.import_meta(pdfpath, bib_data) name, meta = cls.create_meta(pdfpath, bib_data)
p = Paper(name, bib_data = bib_data, metadata = meta) p = Paper(name, bib_data = bib_data, metadata = meta)
return p return p
@ -38,14 +34,13 @@ class Paper(object):
self.number = number self.number = number
def save_to_disc(self): def save_to_disc(self):
files.write_bibdata(self.bib_data, self.name) files.save_bibdata(self.bib_data, self.name)
files.write_meta(self.metadata, self.name) files.save_meta(self.metadata, self.name)
@classmethod @classmethod
def import_bibdata(cls, bibfile): def import_bibdata(cls, bibfile):
"""Import bibligraphic data from a .bibyaml, .bib or .bibtex file""" """Import bibligraphic data from a .bibyaml, .bib or .bibtex file"""
fullbibpath = os.path.abspath(bibfile) fullbibpath = os.path.abspath(bibfile)
files.check_file(fullbibpath)
bib_data = files.load_externalbibfile(fullbibpath) bib_data = files.load_externalbibfile(fullbibpath)
print('{}bibliographic data present in {}{}{}'.format( print('{}bibliographic data present in {}{}{}'.format(
@ -55,20 +50,19 @@ class Paper(object):
return bib_data return bib_data
@classmethod @classmethod
def import_meta(cls, pdfpath, bib_data): def create_meta(cls, pdfpath, bib_data):
fullpdfpath = os.path.abspath(pdfpath) fullpdfpath = os.path.abspath(pdfpath)
files.check_file(fullpdfpath) files.check_file(fullpdfpath)
name, ext = files.name_from_path(pdfpath) name, ext = files.name_from_path(pdfpath)
meta = configparser.ConfigParser() meta = {}
meta.add_section('metadata')
meta.set('metadata', 'name', name) meta['name'] = name
meta.set('metadata', 'extension', ext) meta['extension'] = ext
meta.set('metadata', 'path', os.path.normpath(fullpdfpath)) meta['path'] = fullpdfpath
meta.add_section('notes') meta['notes'] = []
return name, meta return name, meta

@ -1,8 +1,3 @@
try:
import ConfigParser as configparser
except ImportError:
import configparser
import files import files
import color import color
from paper import Paper from paper import Paper
@ -15,16 +10,18 @@ class Repository(object):
def __init__(self): def __init__(self):
self.paperdir = files.find_papersdir() self.paperdir = files.find_papersdir()
self.papers_config = files.load_papers() self.papers_config = files.load_papers()
self.citekeys = dict((ck, name) for ck, name in self.papers_config.items('citekeys')) self.citekeys = self.papers_config['citekeys']
self.numbers = sorted(n[2:] for n in self.papers_config.options('numbers')) self.numbers = self.papers_config['numbers']
# loading existing papers # loading existing papers
def paper_from_number(self, number, fatal = True): def paper_from_number(self, number, fatal = True):
try: try:
citekey = self.papers_config.get('numbers', 'ck'+number) citekey = self.numbers[int(number)]
return self.paper_from_citekey(citekey) paper = self.paper_from_citekey(citekey)
except configparser.NoOptionError: paper.number = int(number)
return paper
except KeyError:
if fatal: if fatal:
print('{}error{}: no paper with number {}{}{}'.format( print('{}error{}: no paper with number {}{}{}'.format(
color.error, color.normal, color.citekey, citekey, color.end)) color.error, color.normal, color.citekey, citekey, color.end))
@ -34,11 +31,9 @@ class Repository(object):
def paper_from_citekey(self, citekey, fatal = True): def paper_from_citekey(self, citekey, fatal = True):
"""Load a paper by its citekey from disk, if necessary.""" """Load a paper by its citekey from disk, if necessary."""
try: try:
paper = self.citekeys[citekey] name = self.citekeys[citekey]
if paper is None: paper = Paper.from_disc(name, citekey = citekey)
name = self.papers_config.get('citekeys', citekey) paper.citekey = citekey
paper = Paper.from_disc(name, citekey = citekey)
self.citekeys[citekey] = paper
return paper return paper
except KeyError: except KeyError:
if fatal: if fatal:
@ -70,15 +65,14 @@ class Repository(object):
p.citekey = self.create_citekey(p.bib_data) p.citekey = self.create_citekey(p.bib_data)
p.number = self.create_number() p.number = self.create_number()
self.papers_config.set('citekeys', p.citekey, p.name) self.papers_config['citekeys'][p.citekey] = p.name
self.papers_config.set('numbers', 'ck' + str(p.number), p.citekey) self.papers_config['numbers'][p.number] = p.citekey
self.citekeys[p.citekey] = p.name self.citekeys[p.citekey] = p.name
self.numbers.append(str(p.number)) self.numbers[p.number] = p.citekey
self.numbers.sort()
# writing all to disk # writing all to disk
files.write_papers(self.papers_config) files.save_papers(self.papers_config)
p.save_to_disc() p.save_to_disc()
return p return p
@ -101,6 +95,6 @@ class Repository(object):
return citekey return citekey
def create_number(self): def create_number(self):
count = self.papers_config.getint('header', 'count') count = int(self.papers_config['count'])
self.papers_config.set('header', 'count', count + 1) self.papers_config['count'] = count + 1
return count return count
Loading…
Cancel
Save