|
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.