Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 16-03-2011
Delfino Delfino is offline
Miembro
 
Registrado: jul 2003
Ubicación: Madrid
Posts: 974
Poder: 21
Delfino Va por buen camino
Exception logging en Delphi

Hola foreros,

Quiero compartir con vosotros el tema del exception logging en Delphi.

En este enlace hay un truco importante como hacerlo.

Pero yo prefiero utilizar el componente TJvDebugHandler de la suite open source JVCL activando las opciones para el proyecto de generar y insertar datos jdbg. De esa manera tengo todo el call stack incluido el numero de la linea de código donde salto la exception.

Saludos..
__________________
¿Microsoft? No, gracias..

Última edición por Delfino fecha: 16-03-2011 a las 14:23:56.
Responder Con Cita
  #2  
Antiguo 16-03-2011
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 22
Caro Va por buen camino
Muchas gracias Delfino.

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.
Responder Con Cita
  #3  
Antiguo 17-03-2011
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.737
Poder: 20
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
Muuuy bueno!
Muuuy simple!
Es lo que estaba buscando desde ayer, tenía una serie de try..except y try..finally y no lograba ver en qué punto fallaba.
Una sola compilación y lo solucioné, gracias al log que genera.
Responder Con Cita
  #4  
Antiguo 18-03-2011
Delfino Delfino is offline
Miembro
 
Registrado: jul 2003
Ubicación: Madrid
Posts: 974
Poder: 21
Delfino Va por buen camino
Lo has hecho con el componente TJvDebugHandler? o con las units ExceptLog y MemCheck?
__________________
¿Microsoft? No, gracias..
Responder Con Cita
  #5  
Antiguo 18-03-2011
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.737
Poder: 20
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
Cita:
Lo has hecho con el componente TJvDebugHandler? o con las units ExceptLog y MemCheck?
Con MemCheck y ExceptLog.

Yo utilizo MemCheck en todos mis proyectos.
Siempre compilo con la opción de "Include TD32 Debug Info" activada y si tras las pruebas sale el informe de errores de memoria, corrijo el código hasta que sea correcto.
Antes de entregarlo al cliente quito la opción de compilacion y quito la unidad MemCheck del proyecto.
Compilo, entrego los binarios y a seguir programando al siguiente versión o a corregir el siguiente bug.

Utilizo mucho try..except y try..finally para que la aplicación informe de errores y siga corriendo correctamente. A veces están anidados y dentro de este bloque se llaman a procedimientos y funciones que también tienen estos bloques.
Pongo breakpoints en varios lugares, pero no pasa en un orden correcto porque se los salta y ejecuta el bloque except o finally.

Cuando ya esta demasiado liado, una erramienta que después de la ejecución te informe de las excepciones por las que ha pasado me ha ayudado enormemente.

Código Delphi [-]
{Esto ejecutaría 
- parte de Proc1 y su bloque Finally, 
- el bloque Finally de Proc2 y 
- el bloque Except del programa

Esto no parará en el Breakpoint
pero ExceptLog te dirá que en Proc1 saltó una Excepción "Division by Cero"
}

procedure proc1
begin
  try
     ...
     a := 1 / 0; // Exception Division by Cero
     ...
     BreakPoint 
     ...
  finally
     ...
  end;
end;

procedure proc2
begin
  try
     Proc1
     ...
  finally
     ...
  end;
end;

procedure Proc3
begin
   try
      Proc2;
   finally
      ...
   end;
end;

begin
   try
      Proc3;
   except
      ...
   end;
end;

Última edición por duilioisola fecha: 18-03-2011 a las 13:26:42.
Responder Con Cita
  #6  
Antiguo 20-03-2011
Delfino Delfino is offline
Miembro
 
Registrado: jul 2003
Ubicación: Madrid
Posts: 974
Poder: 21
Delfino Va por buen camino
Yo lo hago con el componente TJvDebugHandler.

En el evento OnOtherDestination pongo el siguiente codigo :

Código Delphi [-]
 Application.MessageBox(PChar(ErrorHandler.ExceptionStringList[0] + #13#10 +
                              ErrorHandler.ExceptionStringList[1]), 'Error..', MB_ICONERROR);
Asi el usuario solo ve el mensaje del error.

El detalle del error con el numero de linea queda registrado en el fichero indicado en la propiedad Filename. Ademas la propiedad UnhandledExceptionsOnly hace que solo los errores no tratados en un bloque try..except sean mostrados.

Espero que sirva..
__________________
¿Microsoft? No, gracias..
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Error Logging into to requested server : Isc_service_attach() not implemented Jebus Firebird e Interbase 0 05-02-2009 21:39:37
Error Exception Viky Impresión 2 02-12-2008 23:44:20
Error logging into the request server pache Firebird e Interbase 1 08-05-2006 15:12:30
exception arieliten Conexión con bases de datos 3 21-04-2005 00:27:59
Exception EDBEngineError lionsoft Varios 9 23-09-2004 15:27:02


La franja horaria es GMT +2. Ahora son las 08:36:14.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi