File Editor
Directories:
.. (Back)
Admin
Ajax
Asset
Context
Customizer
Debug_Bar
Dialog
Documentation
Duplicate
Editor
Image
JSON_LD
Languages
Log
Meta
Models
Onboarding
PUE
Process
Promoter
REST
Repository
Service_Providers
Shortcode
Support
Tabbed_View
Tooltip
Traits
Utils
Validator
Values
Widget
Files:
Abstract_Deactivation.php
Abstract_Plugin_Register.php
App_Shop.php
Assets.php
Assets_Pipeline.php
Autoloader.php
Cache.php
Cache_Listener.php
Changelog_Reader.php
Container.php
Context.php
Cost_Utils.php
Credits.php
Customizer.php
DB_Lock.php
Data.php
Date_Utils.php
Db.php
Debug.php
Dependency.php
Deprecation.php
Editor.php
Error.php
Exception.php
Extension.php
Extension_Loader.php
Feature_Detection.php
Field.php
Field_Conditional.php
Log.php
Main.php
Notices.php
Plugin_Meta_Links.php
Plugins.php
Plugins_API.php
Post_History.php
Post_Transient.php
Promise.php
Repository.php
Rewrite.php
Settings.php
Settings_Manager.php
Settings_Tab.php
Simple_Table.php
Support.php
Tabbed_View.php
Template.php
Template_Part_Cache.php
Templates.php
Terms.php
Timezones.php
Tracker.php
Updater.php
Validate.php
View_Helpers.php
Create New File
Create
Edit File: Exception.php
<?php /** * Class Tribe__Exception * * Handles exceptions to log when not in debug mode. */ class Tribe__Exception extends Exception { /** * @var Exception */ private $original_exception; /** * Tribe__Exception constructor. * * @param Exception $original_exception */ public function __construct( Exception $original_exception ) { $this->original_exception = $original_exception; } /** * Handles the exception throwing the original when debugging (`WP_DEBUG` defined and `true`) * or quietly logging when `WP_DEBUG` is `false` or not set. * * @return bool `true` if the message was logged, `false` otherwise. * * @throws Exception */ public function handle() { $debug = defined( 'WP_DEBUG' ) && WP_DEBUG; if ( $debug ) { $this->throw_original_exception(); } return $this->log_original_exception_message(); } /** * @return string */ private function get_log_type_for_exception_code( $code ) { $map = array( // @todo [BTRIA-583]: Let's add a decent exception code to log type map here. ); return isset( $map[ $code ] ) ? $map[ $code ] : Tribe__Log::ERROR; } /** * Throws the original exception. * * Provided as a manual override over the default `WP_DEBUG` dependent behaviour. * * @see Tribe__Exception::handle() * * @throws Exception */ public function throw_original_exception() { throw $this->original_exception; } /** * Logs the original exception message. * * Provided as a manual override over the default `WP_DEBUG` dependent behaviour. * * @see Tribe__Exception::handle() * * @return bool `true` if the message was logged, `false` otherwise. */ private function log_original_exception_message() { if ( ! class_exists( 'Tribe__Log' ) ) { return false; } $logger = new Tribe__Log(); $message = $this->original_exception->getMessage(); $log_type = $this->get_log_type_for_exception_code( $this->original_exception->getCode() ); $src = $this->original_exception->getFile() . ':' . $this->original_exception->getLine(); $logger->log( $message, $log_type, $src ); return true; } }
Save Changes
Rename File
Rename