diff options
author | Tristan Gingold <tgingold@free.fr> | 2017-10-17 18:18:41 +0200 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2017-10-17 18:18:41 +0200 |
commit | 4b02db2999cfd9c174be04de1d6a1fb6ed86e956 (patch) | |
tree | 004411b0bdabb501bfc48ccbb1f9b3c8dff83664 | |
parent | 369d2d2cdc76eff902ae578fa0429771c0118224 (diff) | |
download | ghdl-4b02db2999cfd9c174be04de1d6a1fb6ed86e956.tar.gz ghdl-4b02db2999cfd9c174be04de1d6a1fb6ed86e956.tar.bz2 ghdl-4b02db2999cfd9c174be04de1d6a1fb6ed86e956.zip |
iirs: reformat enum, add more enums in python interface.
-rw-r--r-- | src/vhdl/iirs.ads | 724 | ||||
-rwxr-xr-x | src/vhdl/python/pnodespy.py | 10 |
2 files changed, 369 insertions, 365 deletions
diff --git a/src/vhdl/iirs.ads b/src/vhdl/iirs.ads index 950a40986..95239ffb6 100644 --- a/src/vhdl/iirs.ads +++ b/src/vhdl/iirs.ads @@ -4336,22 +4336,22 @@ package Iirs is pragma Inline (Kind_In); type Iir_Signal_Kind is - ( - Iir_Register_Kind, - Iir_Bus_Kind - ); + ( + Iir_Register_Kind, + Iir_Bus_Kind + ); -- If the order of elements in IIR_MODE is modified, also modify the -- order in GRT (types and rtis). type Iir_Mode is - ( - Iir_Unknown_Mode, - Iir_Linkage_Mode, - Iir_Buffer_Mode, - Iir_Out_Mode, - Iir_Inout_Mode, - Iir_In_Mode - ); + ( + Iir_Unknown_Mode, + Iir_Linkage_Mode, + Iir_Buffer_Mode, + Iir_Out_Mode, + Iir_Inout_Mode, + Iir_In_Mode + ); subtype Iir_In_Modes is Iir_Mode range Iir_Inout_Mode .. Iir_In_Mode; subtype Iir_Out_Modes is Iir_Mode range Iir_Out_Mode .. Iir_Inout_Mode; @@ -4390,356 +4390,356 @@ package Iirs is -- List of predefined operators and functions. type Iir_Predefined_Functions is - ( - Iir_Predefined_Error, - - -- Predefined operators for BOOLEAN type - - -- LRM08 9.2.2 Logical Operators - Iir_Predefined_Boolean_And, - Iir_Predefined_Boolean_Or, - Iir_Predefined_Boolean_Nand, - Iir_Predefined_Boolean_Nor, - Iir_Predefined_Boolean_Xor, - Iir_Predefined_Boolean_Xnor, - Iir_Predefined_Boolean_Not, - - -- LRM08 5.2.6 Predefined operations on scalar types. - Iir_Predefined_Boolean_Rising_Edge, - Iir_Predefined_Boolean_Falling_Edge, - - -- Predefined operators for any enumeration type. - - -- LRM08 9.2.3 Relational Operators - Iir_Predefined_Enum_Equality, - Iir_Predefined_Enum_Inequality, - Iir_Predefined_Enum_Less, - Iir_Predefined_Enum_Less_Equal, - Iir_Predefined_Enum_Greater, - Iir_Predefined_Enum_Greater_Equal, - - -- LRM08 5.2.6 Predefined operations on scalar types. - Iir_Predefined_Enum_Minimum, - Iir_Predefined_Enum_Maximum, - Iir_Predefined_Enum_To_String, - - -- Predefined operators for BIT type. - - -- LRM08 9.2.2 Logical Operators - Iir_Predefined_Bit_And, - Iir_Predefined_Bit_Or, - Iir_Predefined_Bit_Nand, - Iir_Predefined_Bit_Nor, - Iir_Predefined_Bit_Xor, - Iir_Predefined_Bit_Xnor, - Iir_Predefined_Bit_Not, - - -- LRM08 9.2.3 Relational Operators - Iir_Predefined_Bit_Match_Equality, - Iir_Predefined_Bit_Match_Inequality, - Iir_Predefined_Bit_Match_Less, - Iir_Predefined_Bit_Match_Less_Equal, - Iir_Predefined_Bit_Match_Greater, - Iir_Predefined_Bit_Match_Greater_Equal, - - -- LRM08 9.2.9 Condition operator - Iir_Predefined_Bit_Condition, - - -- LRM08 5.2.6 Predefined operations on scalar types. - Iir_Predefined_Bit_Rising_Edge, - Iir_Predefined_Bit_Falling_Edge, - - -- Predefined operators for any integer type. - - -- LRM08 9.2.3 Relational Operators - Iir_Predefined_Integer_Equality, - Iir_Predefined_Integer_Inequality, - Iir_Predefined_Integer_Less, - Iir_Predefined_Integer_Less_Equal, - Iir_Predefined_Integer_Greater, - Iir_Predefined_Integer_Greater_Equal, - - -- LRM08 9.2.6 Sign operators - Iir_Predefined_Integer_Identity, - Iir_Predefined_Integer_Negation, - - -- LRM08 9.2.8 Miscellaneous operators - Iir_Predefined_Integer_Absolute, - - -- LRM08 9.2.5 Adding operators - Iir_Predefined_Integer_Plus, - Iir_Predefined_Integer_Minus, - - -- LRM08 9.2.7 Multiplying operators - Iir_Predefined_Integer_Mul, - Iir_Predefined_Integer_Div, - Iir_Predefined_Integer_Mod, - Iir_Predefined_Integer_Rem, - - -- LRM08 9.2.8 Miscellaneous operators - Iir_Predefined_Integer_Exp, - - -- LRM08 5.2.6 Predefined operations on scalar types. - Iir_Predefined_Integer_Minimum, - Iir_Predefined_Integer_Maximum, - Iir_Predefined_Integer_To_String, - - -- Predefined operators for any floating type. - - -- LRM08 9.2.3 Relational Operators - Iir_Predefined_Floating_Equality, - Iir_Predefined_Floating_Inequality, - Iir_Predefined_Floating_Less, - Iir_Predefined_Floating_Less_Equal, - Iir_Predefined_Floating_Greater, - Iir_Predefined_Floating_Greater_Equal, - - -- LRM08 9.2.6 Sign operators - Iir_Predefined_Floating_Identity, - Iir_Predefined_Floating_Negation, - - -- LRM08 9.2.8 Miscellaneous operators - Iir_Predefined_Floating_Absolute, - - -- LRM08 9.2.5 Adding operators - Iir_Predefined_Floating_Plus, - Iir_Predefined_Floating_Minus, - - -- LRM08 9.2.7 Multiplying operators - Iir_Predefined_Floating_Mul, - Iir_Predefined_Floating_Div, - - -- LRM08 9.2.8 Miscellaneous operators - Iir_Predefined_Floating_Exp, - - -- LRM08 5.2.6 Predefined operations on scalar types. - Iir_Predefined_Floating_Minimum, - Iir_Predefined_Floating_Maximum, - Iir_Predefined_Floating_To_String, - Iir_Predefined_Real_To_String_Digits, - Iir_Predefined_Real_To_String_Format, - - -- Predefined operator for universal types. - - -- LRM08 9.2.7 Multiplying operators - Iir_Predefined_Universal_R_I_Mul, - Iir_Predefined_Universal_I_R_Mul, - Iir_Predefined_Universal_R_I_Div, - - -- Predefined operators for physical types. - - -- LRM08 9.2.3 Relational Operators - Iir_Predefined_Physical_Equality, - Iir_Predefined_Physical_Inequality, - Iir_Predefined_Physical_Less, - Iir_Predefined_Physical_Less_Equal, - Iir_Predefined_Physical_Greater, - Iir_Predefined_Physical_Greater_Equal, - - -- LRM08 9.2.6 Sign operators - Iir_Predefined_Physical_Identity, - Iir_Predefined_Physical_Negation, - - -- LRM08 9.2.8 Miscellaneous operators - Iir_Predefined_Physical_Absolute, - - -- LRM08 9.2.5 Adding operators - Iir_Predefined_Physical_Plus, - Iir_Predefined_Physical_Minus, - - -- LRM08 9.2.7 Multiplying operators - Iir_Predefined_Physical_Integer_Mul, - Iir_Predefined_Physical_Real_Mul, - Iir_Predefined_Integer_Physical_Mul, - Iir_Predefined_Real_Physical_Mul, - Iir_Predefined_Physical_Integer_Div, - Iir_Predefined_Physical_Real_Div, - Iir_Predefined_Physical_Physical_Div, - - -- LRM08 5.2.6 Predefined operations on scalar types. - Iir_Predefined_Physical_Minimum, - Iir_Predefined_Physical_Maximum, - Iir_Predefined_Physical_To_String, - Iir_Predefined_Time_To_String_Unit, - - -- Predefined operators for access. - - -- LRM08 9.2.3 Relational Operators - Iir_Predefined_Access_Equality, - Iir_Predefined_Access_Inequality, - - -- Predefined operators for record. - - -- LRM08 9.2.3 Relational Operators - Iir_Predefined_Record_Equality, - Iir_Predefined_Record_Inequality, - - -- Predefined operators for array. - - -- LRM08 9.2.3 Relational Operators - Iir_Predefined_Array_Equality, - Iir_Predefined_Array_Inequality, - Iir_Predefined_Array_Less, - Iir_Predefined_Array_Less_Equal, - Iir_Predefined_Array_Greater, - Iir_Predefined_Array_Greater_Equal, - - -- LRM08 9.2.5 Adding operators - Iir_Predefined_Array_Array_Concat, - Iir_Predefined_Array_Element_Concat, - Iir_Predefined_Element_Array_Concat, - Iir_Predefined_Element_Element_Concat, - - -- LRM08 5.3.2.4 Predefined operations on array types - Iir_Predefined_Array_Minimum, - Iir_Predefined_Array_Maximum, - Iir_Predefined_Vector_Minimum, - Iir_Predefined_Vector_Maximum, - - -- LRM08 9.2.4 Shift operators - Iir_Predefined_Array_Sll, - Iir_Predefined_Array_Srl, - Iir_Predefined_Array_Sla, - Iir_Predefined_Array_Sra, - Iir_Predefined_Array_Rol, - Iir_Predefined_Array_Ror, - - -- LRM08 9.2.2 Logical operators - -- Predefined operators for one dimensional array. - -- For bit and boolean type, the operations are the same. To be - -- neutral, we use TF (for True/False) instead of Bit, Boolean or - -- Logic. - Iir_Predefined_TF_Array_And, - Iir_Predefined_TF_Array_Or, - Iir_Predefined_TF_Array_Nand, - Iir_Predefined_TF_Array_Nor, - Iir_Predefined_TF_Array_Xor, - Iir_Predefined_TF_Array_Xnor, - Iir_Predefined_TF_Array_Not, - - -- LRM08 9.2.2 Logical operators - Iir_Predefined_TF_Reduction_And, - Iir_Predefined_TF_Reduction_Or, - Iir_Predefined_TF_Reduction_Nand, - Iir_Predefined_TF_Reduction_Nor, - Iir_Predefined_TF_Reduction_Xor, - Iir_Predefined_TF_Reduction_Xnor, - Iir_Predefined_TF_Reduction_Not, - - -- LRM08 9.2.2 Logical operators - Iir_Predefined_TF_Array_Element_And, - Iir_Predefined_TF_Element_Array_And, - Iir_Predefined_TF_Array_Element_Or, - Iir_Predefined_TF_Element_Array_Or, - Iir_Predefined_TF_Array_Element_Nand, - Iir_Predefined_TF_Element_Array_Nand, - Iir_Predefined_TF_Array_Element_Nor, - Iir_Predefined_TF_Element_Array_Nor, - Iir_Predefined_TF_Array_Element_Xor, - Iir_Predefined_TF_Element_Array_Xor, - Iir_Predefined_TF_Array_Element_Xnor, - Iir_Predefined_TF_Element_Array_Xnor, - - -- LRM08 9.2.3 Relational Operators - Iir_Predefined_Bit_Array_Match_Equality, - Iir_Predefined_Bit_Array_Match_Inequality, - - -- LRM08 5.3.2.4 Predefined operations on array types - Iir_Predefined_Array_Char_To_String, - Iir_Predefined_Bit_Vector_To_Ostring, - Iir_Predefined_Bit_Vector_To_Hstring, - - -- LRM08 9.2.3 Relational Operators - -- IEEE.Std_Logic_1164.Std_Ulogic - Iir_Predefined_Std_Ulogic_Match_Equality, - Iir_Predefined_Std_Ulogic_Match_Inequality, - Iir_Predefined_Std_Ulogic_Match_Less, - Iir_Predefined_Std_Ulogic_Match_Less_Equal, - Iir_Predefined_Std_Ulogic_Match_Greater, - Iir_Predefined_Std_Ulogic_Match_Greater_Equal, - - -- LRM08 9.2.3 Relational Operators - Iir_Predefined_Std_Ulogic_Array_Match_Equality, - Iir_Predefined_Std_Ulogic_Array_Match_Inequality, - - -- -- Predefined attribute functions. - -- Iir_Predefined_Attribute_Image, - -- Iir_Predefined_Attribute_Value, - -- Iir_Predefined_Attribute_Pos, - -- Iir_Predefined_Attribute_Val, - -- Iir_Predefined_Attribute_Succ, - -- Iir_Predefined_Attribute_Pred, - -- Iir_Predefined_Attribute_Leftof, - -- Iir_Predefined_Attribute_Rightof, - -- Iir_Predefined_Attribute_Left, - -- Iir_Predefined_Attribute_Right, - -- Iir_Predefined_Attribute_Event, - -- Iir_Predefined_Attribute_Active, - -- Iir_Predefined_Attribute_Last_Event, - -- Iir_Predefined_Attribute_Last_Active, - -- Iir_Predefined_Attribute_Last_Value, - -- Iir_Predefined_Attribute_Driving, - -- Iir_Predefined_Attribute_Driving_Value, - - -- Impure subprograms. - - -- LRM08 5.4.3 Allocation and deallocation of objects - Iir_Predefined_Deallocate, - - -- LRM08 5.5.2 File operations - Iir_Predefined_File_Open, - Iir_Predefined_File_Open_Status, - Iir_Predefined_File_Close, - Iir_Predefined_Read, - Iir_Predefined_Read_Length, - Iir_Predefined_Flush, - Iir_Predefined_Write, - Iir_Predefined_Endfile, - - -- Misc impure functions. - Iir_Predefined_Now_Function, - - -- A not predefined and not known function. User function. - Iir_Predefined_None, - - -- Defined in package ieee.std_logic_1164 - - -- Std_Ulogic operations. - Iir_Predefined_Ieee_1164_Scalar_And, - Iir_Predefined_Ieee_1164_Scalar_Nand, - Iir_Predefined_Ieee_1164_Scalar_Or, - Iir_Predefined_Ieee_1164_Scalar_Nor, - Iir_Predefined_Ieee_1164_Scalar_Xor, - Iir_Predefined_Ieee_1164_Scalar_Xnor, - Iir_Predefined_Ieee_1164_Scalar_Not, - - -- Std_Logic_Vector or Std_Ulogic_Vector operations. - -- Length of the result is the length of the left operand. - Iir_Predefined_Ieee_1164_Vector_And, - Iir_Predefined_Ieee_1164_Vector_Nand, - Iir_Predefined_Ieee_1164_Vector_Or, - Iir_Predefined_Ieee_1164_Vector_Nor, - Iir_Predefined_Ieee_1164_Vector_Xor, - Iir_Predefined_Ieee_1164_Vector_Xnor, - Iir_Predefined_Ieee_1164_Vector_Not, - - -- Numeric_Std. - -- Abbreviations: - -- Uns: Unsigned, Sgn: Signed, Nat: Natural, Int: Integer. - Iir_Predefined_Ieee_Numeric_Std_Add_Uns_Uns, - Iir_Predefined_Ieee_Numeric_Std_Add_Uns_Nat, - Iir_Predefined_Ieee_Numeric_Std_Add_Nat_Uns, - Iir_Predefined_Ieee_Numeric_Std_Add_Sgn_Sgn, - Iir_Predefined_Ieee_Numeric_Std_Add_Sgn_Int, - Iir_Predefined_Ieee_Numeric_Std_Add_Int_Sgn, - - Iir_Predefined_Ieee_Numeric_Std_Eq_Uns_Uns, - Iir_Predefined_Ieee_Numeric_Std_Eq_Uns_Nat, - Iir_Predefined_Ieee_Numeric_Std_Eq_Nat_Uns, - Iir_Predefined_Ieee_Numeric_Std_Eq_Sgn_Sgn, - Iir_Predefined_Ieee_Numeric_Std_Eq_Sgn_Int, - Iir_Predefined_Ieee_Numeric_Std_Eq_Int_Sgn -); + ( + Iir_Predefined_Error, + + -- Predefined operators for BOOLEAN type + + -- LRM08 9.2.2 Logical Operators + Iir_Predefined_Boolean_And, + Iir_Predefined_Boolean_Or, + Iir_Predefined_Boolean_Nand, + Iir_Predefined_Boolean_Nor, + Iir_Predefined_Boolean_Xor, + Iir_Predefined_Boolean_Xnor, + Iir_Predefined_Boolean_Not, + + -- LRM08 5.2.6 Predefined operations on scalar types. + Iir_Predefined_Boolean_Rising_Edge, + Iir_Predefined_Boolean_Falling_Edge, + + -- Predefined operators for any enumeration type. + + -- LRM08 9.2.3 Relational Operators + Iir_Predefined_Enum_Equality, + Iir_Predefined_Enum_Inequality, + Iir_Predefined_Enum_Less, + Iir_Predefined_Enum_Less_Equal, + Iir_Predefined_Enum_Greater, + Iir_Predefined_Enum_Greater_Equal, + + -- LRM08 5.2.6 Predefined operations on scalar types. + Iir_Predefined_Enum_Minimum, + Iir_Predefined_Enum_Maximum, + Iir_Predefined_Enum_To_String, + + -- Predefined operators for BIT type. + + -- LRM08 9.2.2 Logical Operators + Iir_Predefined_Bit_And, + Iir_Predefined_Bit_Or, + Iir_Predefined_Bit_Nand, + Iir_Predefined_Bit_Nor, + Iir_Predefined_Bit_Xor, + Iir_Predefined_Bit_Xnor, + Iir_Predefined_Bit_Not, + + -- LRM08 9.2.3 Relational Operators + Iir_Predefined_Bit_Match_Equality, + Iir_Predefined_Bit_Match_Inequality, + Iir_Predefined_Bit_Match_Less, + Iir_Predefined_Bit_Match_Less_Equal, + Iir_Predefined_Bit_Match_Greater, + Iir_Predefined_Bit_Match_Greater_Equal, + + -- LRM08 9.2.9 Condition operator + Iir_Predefined_Bit_Condition, + + -- LRM08 5.2.6 Predefined operations on scalar types. + Iir_Predefined_Bit_Rising_Edge, + Iir_Predefined_Bit_Falling_Edge, + + -- Predefined operators for any integer type. + + -- LRM08 9.2.3 Relational Operators + Iir_Predefined_Integer_Equality, + Iir_Predefined_Integer_Inequality, + Iir_Predefined_Integer_Less, + Iir_Predefined_Integer_Less_Equal, + Iir_Predefined_Integer_Greater, + Iir_Predefined_Integer_Greater_Equal, + + -- LRM08 9.2.6 Sign operators + Iir_Predefined_Integer_Identity, + Iir_Predefined_Integer_Negation, + + -- LRM08 9.2.8 Miscellaneous operators + Iir_Predefined_Integer_Absolute, + + -- LRM08 9.2.5 Adding operators + Iir_Predefined_Integer_Plus, + Iir_Predefined_Integer_Minus, + + -- LRM08 9.2.7 Multiplying operators + Iir_Predefined_Integer_Mul, + Iir_Predefined_Integer_Div, + Iir_Predefined_Integer_Mod, + Iir_Predefined_Integer_Rem, + + -- LRM08 9.2.8 Miscellaneous operators + Iir_Predefined_Integer_Exp, + + -- LRM08 5.2.6 Predefined operations on scalar types. + Iir_Predefined_Integer_Minimum, + Iir_Predefined_Integer_Maximum, + Iir_Predefined_Integer_To_String, + + -- Predefined operators for any floating type. + + -- LRM08 9.2.3 Relational Operators + Iir_Predefined_Floating_Equality, + Iir_Predefined_Floating_Inequality, + Iir_Predefined_Floating_Less, + Iir_Predefined_Floating_Less_Equal, + Iir_Predefined_Floating_Greater, + Iir_Predefined_Floating_Greater_Equal, + + -- LRM08 9.2.6 Sign operators + Iir_Predefined_Floating_Identity, + Iir_Predefined_Floating_Negation, + + -- LRM08 9.2.8 Miscellaneous operators + Iir_Predefined_Floating_Absolute, + + -- LRM08 9.2.5 Adding operators + Iir_Predefined_Floating_Plus, + Iir_Predefined_Floating_Minus, + + -- LRM08 9.2.7 Multiplying operators + Iir_Predefined_Floating_Mul, + Iir_Predefined_Floating_Div, + + -- LRM08 9.2.8 Miscellaneous operators + Iir_Predefined_Floating_Exp, + + -- LRM08 5.2.6 Predefined operations on scalar types. + Iir_Predefined_Floating_Minimum, + Iir_Predefined_Floating_Maximum, + Iir_Predefined_Floating_To_String, + Iir_Predefined_Real_To_String_Digits, + Iir_Predefined_Real_To_String_Format, + + -- Predefined operator for universal types. + + -- LRM08 9.2.7 Multiplying operators + Iir_Predefined_Universal_R_I_Mul, + Iir_Predefined_Universal_I_R_Mul, + Iir_Predefined_Universal_R_I_Div, + + -- Predefined operators for physical types. + + -- LRM08 9.2.3 Relational Operators + Iir_Predefined_Physical_Equality, + Iir_Predefined_Physical_Inequality, + Iir_Predefined_Physical_Less, + Iir_Predefined_Physical_Less_Equal, + Iir_Predefined_Physical_Greater, + Iir_Predefined_Physical_Greater_Equal, + + -- LRM08 9.2.6 Sign operators + Iir_Predefined_Physical_Identity, + Iir_Predefined_Physical_Negation, + + -- LRM08 9.2.8 Miscellaneous operators + Iir_Predefined_Physical_Absolute, + + -- LRM08 9.2.5 Adding operators + Iir_Predefined_Physical_Plus, + Iir_Predefined_Physical_Minus, + + -- LRM08 9.2.7 Multiplying operators + Iir_Predefined_Physical_Integer_Mul, + Iir_Predefined_Physical_Real_Mul, + Iir_Predefined_Integer_Physical_Mul, + Iir_Predefined_Real_Physical_Mul, + Iir_Predefined_Physical_Integer_Div, + Iir_Predefined_Physical_Real_Div, + Iir_Predefined_Physical_Physical_Div, + + -- LRM08 5.2.6 Predefined operations on scalar types. + Iir_Predefined_Physical_Minimum, + Iir_Predefined_Physical_Maximum, + Iir_Predefined_Physical_To_String, + Iir_Predefined_Time_To_String_Unit, + + -- Predefined operators for access. + + -- LRM08 9.2.3 Relational Operators + Iir_Predefined_Access_Equality, + Iir_Predefined_Access_Inequality, + + -- Predefined operators for record. + + -- LRM08 9.2.3 Relational Operators + Iir_Predefined_Record_Equality, + Iir_Predefined_Record_Inequality, + + -- Predefined operators for array. + + -- LRM08 9.2.3 Relational Operators + Iir_Predefined_Array_Equality, + Iir_Predefined_Array_Inequality, + Iir_Predefined_Array_Less, + Iir_Predefined_Array_Less_Equal, + Iir_Predefined_Array_Greater, + Iir_Predefined_Array_Greater_Equal, + + -- LRM08 9.2.5 Adding operators + Iir_Predefined_Array_Array_Concat, + Iir_Predefined_Array_Element_Concat, + Iir_Predefined_Element_Array_Concat, + Iir_Predefined_Element_Element_Concat, + + -- LRM08 5.3.2.4 Predefined operations on array types + Iir_Predefined_Array_Minimum, + Iir_Predefined_Array_Maximum, + Iir_Predefined_Vector_Minimum, + Iir_Predefined_Vector_Maximum, + + -- LRM08 9.2.4 Shift operators + Iir_Predefined_Array_Sll, + Iir_Predefined_Array_Srl, + Iir_Predefined_Array_Sla, + Iir_Predefined_Array_Sra, + Iir_Predefined_Array_Rol, + Iir_Predefined_Array_Ror, + + -- LRM08 9.2.2 Logical operators + -- Predefined operators for one dimensional array. + -- For bit and boolean type, the operations are the same. To be + -- neutral, we use TF (for True/False) instead of Bit, Boolean or + -- Logic. + Iir_Predefined_TF_Array_And, + Iir_Predefined_TF_Array_Or, + Iir_Predefined_TF_Array_Nand, + Iir_Predefined_TF_Array_Nor, + Iir_Predefined_TF_Array_Xor, + Iir_Predefined_TF_Array_Xnor, + Iir_Predefined_TF_Array_Not, + + -- LRM08 9.2.2 Logical operators + Iir_Predefined_TF_Reduction_And, + Iir_Predefined_TF_Reduction_Or, + Iir_Predefined_TF_Reduction_Nand, + Iir_Predefined_TF_Reduction_Nor, + Iir_Predefined_TF_Reduction_Xor, + Iir_Predefined_TF_Reduction_Xnor, + Iir_Predefined_TF_Reduction_Not, + + -- LRM08 9.2.2 Logical operators + Iir_Predefined_TF_Array_Element_And, + Iir_Predefined_TF_Element_Array_And, + Iir_Predefined_TF_Array_Element_Or, + Iir_Predefined_TF_Element_Array_Or, + Iir_Predefined_TF_Array_Element_Nand, + Iir_Predefined_TF_Element_Array_Nand, + Iir_Predefined_TF_Array_Element_Nor, + Iir_Predefined_TF_Element_Array_Nor, + Iir_Predefined_TF_Array_Element_Xor, + Iir_Predefined_TF_Element_Array_Xor, + Iir_Predefined_TF_Array_Element_Xnor, + Iir_Predefined_TF_Element_Array_Xnor, + + -- LRM08 9.2.3 Relational Operators + Iir_Predefined_Bit_Array_Match_Equality, + Iir_Predefined_Bit_Array_Match_Inequality, + + -- LRM08 5.3.2.4 Predefined operations on array types + Iir_Predefined_Array_Char_To_String, + Iir_Predefined_Bit_Vector_To_Ostring, + Iir_Predefined_Bit_Vector_To_Hstring, + + -- LRM08 9.2.3 Relational Operators + -- IEEE.Std_Logic_1164.Std_Ulogic + Iir_Predefined_Std_Ulogic_Match_Equality, + Iir_Predefined_Std_Ulogic_Match_Inequality, + Iir_Predefined_Std_Ulogic_Match_Less, + Iir_Predefined_Std_Ulogic_Match_Less_Equal, + Iir_Predefined_Std_Ulogic_Match_Greater, + Iir_Predefined_Std_Ulogic_Match_Greater_Equal, + + -- LRM08 9.2.3 Relational Operators + Iir_Predefined_Std_Ulogic_Array_Match_Equality, + Iir_Predefined_Std_Ulogic_Array_Match_Inequality, + + -- -- Predefined attribute functions. + -- Iir_Predefined_Attribute_Image, + -- Iir_Predefined_Attribute_Value, + -- Iir_Predefined_Attribute_Pos, + -- Iir_Predefined_Attribute_Val, + -- Iir_Predefined_Attribute_Succ, + -- Iir_Predefined_Attribute_Pred, + -- Iir_Predefined_Attribute_Leftof, + -- Iir_Predefined_Attribute_Rightof, + -- Iir_Predefined_Attribute_Left, + -- Iir_Predefined_Attribute_Right, + -- Iir_Predefined_Attribute_Event, + -- Iir_Predefined_Attribute_Active, + -- Iir_Predefined_Attribute_Last_Event, + -- Iir_Predefined_Attribute_Last_Active, + -- Iir_Predefined_Attribute_Last_Value, + -- Iir_Predefined_Attribute_Driving, + -- Iir_Predefined_Attribute_Driving_Value, + + -- Impure subprograms. + + -- LRM08 5.4.3 Allocation and deallocation of objects + Iir_Predefined_Deallocate, + + -- LRM08 5.5.2 File operations + Iir_Predefined_File_Open, + Iir_Predefined_File_Open_Status, + Iir_Predefined_File_Close, + Iir_Predefined_Read, + Iir_Predefined_Read_Length, + Iir_Predefined_Flush, + Iir_Predefined_Write, + Iir_Predefined_Endfile, + + -- Misc impure functions. + Iir_Predefined_Now_Function, + + -- A not predefined and not known function. User function. + Iir_Predefined_None, + + -- Defined in package ieee.std_logic_1164 + + -- Std_Ulogic operations. + Iir_Predefined_Ieee_1164_Scalar_And, + Iir_Predefined_Ieee_1164_Scalar_Nand, + Iir_Predefined_Ieee_1164_Scalar_Or, + Iir_Predefined_Ieee_1164_Scalar_Nor, + Iir_Predefined_Ieee_1164_Scalar_Xor, + Iir_Predefined_Ieee_1164_Scalar_Xnor, + Iir_Predefined_Ieee_1164_Scalar_Not, + + -- Std_Logic_Vector or Std_Ulogic_Vector operations. + -- Length of the result is the length of the left operand. + Iir_Predefined_Ieee_1164_Vector_And, + Iir_Predefined_Ieee_1164_Vector_Nand, + Iir_Predefined_Ieee_1164_Vector_Or, + Iir_Predefined_Ieee_1164_Vector_Nor, + Iir_Predefined_Ieee_1164_Vector_Xor, + Iir_Predefined_Ieee_1164_Vector_Xnor, + Iir_Predefined_Ieee_1164_Vector_Not, + + -- Numeric_Std. + -- Abbreviations: + -- Uns: Unsigned, Sgn: Signed, Nat: Natural, Int: Integer. + Iir_Predefined_Ieee_Numeric_Std_Add_Uns_Uns, + Iir_Predefined_Ieee_Numeric_Std_Add_Uns_Nat, + Iir_Predefined_Ieee_Numeric_Std_Add_Nat_Uns, + Iir_Predefined_Ieee_Numeric_Std_Add_Sgn_Sgn, + Iir_Predefined_Ieee_Numeric_Std_Add_Sgn_Int, + Iir_Predefined_Ieee_Numeric_Std_Add_Int_Sgn, + + Iir_Predefined_Ieee_Numeric_Std_Eq_Uns_Uns, + Iir_Predefined_Ieee_Numeric_Std_Eq_Uns_Nat, + Iir_Predefined_Ieee_Numeric_Std_Eq_Nat_Uns, + Iir_Predefined_Ieee_Numeric_Std_Eq_Sgn_Sgn, + Iir_Predefined_Ieee_Numeric_Std_Eq_Sgn_Int, + Iir_Predefined_Ieee_Numeric_Std_Eq_Int_Sgn + ); -- Return TRUE iff FUNC is a short-cut predefined function. function Iir_Predefined_Shortcut_P (Func : Iir_Predefined_Functions) diff --git a/src/vhdl/python/pnodespy.py b/src/vhdl/python/pnodespy.py index 89b288995..b846c01b0 100755 --- a/src/vhdl/python/pnodespy.py +++ b/src/vhdl/python/pnodespy.py @@ -16,6 +16,8 @@ def print_enum(name, vals): print print 'class {0}:'.format(name) for n, k in enumerate(vals): + if k == 'None': + k = 'PNone' print ' {0} = {1}'.format(k, n) @@ -69,14 +71,14 @@ def do_class_fields(): def read_spec_enum(type_name, prefix, class_name): """Read an enumeration declaration from iirs.ads""" pat_decl = re.compile(r' type {0} is$'.format(type_name)) - pat_enum = re.compile(r' {0}_(\w+),?(-- .*)?$'.format(prefix)) - lr = pnodes.linereader(pnodes.spec_file) + pat_enum = re.compile(r' {0}_(\w+),?(-- .*)?$'.format(prefix)) + lr = pnodes.linereader(pnodes.kind_file) while not pat_decl.match(lr.get()): pass toks = [] while True: line = lr.get() - if line == ' );\n': + if line == ' );\n': break m = pat_enum.match(line) if m: @@ -88,6 +90,8 @@ def do_libghdl_iirs(): print 'from libghdl import libghdl' do_class_kinds() read_spec_enum('Iir_Mode', 'Iir', 'Iir_Mode') + read_spec_enum('Iir_Predefined_Functions', + 'Iir_Predefined', 'Iir_Predefined') do_iirs_subprg() |