Imported Upstream version 0.9.2
[platform/upstream/iotivity.git] / service / soft-sensor-manager / SSMCore / src / QueryProcessor / DataReader.cpp
1 /******************************************************************
2 *
3 * Copyright 2014 Samsung Electronics All Rights Reserved.
4 *
5 *
6 *
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
10 *
11 *      http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 *
19 ******************************************************************/
20 #include "DataReader.h"
21
22 CDataReader::CDataReader()
23 {
24 }
25
26 CDataReader::~CDataReader()
27 {
28     for (std::map<std::string, std::vector<CModelData *> >::iterator itorModel =
29              m_modelDataList.begin();
30          itorModel != m_modelDataList.end(); ++itorModel)
31     {
32         for (std::vector<CModelData *>::iterator itorData = itorModel->second.begin();
33              itorData != itorModel->second.end(); ++itorData)
34         {
35             SAFE_DELETE(*itorData);
36         }
37     }
38 }
39
40 SSMRESULT CDataReader::addModelData(std::string modelName,
41                                     std::vector<CModelData *> *pModelData)
42 {
43     m_modelDataList[modelName] = *pModelData;
44
45     return SSM_S_OK;
46 }
47
48 SSMRESULT CDataReader::getAffectedModels(std::vector<std::string> *pAffectedModels)
49 {
50     for (std::map<std::string, std::vector<CModelData *> >::iterator itorModel =
51              m_modelDataList.begin();
52          itorModel != m_modelDataList.end(); ++itorModel)
53     {
54         pAffectedModels->push_back(itorModel->first);
55     }
56
57     return SSM_S_OK;
58 }
59
60 SSMRESULT CDataReader::getModelDataCount(std::string modelName, int *pDataCount)
61 {
62     std::map<std::string, std::vector<CModelData *> >::iterator itor;
63
64     itor = m_modelDataList.find(modelName);
65
66     if (itor == m_modelDataList.end())
67     {
68         return SSM_E_FAIL;
69     }
70
71     *pDataCount = itor->second.size();
72
73     return SSM_S_OK;
74 }
75
76 SSMRESULT CDataReader::getModelData(std::string modelName, int dataIndex,
77                                     IModelData **ppModelData)
78 {
79     std::map<std::string, std::vector<CModelData *> >::iterator itor;
80
81     itor = m_modelDataList.find(modelName);
82
83     if (itor == m_modelDataList.end())
84     {
85         return SSM_E_FAIL;
86     }
87
88     if (dataIndex > (int)itor->second.size() - 1)
89     {
90         return SSM_E_FAIL;
91     }
92
93     *ppModelData = itor->second[dataIndex];
94
95     return SSM_S_OK;
96 }