Hi Viktor,
I am very sorry, I just realized I am using an older version of TGET
- In the current TGET, the :Pos() method does not allow the
assignment of a non-editable position to the :nPos var - Therefore,
in the case below, when you assign o:pos := 1, it is actually
assigning 2 and thereby protecting the loop in :DelEnd().
Again, sorry... However, I still feel that the loop in DelEnd() looks
dangerous!
Regards,
Randy.
At 08:17 AM 6/26/2008, you wrote:
Hi Randy,
I've added a small test case, but I couldn't reproduce the loop:
cStr07 := Space(20)
SetPos( 14, 16 )
o := _GET_( cStr07, "cStr07", "(999) 999-9999",, )
o:display()
o:setFocus()
o:pos := 1
o:delEnd()
What am I missing?
Brgds,
Viktor
On 2008.06.25., at 19:27, Randy Portnoff wrote:
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
_______________________________________________
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