stage1_2/derived_conversion_functions.cc
author Manuele Conti <manuele.conti@sirius-es.it>
Thu, 15 Nov 2012 17:30:35 +0100
changeset 745 26cb3fa00d29
child 747 d1c1a0254e4f
permissions -rw-r--r--
Start enumerate conversion functions.
745
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
     1
/*
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
     2
 *  matiec - a compiler for the programming languages defined in IEC 61131-3
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
     3
 *
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
     4
 *  Copyright (C) 2009-2012  Mario de Sousa (msousa@fe.up.pt)
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
     5
 *  Copyright (C) 2012       Manuele Conti  (conti.ma@alice.it)
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
     6
 *
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
     7
 *
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
     8
 *  This program is free software: you can redistribute it and/or modify
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
     9
 *  it under the terms of the GNU General Public License as published by
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    10
 *  the Free Software Foundation, either version 3 of the License, or
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    11
 *  (at your option) any later version.
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    12
 *
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    13
 *  This program is distributed in the hope that it will be useful,
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    14
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    15
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    16
 *  GNU General Public License for more details.
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    17
 *
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    18
 *  You should have received a copy of the GNU General Public License
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    19
 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    20
 *
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    21
 *
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    22
 * This code is made available on the understanding that it will not be
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    23
 * used in safety-critical situations without a full and competent review.
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    24
 */
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    25
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    26
/*
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    27
 * An IEC 61131-3 compiler.
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    28
 *
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    29
 * Based on the
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    30
 * FINAL DRAFT - IEC 61131-3, 2nd Ed. (2001-12-10)
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    31
 *
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    32
 */
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    33
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    34
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    35
#include "derived_conversion_functions.hh"
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    36
#include <sstream>
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    37
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    38
static const int debug = 0;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    39
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    40
derived_conversion_functions_c::derived_conversion_functions_c(symbol_c *ignore) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    41
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    42
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    43
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    44
derived_conversion_functions_c::~derived_conversion_functions_c(void) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    45
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    46
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    47
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    48
std::string &derived_conversion_functions_c::get_declaration(symbol_c *root) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    49
    text = "";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    50
    if (NULL != root) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    51
        root->accept(*this);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    52
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    53
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    54
    return text;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    55
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    56
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    57
void *derived_conversion_functions_c::visit(identifier_c *symbol) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    58
    currentToken = symbol->value;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    59
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    60
    return NULL;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    61
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    62
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    63
void *derived_conversion_functions_c::visit(enumerated_type_declaration_c *symbol) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    64
    std::string enumerateName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    65
    std::string functionName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    66
    std::list <std::string> enumerateValues;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    67
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    68
    symbol->enumerated_type_name->accept(*this);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    69
    enumerateName = currentToken;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    70
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    71
    symbol->enumerated_spec_init->accept(*this);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    72
    enumerateValues = currentTokenList;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    73
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    74
    printStringToEnum  (enumerateName, enumerateValues);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    75
    printEnumToString  (enumerateName, enumerateValues);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    76
    for (size_t s = 8; s <= 64; s*= 2) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    77
        printIntegerToEnum (enumerateName, enumerateValues, true , s);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    78
        printEnumToInteger (enumerateName, enumerateValues, true , s);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    79
        printIntegerToEnum (enumerateName, enumerateValues, false, s);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    80
        printEnumToInteger (enumerateName, enumerateValues, false, s);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    81
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    82
    if (debug) std::cout << text << std::endl;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    83
    
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    84
    return NULL;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    85
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    86
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    87
void *derived_conversion_functions_c::visit(enumerated_value_list_c *symbol) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    88
    list_c *list;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    89
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    90
    currentTokenList.clear();
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    91
    list = (list_c *)symbol;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    92
    for (int i = 0; i < list->n; i++) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    93
        list->elements[i]->accept(*this);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    94
        currentTokenList.push_back(currentToken);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    95
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    96
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    97
    return NULL;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    98
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    99
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   100
std::string derived_conversion_functions_c::getIntegerName(bool isSigned, size_t size) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   101
    std::string integerType = "";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   102
    if (! isSigned) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   103
        integerType = "U";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   104
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   105
    switch(size) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   106
    case 8 : integerType += "S"; break;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   107
    case 16:                     break;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   108
    case 32: integerType += "D"; break;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   109
    case 64: integerType += "L"; break;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   110
    default:                     break;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   111
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   112
    integerType +="INT";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   113
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   114
    return integerType;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   115
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   116
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   117
void derived_conversion_functions_c::printStringToEnum  (std::string &enumerateName, std::list<std::string> &enumerateValues) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   118
    std::list <std::string>::const_iterator itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   119
    std::string functionName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   120
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   121
    functionName = "STRING_TO_" + enumerateName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   122
    text += "FUNCTION " + functionName + " : " + enumerateName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   123
    text += "\nVAR_INPUT\nIN : STRING;\nEND_VAR\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   124
    for (itr = enumerateValues.begin(); itr != enumerateValues.end(); ++itr) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   125
       std::string value = *itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   126
       text += "IF IN = '" + value + "' THEN\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   127
       text += " " + functionName + " := " + value + ";\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   128
       text += " RETURN;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   129
       text += "END_IF;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   130
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   131
    text += "END_FUNCTION\n\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   132
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   133
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   134
void derived_conversion_functions_c::printEnumToString  (std::string &enumerateName, std::list<std::string> &enumerateValues) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   135
    std::list <std::string>::const_iterator itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   136
    std::string functionName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   137
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   138
    functionName = enumerateName + "_TO_STRING";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   139
    text += "FUNCTION " + functionName + " : STRING";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   140
    text += "\nVAR_INPUT\nIN : " + enumerateName + ";\nEND_VAR\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   141
    for (itr = enumerateValues.begin(); itr != enumerateValues.end(); ++itr) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   142
        std::string value = *itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   143
        text += "IF IN = " + value + " THEN\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   144
        text += " " + functionName + " := '" + value + "';\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   145
        text += " RETURN;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   146
        text += "END_IF;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   147
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   148
    text += "END_FUNCTION\n\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   149
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   150
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   151
void derived_conversion_functions_c::printIntegerToEnum (std::string &enumerateName, std::list<std::string> &enumerateValues, bool isSigned, size_t size) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   152
    std::list <std::string>::const_iterator itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   153
    std::string functionName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   154
    std::string integerType;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   155
    int count;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   156
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   157
    integerType  = getIntegerName(isSigned, size);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   158
    functionName = integerType + "_TO_" + enumerateName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   159
    text += "FUNCTION " + functionName + " : " + enumerateName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   160
    text += "\nVAR_INPUT\nIN : " + integerType + ";\nEND_VAR\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   161
    count = 0;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   162
    for (itr = enumerateValues.begin(); itr != enumerateValues.end(); ++itr) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   163
        std::string value = *itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   164
        std::stringstream out;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   165
        out << count;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   166
        text += "IF IN = " + out.str() + " THEN\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   167
        text += " " + functionName + " := " + value + ";\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   168
        text += " RETURN;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   169
        text += "END_IF;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   170
        count++;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   171
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   172
    text += "END_FUNCTION\n\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   173
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   174
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   175
void derived_conversion_functions_c::printEnumToInteger (std::string &enumerateName, std::list<std::string> &enumerateValues, bool isSigned, size_t size) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   176
    std::list <std::string>::const_iterator itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   177
    std::string functionName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   178
    std::string integerType;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   179
    int count;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   180
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   181
    integerType  = getIntegerName(isSigned, size);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   182
    functionName = enumerateName + "_TO_" + integerType;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   183
    text += "FUNCTION " + functionName + " : " + integerType;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   184
    text += "\nVAR_INPUT\nIN : " + enumerateName + ";\nEND_VAR\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   185
    count = 0;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   186
    for (itr = enumerateValues.begin(); itr != enumerateValues.end(); ++itr) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   187
        std::string value = *itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   188
        std::stringstream out;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   189
        out << count;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   190
        text += "IF IN = " + value + " THEN\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   191
        text += " " + functionName + " := " + out.str() + ";\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   192
        text += " RETURN;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   193
        text += "END_IF;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   194
        count++;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   195
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   196
    text += "END_FUNCTION\n\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   197
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   198
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   199
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   200