Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
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 11-11-2005
andres1569 andres1569 is offline
Miembro
 
Registrado: may 2003
Posts: 908
Poder: 24
andres1569 Va por buen camino
Hola, sólo puedo decirte que he probado ese código en Delphi 6.0 y funciona correctamente (haciendo uso de un Frame, como en tu ejemplo)

No creo que tenga que ver con la definición de la propiedad (no hace falta que le asignes ningún método write pues la propiedad ya existe en la clase base). Por el mensaje de error es como si accedieras a una propiedad de un Objeto inexistente, puede que el error esté en otra parte ...
__________________
Guía de Estilo
Responder Con Cita
  #2  
Antiguo 11-11-2005
[maeyanes] maeyanes is offline
Capo de los Capos
 
Registrado: may 2003
Ubicación: Campeche, México
Posts: 2.732
Poder: 26
maeyanes Va por buen camino
Solo una pregunta, la aplicación que estás haciendo en Delphi 2005, es Win32 o .NET?

Por que el error que mencionas al principio del hilo me suena mucho a .NET (por aquello de los assembly), y puede ser que no sea posible hacer en .NET eso que quieres. Claro, solo estoy suponiendo, por que se tendría que investigar bien.


Saludos...
Responder Con Cita
  #3  
Antiguo 12-11-2005
Avatar de gluglu
[gluglu] gluglu is offline
Miembro Premium
 
Registrado: sep 2004
Ubicación: Málaga - España
Posts: 1.455
Poder: 23
gluglu Va por buen camino
La aplicación está hecha en .NET

Durante el transcurso del día, he estado investigando algunos artículos que he encontrado, y parece ser que sí, que con .NET las propiedades que son protegidas, lo son de verdad.

No he probado hacer lo mismo en Delphi 2005 con WIN32.

Uno de los artículos que encontré (en inglés) es :
http://blogs.teamb.com/RudyVelthuis

Cita:
Strict private and strict protected
The private and protected sections of Delphi classes were, according to purists, severely flawed, because they did not prevent access to private or protected fields or methods from code in the same unit. The Delphi RTL and VCL actually use this "friend" concept, so it was not so easy to simply remove it.

But in .NET, private and protected really had to be just that, i.e. no other code should have access to these items (except of course descendant classes to protected items). So we got strict private and strict protected sections. Although this is not documented, it seems that these are also available in the Win32 compiler (thanks to Rob Kennedy for finding out). I'm sure that those who have been asking for this for a long time will be pleased to hear this.
Pero precisamente aquí se hace referencia a : "(except of course descendant classes to protected items)" ... por lo que entiendo que las clases descendientes SI permiten el acceso a dichas propiedades protegidas. ... y es lo que venimos discutiendo todo el tiempo.

Si utilizo la definición como "strict protected" o "strict private", directamente me dá un error de compilación.

De cualquier manera, me sigue pareciendo extraño que el mismo error me dé también cuando accedo a las propiedades públicas ("no protegidas") de la misma clase THackGrid, por lo que me dá la impresión de que algo se me está escapando.

Saludos
Responder Con Cita
  #4  
Antiguo 12-11-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
Pues entonces, según lo que entiendo de lo que dice Rudy Velthuis, ahí está la explicación.

Las clases descendientes siempre van a tener acceso a a las propiedades protegidas de sus ancestros, tanto en NET como en Win32. Aquí no hay diferencia. El punto es que en Win32, Delphi permitía acceso a propiedades protegidas incluso desde otras clases, siempre y cuando estuvieran en la misma unidad. Es esta segunda parte la que parece ya no funcionar con NET (o, como dice Rudy que dicen los puristas, ahora sí funciona).

Cuando haces THackGrid(DBGrid1).Row, es justo lo que la segunda parte dice. THackGrid ciertamente es un descendiente de TDBGrid, pero el acceso es desde otra clase (la del formulario), y el acceso es desde la misma unidad que la clase descendiente.

Si te fijas, este truco del moldeo, realmente sigue todas las reglas del juego que marca Delphi 7-, no hay trampa. Es sólo que tales reglas ya no son las mismas para Delphi 2005.

// Saludos

Última edición por roman fecha: 12-11-2005 a las 02:22:02.
Responder Con Cita
  #5  
Antiguo 12-11-2005
Avatar de gluglu
[gluglu] gluglu is offline
Miembro Premium
 
Registrado: sep 2004
Ubicación: Málaga - España
Posts: 1.455
Poder: 23
gluglu Va por buen camino
... no exactamente Delphi 2005 ! ... mas concretamente .NET

He probado con Win32 para Delphi 2005 y funciona correctamente. Ahora bien, con las aplicaciones en .NET no funciona.

Rizando el rizo : No sería posible llamar desde el Form (Frame en mi caso particular y ejemplo que venimos discutiendo en este hilo), a una procedure definida en la clase THackGrid, que a su vez accediera a las funciones protegidas del DBGrid definido en el Form ??!!

Lo he probado y supongo que ha sido pedirle demasiado porque evidentemente me vuelvo a encontrar de narices con la imposibilidad de acceder desde precisamente la clase THackGrid a elementos del DBGrid del Form.

Algo así como esto:
Código Delphi [-]
type
THackGrid = class(TDBGrid)
procedure Prueba(Sender: TObject);
public property Row;
end;
 
type
TFrame1 = class(TForm)
DBGrid1: TDBGrid;
Panel1: TPanel;
...
procedure TForm.Panel1Enter(Sender: TObject);
begin
  THackGrid.Prueba(nil);
end;
 
procedure THackGrid.Prueba(Sender: TObject);
var
  n_Row: Integer;
begin
  n_Row := THackGrid(TForm.DBGrid1).Row;
end;
Conclusión : Supongo que en .NET ya no es posible lo que venimos discutiendo, no es verdad ?!

Saludos a todos !
Responder Con Cita
  #6  
Antiguo 12-11-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 gluglu
Conclusión : Supongo que en .NET ya no es posible lo que venimos discutiendo, no es verdad ?!
Así es. No porque yo lo sepa sino que me baso en lo dicho por Rudy Velthuis, persona muy repetable.

Toma en cuenta que el moldeo con una clase descendiente no es más que una forma rápida para evitar tener que crear una componente descendiente con "todas las de la ley". Lo indicado es que desciendas una componente de TDBGrid y sea ésa la que coloques en tu frame en lugar del DBGrid original.

// Saludos
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 05:45:43.


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