]> git.mxchange.org Git - flightgear.git/blob - src/ATC/CommStation.cxx
Merge branch 'next' of gitorious.org:fg/flightgear into next
[flightgear.git] / src / ATC / CommStation.cxx
1 #include "CommStation.hxx"
2
3 #include <map>
4
5 #include <Navaids/PositionedBinding.hxx>
6
7 namespace {
8
9 typedef std::multimap<int, flightgear::CommStation*> FrequencyMap;
10 static FrequencyMap static_frequencies;
11
12 typedef std::pair<FrequencyMap::const_iterator, FrequencyMap::const_iterator> FrequencyMapRange;
13
14 } // of anonymous namespace
15
16 namespace flightgear {
17
18 CommStation::CommStation(const std::string& name, FGPositioned::Type t, const SGGeod& pos, int range, int freq) :
19     FGPositioned(t, name, pos),
20     mRangeNM(range),
21     mFreqKhz(freq),
22     mAirport(NULL)
23 {
24     static_frequencies.insert(std::make_pair(freq, this));
25   
26     init(true);
27 }
28
29 void CommStation::setAirport(FGAirport* apt)
30 {
31     mAirport = apt;
32 }
33
34 double CommStation::freqMHz() const
35 {
36     return mFreqKhz / 100.0;
37 }
38
39 PositionedBinding*
40 CommStation::createBinding(SGPropertyNode* nd) const
41 {
42     return new CommStationBinding(this, nd);
43 }
44
45 CommStation*
46 CommStation::findByFreq(int freqKhz, const SGGeod& pos, FGPositioned::Filter* filt)
47 {
48     FrequencyMapRange range = static_frequencies.equal_range(freqKhz);
49     FGPositioned::List results;
50     for (; range.first != range.second; ++range.first) {
51         CommStation* sta = range.first->second;
52         if (filt && !filt->pass(sta)) {
53             continue; // filtered out
54         }
55         
56         results.push_back(sta);
57     }
58     
59     if (results.empty()) {
60         return NULL;
61     }
62     
63     FGPositioned::sortByRange(results, pos);
64     return (CommStation*) results.front().ptr();
65 }
66
67 } // of namespace flightgear