[Bug 6413] Fix importing ProGen files
This isn't a perfect fix because it requires that the ProGen file is encoded with CP437, which is guaranteed only in Version 3.21 and later. svn: r21354
This commit is contained in:
parent
d5dfa05ff9
commit
801f1b77aa
@ -115,8 +115,8 @@ def _read_mem(bname):
|
|||||||
fname = bname + '.mem'
|
fname = bname + '.mem'
|
||||||
f = open(fname, "rb")
|
f = open(fname, "rb")
|
||||||
recfmt = "i28s"
|
recfmt = "i28s"
|
||||||
reclen = struct.calcsize( recfmt )
|
reclen = struct.calcsize( str(recfmt) )
|
||||||
#print "# reclen = %d" % reclen
|
print "# reclen = %d" % reclen
|
||||||
|
|
||||||
mems = []
|
mems = []
|
||||||
while 1:
|
while 1:
|
||||||
@ -137,7 +137,7 @@ def _read_recs(table, bname):
|
|||||||
f = open(fname, "rb")
|
f = open(fname, "rb")
|
||||||
recfmt = table.recfmt
|
recfmt = table.recfmt
|
||||||
log.info("# %s - recfmt = %s" % (table['name1'], recfmt))
|
log.info("# %s - recfmt = %s" % (table['name1'], recfmt))
|
||||||
reclen = struct.calcsize( recfmt )
|
reclen = struct.calcsize(str(recfmt))
|
||||||
log.info("# %s - reclen = %d" % (table['name1'], reclen))
|
log.info("# %s - reclen = %d" % (table['name1'], reclen))
|
||||||
|
|
||||||
recs = []
|
recs = []
|
||||||
@ -435,7 +435,8 @@ class PG30_Def_Table:
|
|||||||
# Just grab a field
|
# Just grab a field
|
||||||
f = self.flds[1]
|
f = self.flds[1]
|
||||||
txt += '"%s"\n' % f
|
txt += '"%s"\n' % f
|
||||||
txt += 'recfmt = %s (length=%d)' % (self.recfmt, struct.calcsize(self.recfmt))
|
txt += 'recfmt = %s (length=%d)' % (self.recfmt,
|
||||||
|
struct.calcsize(str(self.recfmt)))
|
||||||
return txt
|
return txt
|
||||||
|
|
||||||
|
|
||||||
@ -459,9 +460,10 @@ class PG30_Def:
|
|||||||
raise ProgenError(_("Cannot find DEF file: %(deffname)s") % locals())
|
raise ProgenError(_("Cannot find DEF file: %(deffname)s") % locals())
|
||||||
|
|
||||||
# This can throw a IOError
|
# This can throw a IOError
|
||||||
lines = open(fname).readlines()
|
import io
|
||||||
|
lines = io.open(fname, buffering=1, encoding='cp437', errors='strict').readlines()
|
||||||
lines = [l.strip() for l in lines]
|
lines = [l.strip() for l in lines]
|
||||||
content = '\n'.join(lines)
|
content = '\n'.join(lines).encode('utf-8')
|
||||||
parts = re.split(r'\n(?=\[)', content)
|
parts = re.split(r'\n(?=\[)', content)
|
||||||
self.parts = {}
|
self.parts = {}
|
||||||
self.tables = {}
|
self.tables = {}
|
||||||
|
Loading…
Reference in New Issue
Block a user