Lurton wrote:
> Does anyone have an elagant way to do TESTN in /free?

rob@xxxxxxxxx replied:
Monitor;
MyNbr=%dec(MyChar);  // requires 5.2
On-Error;
  // oh crud, not numeric
EndMon;

Rob Berendt

No, that doesn't do exactly what TESTN does. For example, the input '123.45' is accepted by %DEC as a valid number but TESTN doesn't. Likewise, with input '1234J', %DEC throws up but TESTN likes it.


I can't think of any elegant way to replace TESTN within free-form calcs. You could check for digits 0-9 for the all the characters except the last, then check for 0-9, x'C0'-x'C9, and x'D0'-x'D9' as the last character. That is, you could do

%CHECK('0123456789':%SUBST(STR:1:%LEN(STR)-1) AND %CHECK(x'C0C1C2C3C4C5C6C7C8C9D0D1D2D3D4D5D6D7D8D9F0F1F2F3F4F5F6F7F8F9':%SUBST(STR:%LEN(STR)))

But that's not very elegant. Probably better to code a fixed-form TESTN in a procedure, and call that from within your free-form calcs.

Alternatively, you could assign the character string to a character subfield overlaying a zoned decimal subfield, and then monitor for an error trying to use the zoned subfield.

On the other hand, is TESTN *really* what you think you want?

Cheers! Hans


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