Browse Source

Safer import of pickle

pull/51/head
Louis 11 years ago
parent
commit
ae39389d11
  1. 10
      patacrep/songs.py

10
patacrep/songs.py

@ -4,11 +4,15 @@
"""Song management.""" """Song management."""
from unidecode import unidecode from unidecode import unidecode
import cPickle
import hashlib import hashlib
import os import os
import re import re
try:
import cPickle as pickle
except ImportError:
import pickle
from patacrep.authors import processauthors from patacrep.authors import processauthors
from patacrep.plastex import parsetex from patacrep.plastex import parsetex
@ -39,7 +43,7 @@ class Song(object):
def __init__(self, filename, config): def __init__(self, filename, config):
self._filehash = hashlib.md5(open(filename, 'rb').read()).hexdigest() self._filehash = hashlib.md5(open(filename, 'rb').read()).hexdigest()
if os.path.exists(cached_name(filename)): if os.path.exists(cached_name(filename)):
cached = cPickle.load(open(cached_name(filename), 'rb')) cached = pickle.load(open(cached_name(filename), 'rb'))
if ( if (
cached['_filehash'] == self._filehash cached['_filehash'] == self._filehash
and cached['_version'] == self.CACHE_VERSION and cached['_version'] == self.CACHE_VERSION
@ -78,7 +82,7 @@ class Song(object):
cached = {} cached = {}
for attribute in self.cached_attributes: for attribute in self.cached_attributes:
cached[attribute] = getattr(self, attribute) cached[attribute] = getattr(self, attribute)
cPickle.dump(cached, open(cached_name(self.path), 'wb')) pickle.dump(cached, open(cached_name(self.path), 'wb'))
def __repr__(self): def __repr__(self):
return repr((self.titles, self.args, self.path)) return repr((self.titles, self.args, self.path))

Loading…
Cancel
Save