![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
||||
|
||||
|
Pues yo lo hago a través de la JVCL (componentes gratuitos) activando en las propiedades del proyecto la opción de menú "insert jclDebug".
Código:
00003: [18:52:55]Exception ENoResultSet: Error creating cursor handle
Exception
UnitName : DBTables
Procedure : TBDEDataSet.OpenCursor
Line : 4111 OffsetLine : 0
Deep of Except frame-dump : 7
UnitName : DBTables Procedure : TBDEDataSet.OpenCursor SourceName : DBTables.pas Line : 4112
UnitName : DB Procedure : TDataSet.SetActive SourceName : DB.pas Line : 8840
UnitName : SqlExplorer Procedure : TFRMSQL.btnAbrirClick SourceName : SqlExplorer.pas Line : 77
UnitName : SqlExplorer Procedure : TFRMSQL.btnAbrirClick SourceName : SqlExplorer.pas Line : 79
UnitName : Controls Procedure : TWinControl.MainWndProc SourceName : Controls.pas Line : 6137
UnitName : Controls Procedure : TWinControl.MainWndProc SourceName : Controls.pas Line : 6141
Última edición por Lepe fecha: 05-10-2005 a las 20:16:22. |
|
#2
|
||||
|
||||
|
Hola,
Lepe, muchas gracias por tu información, que me ha servido para probar el "JclDebug" e incluso implementarlo (a partir de uno de los ejemplos que se pueden encontrar) en XEditor. ¿Para qué demonios? Ahí está el caso. Este programa, cuando se produce una excepción, muestra al usuario un mensaje con la misma y le da la posibilidad de enviarme por correo un reporte de error. Entonces, me he dicho, hombre, si añades la información del "JclDebug" el reporte de error contendrá bastante más información, que podrá resultar muy útil para tratar de solucionar posibles problemas en el programa. Y dicho y hecho, más o menos, he conseguido que el reporte incluya la información que puede proporcionar en caso de excepción el "JclDebug". Ahora bien, parece ser que no puedo utilizar el compresor de ejecutables para comprimir el del programa susomentado, porque, entonces el "JclDebug" no funciona como debe y al producirse la excepción e intentar conseguir la información correspondiente se produce a su vez otra excepción y... para qué seguir. ![]() El programa ocupa ahora unos 3,44 MB, y comprimido se quedaba en menos de uno, pero, no es esto del todo importante, puesto que el programa instalador comprime el ejecutable (y el resto de archivos) sin que afecte al "JclDebug" y, al cabo, estamos hablando de que antes de implementar lo dicho el programa de instalación ocupaba unos 1,41 MB y ahora se quedaría en 1,95 MB. Puesto que la ejecución del programa no se ve ralentizada (es aquello de que ahora, incluso, no es preciso descomprimir el ejecutable cada que se pone en marcha el programa) y al convencerme el asunto como para pensar en publicar el programa de este modo, asumiendo que no irá comprimido y que el asistente de instalación ocupará un poco más, me pregunto todavía... ¿Merece la pena el reporte de error? ¿Es necesario o puede ser útil cuando el programa ya se ha publicado, quiero decir, cara al usuario? ¿Debería usar el "JclDebug" únicamente cuando esté trabajando yo mismo en el programa y dejar de usarlo a la hora de publicar el mismo? ¿Puedes tú mismo o alguien que esto lea decirme algo que me aclare un poco estas dudas que tengo? Muchas gracias de antemano. Si véis que me dejo algo en el tintero, me lo hacéis saber y veremos cómo hago para explicar lo que sea necesario explicar con más detalle. En todo caso, Lepe, gracias por la información, puesto que nada más sencillo que valerse uno del "JclDebug" (al menos para ciertas cosas, porque no es poco potente, a lo que se ve), sin olvidar el trabajo que les ha tenido que llevar a sus programadores el preparar algo así, claro está. Última edición por dec fecha: 06-10-2005 a las 02:50:07. Razón: Corrección del texto. |
|
#3
|
||||
|
||||
|
Como en este hilo se daba información general, eso mismo hice yo.
Para el caso de jclDebug, ha de tenerse en cuenta 2 cosas: - Hay que incluir en el primer formulario o Datamodule que crees el uses jclDebug, ya que realiza una inicialización en su unidad para empezar el "traceo" de excepciones. - En la distribución de tu ejecutable, tienes que distribuir un archivo .map que se crea al compilar, (abrelo con el bloc de notas para saber de que hablo). En este caso se tiene que distribuir un par de megas más, pero perece la pena. - Además de la información de jclDebug, se debe incluir las ventanas abiertas en tu aplicación (si son varias) para saber lo que hacia el usuario, (el objeto TScreen vale para eso). -En cuanto al uso de compresores de ejecutables, acabo de probarlo, y efectivamente el compresor elimina la información de debug, por lo que interfiere con JCLDEBUG, como ya sabemos: no se puede tener todo . Para el primer punto, yo me he construido mi propia jclDebug, que unicamente cambia los procedimientos por funciones y devuelve el error en una variable. Os lo dejo aqui: (El nombre de la unidad lleva el prefijo LP (Lepe) para que no interfiera con posibles modificaciones de la JCL) Saludos
saludos |
|
#4
|
||||
|
||||
|
Hola,
Cita:
Gracias Lepe por la información, en todo caso. |
|
#5
|
|||
|
|||
|
donde consigo los componentes
estoy buscandolos pero hasta ahora no los encuentro ..
y la ultima Lepe: a que te refieres con lo de las ventanas abiertas ? GRACIAS por tu ayuda Ingel |
|
#6
|
||||
|
||||
|
Hola,
Cita:
|
|
#7
|
||||
|
||||
|
Si tu programa tiene 60 o 70 ventanas y se produce una excepción del tipo '' is not a valid date... ¿En cual de las 70 ventanas se ha producido el error?.
Podríamos averiguarlo por el nombre de la unidad (UnitName del mensaje), pero también nos dá más información de los hábitos de ese usuario, es decir, si tiene varias ventanas de nuestro programa abiertas al mismo tiempo, o si abre una ventana, modifica lo que sea y la cierra; según los hábitos de los usuarios, podemos agilizar la apertura y cierre de las ventanas u otros detalles de nuestra aplicación. El bucle sería algo así:
Ni que decir tiene que todo esto debe grabarse en un .txt o .log y al usuario solo indicarle que ha habido un error y se ha guardado la información de depuración. Para el .log, ya que instalas la JVCL, tienes el TjvLogfile en la pestaña "Jv Utils" En cuanto a las preguntas de dec no puedo asegurar nada. Soy consciente de que en el .exe van algunos datos de la JCLdebug, tal y como dice la ventana que aparece tras hacer un Build Project estando activo el "insert jcl debug data", en mi caso, dice que el archivo .map son 3 megas, y la información de debug incluida en el .exe son 414 kb. No me queda claro si va todo en el exe o no. Compilar sin información de debug y con información de debug si varía 400 kb en el tamaño del ejecutable. saludos saludos |
|
#8
|
||||
|
||||
|
Hola,
Gracias Lepe, por todo. ![]() |
|
#9
|
|||
|
|||
|
Un ejemplo, please
Que corcholis, estoy intentando obtener resultados como los que menciona Lepe, pero no consigo ver esta tipo de info:
Cita:
¿Pero como puedo recoger los errores de ejecución? ¿Podrías ponernos un ejemplo Lepe, de cómo utilizarlo?, ¿cómo llamar a la funciónLogException(ExceptObj: TObject; ExceptAddr: Pointer; IsOS: Boolean):string y recoger el string en el map o en un .log con el TJvLogFile? Gracias, profe... y perdona mi torpeza. |
|
#10
|
|||
|
|||
|
El ejemplo
Me voy a contestar a mi mismo, quizá para no darme vergüenza, ...pero alguien más puede caer. Me ha costado q en cupiera en la cabezota. Quizá por lo puramente simple.
Lepe: te mereces un altar, si me mandas una fotillo, así con un poco de aura, me la pego en el margen de mi pantalla. Esto es alu cinate e im presionante, chicos (y todo en 2 palabras, ;-) ) el resultado en el log: Código:
[10/10/2005 21:29:46]Exception EAccessViolation: Access violation at address 00524D84 in module 'PbaDBX.exe'. Write of address 00000000 (OS Exception) Exception UnitName : Unit1 Procedure : TForm1.BotonErrorClick Line : 210 OffsetLine : 4 Deep of Except frame-dump : 3 UnitName : Controls Procedure : TWinControl.MainWndProc SourceName : Line : 0 UnitName : Controls Procedure : TWinControl.MainWndProc SourceName : Line : 0 //Fin reporte// - ERROR > ...aaauuuuammmmm ...(te estoy cantando unos canticos) ...admirado y venerado Lepe. |
|
#11
|
||||
|
||||
|
Saludos
Cita:
![]()
__________________
Van Troi De León (Not) Guía, Code vB:=Delphi-SQL, ¿Cómo? Viajar en el tiempo no es teóricamente posible, pues si lo fuera, ya estarían aqui contándonos al respecto! |
|
#12
|
||||
|
||||
|
Los que de verdad tienen el mérito son los que empezaron a trabajar con su antecesor ,(que supongo era el mapFileSource), despues los de la JVCL se lo han currado hasta quedarse calvos, para que con un solo clic de ratón se añada toda esa info.
Yo lo único que he hecho es cambiar un procedure por un function.... y poco más. Así que no teneís que admirarme.... más bien hacer un depósito en mi cuenta corriente ![]() Venga, un saludo compañeros. |
|
#13
|
|||
|
|||
|
siguiendo los pasos de Lepe ..
Lepe , estoy tratando de seguir tus consejos ... y he llegado al punto de conseguir el log con el error , pero no me devuelve la linea , ni el pas donde se produjo .. talvez tenga que ver con el 'tipo de error' (ante la ignorancia , viene el delirio
), porque en los casos:error 1: (producido con una query poniendo una instrucion SQL con error de sintacsis..al hacer el open da el error) la info que me da es: UNITNAME: dice OLEDBAccess en lugar de la unit que se produjo ... Porcedure : ToleDbConnection.oledberror Line : 0 y en los sucesivos Unitname ..( 2 en este caso ) todos line 0 ----- Caso error 2: (producido al pasar mal el valor de un parametro a un Store Procedure) de da : Unitname : sysutils prodecure : convertErrorFmt Line : 0 y en los sucesivos Unitname ..en el tercero si me da una referencia al pas uMain.pas Line : 2224 (que no es exactamente el ExecProc sino el showmessage del except del try del ExecProc ) ----------- este es el txt tectual del log: [13/10/2005 12:14:08]Exception EMSError: Línea 1: sintaxis incorrecta cerca de 'fromm'.> [13/10/2005 12:39:11]Exception EConvertError: ' ' no es un valor entero válido Exception UnitName : SysUtils Procedure : ConvertErrorFmt Line : 0 OffsetLine : 0 Deep of Except frame-dump : 5 UnitName : SysUtils Procedure : ConvertErrorFmt SourceName : Line : 0 UnitName : uMain Procedure : TMainMenu.Button1Click SourceName : uMain.pas Line : 2224 UnitName : Controls Procedure : TWinControl.MainWndProc SourceName : Line : 0 UnitName : Controls Procedure : TWinControl.MainWndProc SourceName : Line : 0 > no se cuan lejos estare de que esto sea el log 'optimo y correcto' Saludos y gracias Ingel |
|
#14
|
||||
|
||||
|
Cita:
como primer uses de la ventana? ¿Seguro que has hecho un Build Project o Build All? Si no lo haces, no se genera de nuevo el archivo .map, por tanto las referencias son las antiguas, basta que hayas creado nuevos procedimientos para que no sea capaz de encontrar las entradas en el .map Cita:
Exception.Create, o un simple Raise en bloques try...except. El Frame-Dump es el volcado de llamadas que se han hecho anteriormente hasta llegar al que levantó la excepción; en este caso se ha podido rastrear 5 llamadas, si tu error está 7 llamadas antes, no vas a poder identificar la linea exacta (auque esto ocurre muy pocas veces )Cita:
StrToInt(edit1.text), o algo similar, pero el usuario no ha escrito nada en Edit1, Usa StrtointDef para pasar un valor por defecto. Siempre vas a ver código de DB.pas, Sysutils.pas y similares, ya que es allí donde se levantan excepciones. Ahora te toca levantar tus propias excepciones:
saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. |
![]() |
|
|
|