Talk:CodingStandards

From Pickwiki
Revision as of 22:55, 17 June 2020 by IanMcGowan (talk | contribs)
Jump to navigationJump to search

Ternary assignment preferred

Regarding 2.10 "Avoid using obscure and unfamiliar coding styles", the example shows ternary assignment as "BAD"; that is, obscure and unfamiliar to most PICK programmers. I actually prefer to use ternary assignment instead of multi-line IF-THEN-ELSE logic. Ternary assignment helps to avoid the error where the variable name is mis-typed in the ELSE clause.

Passing an argument by value

Regarding 5.7 "Variables passed to subroutines can be passed by value", scalar variables can be wrapped in parentheses to pass by value, but an array element cannot. Calling FMTPHONE((CM.REC(CM$PHONE))) will pass a pointer reference to the array element, not a copy of its value, so the array element's value may be changed by the subroutine/function.

A better way to ensure an argument is passed by value is to prepend or append an empty string.

 CALL FMTPHONE("":CM.REC(CM$PHONE))

This can be made more explicit with an equate:

 EQU BYVAL LIT \ "": \
 CALL FMTPHONE(BYVAL CM.REC(CM$PHONE))

This EQU BYVAL is too magical for my taste - it looks very much like a built-in language feature. The idea of passing-by-value is really good, I've had many bugs caused by not doing this.