EMANE  1.2.1
locationmanager.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2013 - Adjacent Link LLC, Bridgewater, New Jersey
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * * Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  * * Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in
13  * the documentation and/or other materials provided with the
14  * distribution.
15  * * Neither the name of Adjacent Link LLC nor the names of its
16  * contributors may be used to endorse or promote products derived
17  * from this software without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30  * POSSIBILITY OF SUCH DAMAGE.
31  */
32 
33 #include "locationmanager.h"
34 #include "positionutils.h"
35 
37  nemId_{nemId}{}
38 
40 {
41  for(const auto & location : locations)
42  {
43  EMANE::NEMId targetNEMId{location.getNEMId()};
44 
45  if(nemId_ == targetNEMId)
46  {
47  // if self nem location changes clear
48  // the location pair cache
49  if(localPOV_.update(location.getPosition(),
50  location.getOrientation(),
51  location.getVelocity()))
52  {
53  locationInfoCache_.clear();
54  }
55  }
56  else
57  {
58  auto iter = locationStore_.find(targetNEMId);
59 
60  if(iter != locationStore_.end())
61  {
62  // if nem location changes clear the
63  // location pair chache if any
64  if(iter->second.update(location.getPosition(),
65  location.getOrientation(),
66  location.getVelocity()))
67  {
68  locationInfoCache_.erase(targetNEMId);
69  }
70  }
71  else
72  {
73  locationStore_.insert({targetNEMId,{location.getPosition(),
74  location.getOrientation(),
75  location.getVelocity()}});
76  }
77  }
78  }
79 }
80 
81 
82 std::pair<EMANE::LocationInfo,bool> EMANE::LocationManager::getLocationInfo(NEMId remoteNEMId)
83 {
84  if(!localPOV_ == false)
85  {
86  auto cacheIter = locationInfoCache_.find(remoteNEMId);
87 
88  if(cacheIter != locationInfoCache_.end())
89  {
90  return {cacheIter->second,true};
91  }
92  else
93  {
94  auto iter = locationStore_.find(remoteNEMId);
95 
96  if(iter != locationStore_.end())
97  {
98  LocationInfo locationInfo{localPOV_,iter->second};
99 
100  locationInfoCache_[remoteNEMId] = locationInfo;
101 
102  return {locationInfo,true};
103  }
104  }
105  }
106 
107  return {LocationInfo{},false};
108 }
void update(const Events::Locations &locations)
bool update(const Position &position, const std::pair< const Orientation &, bool > &orientation, const std::pair< const Velocity &, bool > &velocity)
std::uint16_t NEMId
Definition: types.h:52
std::list< Location > Locations
Definition: location.h:108
std::pair< LocationInfo, bool > getLocationInfo(NEMId remoteNEMId)
LocationManager(NEMId nemId)