Punic v3.3.0
  • Namespace
  • Class
  • Tree
  • Todo
  • Deprecated

Namespaces

  • Punic
    • Exception

Classes

  • Punic\Calendar
  • Punic\Comparer
  • Punic\Currency
  • Punic\Data
  • Punic\Language
  • Punic\Misc
  • Punic\Number
  • Punic\Phone
  • Punic\Plural
  • Punic\Territory
  • Punic\Unit

Exceptions

  • Punic\Exception
  • Punic\Exception\BadArgumentType
  • Punic\Exception\BadDataFileContents
  • Punic\Exception\DataFileNotFound
  • Punic\Exception\DataFileNotReadable
  • Punic\Exception\DataFolderNotFound
  • Punic\Exception\InvalidDataFile
  • Punic\Exception\InvalidLocale
  • Punic\Exception\InvalidOverride
  • Punic\Exception\NotImplemented
  • Punic\Exception\ValueNotInList
 1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 
<?php

namespace Punic\Exception;

/**
 * An exception raised when an invalid data override is provided.
 */
class InvalidOverride extends \Punic\Exception
{
    /**
     * Initializes the instance.
     *
     * @param mixed      $data     The data being overridden
     * @param mixed      $override The override data
     * @param \Exception $previous The previous exception used for the exception chaining
     */
    public function __construct($data, $override, $previous = null)
    {
        $message = 'Cannot override '.$this->dataToString($data).' with '.$this->dataToString($override);
        parent::__construct($message, \Punic\Exception::INVALID_OVERRIDE, $previous);
    }

    /**
     * Convert override data to a string.
     *
     * @param  mixed $data
     *
     * @return string
     */
    protected function dataToString($data)
    {
        if (is_array($data)) {
            return 'array with keys '.implode(', ', array_keys($data));
        }

        return gettype($data).' value '.$data;
    }
}
Punic v3.3.0 API documentation generated by ApiGen