note description: "User selectable parameters and rules which govern the results of decimal arithmetic operations" library: "Gobo Eiffel Decimal Arithmetic Library" copyright: "Copyright (c) 2004, Paul G. Crismer and others" license: "MIT License" date: "$Date: 2019-02-07 22:54:15 +0000 (Thu, 07 Feb 2019) $" revision: "$Revision: 102807 $" class MA_DECIMAL_CONTEXT create make_default, make_double, make_extended, make_double_extended, make feature {NONE} -- Initialization default_create -- Process instances of classes with no creation clause. -- (Default: do nothing.) -- (from ANY) do end make (a_digits, a_rounding_mode: INTEGER_32) -- Create a new math context. require a_digits_valid: a_digits >= Minimum_digits and a_digits <= Maximum_digits a_rounding_mode_valid: Integer_array_.has (Rounds, a_rounding_mode) do digits := a_digits rounding_mode := a_rounding_mode create traps.make_filled (False, Signal_division_by_zero, Signal_subnormal) create flags.make_filled (False, Signal_division_by_zero, Signal_subnormal) exponent_limit := Maximum_exponent ensure digits_set: digits = a_digits rounding_mode_set: rounding_mode = a_rounding_mode exponent_limit: exponent_limit = Maximum_exponent end make_default -- Create a new default context for general purpose arithmetic (IEEE 854), single precision. local index: INTEGER_32 do make (Default_digits, Default_rounding_mode) from index := Default_traps.lower until index > Default_traps.upper loop enable_trap (Default_traps.item (index)) index := index + 1 end ensure default_digits: digits = Default_digits default_rounding_mode: rounding_mode = Default_rounding_mode trap_division_by_zero: is_trapped (Signal_division_by_zero) trap_invalid_operation: is_trapped (Signal_invalid_operation) trap_overflow: is_trapped (Signal_overflow) trap_underflow: is_trapped (Signal_underflow) end make_double -- Create a new double precision context. do make_default digits := 2 * Default_digits + 1 ensure default_digits: digits = 2 * Default_digits + 1 default_rounding_mode: rounding_mode = Default_rounding_mode trap_division_by_zero: is_trapped (Signal_division_by_zero) trap_invalid_operation: is_trapped (Signal_invalid_operation) trap_overflow: is_trapped (Signal_overflow) trap_underflow: is_trapped (Signal_underflow) end make_double_extended -- Create a new extented default context, double precision. do make_extended digits := 2 * Default_digits + 1 ensure default_digits: digits = 2 * Default_digits + 1 default_rounding_mode: rounding_mode = Round_half_even end make_extended -- Create a new extended default context (IEEE 854), single precision. do make (Default_digits, Round_half_even) is_extended := True ensure default_digits: digits = Default_digits default_rounding_mode: rounding_mode = Round_half_even end feature -- Access Any_array_: KL_ARRAY_ROUTINES [detachable ANY] -- Routines that ought to be in class ARRAY -- (from KL_IMPORTED_ARRAY_ROUTINES) once create Result ensure -- from KL_IMPORTED_ARRAY_ROUTINES instance_free: class any_array_routines_not_void: Result /= Void end Array_special_integer_: KL_ARRAY_ROUTINES [detachable SPECIAL [INTEGER_32]] -- Routines that ought to be in class ARRAY -- (from KL_IMPORTED_ARRAY_ROUTINES) once create Result ensure -- from KL_IMPORTED_ARRAY_ROUTINES instance_free: class special_integer_array_routines_not_void: Result /= Void end Boolean_array_: KL_ARRAY_ROUTINES [BOOLEAN] -- Routines that ought to be in class ARRAY -- (from KL_IMPORTED_ARRAY_ROUTINES) once create Result ensure -- from KL_IMPORTED_ARRAY_ROUTINES instance_free: class boolean_array_routines_not_void: Result /= Void end Default_context: MA_DECIMAL_CONTEXT obsolete "Use MA_SHARED_DECIMAL_CONTEXT instead. [2005-09-11]" -- Default context for general purpose arithmetic once create Result.make_default ensure default_context_not_void: Result /= Void end Detachable_string_array_routines: KL_ARRAY_ROUTINES [detachable STRING_8] -- Routines that ought to be in class ARRAY -- (from KL_IMPORTED_ARRAY_ROUTINES) once create Result ensure -- from KL_IMPORTED_ARRAY_ROUTINES instance_free: class detachable_string_array_routines_not_void: Result /= Void end digits: INTEGER_32 -- Number of digits (precision) to be used for an operation. -- The DECIMAL operators use this value to determine the precision of results. -- Note that leading zeros (in the integer part of a number) are never significant. e_tiny: INTEGER_32 -- Minimum value of the exponent for subnormal numbers do Result := (- exponent_limit) - (digits - 1) end Exceptions: KL_EXCEPTIONS -- Exception handling -- (from KL_SHARED_EXCEPTIONS) once create Result ensure -- from KL_SHARED_EXCEPTIONS instance_free: class exceptions_not_void: Result /= Void end exponent_limit: INTEGER_32 -- Exponent limit; -- Exponents can range from -exponent_limit through +exponent_limit generating_type: TYPE [detachable MA_DECIMAL_CONTEXT] -- Type of current object -- (type of which it is a direct instance) -- (from ANY) external "built_in" ensure -- from ANY generating_type_not_void: Result /= Void end generator: STRING_8 -- Name of current object's generating class -- (base class of the type of which it is a direct instance) -- (from ANY) external "built_in" ensure -- from ANY generator_not_void: Result /= Void generator_not_empty: not Result.is_empty end Integer_array_: KL_ARRAY_ROUTINES [INTEGER_32] -- Routines that ought to be in class ARRAY -- (from KL_IMPORTED_ARRAY_ROUTINES) once create Result ensure -- from KL_IMPORTED_ARRAY_ROUTINES instance_free: class integer_array_routines_not_void: Result /= Void end precision: INTEGER_32 -- Synonym for 'digits' do Result := digits ensure synonym_of_digits: Result = digits end reason: detachable STRING_8 -- Reason of latest raised signal rounding_mode: INTEGER_32 -- Rounding algorithm to be used for an operation when non-zero digits have to -- be discarded in order to reduce the precision of a result String_: KL_STRING_ROUTINES -- Routines that ought to be in class STRING -- (from KL_IMPORTED_STRING_ROUTINES) once create Result ensure -- from KL_IMPORTED_STRING_ROUTINES instance_free: class string_routines_not_void: Result /= Void end String_array_: KL_ARRAY_ROUTINES [detachable STRING_8] -- Routines that ought to be in class ARRAY -- (from KL_IMPORTED_ARRAY_ROUTINES) once create Result ensure -- from KL_IMPORTED_ARRAY_ROUTINES instance_free: class string_array_routines_not_void: Result /= Void end String_array_routines: KL_ARRAY_ROUTINES [STRING_8] -- Routines that ought to be in class ARRAY -- (from KL_IMPORTED_ARRAY_ROUTINES) once create Result ensure -- from KL_IMPORTED_ARRAY_ROUTINES instance_free: class string_array_routines_not_void: Result /= Void end feature {NONE} -- Access Any_: KL_ANY_ROUTINES -- Routines that ought to be in class ANY -- (from KL_IMPORTED_ANY_ROUTINES) once create Result ensure -- from KL_IMPORTED_ANY_ROUTINES instance_free: class any_routines_not_void: Result /= Void end Decimal: MA_DECIMAL_CONSTANTS -- Decimal constants -- (from MA_SHARED_DECIMAL_CONSTANTS) once create Result ensure -- from MA_SHARED_DECIMAL_CONSTANTS instance_free: class decimal_not_void: Result /= Void end Platform: KL_PLATFORM -- Platform-dependent properties -- (from KL_SHARED_PLATFORM) once create Result ensure -- from KL_SHARED_PLATFORM instance_free: class platform_not_void: Result /= Void end feature -- Comparison frozen deep_equal (a: detachable ANY; b: like arg #1): BOOLEAN -- Are a and b either both void -- or attached to isomorphic object structures? -- (from ANY) do if a = Void then Result := b = Void else Result := b /= Void and then a.is_deep_equal (b) end ensure -- from ANY instance_free: class shallow_implies_deep: standard_equal (a, b) implies Result both_or_none_void: (a = Void) implies (Result = (b = Void)) same_type: (Result and (a /= Void)) implies (b /= Void and then a.same_type (b)) symmetric: Result implies deep_equal (b, a) end frozen equal (a: detachable ANY; b: like arg #1): BOOLEAN -- Are a and b either both void or attached -- to objects considered equal? -- (from ANY) do if a = Void then Result := b = Void else Result := b /= Void and then a.is_equal (b) end ensure -- from ANY instance_free: class definition: Result = (a = Void and b = Void) or else ((a /= Void and b /= Void) and then a.is_equal (b)) end frozen is_deep_equal (other: MA_DECIMAL_CONTEXT): BOOLEAN -- Are Current and other attached to isomorphic object structures? -- (from ANY) require -- from ANY other_not_void: other /= Void external "built_in" ensure -- from ANY shallow_implies_deep: standard_is_equal (other) implies Result same_type: Result implies same_type (other) symmetric: Result implies other.is_deep_equal (Current) end is_equal (other: like Current): BOOLEAN -- Is other equal to Current? require -- from ANY other_not_void: other /= Void do Result := digits = other.digits Result := Result and then exception_on_trap = other.exception_on_trap Result := Result and then exponent_limit = other.exponent_limit Result := Result and then flags.is_equal (other.flags) Result := Result and then is_extended = other.is_extended Result := Result and then rounding_mode = other.rounding_mode Result := Result and then traps.is_equal (other.traps) ensure -- from ANY symmetric: Result implies other ~ Current consistent: standard_is_equal (other) implies Result end frozen standard_equal (a: detachable ANY; b: like arg #1): BOOLEAN -- Are a and b either both void or attached to -- field-by-field identical objects of the same type? -- Always uses default object comparison criterion. -- (from ANY) do if a = Void then Result := b = Void else Result := b /= Void and then a.standard_is_equal (b) end ensure -- from ANY instance_free: class definition: Result = (a = Void and b = Void) or else ((a /= Void and b /= Void) and then a.standard_is_equal (b)) end frozen standard_is_equal (other: MA_DECIMAL_CONTEXT): BOOLEAN -- Is other attached to an object of the same type -- as current object, and field-by-field identical to it? -- (from ANY) require -- from ANY other_not_void: other /= Void external "built_in" ensure -- from ANY same_type: Result implies same_type (other) symmetric: Result implies other.standard_is_equal (Current) end feature -- Status report conforms_to (other: ANY): BOOLEAN -- Does type of current object conform to type -- of other (as per Eiffel: The Language, chapter 13)? -- (from ANY) require -- from ANY other_not_void: other /= Void external "built_in" end exception_on_trap: BOOLEAN -- Should an exception be raised when trap occurs? is_extended: BOOLEAN -- Is current context extended? is_flagged (a_signal: INTEGER_32): BOOLEAN -- Is a_signal flagged? require valid_signal: valid_signal (a_signal) do Result := flags.item (a_signal) end is_trapped (a_signal: INTEGER_32): BOOLEAN -- Is a_signal trapped? require valid_signal: valid_signal (a_signal) do Result := traps.item (a_signal) end same_type (other: ANY): BOOLEAN -- Is type of current object identical to type of other? -- (from ANY) require -- from ANY other_not_void: other /= Void external "built_in" ensure -- from ANY definition: Result = (conforms_to (other) and other.conforms_to (Current)) end valid_signal (a_signal: INTEGER_32): BOOLEAN -- Is a_signal a valid one? do Result := Integer_array_.has (Signals, a_signal) end feature -- Element change disable_exception_on_trap -- Disable exception when trap occurs. do exception_on_trap := False end disable_trap (a_signal: INTEGER_32) -- Enable trapping of a_signal. require valid_signal: valid_signal (a_signal) do traps.put (False, a_signal) ensure not_trapped_signal: not is_trapped (a_signal) end enable_exception_on_trap -- Enable exception when trap occurs. do exception_on_trap := True end enable_trap (a_signal: INTEGER_32) -- Enable trapping of a_signal. require valid_signal: valid_signal (a_signal) do traps.put (True, a_signal) ensure trapped_signal: is_trapped (a_signal) end reset_flag (a_signal: INTEGER_32) -- Reset a_signal. require valid_signal: valid_signal (a_signal) do flags.put (False, a_signal) ensure unflagged_signal: not is_flagged (a_signal) end reset_flags -- Reset all signals to zero. local i, nb: INTEGER_32 do from i := flags.lower nb := flags.upper until i > nb loop flags.put (False, i) i := i + 1 end end set_digits (some_digits: INTEGER_32) -- Set digits to some_digits. require some_digits_valid: some_digits >= Minimum_digits and some_digits <= Maximum_digits do digits := some_digits ensure digits_set: digits = some_digits end set_exponent_limit (a_limit: INTEGER_32) -- Set exponent_limit to a_limit. require limit_positive: a_limit >= 0 do exponent_limit := a_limit ensure limit_set: exponent_limit = a_limit end set_extended -- Set is_extended to True. do is_extended := True ensure extended: is_extended end set_flag (a_signal: INTEGER_32) -- Flag a_signal. require valid_signal: valid_signal (a_signal) do flags.put (True, a_signal) ensure flagged_signal: is_flagged (a_signal) end set_normal -- Set is_extended to False. do is_extended := False ensure normal: not is_extended end set_rounding_mode (a_mode: INTEGER_32) -- Set rounding_mode to a_mode. require valid_mode: Integer_array_.has (Rounds, a_mode) do rounding_mode := a_mode ensure rounding_mode_set: rounding_mode = a_mode end feature -- Conversion out: STRING_8 -- Printable representation do create Result.make (30) Result.append_string ("digits=") Result.append_string (digits.out) Result.append_string (" rounding_mode=") Result.append_string (Round_words.item (Round_words.lower + rounding_mode)) ensure -- from ANY out_not_void: Result /= Void end feature -- Duplication frozen clone (other: detachable ANY): like other obsolete "Use `twin' instead. [2017-05-31]" -- Void if other is void; otherwise new object -- equal to other -- -- For non-void other, clone calls copy; -- to change copying/cloning semantics, redefine copy. -- (from ANY) do if other /= Void then Result := other.twin end ensure -- from ANY instance_free: class equal: Result ~ other end cloned_object: MA_DECIMAL_CONTEXT -- Clone of current object -- (from KL_CLONABLE) do Result := twin ensure -- from KL_CLONABLE cloned_not_void: Result /= Void same_type: Any_.same_types (Result, Current) is_equal: Result.is_equal (Current) end copy (other: like Current) -- Copy other. require -- from ANY other_not_void: other /= Void type_identity: same_type (other) do standard_copy (other) flags := Boolean_array_.cloned_array (other.flags) traps := Boolean_array_.cloned_array (other.traps) ensure -- from ANY is_equal: Current ~ other end frozen deep_clone (other: detachable ANY): like other obsolete "Use `deep_twin' instead. [2017-05-31]" -- Void if other is void: otherwise, new object structure -- recursively duplicated from the one attached to other -- (from ANY) do if other /= Void then Result := other.deep_twin end ensure -- from ANY instance_free: class deep_equal: deep_equal (other, Result) end frozen deep_copy (other: MA_DECIMAL_CONTEXT) -- Effect equivalent to that of: -- copy (other . deep_twin) -- (from ANY) require -- from ANY other_not_void: other /= Void do copy (other.deep_twin) ensure -- from ANY deep_equal: deep_equal (Current, other) end frozen deep_twin: MA_DECIMAL_CONTEXT -- New object structure recursively duplicated from Current. -- (from ANY) external "built_in" ensure -- from ANY deep_twin_not_void: Result /= Void deep_equal: deep_equal (Current, Result) end frozen standard_clone (other: detachable ANY): like other obsolete "Use `standard_twin' instead. [2017-05-31]" -- Void if other is void; otherwise new object -- field-by-field identical to other. -- Always uses default copying semantics. -- (from ANY) do if other /= Void then Result := other.standard_twin end ensure -- from ANY instance_free: class equal: standard_equal (Result, other) end frozen standard_copy (other: MA_DECIMAL_CONTEXT) -- Copy every field of other onto corresponding field -- of current object. -- (from ANY) require -- from ANY other_not_void: other /= Void type_identity: same_type (other) external "built_in" ensure -- from ANY is_standard_equal: standard_is_equal (other) end frozen standard_twin: MA_DECIMAL_CONTEXT -- New object field-by-field identical to other. -- Always uses default copying semantics. -- (from ANY) external "built_in" ensure -- from ANY standard_twin_not_void: Result /= Void equal: standard_equal (Result, Current) end frozen twin: MA_DECIMAL_CONTEXT -- New object equal to Current -- twin calls copy; to change copying/twinning semantics, redefine copy. -- (from ANY) external "built_in" ensure -- from ANY twin_not_void: Result /= Void is_equal: Result ~ Current end feature -- Basic operations frozen as_attached: attached MA_DECIMAL_CONTEXT obsolete "Remove calls to this feature. [2017-05-31]" -- Attached version of Current. -- (Can be used during transitional period to convert -- non-void-safe classes to void-safe ones.) -- (from ANY) do Result := Current end frozen default: detachable MA_DECIMAL_CONTEXT -- Default value of object's type -- (from ANY) do end frozen default_pointer: POINTER -- Default value of type POINTER -- (Avoid the need to write p.default for -- some p of type POINTER.) -- (from ANY) do ensure -- from ANY instance_free: class end default_rescue -- Process exception for routines with no Rescue clause. -- (Default: do nothing.) -- (from ANY) do end frozen do_nothing -- Execute a null action. -- (from ANY) do ensure -- from ANY instance_free: class end signal (a_signal: INTEGER_32; a_message: STRING_8) -- Raise flag a_signal for a_message reason. require valid_signal: valid_signal (a_signal) a_message_not_void: a_message /= Void local exception_message: STRING_8 do set_flag (a_signal) reason := a_message if is_trapped (a_signal) and then exception_on_trap then exception_message := String_.cloned_string (Signal_words.item (a_signal)) exception_message.append_string (" : ") exception_message.append_string (a_message) Exceptions.raise (exception_message) end ensure flagged_signal: is_flagged (a_signal) reason_set: reason = a_message end feature {MA_DECIMAL} -- Implementation force_digits (d: INTEGER_32) -- Force digits to d, just for do_underflow. require d_positive: d >= 0 do digits := d ensure digits_set: digits = d end feature -- Constants: defaults Default_digits: INTEGER_32 = 9 -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Default_rounding_mode: INTEGER_32 -- Default rounding mode -- (from MA_DECIMAL_CONTEXT_CONSTANTS) once Result := Round_half_up ensure -- from MA_DECIMAL_CONTEXT_CONSTANTS instance_free: class definition: Result = Round_half_up end Default_traps: ARRAY [INTEGER_32] -- (from MA_DECIMAL_CONTEXT_CONSTANTS) once Result := <<Signal_division_by_zero, Signal_invalid_operation, Signal_overflow, Signal_underflow>> ensure -- from MA_DECIMAL_CONTEXT_CONSTANTS instance_free: class default_traps_not_void: Result /= Void has_division_by_zero: Integer_array_.has (Result, Signal_division_by_zero) has_invalid_operation: Integer_array_.has (Result, Signal_invalid_operation) has_overflow: Integer_array_.has (Result, Signal_overflow) has_underflow: Integer_array_.has (Result, Signal_underflow) end feature -- Constants: limits Maximum_digits: INTEGER_32 = 999999999 -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Maximum_exponent: INTEGER_32 = 999999999 -- Maximum exponent allowed -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Maximum_integer_as_decimal: MA_DECIMAL obsolete "Use MA_DECIMAL_CONSTANTS.maximum_integer instead. [2005-09-11]" -- Maximum value convertible to integer -- (from MA_DECIMAL_CONTEXT_CONSTANTS) once Result := Decimal.Maximum_integer ensure -- from MA_DECIMAL_CONTEXT_CONSTANTS instance_free: class maximum_integer_not_void: Result /= Void end Minimum_digits: INTEGER_32 = 1 -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Minimum_exponent: INTEGER_32 = -999999999 -- Minimum exponent allowed -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Minimum_integer_as_decimal: MA_DECIMAL obsolete "Use MA_DECIMAL_CONSTANTS.minimum_integer instead. [2005-09-11]" -- Minimum value convertible to integer -- (from MA_DECIMAL_CONTEXT_CONSTANTS) once Result := Decimal.Minimum_integer ensure -- from MA_DECIMAL_CONTEXT_CONSTANTS instance_free: class minimum_integer_not_void: Result /= Void end feature -- Constants: rounding modes Round_ceiling: INTEGER_32 = 2 -- Rounding mode to round to a more positive number; -- All discarded digits are ignored (truncated). The result is neither incremented nor decremented. -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Round_down: INTEGER_32 = 1 -- Rounding mode to round towards zero; -- If any of the discarded digits are non-zero then the result should be rounded towards the next ore negative digit. -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Round_floor: INTEGER_32 = 3 -- Rounding mode to round to a more negative number; -- If any of the discarded digits are non-zero then the result should be rounded towards the next more negative digit. -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Round_half_down: INTEGER_32 = 5 -- Rounding mode to round to nearest neighbor, where an equidistant value is rounded down; -- If the discarded digits represent greater than half (0.5 times) -- the value of a one in the next position then the result should be -- rounded up (away from zero). Otherwise the discarded digits are ignored. -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Round_half_even: INTEGER_32 = 6 -- Rounding mode to round to nearest neighbor, where an equidistant value is rounded to the nearest even neighbor; -- If the discarded digits represent greater than half (0.5 times) the value of a one in the next position then the result should be -- rounded up (away from zero). -- If they represent less than half, then the result should be rounded down. -- Otherwise (they represent exactly half) the result is rounded down if its rightmost digit is even, or rounded up if its -- rightmost digit is odd (to make an even digit). -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Round_half_up: INTEGER_32 = 4 -- Rounding mode to round to nearest neighbor, where an equidistant value is rounded up; -- If the discarded digits represent greater than or equal to half (0.5 times) the value -- of a one in the next position then the result should be rounded up (away from zero). -- Otherwise the discarded digits are ignored. -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Round_unnecessary: INTEGER_32 = 7 -- Rounding mode to assert that no rounding is necessary; -- Rounding (potential loss of information) is not permitted. -- If any of the discarded digits are non-zero then an 'ArithmeticException'should be thrown. -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Round_up: INTEGER_32 = 0 -- Rounding mode to round away from zero; -- If any of the discarded digits are non-zero then the result will be rounded up (away from zero). -- (from MA_DECIMAL_CONTEXT_CONSTANTS) feature -- Constants: signals Signal_division_by_zero: INTEGER_32 = 1 -- Non Zero dividend is divided by zero -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Signal_inexact: INTEGER_32 = 2 -- A result is not exact, or overflows or underflows without being trapped -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Signal_invalid_operation: INTEGER_32 = 3 -- A result would be undefined or impossible -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Signal_lost_digits: INTEGER_32 = 4 -- Non-zero digits have been discarded before an operation -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Signal_overflow: INTEGER_32 = 5 -- The exponent of a result is too large to be represented -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Signal_rounded: INTEGER_32 = 6 -- A result has been rounded, that is, some zero or non-zero digits were discarded -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Signal_subnormal: INTEGER_32 = 8 -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Signal_underflow: INTEGER_32 = 7 -- The exponent of a result is too small to be represented -- (from MA_DECIMAL_CONTEXT_CONSTANTS) feature -- Constants: special flags Special_infinity: INTEGER_32 = 1 -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Special_none: INTEGER_32 = 0 -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Special_quiet_nan: INTEGER_32 = 3 -- (from MA_DECIMAL_CONTEXT_CONSTANTS) Special_signaling_nan: INTEGER_32 = 2 -- (from MA_DECIMAL_CONTEXT_CONSTANTS) feature -- Constants: support Round_words: ARRAY [STRING_8] -- Textual representation of rounding modes -- (from MA_DECIMAL_CONTEXT_CONSTANTS) once Result := <<"Round_up", "Round_down", "Round_ceiling", "Round_floor", "Round_half_up", "Round_half_down", "Round_half_even", "Round_unnecessary">> ensure -- from MA_DECIMAL_CONTEXT_CONSTANTS instance_free: class round_word_not_void: Result /= Void no_void_round_words: not Any_array_.has (Result, Void) end Rounds: ARRAY [INTEGER_32] -- Rounding modes -- (from MA_DECIMAL_CONTEXT_CONSTANTS) once Result := <<Round_half_up, Round_unnecessary, Round_ceiling, Round_down, Round_floor, Round_half_down, Round_half_even, Round_up>> ensure -- from MA_DECIMAL_CONTEXT_CONSTANTS instance_free: class rounds_not_void: Result /= Void end Signal_words: ARRAY [STRING_8] -- Textual representation of signals -- (from MA_DECIMAL_CONTEXT_CONSTANTS) once Result := <<"division_by_zero", "inexact", "invalid_operation", "lost_digits", "overflow", "rounded", "underflow", "subnormal">> ensure -- from MA_DECIMAL_CONTEXT_CONSTANTS instance_free: class signal_words_not_void: Result /= Void no_void_signal_words: not Any_array_.has (Result, Void) end Signals: ARRAY [INTEGER_32] -- Signals -- (from MA_DECIMAL_CONTEXT_CONSTANTS) once Result := <<Signal_division_by_zero, Signal_inexact, Signal_invalid_operation, Signal_lost_digits, Signal_overflow, Signal_rounded, Signal_underflow, Signal_subnormal>> ensure -- from MA_DECIMAL_CONTEXT_CONSTANTS instance_free: class signals_not_void: Result /= Void end feature -- Output Io: STD_FILES -- Handle to standard file setup -- (from ANY) once create Result Result.set_output_default ensure -- from ANY instance_free: class io_not_void: Result /= Void end print (o: detachable ANY) -- Write terse external representation of o -- on standard output. -- (from ANY) do if o /= Void then Io.put_string (o.out) end ensure -- from ANY instance_free: class end frozen tagged_out: STRING_8 -- New string containing terse printable representation -- of current object -- (from ANY) external "built_in" ensure -- from ANY tagged_out_not_void: Result /= Void end feature -- Platform Operating_environment: OPERATING_ENVIRONMENT -- Objects available from the operating system -- (from ANY) once create Result ensure -- from ANY instance_free: class operating_environment_not_void: Result /= Void end feature {NONE} -- Retrieval frozen internal_correct_mismatch -- Called from runtime to perform a proper dynamic dispatch on correct_mismatch -- from MISMATCH_CORRECTOR. -- (from ANY) local l_msg: STRING_8 l_exc: EXCEPTIONS do if attached {MISMATCH_CORRECTOR} Current as l_corrector then l_corrector.correct_mismatch else create l_msg.make_from_string ("Mismatch: ") create l_exc l_msg.append (generating_type.name) l_exc.raise_retrieval_exception (l_msg) end end feature {MA_DECIMAL_HANDLER, MA_DECIMAL_CONTEXT} -- Signals flags: ARRAY [BOOLEAN] -- Signals flagged traps: ARRAY [BOOLEAN] -- Signals trapped invariant positive_digits: digits >= 0 rounding_mode_valid: rounding_mode = Round_ceiling or rounding_mode = Round_down or rounding_mode = Round_floor or rounding_mode = Round_half_down or rounding_mode = Round_half_even or rounding_mode = Round_half_up or rounding_mode = Round_unnecessary or rounding_mode = Round_up flags_not_void: flags /= Void flags_lower: flags.lower = Signal_division_by_zero flags_upper: flags.upper = Signal_subnormal traps_not_void: traps /= Void traps_lower: traps.lower = Signal_division_by_zero traps_upper: traps.upper = Signal_subnormal -- from ANY reflexive_equality: standard_is_equal (Current) reflexive_conformance: conforms_to (Current) end -- class MA_DECIMAL_CONTEXT
Generated by ISE EiffelStudio