diff core/lib/Drupal/Component/Utility/ToStringTrait.php @ 0:4c8ae668cc8c

Initial import (non-working)
author Chris Cannam
date Wed, 29 Nov 2017 16:09:58 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/core/lib/Drupal/Component/Utility/ToStringTrait.php	Wed Nov 29 16:09:58 2017 +0000
@@ -0,0 +1,43 @@
+<?php
+
+namespace Drupal\Component\Utility;
+
+/**
+ * Wraps __toString in a trait to avoid some fatals.
+ */
+trait ToStringTrait {
+
+  /**
+   * Implements the magic __toString() method.
+   */
+  public function __toString() {
+    try {
+      return (string) $this->render();
+    }
+    catch (\Exception $e) {
+      // User errors in __toString() methods are considered fatal in the Drupal
+      // error handler.
+      trigger_error(get_class($e) . ' thrown while calling __toString on a ' . get_class($this) . ' object in ' . $e->getFile() . ' on line ' . $e->getLine() . ': ' . $e->getMessage(), E_USER_ERROR);
+      // In case we are using another error handler that did not fatal on the
+      // E_USER_ERROR, we terminate execution. However, for test purposes allow
+      // a return value.
+      return $this->_die();
+    }
+  }
+
+  /**
+   * For test purposes, wrap die() in an overridable method.
+   */
+  protected function _die() {
+    die();
+  }
+
+  /**
+   * Renders the object as a string.
+   *
+   * @return string|object
+   *   The rendered string or an object implementing __toString().
+   */
+  abstract public function render();
+
+}