Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > OOP
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Coloboración Paypal con ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 18-08-2005
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por Lepe
por otra parte, el programa se queda congelado
En ocasiones, si se desea ver el contenido del formulario durante un "break" se puede optar por abrir la ventana de evaluación (Ctrl+F7) y "evaluar" la expresión Form1.Update.

// Saludos
Responder Con Cita
  #2  
Antiguo 19-08-2005
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 31
Lepe Va por buen camino
Gracias Roman, Yo el depurador no lo uso mucho, F7, F8, raton con hint, y poco más, no suelo usar breakpoints condicionales, ni watch.

La unidad no es cosa compleja, he usado un label de la JVCL, no sé por qué, puedes usar tambien un Label normal.

Tambien uso las nkstrs, para las funciones padright y padleft, se puede usar StringOfchar para obtener el mismo resultado, pero como las uso desde hace tiempo, las tengo siempre más a mano que las de delphi.

Yo al memo le tengo puesto la fuente Courier New, por aquello de fuente No proporcional.

Quizás la más interesante sea la de VerResultadosSql, ahorra mucho tiempo el no tener que poner un grid para ver si la consulta va bien o no. De hecho, junto con padright, padleft y la fuente Courier New va de lujo.

Código Delphi [-]
unit Debug;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls,
  db, dbtables, ComCtrls, ToolWin, JvLabel ; // datamoduletables

type
  TfrmDebug = class(TForm)
    Memo1: TMemo;
    ToolBar1: TToolBar;
    ToolButton1: TToolButton;
    ToolButton2: TToolButton;
    ToolButton3: TToolButton;
    ToolButton4: TToolButton;
    ToolButton5: TToolButton;
    ToolButton6: TToolButton;
    ToolButton7: TToolButton;
    SaveDialog1: TSaveDialog;
    ToolButton8: TToolButton;
    lblLineas: TJvLabel;
    CheckBox1: TCheckBox;
    procedure ToolButton1Click(Sender: TObject);
    procedure ToolButton2Click(Sender: TObject);
    procedure ToolButton3Click(Sender: TObject);
    procedure ToolButton5Click(Sender: TObject);
    procedure CheckBox1Click(Sender: TObject);
  private



    { Private declarations }
  public
    { Public declarations }
    procedure Anade(const Msg:array of string; const valores:array of Integer);overload;
    procedure AnadeCur(const Msg:array of string; const valores:array of Currency);    
    procedure Anade(str:string);overload;
    procedure Anade(str:TStrings); overload;
    procedure Anade(INT:Integer);overload;
    procedure ListaFrm;
    procedure ListaVentanasHijas(aFrm: Tform);
    procedure VerSentenciaSql(dt: TQuery);
    procedure VerResultadoSql(dt:TDataSet);
  end;

var
  frmDebug: TfrmDebug;

implementation
  USES nkstrs;
{$R *.dfm}

{ TfrmDebug }



procedure tfrmdebug.VerSentenciaSql(dt:TQuery);
begin
  frmDebug.Anade(dt.SQL.text);
end;

procedure TfrmDebug.AnadeCur(const Msg:array of string; const valores:array of Currency);
var i:Integer;
begin
  for i:= Low(Msg) TO High(Msg) do
    Memo1.Lines.Add(Msg[i]+': '+ CurrToStr(valores[i]));
  Update;
  lblLineas.Caption:= 'Lineas: '+CurrToStr(Memo1.Lines.Count);
  if not frmDebug.Showing then
    frmDebug.SHOW;
end;


procedure TfrmDebug.Anade(const Msg:array of string; const valores:array of Integer);
var i:Integer;
begin
  for i:= Low(Msg) TO High(Msg) do
    Memo1.Lines.Add(Msg[i]+': '+ IntToStr(valores[i]));
  Update;
  lblLineas.Caption:= 'Lineas: '+IntToStr(Memo1.Lines.Count);
  if not frmDebug.Showing then
    frmDebug.SHOW;
end;

procedure TfrmDebug.Anade(str: string);
begin
  Memo1.Lines.Add(str);
  lblLineas.Caption:= 'Lineas: '+IntToStr(Memo1.Lines.Count);
  if not frmDebug.Showing then
    frmDebug.Show;
end;


procedure TfrmDebug.Anade(INT : integer);
begin
  Memo1.Lines.Add(IntToStr(INT));
  lblLineas.Caption:= 'Lineas: '+IntToStr(Memo1.Lines.Count);
  if not frmDebug.Showing then
    frmDebug.Show;
end;

procedure TfrmDebug.Anade(str:TStrings);
var i:Integer;
begin
  for i:=0 to str.Count-1 do
    frmDebug.Anade(str[i]);

end;

procedure TfrmDebug.ListaVentanasHijas(aFrm:Tform);
var i:Integer;
begin
  frmdebug.anade('');
  anade('*** LISTADO DE VENTANAS (MdiChildren)***');
  for i:=0 to afrm.mdichildcount -1 do
    anade(afrm.mdichildren[i].Name);
  anade(['nº de hijas'],[aFrm.mdichildcount]);

end;


procedure tfrmdebug.ListaFrm();
const TABULADOR = '      ';
Var i:Integer;
Begin
    Memo1.Lines.BeginUpdate;
    memo1.Lines.Add('*** LISTADO DE VENTANAS (TScreen)***');
    For i:=0 to Screen.FormCount-1 do
    Begin
        MEMO1.Lines.Add(padright('Name: '+TForm(Screen.Forms[i]).Name,' ',30)+
        'Clase: '+ Screen.Forms[i].ClassName);
   end; //For i
    Memo1.Lines.Add('nº de ventanas: ' + IntToStr(Screen.FormCount));
    memo1.Lines.Add('***************************');
   Memo1.Lines.EndUpdate;
  lblLineas.Caption:= 'Lineas: '+IntToStr(Memo1.Lines.Count);
  if not frmDebug.Showing then
    frmDebug.Show;

end;

procedure TfrmDebug.VerResultadoSql(dt: TDataSet);
var i:Integer;
    campos :string;
begin
  if dt.Active then
  begin
//    campos := '';
    for i:= 0 to dt.FieldCount-1 do //Nombres de campos
      campos := campos+' ' + padright(dt.Fields[i].FullName,' ',dt.Fields[i].DisplayWidth);
    frmDebug.Anade(campos);
    frmDebug.Anade(PadLeft('','-',Length(campos)));
    dt.First;
    while not dt.Eof do  // valores de la consulta
    begin
      campos := '';
      for i:=0 to dt.FieldCount -1 do
        campos := campos+' ' + padright(dt.Fields[i].AsString,' ',dt.Fields[i].DisplayWidth);
      frmDebug.Anade(campos);
      dt.Next;
    end;
  end;
end;

Un saludo
__________________
Si usted entendió mi comentario, contácteme y gustosamente,
se lo volveré a explicar hasta que no lo entienda, Gracias.
Responder Con Cita
  #3  
Antiguo 19-08-2005
Avatar de lucasarts_18
lucasarts_18 lucasarts_18 is offline
Miembro
 
Registrado: mar 2005
Ubicación: Villa Alemana,Chile
Posts: 1.087
Poder: 23
lucasarts_18 Va por buen camino
Hola:

Gracias Lepe...

Saludos.
__________________
No todo es como parece ser...
Responder Con Cita
  #4  
Antiguo 21-08-2005
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.141
Poder: 36
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Creo que no estará demás si enlazo aquí cierto artículo de Francisco Charte en que se trata sobre la depuración de programas con Delphi.

Otros artículos del autor tampoco son desdeñables.
__________________
David Esperalta
www.decsoftutils.com
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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


La franja horaria es GMT +2. Ahora son las 20:38:11.


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