Skip to content

Latest commit

 

History

History
68 lines (55 loc) · 2.88 KB

05-02-01-Exceptions.md

File metadata and controls

68 lines (55 loc) · 2.88 KB
isChild
true

Exceptions

Exceptions are a standard part of most popular programming languages, but they are often overlooked by PHP programmers. Languages like Ruby are extremely Exception heavy, so whenever something goes wrong such as a HTTP request failing, or a DB query goes wrong, or even if an image asset could not be found, Ruby (or the gems being used) will throw an exception to the screen meaning you instantly know there is a mistake.

PHP itself is fairly lax with this, and a call to file_get_contents() will usually just get you a FALSE and a warning. Many older PHP frameworks like CodeIgniter will just return a false, log a message to their proprietary logs and maybe let you use a method like $this->upload->get_error() to see what went wrong. The problem here is that you have to go looking for a mistake and check the docs to see what the error method is for this class, instead of having it made extremely obvious.

Another problem is when classes automatically throw an error to the screen and exit the process. When you do this you stop another developer from being able to dynamically handle that error. Exceptions should be thrown to make a developer aware of an error, then they can choose how to handle this. E.g:

{% highlight php %}

subject('My Subject'); $email->body('How the heck are you?'); $email->to('[email protected]', 'Some Guy'); try { $email->send(); } catch(Fuel\Email\ValidationFailedException $e) { // The validation failed } catch(Fuel\Email\SendingFailedException $e) { // The driver could not send the email } {% endhighlight %} ### SPL Exceptions An Exception by default has no meaning and the most common to give it meaning is by setting its name: {% highlight php %} lot of custom Exceptions, some of which could have been avoided using the SPL Exceptions provided in the [SPL extension][splext]. If for example you use the `__call()` Magic Method and an invalid method is requested then instead of throwing a standard Exception which is vague, or creating a custom Exception just for that, you could just `throw new BadFunctionCallException;`. * [Read about Exceptions][exceptions] * [Read about SPL Exceptions][splexe] * [Nesting Exceptions In PHP][nesting-exceptions-in-php] * [Exception Best Practices in PHP 5.3][exception-best-practices53] [exceptions]: http://php.net/manual/en/language.exceptions.php [splexe]: http://php.net/manual/en/spl.exceptions.php [splext]: /#standard_php_library [exception-best-practices53]: http://ralphschindler.com/2010/09/15/exception-best-practices-in-php-5-3 [nesting-exceptions-in-php]: http://www.brandonsavage.net/exceptional-php-nesting-exceptions-in-php/