Hi Viktor,

Ok, I think I know what is happening here and is partially my fault - However, I still feel that extra protection needs to be added to this loop.

The picture is "(999) 999-9999"

When this endless loop occurs, I am doing this:

oGet:Pos := 1
oGet:DelEnd()

I say this is my fault since I am setting :Pos to 1, but the first position is not an editable position.

So, what is happening is that nPos is getting set to 1 in :DelEnd() (due to my assignment above) and then ::Pos is stopping at 2 since :Left() in :backSpaceLow() cannot get to 1 (due to the picture) and hence the endless loop.

So, I fixed this in my Harbour build by checking for a change to ::nPos as follows:

METHOD delEnd() CLASS Get

   LOCAL nPos, nLast

   IF ::hasFocus

      nPos := ::nPos
      ::pos := ::nMaxEdit
      nLast := ::nPos + 1

      ::deleteLow()
      DO WHILE ::nPos > nPos .and. ::nPos < nLast
         nLast := ::nPos
         ::backSpaceLow()
      ENDDO

      ::display()
   ENDIF

   RETURN Self


At 12:10 PM 6/25/2008, you wrote:
Hi Randy,

Probably. If we can get a small test case
together, I will add it to rto_get.prg, and
I can try it with Clipper too.

So, var is 20 chars string, picture is "(999) 999-9999".
What keys do you press to get into the endless loop?

Brgds,
Viktor

On 2008.06.25., at 18:04, Randy Portnoff wrote:

Hi all,

I think there is a bug in TGET's delEnd() method - The loop...

DO WHILE ::nPos > nPos
   ::backSpaceLow()
ENDDO

...can become endless in some circumstances. While I cannot
reproduce it in a DOS app, my GUI app (that implements its own
masked edits using TGET) can using a 20-character character variable
and a picture as "(999) 999-9999" - If I reduce the variable to 14
characters (ie. to match the picture length), it seems to work ok.

So, I'm not sure if this should be classified as a bug or not.

Regards,
Randy.

P.S. The use of :Pos and :nPos is very confusing in TGET.PRG


_______________________________________________
Harbour mailing list
Harbour@harbour-project.org
http://lists.harbour-project.org/mailman/listinfo/harbour

_______________________________________________
Harbour mailing list
Harbour@harbour-project.org
http://lists.harbour-project.org/mailman/listinfo/harbour


_______________________________________________
Harbour mailing list
Harbour@harbour-project.org
http://lists.harbour-project.org/mailman/listinfo/harbour

Reply via email to