|
Jim, Wow! Really? Write my own functions, and even bind them in? The hell you say! Sorry about the sarcasm, but really... The point here is, as this thread started, we have a bif that does not conform to its documentation. It says it converts numbers to characters without changing the value, but it removes leading zeros without being asked. 00123 converts to '123'. That is a different value, '00123' is the same value. To test this try comparing them. MOVE one and either eval or evalr the other. They are not the same value, an IF equal fails as does a COMP. Even the system knows they are different values. IBM says it works as designed. I say that it duplicates the function of an existing bif or bif combination. I'm sure the end result will be a change to the documentation, and I'll get over it. However it is relatively early in the life of this bif and It's not unreasonable to think that the documentation is correct and the function performed by the bif should be changed to conform. Tom Westdorp AS/400 Senior Programmer/Analyst IBM Certified Specialist - RPG IV Programmer IBM Certified Specialist - RPG IV Developer Certified Master RPG IV Programmer Internal Telephone # 04-6859 Voice: (702) 221-6859 Fax: (702) 221-6881 tom.westdorp@stationcasinos.com -----Original Message----- From: Jim Langston [mailto:jimlangston@conexfreight.com] Sent: Wednesday, November 22, 2000 8:44 AM To: RPG400-L@midrange.com Subject: Re: %CHAR() Tom, This is the beauty of ILE. You don't like the way a BIF does something, write your own! Very simple to make a function that does exactly what you want the way you want it and stick it in your directory for binding. Give it whatever name you wish. And then just call this function. I understand that programmers are not wanting to do this, but it is the only real logical way to go. If you're not doing it today, I can almost guarantee you that you will be someday. It is really not that hard to build your own binding directory. Put your headers (pr declarations) into a /copy member. Now in your programs you have, what, one extra line of code at the beginning? /COPY MyBind And a few extra parameters to give when you compile. Now you can use your own functions in your programs. IBM does something you don't like? Change it and give it a new name. I think the good folks at IBM could of written this BIF either way, leaving in leading zeros or taking them out. Either way they did it, someone wouldn't of liked it <g> Incidentally, the VALUE did remain unchanged. ' 123' is equal to one hundred twenty three. Also consider that the number you are converting from could be in many different formats, IBM's version of BCD (Packed), Zoned, Binary. Of those only one actually has the zeros and that is Zoned. I think the argument that the original value had 0's is a mute point, because it's a number, not a character. I think we are going to find more and more that IBM is doing things differently then we would of wanted them done, and it is going to be much easier to just build our own functions to do them the way we want them to. For every way IBM does something, there's going to be 20 different ways people think it should of been done. You can please some of the people some of the time... Regards, Jim Langston "Westdorp, Tom" wrote: > > Jim, > > Your desired end is the perfect example of character conversion and a z edit > code combined to get an answer. You want two things, conversion and > editing, and %editc does two things conversion and editing. 'edit' + 'c'. > %char on the other hand just says make things character, but then edits the > result to suppress leading zeros. %editc(fieldx:'Z') is clear and > unambiguous, I submit %char(fieldx) to the same end is not. > > As to "most PC applications do not use leading zeros" begs the question > whose idea of most. We convert a handful of fields from packed decimals on > the 400 send them through serial communications (albeit sometimes over > TCP/IP) usually with LRC characters and in some cases with parity checking. > The formats are dictated by the other vendors to be character fields > containing right justified numbers that are zero filled. We do it hundreds > of thousands of times a day. Frankly, that's all irrelevant. The point is > that we have two bif's that do the same thing, one explicitly and one > implicitly and the answer is to use the explicit one to specify an edit code > that says don't edit. > > BTW, when I show my users numbers, I edit them. %editc or %editw or an edit > code on DDS screen specs, etc. Explicitly edited. So everyone knows it > happened. > > As to XLATE, that's what we do in some cases because the choice was to > either use a MOVE statement or EVALR followed by XLATE. Either way I ended > up with a fixed format RPG400 statement in the middle of a bunch of RPGIV > evals. And a comment to tell the next guy why they are there. And, as you > point out, it has to be the mix of MOVE's and EVALR + XLATE's because the > EVALR + XLATE can produce unwanted substitutions in some cases. Clear? To > some perhaps, but not as clear as a %char the just converts each number in a > field to its character value. > > The 'taking out' I referred to is the zeros that disappeared not a command > or bif or anything. I know its relatively new, and arguably broken. > > >From the book: > >4.1.1.3 %CHAR (Convert to Character Data) > > > %CHAR(expression) > > >%CHAR converts the value of the expression from graphic, UCS-2, numeric, > date, time or > >timestamp data to type character. The converted value remains unchanged, > but is returned in >a format that is compatible with character data. > > Note that it says the converted value remains unchanged. To me that means a > zero is a zero and stays a zero. > > There is a notation of: > > >If a UCS-2 conversion results in substitution characters, a warning message > will be given in >the compiler listing if the parameter is a constant. > >Otherwise, status 00050 will be set at run time but no error message will > be given. > > However, no mention is made of zero suppression or substitution in the case > of numeric values. > > All that said, I will work around it however I still believe it is wrong and > should be APARed. Early, before it becomes a legacy issue. > > Tom Westdorp +--- | 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 +--- +--- | 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.