annotate core/modules/serialization/src/Encoder/XmlEncoder.php @ 14:1fec387a4317

Update Drupal core to 8.5.2 via Composer
author Chris Cannam
date Mon, 23 Apr 2018 09:46:53 +0100
parents 7a779792577d
children 129ea1e6d783
rev   line source
Chris@0 1 <?php
Chris@0 2
Chris@0 3 namespace Drupal\serialization\Encoder;
Chris@0 4
Chris@0 5 use Symfony\Component\Serializer\Encoder\EncoderInterface;
Chris@0 6 use Symfony\Component\Serializer\Encoder\DecoderInterface;
Chris@0 7 use Symfony\Component\Serializer\Encoder\SerializerAwareEncoder;
Chris@0 8 use Symfony\Component\Serializer\Encoder\XmlEncoder as BaseXmlEncoder;
Chris@0 9
Chris@0 10 /**
Chris@0 11 * Adds XML support for serializer.
Chris@0 12 *
Chris@0 13 * This acts as a wrapper class for Symfony's XmlEncoder so that it is not
Chris@0 14 * implementing NormalizationAwareInterface, and can be normalized externally.
Chris@14 15 *
Chris@14 16 * @internal
Chris@14 17 * This encoder should not be used directly. Rather, use the `serializer`
Chris@14 18 * service.
Chris@0 19 */
Chris@0 20 class XmlEncoder extends SerializerAwareEncoder implements EncoderInterface, DecoderInterface {
Chris@0 21
Chris@0 22 /**
Chris@0 23 * The formats that this Encoder supports.
Chris@0 24 *
Chris@0 25 * @var array
Chris@0 26 */
Chris@0 27 static protected $format = ['xml'];
Chris@0 28
Chris@0 29 /**
Chris@0 30 * An instance of the Symfony XmlEncoder to perform the actual encoding.
Chris@0 31 *
Chris@0 32 * @var \Symfony\Component\Serializer\Encoder\XmlEncoder
Chris@0 33 */
Chris@0 34 protected $baseEncoder;
Chris@0 35
Chris@0 36 /**
Chris@0 37 * Gets the base encoder instance.
Chris@0 38 *
Chris@0 39 * @return \Symfony\Component\Serializer\Encoder\XmlEncoder
Chris@0 40 * The base encoder.
Chris@0 41 */
Chris@0 42 public function getBaseEncoder() {
Chris@0 43 if (!isset($this->baseEncoder)) {
Chris@0 44 $this->baseEncoder = new BaseXmlEncoder();
Chris@0 45 $this->baseEncoder->setSerializer($this->serializer);
Chris@0 46 }
Chris@0 47
Chris@0 48 return $this->baseEncoder;
Chris@0 49 }
Chris@0 50
Chris@0 51 /**
Chris@0 52 * Sets the base encoder instance.
Chris@0 53 *
Chris@0 54 * @param \Symfony\Component\Serializer\Encoder\XmlEncoder $encoder
Chris@0 55 */
Chris@0 56 public function setBaseEncoder($encoder) {
Chris@0 57 $this->baseEncoder = $encoder;
Chris@0 58 }
Chris@0 59
Chris@0 60 /**
Chris@0 61 * {@inheritdoc}
Chris@0 62 */
Chris@12 63 public function encode($data, $format, array $context = []) {
Chris@0 64 return $this->getBaseEncoder()->encode($data, $format, $context);
Chris@0 65 }
Chris@0 66
Chris@0 67 /**
Chris@0 68 * {@inheritdoc}
Chris@0 69 */
Chris@0 70 public function supportsEncoding($format) {
Chris@0 71 return in_array($format, static::$format);
Chris@0 72 }
Chris@0 73
Chris@0 74 /**
Chris@0 75 * {@inheritdoc}
Chris@0 76 */
Chris@12 77 public function decode($data, $format, array $context = []) {
Chris@0 78 return $this->getBaseEncoder()->decode($data, $format, $context);
Chris@0 79 }
Chris@0 80
Chris@0 81 /**
Chris@0 82 * {@inheritdoc}
Chris@0 83 */
Chris@0 84 public function supportsDecoding($format) {
Chris@0 85 return in_array($format, static::$format);
Chris@0 86 }
Chris@0 87
Chris@0 88 }