× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



>Have you found a specific issue with 4B values? I never use them and
>haven't for years, but I've been under the impression that they can be
>used interchangably with 10i0 values provided the numeric range isn't
>outside the scope of the variable.

You're right on Bob.

For the archives, I work with telephone switches and other non-IBM sources
of data.  Only IBM has a concept of defining a number by the number of
digits (fixed length); everybody else uses a scheme directly tied to the
hardware.  Typically (but not always) it goes something like this:

smallint = 2 to the 15 = 32,768 = 2 bytes
int = 2 to the 31 = 2,147,483,648 = 4 bytes
bigint = 2 to the 63 = 9.22 x 10 to the 18 = 8 bytes

The issue is that most RPG folks automatically go for "4b 0" when they want
a four byte binary number.  Alas, that 4b turns into a nine digit maximum
fixed number: 999,999,999.  The other platform can send me numbers as large
as 2,147,483,648, so clearly stuff gets lost.

The problem with truncation is that it's subtle.  Code that has worked for
many years suddenly produces odd results; results that accumulate over time
until finally at the end of the month, the profit report shows bizarre
numbers which are traced back to daily imports that have been dropping the
high order digit.  Now I get to go back and re-import all that data and
essentially re-run the whole month.  This is basically the same problem with
defining "work" fields the smallest possible size in order to "save memory."
We've all seen that 3,0 loop counter fall apart when we bump the array to
5000 instead of 500.  This is no different.  4b 0 saves one digit in memory
compared to 10i.

>From my particular view, it's a values issue.  If the cell towers have ID
numbers from 1 to 10, then 4b works great.  When the cell company builds a
new set of towers in another county and decides to number them 1,000,000,001
- 1,000,000,005 in order to make them stand out, then that working code is
busted.  My particular situation is that somebody else determines the
maximum value: not me.

If your code never gets data from external sources and never counts higher
than the 4b limit, then sure, 4b is fine.  But I automatically recommend
that people use 10i, because that 4b is like a CHAIN without checking the
indicator.  Moving to the 10i costs nothing and the code becomes compliant
with external data sources and APIs.  There is only one place where you
cannot use 10i, and that's when the binary variable has decimals, like 4b 2.
But I have never seen that in a production database.
  --buck


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:

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

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.