3v4l.org

run code in 300+ PHP versions simultaneously
<?php /** * Gestiona información de tabla "Estaciones" * * Gestiona información de tabla "Estaciones". * Centraliza lo relativo a la gestión de estaciones y salas * El objetivo es centralizar las distintas tareas e informaciones en una única * aplicación web, o que de ésta se invoquen las otras disponibles. * * @author Héctor Correa * @version 2 * Comienzo 2017 */ require_once 'gryt_config.php'; require (RUTA_LIBPHP.'/Classes/GRYT/class_estaciones.php'); require (RUTA_LIBPHP.'/Classes/GRYT/class_estaciones_excel.php'); require_once 'gryt_setupSmarty.php'; require_once 'gryt_funcs4devel.php'; // Funciones útiles para depurar el código en la etapa de desarrollo $_Version = '2'; $_Cambios = '09/02/2018'; // Tomo la solicitud enviada por la página $_opcion = !isset($_REQUEST['opcion']) ? 'por defecto' : $_REQUEST['opcion']; // diferencia que información se desplegará en en la caja de información de la estación $_caso = !isset($_REQUEST['caso']) ? null : $_REQUEST['caso']; // Fijando parámetros para cada campo de filtrado $_unidad = !isset($_REQUEST['unidad']) ? null : $_REQUEST['unidad']; $_departamento = !isset($_REQUEST['departamento']) ? null : $_REQUEST['departamento']; $_codigo = !isset($_REQUEST['codigotx']) ? null : $_REQUEST['codigotx']; $_estacion = !isset($_REQUEST['estacion']) ? null : $_REQUEST['estacion']; $_id_telelink = !isset($_REQUEST['idtelelink']) ? null : $_REQUEST['idtelelink']; $_tipo_edificio = !isset($_REQUEST['tipoedificio']) ? null : $_REQUEST['tipoedificio']; $_IDE = !isset($_REQUEST['esIDEstacion']) ? null : $_REQUEST['esIDEstacion']; $_Dir = !isset($_REQUEST['esDireccion']) ? null : $_REQUEST['esDireccion']; $_Clo = !isset($_REQUEST['esCoord_Abs_Longitud'])? null : $_REQUEST['esCoord_Abs_Longitud']; $_Cla = !isset($_REQUEST['esCoord_Abs_Latitud']) ? null : $_REQUEST['esCoord_Abs_Latitud']; $_TelB = !isset($_REQUEST['esTelefoniaB']) ? 'NO' : $_REQUEST['esTelefoniaB']; $_Trsms = !isset($_REQUEST['esTransmisiones']) ? 'NO' : $_REQUEST['esTransmisiones']; $_Agrcn = !isset($_REQUEST['esAgregacion']) ? 'NO' : $_REQUEST['esAgregacion']; $_Tel = !isset($_REQUEST['esTelefono']) ? null : $_REQUEST['esTelefono']; $_UTE = !isset($_REQUEST['esCuentaUTE']) ? null : $_REQUEST['esCuentaUTE']; $_Sec = !isset($_REQUEST['esSeccionalPolicial']) ? null : $_REQUEST['esSeccionalPolicial']; $_Bom = !isset($_REQUEST['esBomberos']) ? null : $_REQUEST['esBomberos']; $_Not = !isset($_REQUEST['esNota']) ? null : $_REQUEST['esNota']; $_PuertosCx = !isset($_REQUEST['esPuertosCx']) ? null : $_REQUEST['esPuertosCx']; $_Zona = !isset($_REQUEST['zona']) ? null : $_REQUEST['zona']; $_TipoEd = !isset($_REQUEST['tipoed']) ? null : $_REQUEST['tipoed']; // Parametros de jTable para paginar y ordenar la consulta $_jtParam = array(); $_jtParam[0]= !isset($_REQUEST['jtSorting']) ? 'esUnidad ASC, esEstacion ASC' : $_REQUEST['jtSorting']; $_jtParam[1]= !isset($_REQUEST['jtStartIndex']) ? 0 : $_REQUEST['jtStartIndex']; $_jtParam[2]= !isset($_REQUEST['jtPageSize']) ? 1000 : $_REQUEST['jtPageSize']; function throw_ex($ex) { throw new Exception($ex); }try{ /** * Acciones del script Estaciones * * @param string $_opcion * * actualizar, crear, borrar, listado, cargar, complemento, telelink, ubicacion, excel * default es cargar la página inicial de Estaciones */ switch ($_opcion){ // Actualizar valores en registros case 'actualizar': { /* $sSQL = 'UPDATE '.ESTACION.' SET ' .'esDepartamento ' .' = "' .$_Dep .'", ' .'esUnidad ' .' = "' .$_Uni .'", ' .'esCodigo ' .' = "' .$_Cod .'", ' .'esEstacion ' .' = "' .$_Est .'", ' .'esDireccion ' .' = "' .$_Dir .'", ' .'esCoord_Abs_Longitud ' .' = "' .$_Clo .'", ' .'esCoord_Abs_Latitud ' .' = "' .$_Cla .'", ' .'esTipoEdificacion ' .' = "' .$_Ted .'", ' .'esTelefoniaB ' .' = "' .$_TelB .'", ' .'esTransmisiones' .' = "' .$_Trsms .'", ' .'esAgregacion' .' = "' .$_Agrcn .'", ' .'esTelefono ' .' = "' .$_Tel .'", ' .'esCuentaUTE ' .' = "' .$_UTE .'", ' .'esSeccionalPolicial ' .' = "' .$_Sec .'", ' .'esBomberos ' .' = "' .$_Bom .'", ' .'esNota ' .' = "' .$_Not .'", ' .'esIDTelelink ' .' = "' .$_IDTelelink .'", ' .'esPuertosCx ' .' = "' .$_PuertosCx .'" ' .'WHERE esIDEstacion = ' .$_IDE .';'; $_dbLink = conectarBD(); $result = mysqli_query ($_dblink ,$sSQL) or throw_ex( " ACTUALIZANDO "."<br><br>". mysqli_error($_dblink )."<br><br>".$sSQL); mysqli_free_result($result); mysqli_close($_dblink ); //Return result to jTable $jTableResult = array(); $jTableResult['Result'] = "OK"; print json_encode($jTableResult); break; */ } // Crear nuevos registros case 'crear': { /* $sSQL = 'INSERT INTO '.ESTACION.' ('; .'esDepartamento, esUnidad, esCodigo, esEstacion, esDireccion, ' .'esCoord_Abs_Longitud, esCoord_Abs_Latitud, esTipoEdificacion, ' .'esTelefono, esCuentaUTE, esSeccionalPolicial, esBomberos, esNota, esIDTelelink, esPuertosCx) ' .'VALUES ("'.$_Dep.'", "'.$_Uni.'", "'.$_Cod.'", "'.$_Est.'", "' .$_Dir.'", "'.$_Clo.'", "'.$_Cla.'", "'.$_Ted.'", "'.$_Tel.'", "' .$_UTE.'", "'.$_Sec.'", "'.$_Bom.'", "'.$_Not.'", "'.$_IDTelelink.'", "'.$_PuertosCx.'");'; $_dblink = conectarBD(); $result = mysqli_query ($_dblink ,$sSQL) or throw_ex( ' CREANDO '.'<br /><br />'.mysqli_error($_dblink ).'<br /><br />'.$sSQL); // Obtiene el último registro ingresado para devolverlo a jTable $result = mysqli_query($_dblink ,'SELECT * FROM '.ESTACION.' WHERE esIDEstacion = LAST_INSERT_ID();'); $row = mysqli_fetch_array($result); mysqli_free_result($result); mysqli_close($_dblink ); // Devuelve los resultados a jTable $jTableResult = array(); $jTableResult['Result'] = 'OK'; $jTableResult['Record'] = $row; print json_encode($jTableResult); break; */ } // Borrar un registro case "borrar": { /* $sSQL = "DELETE FROM ".ESTACION." WHERE esIDEstacion = ".$_IDE.";"; $result = mysqli_query($_dblink ,$sSQL) or throw_ex( " BORRANDO "."<br><br>". mysqli_error($_dblink )."<br><br>".$sSQL); break; */ } case 'listado': { $smarty = new Smarty_GRYT(); $smarty-> caching = false; $smarty-> assign('RutaApp','../../../GRYT/'); $smarty-> assign('Nivel',$_SESSION['Nivel']); $smarty-> assign('Unidad',$_unidad); $smarty-> assign('Departamento',$_departamento); $smarty-> assign('Estacion',$_estacion); $smarty-> assign('TipoEd',$_tipo_edificio); $smarty-> assign('IdTelelink',$_id_telelink); $smarty-> assign('Codigo',$_codigo); $smarty-> display('estaciones_lista.tpl'); break; } // Cargar lista de registros por defecto. Equivalente a action=list case 'cargar': { // CondicionesDeFiltrado $_opciones_filtro = 'ID Estacion: ' .$_IDE .' Nombre: ' .$_estacion .' Unidad:' .$_unidad .' Departamento: ' .$_departamento .' Tipo de edificio: ' .$_tipo_edificio .' Id de Telelink: ' .$_id_telelink .' Código Tx: ' .$_codigo; guardarLOGaFichero('Estaciones', 'cargar:', $_opciones_filtro, 'DEBUG'); $_nodos = new Estacion; if (isset($_IDE)) { $_nodos-> set_ID_Estacion($_IDE); }else{ $_nodos-> set_Nombre_Estacion($_estacion); $_nodos-> set_Unidad($_unidad); $_nodos-> set_Departamento($_departamento); $_nodos-> set_Tipo_Edificio($_tipo_edificio); $_nodos-> set_ID_Telelink($_id_telelink); $_nodos-> set_Codigo_Tx($_codigo); $_nodos-> set_Orden($_jtParam); } $_nodos-> get(); print $_nodos->datos_json; break; } case 'complemento': { $_nodos = new Estacion; $smarty = new Smarty_GRYT(); // Crea las opciones que aparecerán en los combos del filtro $smarty-> caching = false; $_nodos->obtUnidades(); $smarty->assign('Zonas', ($_nodos->crearOptions())); $_nodos->obtDepartamentos(); $smarty->assign('Departamentos', ($_nodos->crearOptions())); $_nodos->obtTiposDeEdificio(); $smarty->assign('TiposEdificio', ($_nodos->crearOptions())); $smarty-> assign('Unidad',$_SESSION['Unidad']); $smarty-> assign('Usuario',$_SESSION['CedUsr']); $smarty-> assign('RutaApp',"../../../GRYT/"); $smarty-> assign('Version', $_Version); $smarty-> assign('Cambios', $_Cambios); $smarty-> assign('RutaApp','../../../GRYT/'); $smarty-> assign('Nivel',$_SESSION['Nivel']); $smarty-> assign('Unidad',$_unidad); $smarty-> assign('Departamento',$_departamento); $smarty-> assign('Estacion',$_estacion); $smarty-> assign('TipoEd',$_tipo_edificio); $smarty-> assign('IdTelelink',$_id_telelink); $smarty-> assign('Codigo',$_codigo); $smarty-> display('estaciones_main.tpl'); break; } case 'ubicacion': { $jTableResult = array(); $jTableResult =listarUNAestacion($_IDE); print json_encode($jTableResult); break; } case 'excel': { $_nodos = new Estacion; if (isset($_IDE)) { $_nodos-> set_ID_Estacion($_IDE); }else{ $_nodos-> set_Nombre_Estacion($_estacion); $_nodos-> set_Unidad($_unidad); $_nodos-> set_Departamento($_departamento); $_nodos-> set_Tipo_Edificio($_tipo_edificio); $_nodos-> set_ID_Telelink($_id_telelink); $_nodos-> set_Codigo_Tx($_codigo); } $_nodos-> get(); $_planilla = new ListaEstacion(); $_planilla->subtitulo = 'De prueba'; $_planilla->datos = $_nodos->datos_crudos; $_planilla->construirPlanilla(); break; } case 'datosEstacion': { $_nodos = new Estacion; $_nodos-> set_ID_Estacion($_IDE); $_nodos-> get(); switch ($_caso) { case 'telefonos': { print ($_nodos->obtCamposDeTelefonos()); break; } default: { print ($_nodos->obtCamposDeDatos()); } } break; } default: { $smarty = new Smarty_GRYT(); $smarty-> assign('Unidad',$_SESSION['Unidad']); $smarty-> assign('Nivel',$_SESSION['Nivel']); $smarty-> caching = false; $smarty-> assign('RutaApp',"../../../GRYT/"); $smarty-> assign('Version', $_Version); $smarty-> assign('Cambios', $_Cambios); $smarty-> display('estaciones.tpl'); break; } } } catch(Exception $ex) { // Registra la ocurrencia de un error $ex .= chr(9).chr(10). $_SESSION['Usuario']; guardarLOGaFichero('Log de Errores', 'estaciones.php', $ex, 'ERROR'); echo $ex; }

Here you find the average performance (time & memory) of each version. A grayed out version indicates it didn't complete successfully (based on exit-code).

VersionSystem time (s)User time (s)Memory (MiB)
8.3.60.0070.01418.30
8.3.50.0080.00818.03
8.3.40.0180.00319.14
8.3.30.0120.00319.05
8.3.20.0050.00320.47
8.3.10.0050.00323.64
8.3.00.0080.00019.68
8.2.180.0170.00318.31
8.2.170.0060.00922.96
8.2.160.0140.00020.52
8.2.150.0040.00824.18
8.2.140.0080.00024.66
8.2.130.0050.00320.60
8.2.120.0040.00426.35
8.2.110.0060.00321.18
8.2.100.0060.00617.97
8.2.90.0080.00018.16
8.2.80.0030.00519.11
8.2.70.0030.00518.05
8.2.60.0040.00418.16
8.2.50.0050.00318.22
8.2.40.0060.00320.71
8.2.30.0080.00319.36
8.2.20.0030.00518.24
8.2.10.0050.00318.18
8.2.00.0000.00918.36
8.1.280.0180.00325.92
8.1.270.0000.00822.06
8.1.260.0000.00826.35
8.1.250.0080.00028.09
8.1.240.0090.00022.27
8.1.230.0060.00620.92
8.1.220.0040.00417.77
8.1.210.0080.00019.03
8.1.200.0030.00617.48
8.1.190.0030.00517.63
8.1.180.0080.00018.10
8.1.170.0030.00518.84
8.1.160.0040.00419.05
8.1.150.0040.00420.41
8.1.140.0040.00417.70
8.1.130.0000.00719.11
8.1.120.0040.00417.60
8.1.110.0000.00817.54
8.1.100.0000.00817.61
8.1.90.0060.00317.58
8.1.80.0000.00817.57
8.1.70.0030.00617.61
8.1.60.0000.01017.76
8.1.50.0040.00417.70
8.1.40.0000.00817.77
8.1.30.0000.00817.75
8.1.20.0000.00817.84
8.1.10.0080.00017.73
8.1.00.0080.00017.71
8.0.300.0000.00820.41
8.0.290.0050.00517.13
8.0.280.0070.00018.69
8.0.270.0040.00417.50
8.0.260.0000.00817.06
8.0.250.0070.00017.18
8.0.240.0030.00717.27
8.0.230.0070.00317.30
8.0.220.0070.00017.08
8.0.210.0000.00717.21
8.0.200.0000.00717.31
8.0.190.0090.00017.16
8.0.180.0060.00317.21
8.0.170.0060.00317.30
8.0.160.0000.00717.30
8.0.150.0000.00717.17
8.0.140.0030.00517.14
8.0.130.0060.00013.66
8.0.120.0000.00817.18
8.0.110.0040.00417.15
8.0.100.0030.00617.23
8.0.90.0050.00317.04
8.0.80.0090.00917.14
8.0.70.0000.00717.13
8.0.60.0050.00317.20
8.0.50.0060.00317.25
8.0.30.0100.00817.32
8.0.20.0080.01117.40
8.0.10.0020.00517.19
8.0.00.0130.00717.11
7.4.330.0060.00015.55
7.4.320.0030.00316.80
7.4.300.0030.00316.63
7.4.290.0040.00416.78
7.4.280.0040.00416.63
7.4.270.0000.00716.78
7.4.260.0040.00416.56
7.4.250.0060.00316.66
7.4.240.0000.00816.69
7.4.230.0030.00316.68
7.4.220.0040.00416.48
7.4.210.0060.00916.67
7.4.200.0000.00816.54
7.4.160.0080.00816.62
7.4.150.0090.00917.40
7.4.140.0140.00917.86
7.4.130.0070.01016.66
7.4.120.0140.00816.69
7.4.110.0140.00416.72
7.4.100.0110.01116.80
7.4.90.0140.00316.51
7.4.80.0170.00819.39
7.4.70.0030.01716.51
7.4.60.0070.01016.72
7.4.50.0040.01416.59
7.4.40.0090.00916.48
7.4.10.0100.01014.83
7.4.00.0110.00615.08
7.3.330.0030.00313.40
7.3.320.0030.00313.31
7.3.310.0030.00316.36
7.3.300.0040.00416.35
7.3.290.0110.00916.42
7.3.280.0160.01216.45
7.3.270.0060.01217.40
7.3.260.0090.01216.57
7.3.250.0100.00716.37
7.3.240.0090.00916.58
7.3.230.0060.01216.59
7.3.210.0070.01016.65
7.3.200.0160.00016.48
7.3.190.0120.00616.45
7.3.180.0000.02116.55
7.3.170.0070.00916.46
7.3.160.0100.00716.68
7.3.130.0070.01115.16
7.3.120.0090.00914.75
7.3.110.0120.00914.56
7.3.100.0040.00814.98
7.3.90.0080.00814.93
7.3.80.0060.00614.85
7.3.70.0080.00814.71
7.3.60.0000.00815.02
7.3.50.0060.00314.88
7.3.40.0040.01114.81
7.3.30.0060.00914.87
7.3.20.0040.01116.34
7.3.10.0050.00916.71
7.3.00.0050.01016.38
7.2.330.0120.00616.71
7.2.320.0120.00916.77
7.2.310.0070.01116.56
7.2.300.0090.01216.59
7.2.290.0170.00016.58
7.2.260.0100.01015.05
7.2.250.0030.01714.70
7.2.240.0070.01015.11
7.2.230.0000.00915.22
7.2.220.0000.01815.10
7.2.210.0000.01115.01
7.2.200.0040.01115.23
7.2.190.0100.00315.16
7.2.180.0000.01615.05
7.2.170.0030.01314.90
7.2.160.0060.00615.22
7.2.150.0030.01316.96
7.2.140.0060.00616.96
7.2.130.0090.00516.76
7.2.120.0050.01016.64
7.2.110.0070.01016.78
7.2.100.0070.00316.65
7.2.90.0020.01116.93
7.2.80.0050.00716.67
7.2.70.0050.00616.57
7.2.60.0070.00816.92
7.2.50.0100.00516.75
7.2.40.0040.01316.82
7.2.30.0090.00616.95
7.2.20.0110.00917.22
7.2.10.0120.00616.98
7.2.00.0090.00917.15
7.1.330.0110.00415.85
7.1.320.0000.01115.90
7.1.310.0050.00315.87
7.1.300.0000.00915.46
7.1.290.0030.01315.70
7.1.280.0060.00615.55
7.1.270.0080.00815.69
7.1.260.0070.00715.49
7.1.250.0080.00715.59
7.1.240.0060.00915.73
7.1.230.0030.00715.55
7.1.220.0090.00315.44
7.1.210.0040.00815.65
7.1.200.0030.00815.51
7.1.190.0080.00615.63
7.1.180.0060.00615.68
7.1.170.0030.00815.60
7.1.160.0090.00915.76
7.1.150.0060.00615.59
7.1.140.0040.01216.28
7.1.130.0100.00816.23
7.1.120.0100.00816.28
7.1.110.0160.00515.98
7.1.100.0100.01216.09
7.1.90.0050.01315.70
7.1.80.0100.01215.95
7.1.70.0130.01015.28
7.1.60.0180.00624.40
7.1.50.0200.01024.38
7.1.40.0160.01023.99
7.1.30.0150.01324.29
7.1.20.0180.00924.17
7.1.10.0290.00815.19
7.1.00.0130.00715.25
7.0.330.0070.00715.18
7.0.320.0030.01314.98
7.0.310.0030.00614.98
7.0.300.0040.00415.22
7.0.290.0030.01415.27
7.0.280.0070.00415.45
7.0.270.0060.00615.42
7.0.260.0030.01315.16
7.0.250.0000.00915.27
7.0.240.0030.00915.43
7.0.230.0160.00015.38
7.0.220.0090.00615.33
7.0.210.0100.00315.28
7.0.200.0030.00615.15
7.0.190.0110.00415.24
7.0.180.0070.00715.30
7.0.170.0090.00615.36
7.0.160.0080.00815.16
7.0.150.0090.00615.34
7.0.140.0040.00915.27
7.0.130.0000.01915.38
7.0.120.0040.01115.20
7.0.110.0030.00615.36
7.0.100.0070.01015.37
7.0.90.0000.01615.13
7.0.80.0080.00815.47
7.0.70.0030.00615.22
7.0.60.0040.01115.14
7.0.50.0070.01115.43
7.0.40.0060.00613.26
7.0.30.0070.01013.34
7.0.20.0060.00313.20
7.0.10.0000.01313.27
7.0.00.0000.01013.10
5.6.400.0000.01414.34
5.6.390.0070.00714.03
5.6.380.0060.00614.54
5.6.370.0030.00714.23
5.6.360.0070.00414.20
5.6.350.0030.01314.09
5.6.340.0030.01014.30
5.6.330.0060.01214.20
5.6.320.0060.00914.46
5.6.310.0030.00714.57
5.6.300.0000.01614.16
5.6.290.0000.01314.21
5.6.280.0030.01714.06
5.6.270.0030.00614.21
5.6.260.0040.00714.32
5.6.250.0120.00914.27
5.6.240.0070.01314.48
5.6.230.0000.01414.26
5.6.220.0060.00614.12
5.6.210.0030.01314.18
5.6.200.0070.01014.42
5.6.190.0160.00014.20
5.6.180.0000.01314.18
5.6.170.0000.01914.27
5.6.160.0040.01114.19
5.6.150.0090.00914.05
5.6.140.0070.00314.27
5.6.130.0040.01413.98
5.6.120.0000.01414.13
5.6.110.0030.01014.39
5.6.100.0040.00714.14
5.6.90.0070.00414.45
5.6.80.0000.00914.14
5.6.70.0060.00914.35
5.6.60.0060.01014.05
5.6.50.0070.01014.30
5.6.40.0070.01014.21
5.6.30.0070.01013.86
5.6.20.0090.00613.85
5.6.10.0030.01314.27
5.6.00.0100.00314.06

preferences:
49 ms | 401 KiB | 5 Q