3 * Zend Framework (http://framework.zend.com/)
5 * @link http://github.com/zendframework/zf2 for the canonical source repository
6 * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
7 * @license http://framework.zend.com/license/new-bsd New BSD License
10 namespace Zend\Validator\Barcode
;
12 class Codabar
extends AbstractAdapter
15 * Constructor for this barcode adapter
17 public function __construct()
20 $this->setCharacters('0123456789-$:/.+ABCDTN*E');
21 $this->useChecksum(false);
25 * Checks for allowed characters
26 * @see Zend\Validator\Barcode.AbstractAdapter::checkChars()
28 public function hasValidCharacters($value)
30 if (strpbrk($value, 'ABCD')) {
32 if (!strpbrk($first, 'ABCD')) {
37 $last = substr($value, -1, 1);
38 if (!strpbrk($last, 'ABCD')) {
43 $value = substr($value, 1, -1);
44 } elseif (strpbrk($value, 'TN*E')) {
46 if (!strpbrk($first, 'TN*E')) {
51 $last = substr($value, -1, 1);
52 if (!strpbrk($last, 'TN*E')) {
57 $value = substr($value, 1, -1);
60 $chars = $this->getCharacters();
61 $this->setCharacters('0123456789-$:/.+');
62 $result = parent
::hasValidCharacters($value);
63 $this->setCharacters($chars);