stage1_2/derived_conversion_functions.cc
author Manuele Conti <conti.ma@alice.it>
Mon, 19 Nov 2012 22:53:43 +0100
changeset 747 d1c1a0254e4f
parent 745 26cb3fa00d29
permissions -rw-r--r--
Create functionDataType array in derived_conversion_functions_c.
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
747
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    40
const char *derived_conversion_functions_c::functionDataType[] = {
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    41
		"STRING",
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    42
		"SINT"  ,
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    43
		"INT"   ,
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    44
		"DINT"  ,
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    45
		"LINT"  ,
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    46
		"USINT" ,
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    47
		"UNIT"  ,
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    48
		"UDINT" ,
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    49
		"ULINT" ,
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    50
		NULL
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    51
};
d1c1a0254e4f Create functionDataType array in derived_conversion_functions_c.
Manuele Conti <conti.ma@alice.it>
parents: 745
diff changeset
    52
745
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    53
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
    54
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
derived_conversion_functions_c::~derived_conversion_functions_c(void) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    58
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
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    61
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
    62
    text = "";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    63
    if (NULL != root) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    64
        root->accept(*this);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    65
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    66
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    67
    return text;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    68
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    69
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    70
void *derived_conversion_functions_c::visit(identifier_c *symbol) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    71
    currentToken = symbol->value;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    72
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    73
    return NULL;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    74
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    75
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    76
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
    77
    std::string enumerateName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    78
    std::string functionName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    79
    std::list <std::string> enumerateValues;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    80
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    81
    symbol->enumerated_type_name->accept(*this);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    82
    enumerateName = currentToken;
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
    symbol->enumerated_spec_init->accept(*this);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    85
    enumerateValues = currentTokenList;
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
    printStringToEnum  (enumerateName, enumerateValues);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    88
    printEnumToString  (enumerateName, enumerateValues);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    89
    for (size_t s = 8; s <= 64; s*= 2) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    90
        printIntegerToEnum (enumerateName, enumerateValues, true , s);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    91
        printEnumToInteger (enumerateName, enumerateValues, true , s);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    92
        printIntegerToEnum (enumerateName, enumerateValues, false, s);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    93
        printEnumToInteger (enumerateName, enumerateValues, false, s);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    94
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
    95
    if (debug) std::cout << text << std::endl;
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
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
   101
    list_c *list;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   102
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   103
    currentTokenList.clear();
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   104
    list = (list_c *)symbol;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   105
    for (int i = 0; i < list->n; i++) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   106
        list->elements[i]->accept(*this);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   107
        currentTokenList.push_back(currentToken);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   108
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   109
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   110
    return NULL;
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
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   113
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
   114
    std::string integerType = "";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   115
    if (! isSigned) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   116
        integerType = "U";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   117
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   118
    switch(size) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   119
    case 8 : integerType += "S"; break;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   120
    case 16:                     break;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   121
    case 32: integerType += "D"; break;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   122
    case 64: integerType += "L"; break;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   123
    default:                     break;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   124
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   125
    integerType +="INT";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   126
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   127
    return integerType;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   128
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   129
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   130
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
   131
    std::list <std::string>::const_iterator itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   132
    std::string functionName;
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
    functionName = "STRING_TO_" + enumerateName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   135
    text += "FUNCTION " + functionName + " : " + enumerateName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   136
    text += "\nVAR_INPUT\nIN : STRING;\nEND_VAR\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   137
    for (itr = enumerateValues.begin(); itr != enumerateValues.end(); ++itr) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   138
       std::string value = *itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   139
       text += "IF IN = '" + value + "' THEN\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   140
       text += " " + functionName + " := " + value + ";\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   141
       text += " RETURN;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   142
       text += "END_IF;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   143
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   144
    text += "END_FUNCTION\n\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   145
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   146
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   147
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
   148
    std::list <std::string>::const_iterator itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   149
    std::string functionName;
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
    functionName = enumerateName + "_TO_STRING";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   152
    text += "FUNCTION " + functionName + " : STRING";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   153
    text += "\nVAR_INPUT\nIN : " + enumerateName + ";\nEND_VAR\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   154
    for (itr = enumerateValues.begin(); itr != enumerateValues.end(); ++itr) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   155
        std::string value = *itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   156
        text += "IF IN = " + value + " THEN\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   157
        text += " " + functionName + " := '" + value + "';\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   158
        text += " RETURN;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   159
        text += "END_IF;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   160
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   161
    text += "END_FUNCTION\n\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   162
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   163
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   164
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
   165
    std::list <std::string>::const_iterator itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   166
    std::string functionName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   167
    std::string integerType;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   168
    int count;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   169
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   170
    integerType  = getIntegerName(isSigned, size);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   171
    functionName = integerType + "_TO_" + enumerateName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   172
    text += "FUNCTION " + functionName + " : " + enumerateName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   173
    text += "\nVAR_INPUT\nIN : " + integerType + ";\nEND_VAR\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   174
    count = 0;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   175
    for (itr = enumerateValues.begin(); itr != enumerateValues.end(); ++itr) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   176
        std::string value = *itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   177
        std::stringstream out;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   178
        out << count;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   179
        text += "IF IN = " + out.str() + " THEN\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   180
        text += " " + functionName + " := " + value + ";\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   181
        text += " RETURN;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   182
        text += "END_IF;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   183
        count++;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   184
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   185
    text += "END_FUNCTION\n\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   186
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   187
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   188
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
   189
    std::list <std::string>::const_iterator itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   190
    std::string functionName;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   191
    std::string integerType;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   192
    int count;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   193
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   194
    integerType  = getIntegerName(isSigned, size);
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   195
    functionName = enumerateName + "_TO_" + integerType;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   196
    text += "FUNCTION " + functionName + " : " + integerType;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   197
    text += "\nVAR_INPUT\nIN : " + enumerateName + ";\nEND_VAR\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   198
    count = 0;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   199
    for (itr = enumerateValues.begin(); itr != enumerateValues.end(); ++itr) {
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   200
        std::string value = *itr;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   201
        std::stringstream out;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   202
        out << count;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   203
        text += "IF IN = " + value + " THEN\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   204
        text += " " + functionName + " := " + out.str() + ";\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   205
        text += " RETURN;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   206
        text += "END_IF;\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   207
        count++;
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   208
    }
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   209
    text += "END_FUNCTION\n\n";
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   210
}
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   211
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   212
26cb3fa00d29 Start enumerate conversion functions.
Manuele Conti <manuele.conti@sirius-es.it>
parents:
diff changeset
   213