2023-05-03 11:06:20 +02:00
|
|
|
== Why is this an issue?
|
|
|
|
|
2021-04-28 16:49:39 +02:00
|
|
|
The use of ``++options( *nopass )++`` on a parameter makes it optional, so it should always be checked before use.
|
|
|
|
|
2021-04-28 18:08:03 +02:00
|
|
|
|
2023-05-03 11:06:20 +02:00
|
|
|
=== Noncompliant code example
|
2021-04-28 16:49:39 +02:00
|
|
|
|
2022-02-04 17:28:24 +01:00
|
|
|
[source,rpg]
|
2021-04-28 16:49:39 +02:00
|
|
|
----
|
|
|
|
DCL-PR VIOLATION1 EXTPGM;
|
|
|
|
LASTNAME Char(10);
|
|
|
|
FIRSTNAME Char(10) OPTIONS(*NOPASS:*OMIT);
|
|
|
|
END-PR;
|
|
|
|
|
|
|
|
DCL-PI VIOLATION1;
|
|
|
|
LASTNAME Char(10);
|
|
|
|
FIRSTNAME Char(10) OPTIONS(*NOPASS:*OMIT);
|
|
|
|
END-PI;
|
|
|
|
|
|
|
|
dsply FIRSTNAME;
|
|
|
|
dsply LASTNAME; // Noncompliant; LASTNAME is optional
|
|
|
|
*inlr = *on;
|
|
|
|
----
|
|
|
|
|
2021-04-28 18:08:03 +02:00
|
|
|
|
2023-05-03 11:06:20 +02:00
|
|
|
=== Compliant solution
|
2021-04-28 16:49:39 +02:00
|
|
|
|
2022-02-04 17:28:24 +01:00
|
|
|
[source,rpg]
|
2021-04-28 16:49:39 +02:00
|
|
|
----
|
|
|
|
DCL-PR VIOLATION1 EXTPGM;
|
|
|
|
LASTNAME Char(10);
|
|
|
|
FIRSTNAME Char(10) OPTIONS(*NOPASS:*OMIT);
|
|
|
|
END-PR;
|
|
|
|
|
|
|
|
DCL-PI VIOLATION1;
|
|
|
|
LASTNAME Char(10);
|
|
|
|
FIRSTNAME Char(10) OPTIONS(*NOPASS:*OMIT);
|
|
|
|
END-PI;
|
|
|
|
|
|
|
|
dsply FIRSTNAME;
|
|
|
|
IF %PARMS > 1;
|
|
|
|
dsply LASTNAME;
|
|
|
|
EndIf;
|
|
|
|
*inlr = *on;
|
|
|
|
----
|
2021-04-28 18:08:03 +02:00
|
|
|
|
2021-06-02 20:44:38 +02:00
|
|
|
|
2021-06-03 09:05:38 +02:00
|
|
|
ifdef::env-github,rspecator-view[]
|
2021-09-20 15:38:42 +02:00
|
|
|
|
|
|
|
'''
|
|
|
|
== Implementation Specification
|
|
|
|
(visible only on this page)
|
|
|
|
|
2023-05-25 14:18:12 +02:00
|
|
|
=== Message
|
|
|
|
|
|
|
|
Make sure this optional parameter was actually passed before you use it.
|
|
|
|
|
|
|
|
|
|
|
|
=== Highlighting
|
|
|
|
|
|
|
|
Parameter name
|
2021-09-20 15:38:42 +02:00
|
|
|
|
|
|
|
|
2021-06-08 15:52:13 +02:00
|
|
|
'''
|
2021-06-02 20:44:38 +02:00
|
|
|
== Comments And Links
|
|
|
|
(visible only on this page)
|
|
|
|
|
2023-05-25 14:18:12 +02:00
|
|
|
=== on 28 Oct 2015, 20:10:15 Ann Campbell wrote:
|
|
|
|
Source: user suggestion with background from \http://www.itjungle.com/fhg/fhg010505-story02.html
|
|
|
|
|
|
|
|
=== on 29 Oct 2015, 13:47:46 Pierre-Yves Nicolas wrote:
|
|
|
|
\[~ann.campbell.2] This rule looks more like a bug detection rule than something about api-design or readability.
|
|
|
|
|
|
|
|
=== on 29 Oct 2015, 14:02:11 Ann Campbell wrote:
|
|
|
|
You're right [~pierre-yves.nicolas]. Adjusted.
|
|
|
|
|
|
|
|
=== on 29 Oct 2015, 14:07:55 Pierre-Yves Nicolas wrote:
|
|
|
|
\[~ann.campbell.2] Should we also update the SQALE characteristic?
|
|
|
|
|
|
|
|
=== on 29 Oct 2015, 14:20:29 Ann Campbell wrote:
|
|
|
|
Thanks [~pierre-yves.nicolas]. That's done too now.
|
|
|
|
|
2021-06-03 09:05:38 +02:00
|
|
|
endif::env-github,rspecator-view[]
|