| [51b73452] | 1 | /* | 
|---|
|  | 2 | * This file is part of the Cforall project | 
|---|
|  | 3 | * | 
|---|
|  | 4 | * $Id: OperatorTable.cc,v 1.6 2003/01/19 04:19:31 rcbilson Exp $ | 
|---|
|  | 5 | * | 
|---|
|  | 6 | */ | 
|---|
|  | 7 |  | 
|---|
|  | 8 | #include <map> | 
|---|
|  | 9 |  | 
|---|
|  | 10 | #include "OperatorTable.h" | 
|---|
|  | 11 |  | 
|---|
|  | 12 | namespace CodeGen { | 
|---|
|  | 13 |  | 
|---|
|  | 14 | namespace { | 
|---|
|  | 15 |  | 
|---|
|  | 16 | const OperatorInfo tableValues[] = { | 
|---|
|  | 17 | {       "?[?]",         "",             "_operator_index",              OT_INDEX                }, | 
|---|
|  | 18 | {       "?()",          "",             "_operator_call",               OT_CALL                 }, | 
|---|
|  | 19 | {       "?++",          "++",           "_operator_postincr",           OT_POSTFIXASSIGN        }, | 
|---|
|  | 20 | {       "?--",          "--",           "_operator_postdecr",           OT_POSTFIXASSIGN        }, | 
|---|
|  | 21 | {       "*?",           "*",            "_operator_deref",              OT_PREFIX               }, | 
|---|
|  | 22 | {       "+?",           "+",            "_operator_unaryplus",          OT_PREFIX               }, | 
|---|
|  | 23 | {       "-?",           "-",            "_operator_unaryminus",         OT_PREFIX               }, | 
|---|
|  | 24 | {       "~?",           "~",            "_operator_bitnot",             OT_PREFIX               }, | 
|---|
|  | 25 | {       "!?",           "!",            "_operator_lognot",             OT_PREFIX               }, | 
|---|
|  | 26 | {       "++?",          "++",           "_operator_preincr",            OT_PREFIXASSIGN         }, | 
|---|
|  | 27 | {       "--?",          "--",           "_operator_predecr",            OT_PREFIXASSIGN         }, | 
|---|
|  | 28 | {       "?*?",          "*",            "_operator_multiply",           OT_INFIX                }, | 
|---|
|  | 29 | {       "?/?",          "/",            "_operator_divide",             OT_INFIX                }, | 
|---|
|  | 30 | {       "?%?",          "%",            "_operator_modulus",            OT_INFIX                }, | 
|---|
|  | 31 | {       "?+?",          "+",            "_operator_add",                OT_INFIX                }, | 
|---|
|  | 32 | {       "?-?",          "-",            "_operator_subtract",           OT_INFIX                }, | 
|---|
|  | 33 | {       "?<<?",         "<<",           "_operator_shiftleft",          OT_INFIX                }, | 
|---|
|  | 34 | {       "?>>?",         ">>",           "_operator_shiftright",         OT_INFIX                }, | 
|---|
|  | 35 | {       "?<?",          "<",            "_operator_less",               OT_INFIX                }, | 
|---|
|  | 36 | {       "?>?",          ">",            "_operator_greater",            OT_INFIX                }, | 
|---|
|  | 37 | {       "?<=?",         "<=",           "_operator_lessequal",          OT_INFIX                }, | 
|---|
|  | 38 | {       "?>=?",         ">=",           "_operator_greaterequal",       OT_INFIX                }, | 
|---|
|  | 39 | {       "?==?",         "==",           "_operator_equal",              OT_INFIX                }, | 
|---|
|  | 40 | {       "?!=?",         "!=",           "_operator_notequal",           OT_INFIX                }, | 
|---|
|  | 41 | {       "?&?",          "&",            "_operator_bitand",             OT_INFIX                }, | 
|---|
|  | 42 | {       "?^?",          "^",            "_operator_bitxor",             OT_INFIX                }, | 
|---|
|  | 43 | {       "?|?",          "|",            "_operator_bitor",              OT_INFIX                }, | 
|---|
|  | 44 | {       "?=?",          "=",            "_operator_assign",             OT_INFIXASSIGN          }, | 
|---|
|  | 45 | {       "?*=?",         "*=",           "_operator_multassign",         OT_INFIXASSIGN          }, | 
|---|
|  | 46 | {       "?/=?",         "/=",           "_operator_divassign",          OT_INFIXASSIGN          }, | 
|---|
|  | 47 | {       "?%=?",         "%=",           "_operator_modassign",          OT_INFIXASSIGN          }, | 
|---|
|  | 48 | {       "?+=?",         "+=",           "_operator_addassign",          OT_INFIXASSIGN          }, | 
|---|
|  | 49 | {       "?-=?",         "-=",           "_operator_subassign",          OT_INFIXASSIGN          }, | 
|---|
|  | 50 | {       "?<<=?",        "<<=",          "_operator_shiftleftassign",    OT_INFIXASSIGN          }, | 
|---|
|  | 51 | {       "?>>=?",        ">>=",          "_operator_shiftrightassign",   OT_INFIXASSIGN          }, | 
|---|
|  | 52 | {       "?&=?",         "&=",           "_operator_bitandassign",       OT_INFIXASSIGN          }, | 
|---|
|  | 53 | {       "?^=?",         "^=",           "_operator_bitxorassign",       OT_INFIXASSIGN          }, | 
|---|
|  | 54 | {       "?|=?",         "|=",           "_operator_bitorassign",        OT_INFIXASSIGN          }, | 
|---|
|  | 55 | {       "0",            "0",            "_constant_zero",               OT_CONSTANT             }, | 
|---|
|  | 56 | {       "1",            "1",            "_constant_one",                        OT_CONSTANT             } | 
|---|
|  | 57 | }; | 
|---|
|  | 58 |  | 
|---|
|  | 59 | const int numOps = sizeof( tableValues ) / sizeof( OperatorInfo ); | 
|---|
|  | 60 |  | 
|---|
|  | 61 | std::map< std::string, OperatorInfo > table; | 
|---|
|  | 62 |  | 
|---|
|  | 63 | void | 
|---|
|  | 64 | initialize() | 
|---|
|  | 65 | { | 
|---|
|  | 66 | for( int i = 0; i < numOps; ++i ) { | 
|---|
|  | 67 | table[ tableValues[i].inputName ] = tableValues[i]; | 
|---|
|  | 68 | } | 
|---|
|  | 69 | } | 
|---|
|  | 70 |  | 
|---|
|  | 71 | } // namespace | 
|---|
|  | 72 |  | 
|---|
|  | 73 | bool | 
|---|
|  | 74 | operatorLookup( std::string funcName, OperatorInfo &info ) | 
|---|
|  | 75 | { | 
|---|
|  | 76 | static bool init = false; | 
|---|
|  | 77 | if( !init ) { | 
|---|
|  | 78 | initialize(); | 
|---|
|  | 79 | } | 
|---|
|  | 80 | std::map< std::string, OperatorInfo >::const_iterator i = table.find( funcName ); | 
|---|
|  | 81 | if( i == table.end() ) { | 
|---|
|  | 82 | return false; | 
|---|
|  | 83 | } else { | 
|---|
|  | 84 | info = i->second; | 
|---|
|  | 85 | return true; | 
|---|
|  | 86 | } | 
|---|
|  | 87 | } | 
|---|
|  | 88 |  | 
|---|
|  | 89 | } // namespace CodeGen | 
|---|