<?php /* * This file is part of the Symfony package. * * (c) Fabien Potencier <fabien@symfony.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\Mime\Encoder; use Symfony\Component\Mime\CharacterStream; /** * @author Chris Corbyn */ final class Rfc2231Encoder implements EncoderInterface { /** * Takes an unencoded string and produces a string encoded according to RFC 2231 from it. */ public function encodeString(string $string, ?string $charset = 'utf-8', int $firstLineOffset = 0, int $maxLineLength = 0): string { $lines = []; $lineCount = 0; $lines[] = ''; $currentLine = &$lines[$lineCount++]; if (0 >= $maxLineLength) { $maxLineLength = 75; } $charStream = new CharacterStream($string, $charset); $thisLineLength = $maxLineLength - $firstLineOffset; while (null !== $char = $charStream->read(4)) { $encodedChar = rawurlencode($char); if ('' !== $currentLine && \strlen($currentLine.$encodedChar) > $thisLineLength) { $lines[] = ''; $currentLine = &$lines[$lineCount++]; $thisLineLength = $maxLineLength; } $currentLine .= $encodedChar; } return implode("\r\n", $lines); } }
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
AddressEncoderInterface.php | File | 689 B | 0644 |
|
Base64ContentEncoder.php | File | 1.3 KB | 0644 |
|
Base64Encoder.php | File | 1.25 KB | 0644 |
|
Base64MimeHeaderEncoder.php | File | 1.26 KB | 0644 |
|
ContentEncoderInterface.php | File | 668 B | 0644 |
|
EightBitContentEncoder.php | File | 834 B | 0644 |
|
EncoderInterface.php | File | 717 B | 0644 |
|
IdnAddressEncoder.php | File | 1.28 KB | 0644 |
|
MimeHeaderEncoderInterface.php | File | 467 B | 0644 |
|
QpContentEncoder.php | File | 1.78 KB | 0644 |
|
QpEncoder.php | File | 7.7 KB | 0644 |
|
QpMimeHeaderEncoder.php | File | 1.05 KB | 0644 |
|
Rfc2231Encoder.php | File | 1.4 KB | 0644 |
|