Thanks Scott.

Since only VARYING strings (or expressions) has to be done at runtime I
find too restrictive the %LEN usage. As Jon remarked %LEN(MyFixedLenString)
CAN be determined at compile time.

The real problem is we recently added TEMPLATE to our dictionary, in V5R4
we used to have it based on a pointer. and we have lot of programs passing
%LEN(MyFixedLenString).

TEMPLATE and the consequent possibility of having data without allocated
storage is recent, in 2004 what was the diffrence between x =
myfunc(myvar:%len(myvar)) and x = myfunc(myvar:%size(myvar))?



--
Marco Facchinetti

Mr S.r.l.

Tel. 035 962885
Cel. 393 9620498

Skype: facchinettimarco


2013/6/18 Scott Klement <rpg400-l@xxxxxxxxxxxxxxxx>

hi Marco,

%SIZE works at compile-time. As your program is compiled, the compiler
takes the total size of the object (variable, DS, etc) and inserts it in
place of the %SIZE BIF.

%LEN works at run-time. It checks the current length of the item (not
based on it's definition, but based on the data inside it -- for
example, a VARYING string can have a different length based on the data
inside of it.) Since a TEMPLATE field cannot store data, it does not
make sense to use it with %LEN.

-SK



On 6/18/2013 1:24 PM, Marco Facchinetti wrote:
Just curious why an item defined with the TEMPLATE keyword is valid as
%SIZE's argument but not for %LEN.

TIA
--
Marco Facchinetti

Mr S.r.l.

Tel. 035 962885
Cel. 393 9620498

Skype: facchinettimarco

--
This is the RPG programming on the IBM i (AS/400 and iSeries) (RPG400-L)
mailing list
To post a message email: RPG400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/rpg400-l.



As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:
Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2024 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.