[AccessD] Naming Conventions

Steve Conklin (Developer@UltraDNT) Developer at UltraDNT.com
Thu Aug 5 17:28:21 CDT 2004


Just to throw in another, late, point on this, I do it this way:

For I = 1 To 10
Next ' I

I throw in the variable after an apostrophe, so it's there, but
commented out because somewhere else  in my life (VBS?) you *can't* put
the variable after the Next because it throws an error.  This one
method works on both.

Steve


-----Original Message-----
From: accessd-bounces at databaseadvisors.com
[mailto:accessd-bounces at databaseadvisors.com] On Behalf Of Brett
Barabash
Sent: Thursday, August 05, 2004 2:54 PM
To: Access Developers discussion and problem solving
Subject: RE: [AccessD] Naming Conventions


Gustav,
This thread has to end for me.  My paid project work is suffering, so
here's my last shot at getting my point across.

> I think that Next alone is more safe as it complete eliminates these
classic typo errors:

>For I = 1 To 10
>   For J = 1 To 10
>   Next I
>Next I

In Access 2.0, it gives me a "Next without For" compiler error. In
Access 2003, VB6 and VB.NET, it me an "Invalid Next control variable
reference" compiler error.

I'm reasonably sure that there are no versions of VB or VBA that allow
this bug to slip past the compiler.  In all cases, the COMPILER
eliminates the typo error.  Still no chance of introducing runtime
errors by using my syntax.

More safe?  From those big, bad compile-time errors?  Gimme a break...
Next!

>Would you like:
>
>  While N < 50
>    ' Do stuff
>  Wend N

No Sam, I would not like it in a box, with a fox, on a train, or in a
plane.  You're repeating the same tired argument with different
keywords.  As I said before (about the If statements and Do loops), this
loop is controlled by a CONDITION, not a counter variable.  True, the
condition MAY involve the value of a single variable, but what about:

' Wait 1 second
While GetTickCount() - lngStartCount < 1000
   DoEvents
Wend

So to conclude, I feel that the extra effort of including the For
counter variable with the Next statement is worth the effort because:

A) It allows me to tell what block a Next block belongs to, without
having to scroll up to the For statement.

B) In cases of nested loops, it helps me to ensure that my code is
placed within the proper loop.

C) Using this syntax does not increase the possibility of runtime
errors, but there is a minor chance that it may reduce them (see B).

D) Although they are not required by the compiler, I consider them a
best practice to improve code readability.  As a team developer, I
accept the fact that the people maintaining my code may not possess
above average code-deciphering skills like Gustav, and instead tend
towards average like myself.  _I_ find it easier to read and maintain,
and obviously there are others who do as well, or else it would have
been deprecated in the syntax overhaul of VB.NET.  Conversely, I haven't
heard a reasonable argument why it would make code harder to read or
maintain.



-----Original Message-----
From: accessd-bounces at databaseadvisors.com
[mailto:accessd-bounces at databaseadvisors.com] On Behalf Of Gustav Brock
Sent: Thursday, August 05, 2004 11:57 AM
To: Access Developers discussion and problem solving
Subject: Re: [AccessD] Naming Conventions

Hi Brett

>> I would have been silent.

> Wow!  I actually found something that would silence Gustav.  Gotta
> make a note of that... ;-)

>> So, you would prefer the syntax:
>>  If I = 2 Then
>>    ' Do stuff
>>  End If I

> Two points here:
> First of all, that's not valid VB(A) syntax, so it's pretty hard to
> truly comment on what I "prefer", since I couldn't have possibly used 
> that construct and formulated an opinion based on experience.
Right???

Of course. I was moving along the tangent of Arthur's notes about
"revised" syntax on the dba-tech list.

> However, this is an easy one since your example is clearly not 
> analogous to what I stated.

> A For...Next loop corresponds to a single loop variable.  If 
> statements, Do...While loops, etc. are tied to conditions (I = 2, 
> strLastName = "Jones", etc.), not variables.  If I place the letter I 
> next to the End If, it isn't very helpful since it is the condition (I

> = 2) that is the basis of the code block.

You are right about the Do .. Until loop.
However, I find it very analogous to

  For I = 1 To 50
    ' Do stuff
  Next I

Also While .. Wend doesn't use it.
Would you like:

  While N < 50
    ' Do stuff
  Wend N

> Repeating the entire condition string at the bottom of the block would

> be far too wordy and the code maintainance required would outweigh its

> benefit.

Certainly. But I have thought about the Next (I) syntax. Though I seldom
use nested loops and - when doing so - have found it very easy to keep
track of the loops (I mean: one is indented inside another which is
indented inside a third etc) I think that Next alone is more safe as it
complete eliminates these classic typo errors:

  For I = 1 To 10
    For J = 1 To 10
    Next I
  Next J

or:

  For I = 1 To 10
    For J = 1 To 10
    Next I
  Next I

Using

  For I = 1 To 10
    For J = 1 To 10
    Next
  Next

prevents and completely eliminates these errors. And I have yet to see a
code example where this could confuse a decent programmer.

To cut it out:
How could the nested For/For/For .. Next/Next/Next loops ever cause an
error? 

/gustav



------------------------------------------------------------------------
--------------------------------------------
The information in this email may contain confidential information that 
is legally privileged. The information is only for the use of the
intended 
recipient(s) named above. If you are not the intended recipient(s), you 
are hereby notified that any disclosure, copying, distribution, or the
taking 
of any action in regard to the content of this email is strictly
prohibited.  If 
transmission is incorrect, unclear, or incomplete, please notify the
sender 
immediately. The authorized recipient(s) of this information is/are
prohibited 
from disclosing this information to any other party and is/are required
to 
destroy the information after its stated need has been fulfilled.

Any views expressed in this message are those of the individual
sender, except where the sender specifies and with authority,
states them to be the views of Tappe Construction Co.

This footer also confirms that this email message has been scanned
for the presence of computer viruses.Scanning of this message and
addition of this footer is performed by SurfControl E-mail Filter
software
in conjunction with virus detection software.

-- 
_______________________________________________
AccessD mailing list
AccessD at databaseadvisors.com
http://databaseadvisors.com/mailman/listinfo/accessd
Website: http://www.databaseadvisors.com




More information about the AccessD mailing list