mbed Connector Interface simplification API on top of mbed-client
Fork of mbedConnectorInterfaceV3 by
NOTE:
This repo has been replaced with https://github.com/ARMmbed/mbedConnectorInterface. No further updates will occur with this repo. Please use the github repo instead. Thanks!
source/NamedPointer.cpp
- Committer:
- ansond
- Date:
- 2016-06-14
- Revision:
- 27:b8aaf7dc7023
- Child:
- 38:bb6d2be4d54c
File content as of revision 27:b8aaf7dc7023:
/** * @file NamedPointer.cpp * @brief mbed CoAP Endpoint Device Management Named Pointer * @author Doug Anson * @version 1.0 * @see * * Copyright (c) 2016 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ // Base Class #include "mbed-connector-interface/ObjectInstanceManager.h" // constructor NamedPointer::NamedPointer(string name,void *ptr) { this->m_name = name; this->m_ptr = ptr; this->m_list = (void *)new NamedPointerList(); } // copy constructor NamedPointer::NamedPointer(const NamedPointer &np) { this->m_name = np.m_name; this->m_ptr = np.m_ptr; this->m_list = this->copyList(np.m_list); } // Destructor NamedPointer::~NamedPointer() { NamedPointerList *list = (NamedPointerList *)this->m_list; if (list != NULL) { delete list; } } // Get the Name string NamedPointer::name() { return this->m_name; } // Get the Pointer void *NamedPointer::ptr() { return this->m_ptr; } // Get any associated list void *NamedPointer::list() { return this->m_list; } // Copy the list void *NamedPointer::copyList(void *list) { NamedPointerList *npl = new NamedPointerList(); NamedPointerList *tmp_list = (NamedPointerList *)list; for(int i=0;tmp_list != NULL && i<tmp_list->size();++i) { npl->push_back(tmp_list->at(i)); } return (void *)npl; }