|
This question is for Hans or Barbara (or anyone else who knows):
Why does the RPG IV compiler reject the following line with RNF7563?
C EVAL %LEN(cmdString) = *ZERO
when cmdString is defined as:
D cmdString S 5768 VARYING
I see the documentation says:
"The parameter must not be a figurative constant."
but that suggests to me the parameter of the BIF cannot be a figurative
constant (e.g., something stupid like x = %LEN(*HIVAL)) not that I can't used
a figurative constant to assign the current length.
I want to know why they can't be used. I can understand rejecting many of the
figurative constants but rejecting *ZERO seems a bit short-sighted to me.
What is the real difference between the failing line and the following:
C EVAL %LEN(cmdString) = 0
which is accepted by the compiler.
Especially in view of the fact that the compiler is quite happy with a
construct like:
C IF %LEN(cmdString) = *ZERO
I would expect %LEN(cmdString) = *ZERO to set the length to zero;
%LEN(cmdString) = *HIVAL to set the length to 99999 since the length component
is a BIN(2) and to generate an error if the declared length is less than
99999; %LEN(cmdString) = *LOVAL to generate an error because you can't have a
negative length -- although there is a reasonable argument that *LOVAL should
be the same as *ZERO in this case because the smallest variable length value
is zero.
In the words of a famous, now dead, Australian; Why is it so?
I can feel a PMR coming on ....
Regards,
Simon Coulter.
«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»
«» FlyByNight Software AS/400 Technical Specialists «»
«» Eclipse the competition - run your business on an IBM AS/400. «»
«» «»
«» Phone: +61 3 9419 0175 Mobile: +61 0411 091 400 «»
«» Fax: +61 3 9419 0175 mailto: shc@flybynight.com.au «»
«» «»
«» Windoze should not be open at Warp speed. «»
«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»
+---
| This is the RPG/400 Mailing List!
| To submit a new message, send your mail to RPG400-L@midrange.com.
| To subscribe to this list send email to RPG400-L-SUB@midrange.com.
| To unsubscribe from this list send email to RPG400-L-UNSUB@midrange.com.
| Questions should be directed to the list owner/operator: david@midrange.com
+---
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.