CUSTOMIZED FOR WATER MONITOR

Committer:
DuyLionTran
Date:
Thu Dec 07 17:07:22 2017 +0000
Revision:
0:51d7bdf88981
CUSTOMIZED FOR WATER MONITOR

Who changed what in which revision?

UserRevisionLine numberNew contents of line
DuyLionTran 0:51d7bdf88981 1 /**
DuyLionTran 0:51d7bdf88981 2 ******************************************************************************
DuyLionTran 0:51d7bdf88981 3 * @file RecordGEO.cpp
DuyLionTran 0:51d7bdf88981 4 * @author ST / Central Labs
DuyLionTran 0:51d7bdf88981 5 * @version V2.0.0
DuyLionTran 0:51d7bdf88981 6 * @date 28 Apr 2017
DuyLionTran 0:51d7bdf88981 7 * @brief RecordGEO implementation.
DuyLionTran 0:51d7bdf88981 8 ******************************************************************************
DuyLionTran 0:51d7bdf88981 9 * @attention
DuyLionTran 0:51d7bdf88981 10 *
DuyLionTran 0:51d7bdf88981 11 * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
DuyLionTran 0:51d7bdf88981 12 *
DuyLionTran 0:51d7bdf88981 13 * Redistribution and use in source and binary forms, with or without modification,
DuyLionTran 0:51d7bdf88981 14 * are permitted provided that the following conditions are met:
DuyLionTran 0:51d7bdf88981 15 * 1. Redistributions of source code must retain the above copyright notice,
DuyLionTran 0:51d7bdf88981 16 * this list of conditions and the following disclaimer.
DuyLionTran 0:51d7bdf88981 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
DuyLionTran 0:51d7bdf88981 18 * this list of conditions and the following disclaimer in the documentation
DuyLionTran 0:51d7bdf88981 19 * and/or other materials provided with the distribution.
DuyLionTran 0:51d7bdf88981 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
DuyLionTran 0:51d7bdf88981 21 * may be used to endorse or promote products derived from this software
DuyLionTran 0:51d7bdf88981 22 * without specific prior written permission.
DuyLionTran 0:51d7bdf88981 23 *
DuyLionTran 0:51d7bdf88981 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
DuyLionTran 0:51d7bdf88981 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
DuyLionTran 0:51d7bdf88981 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DuyLionTran 0:51d7bdf88981 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
DuyLionTran 0:51d7bdf88981 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DuyLionTran 0:51d7bdf88981 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
DuyLionTran 0:51d7bdf88981 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
DuyLionTran 0:51d7bdf88981 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
DuyLionTran 0:51d7bdf88981 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
DuyLionTran 0:51d7bdf88981 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
DuyLionTran 0:51d7bdf88981 34 *
DuyLionTran 0:51d7bdf88981 35 ******************************************************************************
DuyLionTran 0:51d7bdf88981 36 */
DuyLionTran 0:51d7bdf88981 37 #include <cstdio>
DuyLionTran 0:51d7bdf88981 38
DuyLionTran 0:51d7bdf88981 39 #include "RecordGeo.h"
DuyLionTran 0:51d7bdf88981 40
DuyLionTran 0:51d7bdf88981 41 namespace NDefLib {
DuyLionTran 0:51d7bdf88981 42
DuyLionTran 0:51d7bdf88981 43 const std::string RecordGeo::sGeoTag = ("geo:");
DuyLionTran 0:51d7bdf88981 44
DuyLionTran 0:51d7bdf88981 45 //number of digits used for print the coordintate
DuyLionTran 0:51d7bdf88981 46 #define N_FLOAT_DIGIS 4
DuyLionTran 0:51d7bdf88981 47 #define N_INTEGER_DIGIS 3
DuyLionTran 0:51d7bdf88981 48 //string with the 2 coordinate format
DuyLionTran 0:51d7bdf88981 49 #define COORDINATE_WRITE_FORMAT "%3.4f,%3.4f"
DuyLionTran 0:51d7bdf88981 50 //+1 = sign, +1 = .
DuyLionTran 0:51d7bdf88981 51 #define COORDINATE_STR_SIZE (1+N_INTEGER_DIGIS+1+N_FLOAT_DIGIS)
DuyLionTran 0:51d7bdf88981 52
DuyLionTran 0:51d7bdf88981 53 //string to use for read a couple of coordinate
DuyLionTran 0:51d7bdf88981 54 #define COORDINATE_READ_FORMAT "%f,%f"
DuyLionTran 0:51d7bdf88981 55
DuyLionTran 0:51d7bdf88981 56
DuyLionTran 0:51d7bdf88981 57 RecordGeo::RecordGeo(const float lat, const float lon) :
DuyLionTran 0:51d7bdf88981 58 RecordURI(sGeoTag), mLatitiude(lat), mLongitude(lon), mContentIsChange(true) {
DuyLionTran 0:51d7bdf88981 59 };
DuyLionTran 0:51d7bdf88981 60
DuyLionTran 0:51d7bdf88981 61 void RecordGeo::update_content(){
DuyLionTran 0:51d7bdf88981 62 if(!mContentIsChange) {
DuyLionTran 0:51d7bdf88981 63 return;
DuyLionTran 0:51d7bdf88981 64 }
DuyLionTran 0:51d7bdf88981 65
DuyLionTran 0:51d7bdf88981 66 //2 coordinate +1 for the separator +1 for the \0
DuyLionTran 0:51d7bdf88981 67 char buffer[2*COORDINATE_STR_SIZE+1+1];
DuyLionTran 0:51d7bdf88981 68 std::sprintf(buffer,COORDINATE_WRITE_FORMAT,mLatitiude,mLongitude);
DuyLionTran 0:51d7bdf88981 69 mContent.clear();
DuyLionTran 0:51d7bdf88981 70 mContent.append(buffer);
DuyLionTran 0:51d7bdf88981 71
DuyLionTran 0:51d7bdf88981 72 mContentIsChange=false;
DuyLionTran 0:51d7bdf88981 73 }
DuyLionTran 0:51d7bdf88981 74
DuyLionTran 0:51d7bdf88981 75 RecordGeo* RecordGeo::parse(const RecordHeader &header, const uint8_t * const buffer) {
DuyLionTran 0:51d7bdf88981 76 uint16_t offset = 0;
DuyLionTran 0:51d7bdf88981 77 if (buffer[offset++] != RecordURI::sNDEFUriIdCode) {
DuyLionTran 0:51d7bdf88981 78 return NULL;
DuyLionTran 0:51d7bdf88981 79 }
DuyLionTran 0:51d7bdf88981 80 if (buffer[offset++] != RecordURI::UNKNOWN) {
DuyLionTran 0:51d7bdf88981 81 return NULL;
DuyLionTran 0:51d7bdf88981 82 }
DuyLionTran 0:51d7bdf88981 83 if (sGeoTag.compare(0, sGeoTag.size(), (const char*) buffer + offset, sGeoTag.size()) != 0) {
DuyLionTran 0:51d7bdf88981 84 return NULL;
DuyLionTran 0:51d7bdf88981 85 }
DuyLionTran 0:51d7bdf88981 86 offset += sGeoTag.size();
DuyLionTran 0:51d7bdf88981 87
DuyLionTran 0:51d7bdf88981 88 const std::string uriContent((const char*) (buffer + offset), header.get_payload_length() - offset);
DuyLionTran 0:51d7bdf88981 89
DuyLionTran 0:51d7bdf88981 90 float lat, lon;
DuyLionTran 0:51d7bdf88981 91 //build the record only if both the coordinate are available
DuyLionTran 0:51d7bdf88981 92 if (std::sscanf(uriContent.c_str(),COORDINATE_READ_FORMAT,&lat,&lon)!=2) {
DuyLionTran 0:51d7bdf88981 93 return NULL;
DuyLionTran 0:51d7bdf88981 94 }
DuyLionTran 0:51d7bdf88981 95
DuyLionTran 0:51d7bdf88981 96 return new RecordGeo(lat,lon);
DuyLionTran 0:51d7bdf88981 97 }
DuyLionTran 0:51d7bdf88981 98
DuyLionTran 0:51d7bdf88981 99 } /* namespace NDefLib */
DuyLionTran 0:51d7bdf88981 100
DuyLionTran 0:51d7bdf88981 101
DuyLionTran 0:51d7bdf88981 102 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/