/** * Método para manejar las excepciones ocurridas en la aplicación * @param exception Excepción producida (\Exception o \Error) * @author Esteban De La Fuente Rubio, DeLaF (esteban[at]delaf.cl) * @version 2016-01-07 */ public static function handler($exception) { ob_clean(); // Generar arreglo $data = array('exception' => get_class($exception), 'message' => $exception->getMessage(), 'trace' => $exception->getTraceAsString(), 'code' => $exception->getCode(), 'severity' => isset($exception->severity) ? $exception->severity : LOG_ERR); // renderizar dependiendo de si es una web o es una shell if (isset($_SERVER['REQUEST_URI'])) { $controller = new Controller_Error(new Network_Request(), new Network_Response()); $controller->error_reporting = Configure::read('debug'); $controller->display($data); $controller->shutdownProcess(); $controller->response->status($data['code']); $controller->response->send(); } else { $stdout = new Shell_Output('php://stdout'); $stdout->write("\n" . '<error>' . $data['exception'] . ':</error>', 2); $stdout->write("\t" . '<error>' . str_replace("\n", "\n\t", $data['message']) . '</error>', 2); $stdout->write("\t" . '<error>' . str_replace("\n", "\n\t", $data['trace']) . '</error>', 2); } }
/** * Método para mostrar estadísticas finales de la ejecución del comando * @param stream Se permite elegir a través de que stream se enviarán las estadísticas * @author Esteban De La Fuente Rubio, DeLaF (esteban[at]delaf.cl) * @version 2015-02-03 */ public function showStats($stream = 'php://stderr') { $out = new Shell_Output($stream); // tiempo que tomó la ejecución del comando $time = microtime(true) - TIME_START; if ($time < 60) { $out->write('Proceso ejecutado en ' . num($time, 1) . ' segundos.' . "\n"); } else { if ($time < 3600) { $out->write('Proceso ejecutado en ' . num($time / 60, 1) . ' minutos.' . "\n"); } else { $out->write('Proceso ejecutado en ' . num($time / 3600, 1) . ' horas.' . "\n"); } } }