source: trunk/tmdmcreator/src/tmdmprocessor.cpp @ 27

Revision 21, 8.2 KB checked in by lucsch, 12 years ago (diff)
  • TmDmCreator is now working (supports language selection)
  • Adding swisstopo data model definition
RevLine 
[15]1/***************************************************************************
2 tmdmprocessor.cpp
3 -------------------
[16]4 copyright            : (C) 2013 CREALP Lucien Schreiber
[15]5 email                : lucien.schreiber at crealp dot vs dot ch
6 ***************************************************************************/
7
8/***************************************************************************
9 *                                                                         *
10 *   This program is free software; you can redistribute it and/or modify  *
11 *   it under the terms of the GNU General Public License as published by  *
12 *   the Free Software Foundation; either version 2 of the License, or     *
13 *   (at your option) any later version.                                   *
14 *                                                                         *
15 ***************************************************************************/
16
17#include "tmdmprocessor.h"
18#include "tmdmcopier.h"
19
[17]20TmDmProcessor::TmDmProcessor(const wxFileName & src, const wxFileName & dest) {
21    m_FileSrc = src;
22    m_FileDst = dest;
[21]23    m_LanguageCol = 0;
[15]24}
25
[16]26
27
[15]28TmDmProcessor::~TmDmProcessor() {
29}
30
[16]31
32
[15]33int TmDmProcessor::FindBlock(const wxString & blockname) {
[17]34    wxFileInputStream input(m_FileSrc.GetFullPath());
35    wxTextInputStream text(input);
36    long myLineIndex = 0;
37    while(input.IsOk() && !input.Eof() ){
38        wxString myLine = text.ReadLine();
39        if (myLine.StartsWith(blockname)==true){
40            return myLineIndex;
41        }
42        myLineIndex++;
43    }
[16]44    return wxNOT_FOUND;
[15]45}
46
[16]47
48
[21]49wxString TmDmProcessor::SwitchCols(wxArrayString * cols, wxArrayString * values, int item) {
50    if (m_LanguageCol == 0) {
51        return values->Item(item);
52    }
53   
[16]54
[21]55    if(cols->Item(item).Contains(_T("_0")) == true) {
56        return values->Item(item + m_LanguageCol);
57    }
58   
59    wxString myColName = wxString::Format(_T("_%d"), m_LanguageCol);
60    if (cols->Item(item).Contains(myColName) == true) {
61        return values->Item(item - m_LanguageCol);
62    }
63    return values->Item(item);
64}
[16]65
66
67
[21]68void TmDmProcessor::SetLanguageColumn(int value) {
69    m_LanguageCol = value;
70}
[16]71
[21]72
73
74
75
76
77
78
[17]79TmDmProcessorSimple::TmDmProcessorSimple(const wxFileName & src, const wxFileName & dest) : TmDmProcessor(src,dest) {
[15]80}
81
[16]82
83
[15]84TmDmProcessorSimple::~TmDmProcessorSimple() {
85}
86
[16]87
88
[18]89bool TmDmProcessorSimple::ProcessBlock(int blockstart, const wxString & tablename) {
90    wxArrayString mySQLCols;
91    TmDmCopier myCopier(m_FileDst);
[19]92    myCopier.CopyFrom(wxString::Format(_T("\n-- %s --\n"), tablename));
93
[17]94   
95    wxFileInputStream input(m_FileSrc.GetFullPath());
96    wxTextInputStream text(input);
97    long myLineIndex = 0;
98    while(input.IsOk() && !input.Eof() ){
[18]99        wxString myRow = text.ReadLine();
[17]100        if (myLineIndex <= blockstart) {
101            myLineIndex++;
102            continue;
103        }
104       
[18]105        if (myLineIndex == blockstart+1) {
106            mySQLCols = wxStringTokenize(myRow, _T("\t"), wxTOKEN_RET_EMPTY);
107            myLineIndex++;
108            continue;
109        }
[17]110       
[18]111        wxArrayString myValues = wxStringTokenize(myRow, _T("\t"), wxTOKEN_RET_EMPTY_ALL);
112        bool bEmpty = true;
113        for (unsigned int i = 0; i< myValues.GetCount(); i++) {
114            if (myValues[i] != wxEmptyString) {
115                bEmpty = false;
116                break;
117            }
118        }
119        if (bEmpty == true) {
120            // ok empty line found
121            return true;
122        }
[17]123       
[18]124        // write insert sentence
125        wxString myInsert = wxString::Format(_T("INSERT INTO `%s` ("), tablename);
126        for (unsigned int i = 0; i< mySQLCols.GetCount(); i++) {
127            myInsert.Append(wxString::Format(_T("%s,"), mySQLCols.Item(i)));
128        }
129        myInsert.RemoveLast();
130        myInsert.Append(_T(") VALUES ("));
131        for (unsigned int i = 0; i< mySQLCols.GetCount(); i++) {
[21]132            myInsert.Append(wxString::Format(_T("\"%s\","), SwitchCols(&mySQLCols, &myValues, i)));
[18]133        }
134        myInsert.RemoveLast();
135        myInsert.Append(_T(");\n"));
136        myCopier.CopyFrom(myInsert);
[17]137        myLineIndex++;
138    }
[16]139    return false;
[15]140}
141
[16]142
143
144
145
146
147
148
149
[17]150TmDmProcessorAttributs::TmDmProcessorAttributs(const wxFileName & src, const wxFileName & dest) : TmDmProcessor(src,dest) {
[15]151}
152
[19]153
154
[15]155TmDmProcessorAttributs::~TmDmProcessorAttributs() {
156}
157
[19]158
159
160bool TmDmProcessorAttributs::_ProcessAttributesName(int blockstart) {
161    wxArrayString mySQLCols;
162    TmDmCopier myCopier(m_FileDst);
163    myCopier.CopyFrom(wxString::Format(_T("\n-- %s --\n"), _T("dmn_layer_attribut")));
164    int NUM_COLS = 3;
165    wxArrayString myPreviousRow;
166   
167    wxFileInputStream input(m_FileSrc.GetFullPath());
168    wxTextInputStream text(input);
169    long myLineIndex = 0;
170    while(input.IsOk() && !input.Eof() ){
171        wxString myRow = text.ReadLine();
172        if (myLineIndex <= blockstart) {
173            myLineIndex++;
174            continue;
175        }
176       
177        if (myLineIndex == blockstart+1) {
178            mySQLCols = wxStringTokenize(myRow, _T("\t"), wxTOKEN_RET_EMPTY);
179            myLineIndex++;
180            continue;
181        }
182       
183        wxArrayString myValues = wxStringTokenize(myRow, _T("\t"), wxTOKEN_RET_EMPTY_ALL);
184        bool bEmpty = true;
185        for (unsigned int i = 0; i< myValues.GetCount(); i++) {
186            if (myValues[i] != wxEmptyString) {
187                bEmpty = false;
188                break;
189            }
190        }
191        if (bEmpty == true) {
192            // ok empty line found
193            return true;
194        }
195       
196        // check that this row differs from previous
197        wxArrayString myAttributRow;
198        for (unsigned int i = 0; i< NUM_COLS; i++) {
199            myAttributRow.Add(myValues.Item(i));
200        }
201        if (myAttributRow == myPreviousRow) {
202            continue;
203        }
204        myPreviousRow = myAttributRow;
205       
206       
207        wxString myInsert = _T("INSERT INTO `dmn_layer_attribut` VALUES (");
208        for (unsigned int i = 0; i< myAttributRow.GetCount(); i++) {
209            myInsert.Append(wxString::Format(_T("\"%s\","), myAttributRow.Item(i)));
210        }
211        myInsert.RemoveLast();
212        myInsert.Append(_T(");\n"));
213        myCopier.CopyFrom(myInsert);
214        myLineIndex++;
215    }
216    return true;
217}
218
219
220
221bool TmDmProcessorAttributs::_ProcessAttributesValues(int blockstart) {
222    wxArrayString mySQLCols;
223    TmDmCopier myCopier(m_FileDst);
224    myCopier.CopyFrom(wxString::Format(_T("\n-- %s --\n"), _T("attribut values")));
225    int START_COL = 3;
226   
227    wxFileInputStream input(m_FileSrc.GetFullPath());
228    wxTextInputStream text(input);
229    long myLineIndex = 0;
230    while(input.IsOk() && !input.Eof() ){
231        wxString myRow = text.ReadLine();
232        if (myLineIndex <= blockstart) {
233            myLineIndex++;
234            continue;
235        }
236       
237        if (myLineIndex == blockstart+1) {
238            mySQLCols = wxStringTokenize(myRow, _T("\t"), wxTOKEN_RET_EMPTY);
239            myLineIndex++;
240            continue;
241        }
242       
243       
244        wxArrayString myValues = wxStringTokenize(myRow, _T("\t"), wxTOKEN_RET_EMPTY_ALL);
245        bool bEmpty = true;
246        for (unsigned int i = 0; i< myValues.GetCount(); i++) {
247            if (myValues[i] != wxEmptyString) {
248                bEmpty = false;
249                break;
250            }
251        }
252        if (bEmpty == true) {
253            // ok empty line found
254            return true;
255        }
256       
257        // query to dmn_catalog
258        wxString myInsert = _T("INSERT INTO `dmn_catalog` VALUES (");
259        for (unsigned int i = START_COL; i< mySQLCols.GetCount(); i++) {
[21]260            myInsert.Append(wxString::Format(_T("\"%s\","), SwitchCols(&mySQLCols, &myValues, i)));
[19]261        }
262        myInsert.RemoveLast();
263        myInsert.Append(_T(");\n"));
264       
265       
266        // query to dmn_attribut_value
267        myInsert.Append(wxString::Format(_T("INSERT INTO `dmn_attribut_value` VALUES (%s, %s);\n"),
268                                         myValues.Item(0), myValues.Item(START_COL)));
269       
270        myCopier.CopyFrom(myInsert);
271        myLineIndex++;
272    }
273    return true;
274}
275
276
277
[18]278bool TmDmProcessorAttributs::ProcessBlock(int blockstart, const wxString & tablename) {
[19]279    if (_ProcessAttributesName(blockstart) == false) {
280        return false;
281    }
282   
283    if (_ProcessAttributesValues(blockstart) == false) {
284        return false;
285    }
286    return true;
[15]287}
288
[19]289
290
Note: See TracBrowser for help on using the repository browser.