LabWindows/CVI

cancel
Showing results for 
Search instead for 
Did you mean: 

collapsible regions do not always work properly in CVI2009

Solved!
Go to solution

Luckily this isn't a burning problem for me - I just found out and being curiosity driven, I wanted to share my experience (or report a bug, whatever).

 

Anyway, I appreciate your interest, thanks.

 

Wolfgang

 

 

0 Kudos
Message 11 of 18
(2,577 Views)

Wolfgang,

 

Your speculation that the size of the preceding function is affecting how the QuitCallback region is identified is correct. When CVI dtects a brace-delimited block it tries to determine its context of this block in the program, in order to classify the block properly. For this, it needs to parse the preceding code, looking for other braces that will define the context appropriately. For performance reasons it only parses the preceding code up to a certain number of lines (not quite sure what that number is, but it's almost certainly less than 3000). If it can't find the opening brace of the preceding block within that number of lines, it gives up on establishing a context and instead treats the block as a generic block. To the best of my knowledge, this only has an impact on where the twistie appears -- if it's a generic block it appears in the line with the opening brace, instead of the preceding statement or function definition line, but I could be wrong about this. Let me know if you see other effects.

 

Luis

 

0 Kudos
Message 12 of 18
(2,568 Views)

Compliments to my nose 🙂

 

OK, Luis, yes, I do see other side effects, as mentioned in the earlier posts of this subject.

 

Most irritating to me is the fact that if you scroll through the text (after the long function), the marker positions do not get updated, they simply remain in their position, hence mostly indicating the wrong position (see the screen shots above, with no markers or markers at obviously wrong positions). Only if you refresh the screen, e.g. by ALT-tabbing to a different program and back again, the correct positions are indicated.

It seems that this is due to performance reasons, too. But I consider it very annoying because it makes the markers unreliable.

 

I am adding yet another example showing the variations: missing marker, wrong marker, accidentally correct marker...

 

marker.jpg

 

Wolfgang

0 Kudos
Message 13 of 18
(2,560 Views)

Hi Luis,

 

1) The free MS Visual C Express Editor handles the case correctly 🙂 

2) CVI handles it correctly, but only provided one is willing to force a screen refresh; so maybe the 'misbehaviour' is motivated by performance reasons, but the result is not, it simply misses a refresh.

3) It would be nice to have it fixed

 

Wolfgang 

 

0 Kudos
Message 14 of 18
(2,548 Views)
Solution
Accepted by Wolfgang

Hi Wolfgang,

 

Yes, I'm sorry I hadn't noticed that you had also complained about the scrolling behavior. This is a known issue (#208315) in CVI 2009 -- when scrolling through the file using your arrow keys, the region column does not redraw. To get it to redraw, you have to actually move the caret through each individual line, after scrolling. This is actually a bug, and it's not related to the large-function performance issue that I was alluding to earlier.

 

For what it's worth, if you show line numbers in the file (View>>Line Numbers), the scrolling problem doesn't happen.

 

Luis

0 Kudos
Message 15 of 18
(2,528 Views)

Hi Luis,

 

thanks for the update, and thanks it's a bug and not my stupidity 🙂

 

But this issue makes me reiterate a wish I have expressed earlier: It would be most useful to all of us if the list of known bugs would be public.

We could have saved some time and effort in this and related cases. If users encounter some strange behavior they could check this list first...

 

Wolfgang

Message 16 of 18
(2,520 Views)

Agreed.

 

We're working on this now, and we should have a list out fairly soon. Sorry it's taken so long...

 

Luis

Message 17 of 18
(2,514 Views)

bookkeeping: fixed in CVI 2009 SP1 Smiley Happy

0 Kudos
Message 18 of 18
(1,812 Views)