|
This 'Qp0lGetAttr' API was a little different in that it does not require *NULL terminated strings. Instead you pass a datastructure that tells how big of a buffer you're passing. I did experience all of the fun you listed below when I first tried to implement lstat64(). After all that, I figured out that this API gives you all the date information, except for creation date. Thanks everyone for your help. I'm a little wiser on C API calling now. "Bob Cozzi" <cozzi@xxxxxxxxx> Sent by: To rpg400-l-bounces@ "'RPG programming on the AS400 / midrange.com iSeries'" <rpg400-l@xxxxxxxxxxxx> cc 01/27/2006 11:26 Fax to AM Subject RE: CONST vs. VALUE on a pointer Please respond to parameter RPG programming on the AS400 / iSeries <rpg400-l@midrang e.com> You're calling a C function. In C, char* or "const char*" are similar to passing this: D path 640A The CONST keyword means nothing at this point. However, in your case, it is expecting a null-terminated string. RPG IV automatically creates these strings when you add OPTIONS(*STRING) to a pointer parameter. So first we have to convert the above to a pointer, as follows: D path * This is okay if we pass %addr(myField), but if we only pass this, then we also need to include the null terminator, X'00'. Not very pretty, so we let RPG do it for us. D path * Options(*STRING) Hmmm... something's not working, what is it? Well in the called procedure it is looking at the address of the value passed in, and taking the information in that address, as data. Unfortunately since RPG passes-by-reference, the data the called routine is looking at is actually the pointer, not the value we passed to it. So we need to make it more C-friendly, by passing the address "by value", D path * VALUE Options(*STRING) Now suddenly it works, but we still have an issue. When we call this procedure, we should use %trimR(myPath) to delete any trailing blanks in the path name. What if we used this instead? D path * Const Options(*STRING) It is these same as without the CONST keyword, pass-by-reference and you'll get crap. -Bob Cozzi www.RPGxTools.com RPG xTools - Enjoy programming again. -----Original Message----- From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of darren@xxxxxxxxx Sent: Friday, January 27, 2006 9:09 AM To: rpg400-l@xxxxxxxxxxxx Subject: CONST vs. VALUE on a pointer parameter I attempted to call the Qp0lGetAttr API to get the creation date of a file in the IFS. I used the following prototype. D Qp0lGetAttr PR 10I 0 ExtProc('Qp0lGetAttr') D path * Const D AttArrPtr * Const D BuffPtr * Const D BuffLenSent 10U 0 Const D BuffLenNeed 10U 0 D BuffLenRet 10U 0 D FollowLink 10U 0 Value The above did not work, apparently because I had used Const. The program compiles fine both ways, but the API returns a -1 indicating that some kind of error occurred. I can toggle the 'path' parameter from Value to Const and get it to fail, with everything else as shown below. My reason for using Const was to document that the variable being pointed to was an Input only variable per the API's specs. Can someone in the know, educate me as to the different between Const and Value in this case? D Qp0lGetAttr PR 10I 0 ExtProc('Qp0lGetAttr') D path * Value D AttArrPtr * Value D BuffPtr * Value D BuffLenSent 10U 0 Value D BuffLenNeed 10U 0 D BuffLenRet 10U 0 D FollowLink 10U 0 Value -- This is the RPG programming on the AS400 / 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. -- This is the RPG programming on the AS400 / 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 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.