Code93.py revision 040e298be5b23e77e33309d65449072183c82d5c
'''
Copyright (C) 2007 Martin Owens
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
'''
from Base import Barcode
chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%'
encode = list(chars)
encode.append('($)')
encode.append('(/)')
encode.append('(+)')
encode.append('(%)')
encode.append('MARKER')
map = {}
i = 0
for char in encode:
map[char] = i
i = i + 1
# Extended encoding maps for full ASCII Code93
def getMap(array):
result = {}
y = 10
for x in array:
result[chr(x)] = encode[y]
y = y + 1
return result;
# MapA is eclectic, but B, C, D are all ASCII ranges
mapA = getMap([27,28,29,30,31,59,60,61,62,63,91,92,93,94,95,123,124,125,126,127,0,64,96,127,127,127]) # %
mapB = getMap(range(1, 26)) # $
mapC = getMap(range(33, 58)) # /
mapD = getMap(range(97, 122)) # +
encoding = '100010100 101001000 101000100 101000010 100101000 100100100 100100010 101010000 100010010 100001010 110101000 110100100 110100010 110010100 110010010 110001010 101101000 101100100 101100010 100110100 100011010 101011000 101001100 101000110 100101100 100010110 110110100 110110010 110101100 110100110 110010110 110011010 101101100 101100110 100110110 100111010 100101110 111010100 111010010 111001010 101101110 101110110 110101110 100100110 111011010 111010110 100110010 101011110'.split()
class Object(Barcode):
def encode(self, text):
bits = self.encode93('MARKER')
# Extend to ASCII charset ( return Array )
text = self.encodeAscii(text)
# Calculate the checksums
text.append(self.checksum(text, 20)) # C
text.append(self.checksum(text, 15)) # K
# Now convert text into the encoding bits (black and white stripes)
for char in text:
bits = bits + self.encode93(char)
self.inclabel = text
return bits
def checksum(self, text, mod):
weight = len(text) % mod
check = 0
for char in text:
check = check + (map[char] * weight)
# Reset the weight is required
weight = weight - 1
if weight == 0:
weight = mod
return encode[check % 47]
# Some charicters need re-encoding into the code93 specification
def encodeAscii(self, text):
result = []
for char in text:
if map.has_key(char):
result.append(char)
elif mapA.has_key(char):
result.append('(%)')
result.append(mapA[char])
elif mapB.has_key(char):
result.append('($)')
result.append(mapB[char])
elif mapC.has_key(char):
result.append('(/)')
result.append(mapC[char])
elif mapD.has_key(char):
result.append('(+)')
result.append(mapD[char])
return result
def encode93(self, char):
if map.has_key(char):
return encoding[map[char]]
return ''