Programmer Guide/Command Reference/INT: Difference between revisions

From STX Wiki
Jump to navigationJump to search
No edit summary
No edit summary
 
(12 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{DISPLAYTITLE:{{SUBPAGENAME}}}}
{{DISPLAYTITLE:INT, INTCHECK}}
<var>var</var> := INT <var>expression</var>
{|class="einrahmen"
var>var</var> := INTCHECK <var>expression</var>
!command !!return value !!value of RC
 
|-
The <code>INT</code> statement will cause your expression being evaluated as an integer expression. More precisely (more precisely less wrongly), the expression will be evaluated numerically, and the result will be converted to an integer whose textual representation will be the string to be assigned to the destination variable. The calculation itself will be done with the point floating, though (see the below examples for what that means).
|<code>INT <var>expression</var></code>  
 
|integer part of evaluated ''expression'' or<BR>empty string if the evaluation fails
Note that the <code>INT</code> statement converts the result to an integer by ''truncating'' it. There is no rounding involved, no rounding at all.
|0<BR>error code
 
|-
In case of the expression being syntactically ill-formed, an error (<code>INT</code>) or warning (<code>INTCHECK</code>) is reported.
|<code>INTCHECK <var>expression</var></code>  
 
|integer part of evaluated ''expression'' or<BR>empty string if the evaluation fails
|0<BR>warning code
|}
;Description: The ''expression'' will be evaluated numerically, and the result will be converted to an integer whose textual representation is the return value. The calculation itself will be done with floating point accuracy. The same evaluation rules as defined for the [[../NUM|NUM command]] apply to this command.
;Notes:
:* The <code>INT</code> command converts the result to an integer by ''truncating'' it. There is no rounding involved, no rounding at all.
:* In case of the expression being syntactically ill-formed, an error (<code>INT</code>) or warning (<code>INTCHECK</code>) is reported.
;See also: [[../NUM|NUM, NUMCHECK]], [[../EVAL|EVAL, EVALCHECK]], [[../SEGMENT|SEGMENT]]
;Examples:
  #result := int 3.1          // #result is set to 3
  #result := int 3.1          // #result is set to 3
  #result := int 3.9          // #result is set to 3, too
  #result := int 3.9          // #result is set to 3, too
Line 16: Line 24:
  // compare the preceding example with the following one:
  // compare the preceding example with the following one:
  #result := int 3 * int(3.9)  // here, #result will be assigned 9 - cool, isn't it?
  #result := int 3 * int(3.9)  // here, #result will be assigned 9 - cool, isn't it?
See also: [[Programmer Guide/Command Reference/NUM|NUM]], [[Programmer Guide/Command Reference/EVAL|EVAL]]

Latest revision as of 10:49, 26 April 2011

command return value value of RC
INT expression integer part of evaluated expression or
empty string if the evaluation fails
0
error code
INTCHECK expression integer part of evaluated expression or
empty string if the evaluation fails
0
warning code
Description
The expression will be evaluated numerically, and the result will be converted to an integer whose textual representation is the return value. The calculation itself will be done with floating point accuracy. The same evaluation rules as defined for the NUM command apply to this command.
Notes
  • The INT command converts the result to an integer by truncating it. There is no rounding involved, no rounding at all.
  • In case of the expression being syntactically ill-formed, an error (INT) or warning (INTCHECK) is reported.
See also
NUM, NUMCHECK, EVAL, EVALCHECK, SEGMENT
Examples
#result := int 3.1           // #result is set to 3
#result := int 3.9           // #result is set to 3, too
#result := int 3.9 * 3.9     // #result is set to 15 (note that calculation
                             // is done in floating point, resulting in 15.21,
                             // and truncation occurs only on assigning
// compare the preceding example with the following one:
#result := int 3 * int(3.9)  // here, #result will be assigned 9 - cool, isn't it?

Navigation menu

Personal tools