~openerp-chinese-team/openerp-china/openerp-china

« back to all changes in this revision

Viewing changes to oecn_base_fonts/reportlab_patch.py

  • Committer: JoshuaJan
  • Date: 2013-03-28 09:08:19 UTC
  • Revision ID: popkar77@gmail.com-20130328090819-3h2qaqjnthe9ek68
more configure

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# -*- coding: utf-8 -*-
 
2
# bug from :http://two.pairlist.net/pipermail/reportlab-users/2012-January/010336.html
 
3
# get fonts name and file path
 
4
# ff.search() may resulting error if any AFMFont resided in
 
5
# the search path has defined width that is not an integer
 
6
# a dirty workaround:
 
7
# replace following code around #110 in reportlab.pdfbase.pdfmetrics
 
8
# From:
 
9
# width = string.atoi(r)
 
10
# To:
 
11
# width = int(float(r))
 
12
import string
 
13
import reportlab.pdfbase.pdfmetrics 
 
14
from reportlab.lib.utils import open_and_readlines
 
15
 
 
16
def parseAFMFile(afmFileName):
 
17
    """Quick and dirty - gives back a top-level dictionary
 
18
    with top-level items, and a 'widths' key containing
 
19
    a dictionary of glyph names and widths.  Just enough
 
20
    needed for embedding.  A better parser would accept
 
21
    options for what data you wwanted, and preserve the
 
22
    order."""
 
23
 
 
24
    lines = open_and_readlines(afmFileName, 'r')
 
25
    if len(lines)<=1:
 
26
        #likely to be a MAC file
 
27
        if lines: lines = string.split(lines[0],'\r')
 
28
        if len(lines)<=1:
 
29
            raise ValueError, 'AFM file %s hasn\'t enough data' % afmFileName
 
30
    topLevel = {}
 
31
    glyphLevel = []
 
32
 
 
33
    lines = [l for l in map(string.strip, lines) if not l.lower().startswith('comment')]
 
34
    #pass 1 - get the widths
 
35
    inMetrics = 0  # os 'TOP', or 'CHARMETRICS'
 
36
    for line in lines:
 
37
        if line[0:16] == 'StartCharMetrics':
 
38
            inMetrics = 1
 
39
        elif line[0:14] == 'EndCharMetrics':
 
40
            inMetrics = 0
 
41
        elif inMetrics:
 
42
            chunks = string.split(line, ';')
 
43
            chunks = map(string.strip, chunks)
 
44
            cidChunk, widthChunk, nameChunk = chunks[0:3]
 
45
 
 
46
            # character ID
 
47
            l, r = string.split(cidChunk)
 
48
            assert l == 'C', 'bad line in font file %s' % line
 
49
            cid = string.atoi(r)
 
50
 
 
51
            # width
 
52
            l, r = string.split(widthChunk)
 
53
            assert l == 'WX', 'bad line in font file %s' % line
 
54
            #width = string.atoi(r)
 
55
            width = int(float(r))
 
56
 
 
57
            # name
 
58
            l, r = string.split(nameChunk)
 
59
            assert l == 'N', 'bad line in font file %s' % line
 
60
            name = r
 
61
 
 
62
            glyphLevel.append((cid, width, name))
 
63
 
 
64
    # pass 2 font info
 
65
    inHeader = 0
 
66
    for line in lines:
 
67
        if line[0:16] == 'StartFontMetrics':
 
68
            inHeader = 1
 
69
        if line[0:16] == 'StartCharMetrics':
 
70
            inHeader = 0
 
71
        elif inHeader:
 
72
            if line[0:7] == 'Comment': pass
 
73
            try:
 
74
                left, right = string.split(line,' ',1)
 
75
            except:
 
76
                raise ValueError, "Header information error in afm %s: line='%s'" % (afmFileName, line)
 
77
            try:
 
78
                right = string.atoi(right)
 
79
            except:
 
80
                pass
 
81
            topLevel[left] = right
 
82
 
 
83
 
 
84
    return (topLevel, glyphLevel)
 
85
 
 
86
reportlab.pdfbase.pdfmetrics.parseAFMFile = parseAFMFile
 
87
 
 
88
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
 
 
b'\\ No newline at end of file'