Added the zend framework 2 library, the path is specified in line no.26 in zend_modul...
[openemr.git] / interface / modules / zend_modules / library / Zend / Mail / Header / HeaderWrap.php
blob4ea98f6a17156fad33ea3c1b1bdba654214a8f7c
1 <?php
2 /**
3 * Zend Framework (http://framework.zend.com/)
5 * @link http://github.com/zendframework/zf2 for the canonical source repository
6 * @copyright Copyright (c) 2005-2013 Zend Technologies USA Inc. (http://www.zend.com)
7 * @license http://framework.zend.com/license/new-bsd New BSD License
8 */
10 namespace Zend\Mail\Header;
12 use Zend\Mail\Headers;
13 use Zend\Mime\Mime;
15 /**
16 * Utility class used for creating wrapped or MIME-encoded versions of header
17 * values.
19 abstract class HeaderWrap
21 /**
22 * Wrap a long header line
24 * @param string $value
25 * @param HeaderInterface $header
26 * @return string
28 public static function wrap($value, HeaderInterface $header)
30 if ($header instanceof UnstructuredInterface) {
31 return static::wrapUnstructuredHeader($value, $header);
32 } elseif ($header instanceof StructuredInterface) {
33 return static::wrapStructuredHeader($value, $header);
35 return $value;
38 /**
39 * Wrap an unstructured header line
41 * Wrap at 78 characters or before, based on whitespace.
43 * @param string $value
44 * @param HeaderInterface $header
45 * @return string
47 protected static function wrapUnstructuredHeader($value, HeaderInterface $header)
49 $encoding = $header->getEncoding();
50 if ($encoding == 'ASCII') {
51 return wordwrap($value, 78, Headers::FOLDING);
53 return static::mimeEncodeValue($value, $encoding, 78);
56 /**
57 * Wrap a structured header line
59 * @param string $value
60 * @param StructuredInterface $header
61 * @return string
63 protected static function wrapStructuredHeader($value, StructuredInterface $header)
65 $delimiter = $header->getDelimiter();
67 $length = strlen($value);
68 $lines = array();
69 $temp = '';
70 for ($i = 0; $i < $length; $i++) {
71 $temp .= $value[$i];
72 if ($value[$i] == $delimiter) {
73 $lines[] = $temp;
74 $temp = '';
77 return implode(Headers::FOLDING, $lines);
80 /**
81 * MIME-encode a value
83 * Performs quoted-printable encoding on a value, setting maximum
84 * line-length to 998.
86 * @param string $value
87 * @param string $encoding
88 * @param int $lineLength maximum line-length, by default 998
89 * @return string Returns the mime encode value without the last line ending
91 public static function mimeEncodeValue($value, $encoding, $lineLength = 998)
93 return Mime::encodeQuotedPrintableHeader($value, $encoding, $lineLength, Headers::EOL);