--- /dev/null
+<?php
+
+/*
+ * This file is part of Psy Shell.
+ *
+ * (c) 2012-2017 Justin Hileman
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Psy\Exception;
+
+/**
+ * A "fatal error" Exception for Psy.
+ */
+class FatalErrorException extends \ErrorException implements Exception
+{
+ private $rawMessage;
+
+ /**
+ * Create a fatal error.
+ *
+ * @param string $message (default: "")
+ * @param int $code (default: 0)
+ * @param int $severity (default: 9000)
+ * @param string $filename (default: null)
+ * @param int $lineno (default: null)
+ * @param \Exception $previous (default: null)
+ */
+ public function __construct($message = '', $code = 0, $severity = 9000, $filename = null, $lineno = null, $previous = null)
+ {
+ $this->rawMessage = $message;
+ $message = sprintf('PHP Fatal error: %s in %s on line %d', $message, $filename ?: "eval()'d code", $lineno);
+ parent::__construct($message, $code, $severity, $filename, $lineno, $previous);
+ }
+
+ /**
+ * Return a raw (unformatted) version of the error message.
+ *
+ * @return string
+ */
+ public function getRawMessage()
+ {
+ return $this->rawMessage;
+ }
+}