------------------------------------------------------------------------------ | |

-- -- | |

-- GNAT COMPILER COMPONENTS -- | |

-- -- | |

-- E X P _ F I X D -- | |

-- -- | |

-- S p e c -- | |

-- -- | |

-- Copyright (C) 1992-2021, Free Software Foundation, Inc. -- | |

-- -- | |

-- GNAT is free software; you can redistribute it and/or modify it under -- | |

-- terms of the GNU General Public License as published by the Free Soft- -- | |

-- ware Foundation; either version 3, or (at your option) any later ver- -- | |

-- sion. GNAT is distributed in the hope that it will be useful, but WITH- -- | |

-- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY -- | |

-- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -- | |

-- for more details. You should have received a copy of the GNU General -- | |

-- Public License distributed with GNAT; see file COPYING3. If not, go to -- | |

-- http://www.gnu.org/licenses for a complete copy of the license. -- | |

-- -- | |

-- GNAT was originally developed by the GNAT team at New York University. -- | |

-- Extensive contributions were provided by Ada Core Technologies Inc. -- | |

-- -- | |

------------------------------------------------------------------------------ | |

-- Expand routines for fixed-point convert, divide and multiply operations | |

with Types; use Types; | |

package Exp_Fixd is | |

-- General note on universal fixed. In the routines below, a fixed-point | |

-- type is always a specific fixed-point type or universal real, never | |

-- universal fixed. Universal fixed only appears as the result type of a | |

-- division or multiplication and in all such cases, the parent node, which | |

-- must be either a conversion node or a 'Round attribute reference node, | |

-- has the specific type information. In both cases, the parent node is | |

-- removed from the tree, and the appropriate routine in this package is | |

-- called with a multiply or divide node with all types (and also possibly | |

-- the Rounded_Result flag) set. | |

---------------------------- | |

-- Fixed-Point Conversion -- | |

---------------------------- | |

procedure Expand_Convert_Fixed_To_Fixed (N : Node_Id); | |

-- This routine expands the conversion of one fixed-point type to another, | |

-- N is the N_Op_Conversion node with the result and expression types (and | |

-- possibly the Rounded_Result flag) set. | |

procedure Expand_Convert_Fixed_To_Float (N : Node_Id); | |

-- This routine expands the conversion from a fixed-point type to a | |

-- floating-point type. N is an N_Type_Conversion node with the result | |

-- and expression types set. | |

procedure Expand_Convert_Fixed_To_Integer (N : Node_Id); | |

-- This routine expands the conversion from a fixed-point type to an | |

-- integer type. N is an N_Type_Conversion node with the result and | |

-- operand types set. | |

procedure Expand_Convert_Float_To_Fixed (N : Node_Id); | |

-- This routine expands the conversion from a floating-point type to | |

-- a fixed-point type. N is an N_Type_Conversion node with the result | |

-- and operand types (and possibly the Rounded_Result flag) set. | |

procedure Expand_Convert_Integer_To_Fixed (N : Node_Id); | |

-- This routine expands the conversion from an integer type to a | |

-- fixed-point type. N is an N_Type_Conversion node with the result | |

-- and operand types (and possibly the Rounded_Result flag) set. | |

-------------------------- | |

-- Fixed-Point Division -- | |

-------------------------- | |

procedure Expand_Decimal_Divide_Call (N : Node_Id); | |

-- This routine expands a call to the procedure Decimal.Divide. The | |

-- argument N is the N_Function_Call node. | |

procedure Expand_Divide_Fixed_By_Fixed_Giving_Fixed (N : Node_Id); | |

-- This routine expands the division between fixed-point types, with | |

-- a fixed-point type result. N is an N_Op_Divide node with operand | |

-- and result types (and possibly the Rounded_Result flag) set. Either | |

-- (but not both) of the operands may be universal real. | |

procedure Expand_Divide_Fixed_By_Fixed_Giving_Float (N : Node_Id); | |

-- This routine expands the division between two fixed-point types with | |

-- a floating-point result. N is an N_Op_Divide node with the result | |

-- and operand types set. Either (but not both) of the operands may be | |

-- universal real. | |

procedure Expand_Divide_Fixed_By_Fixed_Giving_Integer (N : Node_Id); | |

-- This routine expands the division between two fixed-point types with | |

-- an integer type result. N is an N_Op_Divide node with the result and | |

-- operand types set. Either (but not both) of the operands may be | |

-- universal real. | |

procedure Expand_Divide_Fixed_By_Integer_Giving_Fixed (N : Node_Id); | |

-- This routine expands the division between a fixed-point type and | |

-- standard integer type. The result type is the same fixed-point type | |

-- as the operand type. N is an N_Op_Divide node with the result and | |

-- left operand types being the fixed-point type, and the right operand | |

-- type being standard integer (and possibly Rounded_Result set). | |

-------------------------------- | |

-- Fixed-Point Multiplication -- | |

-------------------------------- | |

procedure Expand_Multiply_Fixed_By_Fixed_Giving_Fixed (N : Node_Id); | |

-- This routine expands the multiplication between fixed-point types | |

-- with a fixed-point type result. N is an N_Op_Multiply node with the | |

-- result and operand types set. Either (but not both) of the operands | |

-- may be universal real. | |

procedure Expand_Multiply_Fixed_By_Fixed_Giving_Float (N : Node_Id); | |

-- This routine expands the multiplication between two fixed-point types | |

-- with a floating-point result. N is an N_Op_Multiply node with the | |

-- result and operand types set. Either (but not both) of the operands | |

-- may be universal real. | |

procedure Expand_Multiply_Fixed_By_Fixed_Giving_Integer (N : Node_Id); | |

-- This routine expands the multiplication between two fixed-point types | |

-- with an integer result. N is an N_Op_Multiply node with the result | |

-- and operand types set. Either (but not both) of the operands may be | |

-- be universal real. | |

procedure Expand_Multiply_Fixed_By_Integer_Giving_Fixed (N : Node_Id); | |

-- This routine expands the multiplication between a fixed-point type and | |

-- a standard integer type. The result type is the same fixed-point type | |

-- as the fixed operand type. N is an N_Op_Multiply node whose result type | |

-- and left operand types are the fixed-point type, and whose right operand | |

-- type is always standard integer. | |

procedure Expand_Multiply_Integer_By_Fixed_Giving_Fixed (N : Node_Id); | |

-- This routine expands the multiplication between standard integer and a | |

-- fixed-point type. The result type is the same fixed-point type as the | |

-- fixed operand type. N is an N_Op_Multiply node whose result type | |

-- and right operand types are the fixed-point type, and whose left operand | |

-- type is always standard integer. | |

end Exp_Fixd; |